|
@@ -1,3 +1,5 @@
|
|
|
+# This requires GNU make, which is typically "gmake" on BSD systems
|
|
|
+
|
|
|
INCLUDES=
|
|
|
DEFS=
|
|
|
LIBS=
|
|
@@ -28,12 +30,14 @@ endif
|
|
|
|
|
|
# Determine system build architecture from compiler target
|
|
|
CC_MACH=$(shell $(CC) -dumpmachine | cut -d '-' -f 1)
|
|
|
-ZT_ARCHITECTURE=0
|
|
|
+ZT_ARCHITECTURE=999
|
|
|
ifeq ($(CC_MACH),x86_64)
|
|
|
ZT_ARCHITECTURE=2
|
|
|
+ ZT_USE_X64_ASM_SALSA2012=1
|
|
|
endif
|
|
|
ifeq ($(CC_MACH),amd64)
|
|
|
ZT_ARCHITECTURE=2
|
|
|
+ ZT_USE_X64_ASM_SALSA2012=1
|
|
|
endif
|
|
|
ifeq ($(CC_MACH),i386)
|
|
|
ZT_ARCHITECTURE=1
|
|
@@ -43,16 +47,74 @@ ifeq ($(CC_MACH),i686)
|
|
|
endif
|
|
|
ifeq ($(CC_MACH),arm)
|
|
|
ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),armel)
|
|
|
+ ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),armhf)
|
|
|
+ ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),armv6)
|
|
|
+ ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),armv6zk)
|
|
|
+ ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),armv6kz)
|
|
|
+ ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),armv7)
|
|
|
+ ZT_ARCHITECTURE=3
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+ ZT_USE_ARM32_NEON_ASM_SALSA2012=1
|
|
|
endif
|
|
|
ifeq ($(CC_MACH),arm64)
|
|
|
ZT_ARCHITECTURE=4
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
endif
|
|
|
ifeq ($(CC_MACH),aarch64)
|
|
|
ZT_ARCHITECTURE=4
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),mipsel)
|
|
|
+ ZT_ARCHITECTURE=5
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),mips)
|
|
|
+ ZT_ARCHITECTURE=5
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
endif
|
|
|
+ifeq ($(CC_MACH),mips64)
|
|
|
+ ZT_ARCHITECTURE=6
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+endif
|
|
|
+ifeq ($(CC_MACH),mips64el)
|
|
|
+ ZT_ARCHITECTURE=6
|
|
|
+ override DEFS+=-DZT_NO_TYPE_PUNNING
|
|
|
+endif
|
|
|
+
|
|
|
+# Fail if system architecture could not be determined
|
|
|
+ifeq ($(ZT_ARCHITECTURE),999)
|
|
|
+ERR=$(error FATAL: architecture could not be determined from $(CC) -dumpmachine: $CC_MACH)
|
|
|
+.PHONY: err
|
|
|
+err: ; $(ERR)
|
|
|
+endif
|
|
|
+
|
|
|
DEFS+=-DZT_BUILD_PLATFORM=$(ZT_BUILD_PLATFORM) -DZT_BUILD_ARCHITECTURE=$(ZT_ARCHITECTURE) -DZT_SOFTWARE_UPDATE_DEFAULT="\"disable\""
|
|
|
|
|
|
-CXXFLAGS+=$(CFLAGS) -fno-rtti -std=c++11 -D_GLIBCXX_USE_C99 -D_GLIBCXX_USE_C99_MATH -D_GLIBCXX_USE_C99_MATH_TR1
|
|
|
+CXXFLAGS+=$(CFLAGS) -fno-rtti -std=c++11 #-D_GLIBCXX_USE_C99 -D_GLIBCXX_USE_C99_MATH -D_GLIBCXX_USE_C99_MATH_TR1
|
|
|
|
|
|
all: one
|
|
|
|