X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2FMakefile;h=dbf8143576fdb642c1346b4eab067b7113c8738b;hp=86693ab21e1a32f7b2ba8b8c0677fd2d03179006;hb=61e44433426296dc388e75c864522580ec4ba3a5;hpb=7b0b4637208cc2c97b67f873e8ef194051307e2c diff --git a/src/Makefile b/src/Makefile index 86693ab2..dbf81435 100644 --- a/src/Makefile +++ b/src/Makefile @@ -1,6 +1,6 @@ # Stockfish, a UCI chess playing engine derived from Glaurung 2.1 # Copyright (C) 2004-2008 Tord Romstad (Glaurung author) -# Copyright (C) 2008-2013 Marco Costalba, Joona Kiiski, Tord Romstad +# Copyright (C) 2008-2014 Marco Costalba, Joona Kiiski, Tord Romstad # # Stockfish is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -65,47 +65,48 @@ OBJS = benchmark.o bitbase.o bitboard.o book.o endgame.o evaluate.o main.o \ # or modifying existing flags, you have to make sure there are no extra spaces # at the end of the line for flag values. -### 2.1. General +### 2.1. General and architecture defaults debug = no optimize = yes +os = any +bits = 32 +prefetch = no +bsfq = no +popcnt = no +sse = no + ### 2.2 Architecture specific -# General-section -ifeq ($(ARCH),general-64) +ifeq ($(ARCH),general-32) arch = any - os = any - bits = 64 - prefetch = no - bsfq = no - popcnt = no - sse = no endif -ifeq ($(ARCH),general-32) +ifeq ($(ARCH),x86-32-old) + arch = i386 +endif + +ifeq ($(ARCH),x86-32) + arch = i386 + prefetch = yes + sse = yes +endif + +ifeq ($(ARCH),general-64) arch = any - os = any - bits = 32 - prefetch = no - bsfq = no - popcnt = no - sse = no + bits = 64 endif -# x86-section ifeq ($(ARCH),x86-64) arch = x86_64 - os = any bits = 64 prefetch = yes bsfq = yes - popcnt = no sse = yes endif ifeq ($(ARCH),x86-64-modern) arch = x86_64 - os = any bits = 64 prefetch = yes bsfq = yes @@ -113,56 +114,26 @@ ifeq ($(ARCH),x86-64-modern) sse = yes endif -ifeq ($(ARCH),x86-32) - arch = i386 - os = any - bits = 32 - prefetch = yes - bsfq = no - popcnt = no - sse = yes -endif - -ifeq ($(ARCH),x86-32-old) - arch = i386 - os = any - bits = 32 - prefetch = no - bsfq = no - popcnt = no - sse = no -endif - -#arm section ifeq ($(ARCH),armv7) arch = armv7 - os = any - bits = 32 prefetch = yes bsfq = yes - popcnt = no - sse = no endif -# osx-section +ifeq ($(ARCH),osx-ppc-32) + arch = ppc + os = osx +endif + ifeq ($(ARCH),osx-ppc-64) arch = ppc64 os = osx bits = 64 - prefetch = no - bsfq = no - popcnt = no - sse = no endif -ifeq ($(ARCH),osx-ppc-32) - arch = ppc - os = osx - bits = 32 - prefetch = no - bsfq = no - popcnt = no - sse = no +ifeq ($(ARCH),linux-ppc-64) + arch = ppc64 + bits = 64 endif ifeq ($(ARCH),osx-x86-64) @@ -171,14 +142,22 @@ ifeq ($(ARCH),osx-x86-64) bits = 64 prefetch = yes bsfq = yes - popcnt = no + sse = yes +endif + +ifeq ($(ARCH),osx-x86-64-modern) + arch = x86_64 + os = osx + bits = 64 + prefetch = yes + bsfq = yes + popcnt = yes sse = yes endif ifeq ($(ARCH),osx-x86-32) arch = i386 os = osx - bits = 32 prefetch = yes bsfq = no popcnt = no @@ -191,88 +170,67 @@ endif ### ========================================================================== ### 3.1 Selecting compiler (default = gcc) + +CXXFLAGS += -Wall -Wcast-qual -fno-exceptions -fno-rtti $(EXTRACXXFLAGS) +LDFLAGS += $(EXTRALDFLAGS) + ifeq ($(COMP),) COMP=gcc endif -ifeq ($(COMP),mingw) - comp=mingw +ifeq ($(COMP),gcc) + comp=gcc CXX=g++ - profile_prepare = gcc-profile-prepare - profile_make = gcc-profile-make - profile_use = gcc-profile-use - profile_clean = gcc-profile-clean + CXXFLAGS += -ansi -pedantic -Wno-long-long -Wextra -Wshadow endif -ifeq ($(COMP),gcc) - comp=gcc +ifeq ($(COMP),mingw) + comp=mingw CXX=g++ - profile_prepare = gcc-profile-prepare - profile_make = gcc-profile-make - profile_use = gcc-profile-use - profile_clean = gcc-profile-clean + CXXFLAGS += -Wextra -Wshadow + LDFLAGS += -static-libstdc++ -static-libgcc endif ifeq ($(COMP),icc) comp=icc CXX=icpc - profile_prepare = icc-profile-prepare - profile_make = icc-profile-make - profile_use = icc-profile-use - profile_clean = icc-profile-clean + CXXFLAGS += -diag-disable 1476,10120 -Wcheck -Wabi -Wdeprecated -strict-ansi endif ifeq ($(COMP),clang) comp=clang CXX=clang++ - profile_prepare = gcc-profile-prepare - profile_make = gcc-profile-make - profile_use = gcc-profile-use - profile_clean = gcc-profile-clean -endif - -### 3.2 General compiler settings -CXXFLAGS = -Wall -Wcast-qual -fno-exceptions -fno-rtti $(EXTRACXXFLAGS) - -ifeq ($(comp),gcc) CXXFLAGS += -ansi -pedantic -Wno-long-long -Wextra -Wshadow endif -ifeq ($(comp),mingw) - CXXFLAGS += -Wextra -Wshadow -endif - ifeq ($(comp),icc) - CXXFLAGS += -wd383,981,1418,1419,1476,10187,10188,11505,11503 -Wcheck -Wabi -Wdeprecated -strict-ansi -endif - -ifeq ($(comp),clang) - CXXFLAGS += -ansi -pedantic -Wno-long-long -Wextra -Wshadow + profile_prepare = icc-profile-prepare + profile_make = icc-profile-make + profile_use = icc-profile-use + profile_clean = icc-profile-clean +else + profile_prepare = gcc-profile-prepare + profile_make = gcc-profile-make + profile_use = gcc-profile-use + profile_clean = gcc-profile-clean endif ifeq ($(os),osx) - CXXFLAGS += -arch $(arch) -mmacosx-version-min=10.0 -endif - -### 3.3 General linker settings -LDFLAGS = $(EXTRALDFLAGS) - -ifeq ($(comp),mingw) - LDFLAGS += -static-libstdc++ -static-libgcc + CXXFLAGS += -arch $(arch) -mmacosx-version-min=10.6 + LDFLAGS += -arch $(arch) -mmacosx-version-min=10.6 endif ### On mingw use Windows threads, otherwise POSIX ifneq ($(comp),mingw) - # Haiku has pthreads in its libroot, so only link it in on other platforms - ifneq ($(UNAME),Haiku) - LDFLAGS += -lpthread + # On Android Bionic's C library comes with its own pthread implementation bundled in + ifneq ($(arch),armv7) + # Haiku has pthreads in its libroot, so only link it in on other platforms + ifneq ($(UNAME),Haiku) + LDFLAGS += -lpthread + endif endif endif -ifeq ($(os),osx) - LDFLAGS += -arch $(arch) -mmacosx-version-min=10.0 -endif - ### 3.4 Debugging ifeq ($(debug),no) CXXFLAGS += -DNDEBUG @@ -296,7 +254,7 @@ ifeq ($(optimize),yes) endif ifeq ($(arch),armv7) - CXXFLAGS += -fno-gcse + CXXFLAGS += -fno-gcse -mthumb -march=armv7-a -mfloat-abi=softfp endif endif @@ -308,15 +266,15 @@ ifeq ($(optimize),yes) ifeq ($(os),osx) CXXFLAGS += -fast -mdynamic-no-pic else - CXXFLAGS += -O3 + CXXFLAGS += -fast endif endif ifeq ($(comp),clang) - ### -O4 requires a linker that supports LLVM's LTO CXXFLAGS += -O3 ifeq ($(os),osx) + CXXFLAGS += -flto ifeq ($(arch),i386) CXXFLAGS += -mdynamic-no-pic endif @@ -394,8 +352,10 @@ help: @echo "x86-64-modern > x86 64-bit with popcnt support" @echo "x86-32 > x86 32-bit with SSE support" @echo "x86-32-old > x86 32-bit fall back for old hardware" + @echo "linux-ppc-64 > PPC-Linux 64 bit" @echo "osx-ppc-64 > PPC-Mac OS X 64 bit" @echo "osx-ppc-32 > PPC-Mac OS X 32 bit" + @echo "osx-x86-64-modern > x86-Mac OS X 64 bit with popcnt support" @echo "osx-x86-64 > x86-Mac OS X 64 bit" @echo "osx-x86-32 > x86-Mac OS X 32 bit" @echo "armv7 > ARMv7 32 bit" @@ -447,7 +407,8 @@ profile-build: embed-signature: @echo "Running benchmark for getting the signature ..." @$(SIGNBENCH) 2>&1 | sed -n 's/Nodes searched : \(.*\)/\/string Version\/s\/"\\(.*\\)"\/"sig-\1"\//p' > sign.txt - @sed -i'' -f sign.txt misc.cpp + @sed -f sign.txt misc.cpp > misc2.cpp + @mv misc2.cpp misc.cpp @rm sign.txt signature-build: build embed-signature