2018-09-09 07:01:10 +00:00
|
|
|
|
2016-01-24 22:02:16 +00:00
|
|
|
###########################################################
|
2016-06-09 03:30:39 +00:00
|
|
|
##### System Attributes and Programs #####
|
2016-01-24 22:02:16 +00:00
|
|
|
###########################################################
|
|
|
|
|
2018-01-25 23:39:24 +00:00
|
|
|
# https://www.gnu.org/software/make/manual/make.html#Makefile-Conventions
|
2018-02-05 13:54:13 +00:00
|
|
|
# and https://www.gnu.org/prep/standards/standards.html
|
|
|
|
|
2018-01-25 23:39:24 +00:00
|
|
|
SHELL = /bin/sh
|
|
|
|
|
2017-08-17 16:33:43 +00:00
|
|
|
# If needed
|
|
|
|
TMPDIR ?= /tmp
|
|
|
|
# Used for ARMv7 and NEON.
|
|
|
|
FP_ABI ?= hard
|
2018-11-13 19:02:40 +00:00
|
|
|
# Used for feature tests
|
|
|
|
TOUT ?= a.out
|
|
|
|
TOUT := $(strip $(TOUT))
|
2017-08-17 16:33:43 +00:00
|
|
|
|
2018-02-05 13:54:13 +00:00
|
|
|
# Command and arguments
|
2015-07-31 12:09:59 +00:00
|
|
|
AR ?= ar
|
2015-12-25 21:06:43 +00:00
|
|
|
ARFLAGS ?= -cr # ar needs the dash on OpenBSD
|
2015-07-31 12:09:59 +00:00
|
|
|
RANLIB ?= ranlib
|
2015-12-25 21:06:43 +00:00
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
CP ?= cp
|
2015-12-26 11:45:59 +00:00
|
|
|
MV ?= mv
|
2017-03-10 06:53:51 +00:00
|
|
|
RM ?= rm -f
|
2015-11-05 06:59:46 +00:00
|
|
|
CHMOD ?= chmod
|
2018-02-05 13:54:13 +00:00
|
|
|
MKDIR ?= mkdir -p
|
|
|
|
|
2015-11-08 20:29:56 +00:00
|
|
|
LN ?= ln -sf
|
2015-11-25 04:14:53 +00:00
|
|
|
LDCONF ?= /sbin/ldconfig -n
|
2016-06-09 03:30:39 +00:00
|
|
|
|
2018-02-05 13:54:13 +00:00
|
|
|
INSTALL = install
|
|
|
|
INSTALL_PROGRAM = $(INSTALL)
|
|
|
|
INSTALL_DATA = $(INSTALL) -m 644
|
|
|
|
|
2018-07-21 10:15:40 +00:00
|
|
|
# Solaris provides a non-Posix grep at /usr/bin
|
2018-11-17 20:28:30 +00:00
|
|
|
ifneq ($(wildcard /usr/xpg4/bin/grep),)
|
2017-08-29 12:57:04 +00:00
|
|
|
GREP ?= /usr/xpg4/bin/grep
|
|
|
|
else
|
|
|
|
GREP ?= grep
|
|
|
|
endif
|
|
|
|
|
2018-11-13 19:02:40 +00:00
|
|
|
# Attempt to determine target machine, fallback to "this" machine.
|
|
|
|
# The target machine is the one the package runs on. Most people
|
2018-01-29 01:23:48 +00:00
|
|
|
# call this the "target", but not Autotools.
|
2018-01-27 18:05:23 +00:00
|
|
|
HOSTX := $(shell $(CXX) $(CXXFLAGS) -dumpmachine 2>/dev/null | cut -f 1 -d '-')
|
|
|
|
ifeq ($(HOSTX),)
|
|
|
|
HOSTX := $(shell uname -m 2>/dev/null)
|
|
|
|
endif
|
|
|
|
|
|
|
|
IS_X86 := $(shell echo "$(HOSTX)" | $(GREP) -v "64" | $(GREP) -i -c -E 'i.86|x86|i86')
|
|
|
|
IS_X64 := $(shell echo "$(HOSTX)" | $(GREP) -i -c -E '_64|d64')
|
|
|
|
IS_PPC32 := $(shell echo "$(HOSTX)" | $(GREP) -v "64" | $(GREP) -i -c -E 'ppc|power')
|
2018-11-18 06:52:42 +00:00
|
|
|
IS_PPC64 := $(shell echo "$(HOSTX)" | $(GREP) -i -c -E 'ppc64|powerpc64|power64')
|
2018-09-09 07:01:10 +00:00
|
|
|
IS_SPARC32 := $(shell echo "$(HOSTX)" | $(GREP) -v "64" | $(GREP) -i -c -E 'sun|sparc')
|
|
|
|
IS_SPARC64 := $(shell echo "$(HOSTX)" | $(GREP) -i -c -E 'sun|sparc64')
|
2018-11-13 19:02:40 +00:00
|
|
|
IS_ARM32 := $(shell echo "$(HOSTX)" | $(GREP) -i -c -E 'arm|armhf|arm7l|eabihf')
|
2018-12-01 15:42:20 +00:00
|
|
|
IS_ARMV8 := $(shell echo "$(HOSTX)" | $(GREP) -i -c -E 'aarch32|aarch64|arm64|armv8')
|
2018-01-27 18:05:23 +00:00
|
|
|
|
2018-01-29 01:23:48 +00:00
|
|
|
IS_NEON := $(shell $(CXX) $(CXXFLAGS) -dumpmachine 2>/dev/null | $(GREP) -i -c -E 'armv7|armhf|arm7l|eabihf|armv8|aarch32|aarch64')
|
2018-01-28 18:33:03 +00:00
|
|
|
|
2018-11-17 20:28:30 +00:00
|
|
|
# Attempt to determine platform
|
2018-01-27 18:05:23 +00:00
|
|
|
SYSTEMX := $(shell $(CXX) $(CXXFLAGS) -dumpmachine 2>/dev/null)
|
2018-11-17 20:28:30 +00:00
|
|
|
ifeq ($(SYSTEMX),)
|
|
|
|
SYSTEMX := $(shell uname -s 2>/dev/null)
|
|
|
|
endif
|
|
|
|
|
2018-01-27 18:05:23 +00:00
|
|
|
IS_LINUX := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c "Linux")
|
|
|
|
IS_MINGW := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c "MinGW")
|
|
|
|
IS_CYGWIN := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c "Cygwin")
|
|
|
|
IS_DARWIN := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c "Darwin")
|
|
|
|
IS_NETBSD := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c "NetBSD")
|
2018-11-19 07:28:29 +00:00
|
|
|
IS_AIX := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c "aix")
|
2018-12-01 08:16:54 +00:00
|
|
|
IS_SUN := $(shell echo "$(SYSTEMX)" | $(GREP) -i -c -E "SunOS|Solaris")
|
2017-10-13 05:27:09 +00:00
|
|
|
|
2017-10-27 22:09:40 +00:00
|
|
|
SUN_COMPILER := $(shell $(CXX) -V 2>&1 | $(GREP) -i -c -E 'CC: (Sun|Studio)')
|
2017-10-13 05:27:09 +00:00
|
|
|
GCC_COMPILER := $(shell $(CXX) --version 2>/dev/null | $(GREP) -v -E '(llvm|clang)' | $(GREP) -i -c -E '(gcc|g\+\+)')
|
2017-12-30 23:38:40 +00:00
|
|
|
XLC_COMPILER := $(shell $(CXX) -qversion 2>/dev/null |$(GREP) -i -c "IBM XL")
|
2017-10-13 05:27:09 +00:00
|
|
|
CLANG_COMPILER := $(shell $(CXX) --version 2>/dev/null | $(GREP) -i -c -E '(llvm|clang)')
|
|
|
|
INTEL_COMPILER := $(shell $(CXX) --version 2>/dev/null | $(GREP) -i -c '\(icc\)')
|
2017-11-22 12:57:39 +00:00
|
|
|
|
|
|
|
# Various Port compilers on OS X
|
2017-10-13 05:27:09 +00:00
|
|
|
MACPORTS_COMPILER := $(shell $(CXX) --version 2>/dev/null | $(GREP) -i -c "macports")
|
2017-11-22 12:57:39 +00:00
|
|
|
HOMEBREW_COMPILER := $(shell $(CXX) --version 2>/dev/null | $(GREP) -i -c "homebrew")
|
2018-01-25 14:17:54 +00:00
|
|
|
ifeq ($(IS_DARWIN),1)
|
|
|
|
ifneq ($(MACPORTS_COMPILER)$(HOMEBREW_COMPILER),00)
|
|
|
|
OSXPORT_COMPILER := 1
|
|
|
|
endif
|
2017-11-22 12:57:39 +00:00
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-08-19 10:10:30 +00:00
|
|
|
# Enable shared object versioning for Linux and Solaris
|
|
|
|
HAS_SOLIB_VERSION ?= 0
|
|
|
|
ifneq ($(IS_LINUX)$(IS_SUN),00)
|
2018-12-01 11:04:45 +00:00
|
|
|
HAS_SOLIB_VERSION := 1
|
2018-08-19 10:10:30 +00:00
|
|
|
endif
|
2015-11-08 20:29:56 +00:00
|
|
|
|
2018-07-31 17:33:57 +00:00
|
|
|
# Formely adhoc.cpp was created from adhoc.cpp.proto when needed.
|
|
|
|
ifeq ($(wildcard adhoc.cpp),)
|
|
|
|
$(shell cp adhoc.cpp.proto adhoc.cpp)
|
|
|
|
endif
|
|
|
|
|
2018-12-01 11:04:45 +00:00
|
|
|
# Tell MacPorts and Homebrew GCC to use Clang integrated assembler
|
|
|
|
# http://github.com/weidai11/cryptopp/issues/190
|
|
|
|
ifeq ($(GCC_COMPILER)$(OSXPORT_COMPILER),11)
|
|
|
|
ifeq ($(findstring -Wa,-q,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -Wa,-q
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
# Hack to skip CPU feature tests for some recipes
|
|
|
|
DETECT_FEATURES ?= 1
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_DISABLE_ASM,$(CXXFLAGS)),-DCRYPTOPP_DISABLE_ASM)
|
|
|
|
DETECT_FEATURES := 0
|
|
|
|
else ifeq ($(findstring clean,$(MAKECMDGOALS)),clean)
|
|
|
|
DETECT_FEATURES := 0
|
|
|
|
else ifeq ($(findstring distclean,$(MAKECMDGOALS)),distclean)
|
|
|
|
DETECT_FEATURES := 0
|
2018-11-13 19:02:40 +00:00
|
|
|
else ifeq ($(findstring distclean,$(MAKECMDGOALS)),trim)
|
|
|
|
DETECT_FEATURES := 0
|
2018-11-12 19:59:36 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-21 21:25:34 +00:00
|
|
|
# Strip out -Wall, -Wextra and friends for feature testing
|
|
|
|
ifeq ($(DETECT_FEATURES),1)
|
2018-12-05 23:30:25 +00:00
|
|
|
TCXXFLAGS := $(filter-out -Wall -Wextra -Werror% -Wunused -Wconversion -Wp%, $(CXXFLAGS))
|
2018-11-21 21:25:34 +00:00
|
|
|
ifneq ($(strip $(TCXXFLAGS)),)
|
|
|
|
$(info Using testing flags: $(TCXXFLAGS))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2018-11-17 20:28:30 +00:00
|
|
|
# Fixup AIX
|
|
|
|
ifeq ($(IS_AIX),1)
|
|
|
|
TPROG = TestPrograms/test_64bit.cxx
|
2018-11-21 21:25:34 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
2018-11-19 07:28:29 +00:00
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-17 20:28:30 +00:00
|
|
|
IS_PPC64=1
|
|
|
|
else
|
|
|
|
IS_PPC32=1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2018-12-01 09:02:15 +00:00
|
|
|
# libc++ is LLVM's standard C++ library. If we add libc++
|
|
|
|
# here then all user programs must use it too. The open
|
|
|
|
# question is, which choice is easier on users?
|
|
|
|
ifneq ($(IS_DARWIN),0)
|
|
|
|
CXX ?= c++
|
|
|
|
# CXXFLAGS += -stdlib=libc++
|
|
|
|
AR = libtool
|
|
|
|
ARFLAGS = -static -o
|
|
|
|
endif
|
|
|
|
|
2016-06-09 03:30:39 +00:00
|
|
|
###########################################################
|
|
|
|
##### General Variables #####
|
|
|
|
###########################################################
|
|
|
|
|
|
|
|
# Base CXXFLAGS used if the user did not specify them
|
2016-06-09 04:54:53 +00:00
|
|
|
ifeq ($(SUN_COMPILER),1)
|
2018-07-21 10:15:40 +00:00
|
|
|
CXXFLAGS ?= -DNDEBUG -g -xO3
|
2018-11-11 06:14:43 +00:00
|
|
|
ZOPT = -xO0
|
2016-06-09 03:30:39 +00:00
|
|
|
else
|
2017-08-04 22:31:52 +00:00
|
|
|
CXXFLAGS ?= -DNDEBUG -g2 -O3
|
2018-11-11 06:14:43 +00:00
|
|
|
ZOPT = -O0
|
2016-06-09 03:30:39 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-10 13:00:14 +00:00
|
|
|
# On ARM we may compile aes_armv4.S though the CC compiler
|
2018-07-11 10:59:44 +00:00
|
|
|
ifeq ($(GCC_COMPILER),1)
|
|
|
|
CC=gcc
|
|
|
|
else ifeq ($(CLANG_COMPILER),1)
|
|
|
|
CC=clang
|
|
|
|
endif
|
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
# Default prefix for make install
|
|
|
|
ifeq ($(PREFIX),)
|
2015-12-25 21:06:43 +00:00
|
|
|
PREFIX = /usr/local
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2015-12-29 11:32:45 +00:00
|
|
|
# http://www.gnu.org/prep/standards/html_node/Directory-Variables.html
|
|
|
|
ifeq ($(DATADIR),)
|
|
|
|
DATADIR := $(PREFIX)/share
|
|
|
|
endif
|
|
|
|
ifeq ($(LIBDIR),)
|
|
|
|
LIBDIR := $(PREFIX)/lib
|
|
|
|
endif
|
|
|
|
ifeq ($(BINDIR),)
|
|
|
|
BINDIR := $(PREFIX)/bin
|
|
|
|
endif
|
|
|
|
ifeq ($(INCLUDEDIR),)
|
|
|
|
INCLUDEDIR := $(PREFIX)/include
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Fix CXX on Cygwin 1.1.4
|
|
|
|
ifeq ($(CXX),gcc)
|
2015-11-05 06:59:46 +00:00
|
|
|
CXX := g++
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2015-12-31 06:43:42 +00:00
|
|
|
# We honor ARFLAGS, but the "v" option used by default causes a noisy make
|
2015-11-05 06:59:46 +00:00
|
|
|
ifeq ($(ARFLAGS),rv)
|
|
|
|
ARFLAGS = r
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2017-03-20 12:51:10 +00:00
|
|
|
# Clang integrated assembler will be used with -Wa,-q
|
|
|
|
CLANG_INTEGRATED_ASSEMBLER ?= 0
|
|
|
|
|
2018-11-17 20:50:04 +00:00
|
|
|
# Original MinGW targets Win2k by default, but lacks proper Win2k support
|
2017-11-07 01:49:16 +00:00
|
|
|
# if target Windows version is not specified, use Windows XP instead
|
2018-01-27 18:05:23 +00:00
|
|
|
ifeq ($(IS_MINGW),1)
|
2017-11-07 01:49:16 +00:00
|
|
|
ifeq ($(findstring -D_WIN32_WINNT,$(CXXFLAGS)),)
|
|
|
|
ifeq ($(findstring -D_WIN32_WINDOWS,$(CXXFLAGS)),)
|
|
|
|
ifeq ($(findstring -DWINVER,$(CXXFLAGS)),)
|
|
|
|
ifeq ($(findstring -DNTDDI_VERSION,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -D_WIN32_WINNT=0x0501
|
|
|
|
endif # NTDDI_VERSION
|
|
|
|
endif # WINVER
|
|
|
|
endif # _WIN32_WINDOWS
|
|
|
|
endif # _WIN32_WINNT
|
2018-01-27 18:05:23 +00:00
|
|
|
endif # IS_MINGW
|
2017-11-07 01:49:16 +00:00
|
|
|
|
2018-11-17 20:50:04 +00:00
|
|
|
# Newlib needs _XOPEN_SOURCE=600 for signals
|
|
|
|
TPROG = TestPrograms/test_newlib.cxx
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-17 20:50:04 +00:00
|
|
|
ifeq ($(findstring -D_XOPEN_SOURCE,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -D_XOPEN_SOURCE=600
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2016-01-24 22:02:16 +00:00
|
|
|
###########################################################
|
|
|
|
##### X86/X32/X64 Options #####
|
|
|
|
###########################################################
|
|
|
|
|
2018-01-27 18:05:23 +00:00
|
|
|
ifneq ($(IS_X86)$(IS_X64),00)
|
2018-11-12 19:59:36 +00:00
|
|
|
ifeq ($(DETECT_FEATURES),1)
|
2016-06-16 09:17:16 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
ifeq ($(SUN_COMPILER),1)
|
|
|
|
SSE2_FLAG = -xarch=sse2
|
|
|
|
SSE3_FLAG = -xarch=sse3
|
|
|
|
SSSE3_FLAG = -xarch=ssse3
|
|
|
|
SSE41_FLAG = -xarch=sse4_1
|
|
|
|
SSE42_FLAG = -xarch=sse4_2
|
2018-12-04 23:32:45 +00:00
|
|
|
CLMUL_FLAG = -xarch=aes
|
2018-12-01 08:16:54 +00:00
|
|
|
AESNI_FLAG = -xarch=aes
|
|
|
|
AVX_FLAG = -xarch=avx
|
|
|
|
AVX2_FLAG = -xarch=avx2
|
|
|
|
SHANI_FLAG = -xarch=sha
|
|
|
|
else
|
|
|
|
SSE2_FLAG = -msse2
|
|
|
|
SSE3_FLAG = -msse3
|
|
|
|
SSSE3_FLAG = -mssse3
|
|
|
|
SSE41_FLAG = -msse4.1
|
|
|
|
SSE42_FLAG = -msse4.2
|
|
|
|
CLMUL_FLAG = -mpclmul
|
|
|
|
AESNI_FLAG = -maes
|
|
|
|
AVX_FLAG = -mavx
|
|
|
|
AVX2_FLAG = -mavx2
|
|
|
|
SHANI_FLAG = -msha
|
|
|
|
endif
|
|
|
|
|
2018-11-12 20:37:14 +00:00
|
|
|
TPROG = TestPrograms/test_x86_sse2.cxx
|
2018-12-01 08:16:54 +00:00
|
|
|
TOPT = $(SSE2_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
CHACHA_FLAG = $(SSE2_FLAG)
|
|
|
|
SUN_LDFLAGS += $(SSE2_FLAG)
|
|
|
|
else
|
|
|
|
SSE2_FLAG =
|
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_ssse3.cxx
|
|
|
|
TOPT = $(SSSE3_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
ARIA_FLAG = $(SSSE3_FLAG)
|
|
|
|
CHAM_FLAG = $(SSSE3_FLAG)
|
|
|
|
LEA_FLAG = $(SSSE3_FLAG)
|
|
|
|
SIMECK_FLAG = $(SSSE3_FLAG)
|
|
|
|
SIMON64_FLAG = $(SSSE3_FLAG)
|
|
|
|
SIMON128_FLAG = $(SSSE3_FLAG)
|
|
|
|
SPECK64_FLAG = $(SSSE3_FLAG)
|
|
|
|
SPECK128_FLAG = $(SSSE3_FLAG)
|
|
|
|
SUN_LDFLAGS += $(SSSE3_FLAG)
|
2018-11-11 06:14:43 +00:00
|
|
|
else
|
2018-12-01 08:16:54 +00:00
|
|
|
SSSE3_FLAG =
|
2018-11-11 06:14:43 +00:00
|
|
|
endif
|
2018-11-12 08:37:32 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_sse41.cxx
|
|
|
|
TOPT = $(SSE41_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
BLAKE2B_FLAG = $(SSE41_FLAG)
|
|
|
|
BLAKE2S_FLAG = $(SSE41_FLAG)
|
|
|
|
SIMON64_FLAG = $(SSE41_FLAG)
|
|
|
|
SPECK64_FLAG = $(SSE41_FLAG)
|
|
|
|
SUN_LDFLAGS += $(SSE41_FLAG)
|
|
|
|
else
|
|
|
|
SSE41_FLAG =
|
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_sse42.cxx
|
|
|
|
TOPT = $(SSE42_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
CRC_FLAG = $(SSE42_FLAG)
|
|
|
|
SUN_LDFLAGS += $(SSE42_FLAG)
|
|
|
|
else
|
|
|
|
SSE42_FLAG =
|
|
|
|
endif
|
2017-08-17 16:33:43 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_clmul.cxx
|
|
|
|
TOPT = $(CLMUL_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
GCM_FLAG = $(SSSE3_FLAG) $(CLMUL_FLAG)
|
|
|
|
SUN_LDFLAGS += $(CLMUL_FLAG)
|
|
|
|
else
|
|
|
|
CLMUL_FLAG =
|
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_aes.cxx
|
|
|
|
TOPT = $(AESNI_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
AES_FLAG = $(SSE41_FLAG) $(AESNI_FLAG)
|
|
|
|
SM4_FLAG = $(SSSE3_FLAG) $(AESNI_FLAG)
|
|
|
|
SUN_LDFLAGS += $(AESNI_FLAG)
|
|
|
|
else
|
|
|
|
AESNI_FLAG =
|
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_avx.cxx
|
|
|
|
TOPT = $(AVX_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
# XXX_FLAG = $(AVX_FLAG)
|
|
|
|
SUN_LDFLAGS += $(AVX_FLAG)
|
2018-11-11 06:14:43 +00:00
|
|
|
else
|
2018-12-01 08:16:54 +00:00
|
|
|
AVX_FLAG =
|
2018-07-30 23:14:51 +00:00
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
TPROG = TestPrograms/test_x86_avx2.cxx
|
|
|
|
TOPT = $(AVX2_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
CHACHA_AVX2_FLAG = $(AVX2_FLAG)
|
|
|
|
SUN_LDFLAGS += $(AVX2_FLAG)
|
|
|
|
else
|
|
|
|
AVX2_FLAG =
|
|
|
|
endif
|
|
|
|
|
|
|
|
TPROG = TestPrograms/test_x86_sha.cxx
|
|
|
|
TOPT = $(SHANI_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
SHA_FLAG = $(SSE42_FLAG) $(SHANI_FLAG)
|
|
|
|
SUN_LDFLAGS += $(SHANI_FLAG)
|
|
|
|
else
|
2018-12-01 08:55:39 +00:00
|
|
|
SHANI_FLAG =
|
2018-12-01 08:16:54 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(SUN_COMPILER),1)
|
|
|
|
LDFLAGS += $(SUN_LDFLAGS)
|
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-12-01 08:16:54 +00:00
|
|
|
ifeq ($(SSE2_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
|
|
|
else ifeq ($(SSE3_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_SSE3
|
|
|
|
else ifeq ($(SSSE3_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_SSSE3
|
|
|
|
else ifeq ($(SSE41_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_SSE4
|
|
|
|
else ifeq ($(SSE42_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_SSE4
|
2018-12-01 11:04:45 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq ($(SSE42_FLAG),)
|
2018-12-02 02:33:17 +00:00
|
|
|
|
|
|
|
# Unusual GCC/Clang on Macports. It assembles AES, but not CLMUL.
|
|
|
|
# test_x86_clmul.s:15: no such instruction: 'pclmulqdq $0, %xmm1,%xmm0'
|
|
|
|
ifeq ($(CLMUL_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_CLMUL
|
|
|
|
endif
|
|
|
|
ifeq ($(AESNI_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_AESNI
|
|
|
|
endif
|
|
|
|
|
2018-12-01 11:04:45 +00:00
|
|
|
ifeq ($(AVX_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_AVX
|
|
|
|
else ifeq ($(AVX2_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_AVX2
|
|
|
|
else ifeq ($(SHANI_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_SHANI
|
|
|
|
endif
|
2018-12-01 08:16:54 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
# DETECT_FEATURES
|
2018-11-11 06:14:43 +00:00
|
|
|
endif
|
2017-08-24 23:17:21 +00:00
|
|
|
|
|
|
|
ifneq ($(INTEL_COMPILER),0)
|
|
|
|
CXXFLAGS += -wd68 -wd186 -wd279 -wd327 -wd161 -wd3180
|
2018-11-11 06:14:43 +00:00
|
|
|
|
|
|
|
ICC111_OR_LATER := $(shell $(CXX) --version 2>&1 | $(GREP) -c -E "\(ICC\) ([2-9][0-9]|1[2-9]|11\.[1-9])")
|
2017-08-24 23:17:21 +00:00
|
|
|
ifeq ($(ICC111_OR_LATER),0)
|
2018-11-11 06:14:43 +00:00
|
|
|
# "internal error: backend signals" occurs on some x86 inline assembly with ICC 9 and
|
|
|
|
# some x64 inline assembly with ICC 11.0. If you want to use Crypto++'s assembly code
|
|
|
|
# with ICC, try enabling it on individual files
|
2017-08-24 23:17:21 +00:00
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2016-06-15 13:55:10 +00:00
|
|
|
# Allow use of "/" operator for GNU Assembler.
|
|
|
|
# http://sourceware.org/bugzilla/show_bug.cgi?id=4572
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_DISABLE_ASM,$(CXXFLAGS)),)
|
2018-11-11 06:14:43 +00:00
|
|
|
ifeq ($(IS_SUN)$(GCC_COMPILER),11)
|
|
|
|
CXXFLAGS += -Wa,--divide
|
|
|
|
endif
|
2016-06-15 13:55:10 +00:00
|
|
|
endif
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2018-12-05 18:22:10 +00:00
|
|
|
# Most Clang cannot handle mixed asm with positional arguments, where the
|
|
|
|
# body is Intel style with no prefix and the templates are AT&T style.
|
|
|
|
# Also see https://bugs.llvm.org/show_bug.cgi?id=39895 .
|
|
|
|
TPROG = TestPrograms/test_mixed_asm.cxx
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifneq ($(strip $(HAVE_OPT)),0)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_MIXED_ASM
|
|
|
|
endif
|
|
|
|
|
2018-11-11 06:14:43 +00:00
|
|
|
# IS_X86, IS_X32 and IS_X64
|
|
|
|
endif
|
2016-01-24 22:02:16 +00:00
|
|
|
|
|
|
|
###########################################################
|
2018-11-11 06:14:43 +00:00
|
|
|
##### ARM A-32, Aach64 and NEON #####
|
2016-01-24 22:02:16 +00:00
|
|
|
###########################################################
|
2015-12-25 21:06:43 +00:00
|
|
|
|
2018-11-11 06:14:43 +00:00
|
|
|
ifneq ($(IS_ARM32)$(IS_ARMV8)$(IS_NEON),000)
|
2018-11-12 19:59:36 +00:00
|
|
|
ifeq ($(DETECT_FEATURES),1)
|
2018-11-11 06:14:43 +00:00
|
|
|
|
|
|
|
ifeq ($(IS_ARM32)$(IS_NEON),11)
|
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
TPROG = TestPrograms/test_arm_neon.cxx
|
2018-11-11 06:14:43 +00:00
|
|
|
TOPT = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2017-08-17 20:35:56 +00:00
|
|
|
NEON_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
Add ARMv8.4 cpu feature detection support (GH #685) (#687)
This PR adds ARMv8.4 cpu feature detection support. Previously we only needed ARMv8.1 and things were much easier. For example, ARMv8.1 `__ARM_FEATURE_CRYPTO` meant PMULL, AES, SHA-1 and SHA-256 were available. ARMv8.4 `__ARM_FEATURE_CRYPTO` means PMULL, AES, SHA-1, SHA-256, SHA-512, SHA-3, SM3 and SM4 are available.
We still use the same pattern as before. We make something available based on compiler version and/or preprocessor macros. But this time around we had to tighten things up a bit to ensure ARMv8.4 did not cross-pollinate down into ARMv8.1.
ARMv8.4 is largely untested at the moment. There is no hardware in the field and CI lacks QEMU with the relevant patches/support. We will probably have to revisit some of this stuff in the future.
Since this update applies to ARM gadgets we took the time to expand Android and iOS testing on Travis. Travis now tests more platforms, and includes Autotools and CMake builds, too.
2018-07-15 12:35:14 +00:00
|
|
|
ARIA_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2017-12-10 17:11:53 +00:00
|
|
|
AES_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
Add ARMv8.4 cpu feature detection support (GH #685) (#687)
This PR adds ARMv8.4 cpu feature detection support. Previously we only needed ARMv8.1 and things were much easier. For example, ARMv8.1 `__ARM_FEATURE_CRYPTO` meant PMULL, AES, SHA-1 and SHA-256 were available. ARMv8.4 `__ARM_FEATURE_CRYPTO` means PMULL, AES, SHA-1, SHA-256, SHA-512, SHA-3, SM3 and SM4 are available.
We still use the same pattern as before. We make something available based on compiler version and/or preprocessor macros. But this time around we had to tighten things up a bit to ensure ARMv8.4 did not cross-pollinate down into ARMv8.1.
ARMv8.4 is largely untested at the moment. There is no hardware in the field and CI lacks QEMU with the relevant patches/support. We will probably have to revisit some of this stuff in the future.
Since this update applies to ARM gadgets we took the time to expand Android and iOS testing on Travis. Travis now tests more platforms, and includes Autotools and CMake builds, too.
2018-07-15 12:35:14 +00:00
|
|
|
CRC_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2017-08-17 23:04:00 +00:00
|
|
|
GCM_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-11-02 23:09:36 +00:00
|
|
|
BLAKE2B_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
|
|
|
BLAKE2S_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-10-24 15:00:35 +00:00
|
|
|
CHACHA_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-07-04 10:48:54 +00:00
|
|
|
CHAM_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-06-23 07:54:51 +00:00
|
|
|
LEA_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
Add ARMv8.4 cpu feature detection support (GH #685) (#687)
This PR adds ARMv8.4 cpu feature detection support. Previously we only needed ARMv8.1 and things were much easier. For example, ARMv8.1 `__ARM_FEATURE_CRYPTO` meant PMULL, AES, SHA-1 and SHA-256 were available. ARMv8.4 `__ARM_FEATURE_CRYPTO` means PMULL, AES, SHA-1, SHA-256, SHA-512, SHA-3, SM3 and SM4 are available.
We still use the same pattern as before. We make something available based on compiler version and/or preprocessor macros. But this time around we had to tighten things up a bit to ensure ARMv8.4 did not cross-pollinate down into ARMv8.1.
ARMv8.4 is largely untested at the moment. There is no hardware in the field and CI lacks QEMU with the relevant patches/support. We will probably have to revisit some of this stuff in the future.
Since this update applies to ARM gadgets we took the time to expand Android and iOS testing on Travis. Travis now tests more platforms, and includes Autotools and CMake builds, too.
2018-07-15 12:35:14 +00:00
|
|
|
SHA_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-07-01 07:11:00 +00:00
|
|
|
SIMECK_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-08-15 13:59:40 +00:00
|
|
|
SIMON64_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
|
|
|
SIMON128_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
|
|
|
SPECK64_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
|
|
|
SPECK128_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-07-13 14:39:08 +00:00
|
|
|
SM4_FLAG = -march=armv7-a -mfloat-abi=$(FP_ABI) -mfpu=neon
|
2018-11-11 06:14:43 +00:00
|
|
|
else
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
2017-08-17 20:35:56 +00:00
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
|
|
|
# IS_NEON
|
2017-08-17 16:33:43 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(IS_ARMV8),1)
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
TPROG = TestPrograms/test_arm_acle.cxx
|
2018-11-11 06:14:43 +00:00
|
|
|
TOPT = -march=armv8-a
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-12 19:59:36 +00:00
|
|
|
ACLE_FLAG += -DCRYPTOPP_ARM_ACLE_AVAILABLE=1
|
|
|
|
else
|
2018-11-11 06:14:43 +00:00
|
|
|
CXXFLAGS += -DCRYPTOPP_ARM_ACLE_AVAILABLE=0
|
|
|
|
endif
|
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
TPROG = TestPrograms/test_arm_asimd.cxx
|
2018-11-11 06:14:43 +00:00
|
|
|
TOPT = -march=armv8-a
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-11 06:14:43 +00:00
|
|
|
ASIMD_FLAG = -march=armv8-a
|
2017-08-17 20:35:56 +00:00
|
|
|
ARIA_FLAG = -march=armv8-a
|
2018-11-02 23:09:36 +00:00
|
|
|
BLAKE2B_FLAG = -march=armv8-a
|
|
|
|
BLAKE2S_FLAG = -march=armv8-a
|
2018-10-24 15:00:35 +00:00
|
|
|
CHACHA_FLAG = -march=armv8-a
|
2018-07-04 10:48:54 +00:00
|
|
|
CHAM_FLAG = -march=armv8-a
|
2018-06-23 07:54:51 +00:00
|
|
|
LEA_FLAG = -march=armv8-a
|
2017-08-17 20:35:56 +00:00
|
|
|
NEON_FLAG = -march=armv8-a
|
2018-07-01 07:11:00 +00:00
|
|
|
SIMECK_FLAG = -march=armv8-a
|
2018-08-15 13:59:40 +00:00
|
|
|
SIMON64_FLAG = -march=armv8-a
|
|
|
|
SIMON128_FLAG = -march=armv8-a
|
|
|
|
SPECK64_FLAG = -march=armv8-a
|
|
|
|
SPECK128_FLAG = -march=armv8-a
|
2018-07-13 14:39:08 +00:00
|
|
|
SM4_FLAG = -march=armv8-a
|
2018-11-11 06:14:43 +00:00
|
|
|
else
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
2017-08-17 20:35:56 +00:00
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
|
|
|
ifneq ($(ASIMD_FLAG),)
|
2018-11-12 19:59:36 +00:00
|
|
|
TPROG = TestPrograms/test_arm_crc.cxx
|
2018-12-04 10:49:21 +00:00
|
|
|
TOPT = -march=armv8-a+crc
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-12-04 10:49:21 +00:00
|
|
|
CRC_FLAG = -march=armv8-a+crc
|
2018-11-12 19:59:36 +00:00
|
|
|
else
|
|
|
|
CXXFLAGS += -DCRYPTOPP_ARM_CRC32_AVAILABLE=0
|
2018-11-11 06:14:43 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
TPROG = TestPrograms/test_arm_aes.cxx
|
2018-12-04 10:49:21 +00:00
|
|
|
TOPT = -march=armv8-a+crypto
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-12-04 10:49:21 +00:00
|
|
|
AES_FLAG = -march=armv8-a+crypto
|
2018-11-12 19:59:36 +00:00
|
|
|
else
|
|
|
|
CXXFLAGS += -DCRYPTOPP_ARM_AES_AVAILABLE=0
|
|
|
|
endif
|
|
|
|
|
|
|
|
TPROG = TestPrograms/test_arm_pmull.cxx
|
2018-12-04 10:49:21 +00:00
|
|
|
TOPT = -march=armv8-a+crypto
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-12-04 10:49:21 +00:00
|
|
|
GCM_FLAG = -march=armv8-a+crypto
|
2018-11-12 19:59:36 +00:00
|
|
|
else
|
|
|
|
CXXFLAGS += -DCRYPTOPP_ARM_PMULL_AVAILABLE=0
|
|
|
|
endif
|
|
|
|
|
|
|
|
TPROG = TestPrograms/test_arm_sha.cxx
|
2018-12-04 10:49:21 +00:00
|
|
|
TOPT = -march=armv8-a+crypto
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-12-04 10:49:21 +00:00
|
|
|
SHA_FLAG = -march=armv8-a+crypto
|
2018-11-12 19:59:36 +00:00
|
|
|
else
|
|
|
|
CXXFLAGS += -DCRYPTOPP_ARM_SHA_AVAILABLE=0
|
2018-11-11 06:14:43 +00:00
|
|
|
endif
|
|
|
|
|
2018-12-01 15:42:20 +00:00
|
|
|
TPROG = TestPrograms/test_arm_sm3.cxx
|
|
|
|
TOPT = -march=armv8.4-a+crypto
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
SM3_FLAG = -march=armv8.4-a+crypto
|
|
|
|
SM4_FLAG = -march=armv8.4-a+crypto
|
2018-11-11 06:14:43 +00:00
|
|
|
endif
|
2018-12-01 15:42:20 +00:00
|
|
|
|
|
|
|
TPROG = TestPrograms/test_arm_sha3.cxx
|
|
|
|
TOPT = -march=armv8.4-a+crypto
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(CXXFLAGS) $(ACLE_FLAG) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
SHA3_FLAG = -march=armv8.4-a+crypto
|
|
|
|
endif
|
2018-12-01 17:48:47 +00:00
|
|
|
|
2018-12-01 15:42:20 +00:00
|
|
|
# ASIMD_FLAG
|
2018-07-13 14:39:08 +00:00
|
|
|
endif
|
2018-11-11 06:14:43 +00:00
|
|
|
|
|
|
|
# IS_ARMV8
|
|
|
|
endif
|
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
# DETECT_FEATURES
|
2018-11-11 06:14:43 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
# IS_ARM32, IS_ARMV8, IS_NEON
|
2017-08-17 16:33:43 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-11 06:14:43 +00:00
|
|
|
###########################################################
|
|
|
|
##### PowerPC #####
|
|
|
|
###########################################################
|
|
|
|
|
2018-08-05 16:32:36 +00:00
|
|
|
# PowerPC and PowerPC-64. Altivec is available with POWER4 with GCC and
|
|
|
|
# POWER6 with XLC. The tests below are crafted for IBM XLC and the LLVM
|
|
|
|
# front-end. XLC/LLVM only supplies POWER8 so we have to set the flags for
|
|
|
|
# XLC/LLVM to POWER8. I've got a feeling LLVM is going to cause trouble.
|
2018-08-05 09:39:42 +00:00
|
|
|
ifneq ($(IS_PPC32)$(IS_PPC64),00)
|
2018-11-12 19:59:36 +00:00
|
|
|
ifeq ($(DETECT_FEATURES),1)
|
2018-11-11 06:14:43 +00:00
|
|
|
|
2018-11-15 01:01:05 +00:00
|
|
|
ifeq ($(XLC_COMPILER),1)
|
|
|
|
POWER9_FLAG = -qarch=pwr9 -qaltivec
|
|
|
|
POWER8_FLAG = -qarch=pwr8 -qaltivec
|
|
|
|
POWER7_FLAG = -qarch=pwr7 -qaltivec
|
2018-11-29 02:35:07 +00:00
|
|
|
POWER6_FLAG = -qarch=pwr6 -qaltivec
|
|
|
|
POWER5_FLAG = -qarch=pwr5 -qaltivec
|
|
|
|
POWER4_FLAG = -qarch=pwr4 -qaltivec
|
2018-11-29 00:58:58 +00:00
|
|
|
ALTIVEC_FLAG = -qaltivec
|
2018-11-15 01:01:05 +00:00
|
|
|
else
|
|
|
|
POWER9_FLAG = -mcpu=power9 -maltivec
|
|
|
|
POWER8_FLAG = -mcpu=power8 -maltivec
|
|
|
|
POWER7_FLAG = -mcpu=power7 -maltivec
|
2018-11-29 00:58:58 +00:00
|
|
|
ALTIVEC_FLAG = -maltivec
|
2018-11-15 01:01:05 +00:00
|
|
|
endif
|
2018-08-05 09:39:42 +00:00
|
|
|
|
2018-11-15 01:01:05 +00:00
|
|
|
# XLC with LLVM front-ends failed to define XLC defines.
|
2018-11-15 01:18:56 +00:00
|
|
|
#ifeq ($(findstring -qxlcompatmacros,$(CXXFLAGS)),)
|
|
|
|
# TPROG = TestPrograms/test_ppc_altivec.cxx
|
|
|
|
# TOPT = -qxlcompatmacros
|
2018-11-21 21:25:34 +00:00
|
|
|
# HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
2018-11-19 01:49:55 +00:00
|
|
|
# ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-15 01:18:56 +00:00
|
|
|
# CXXFLAGS += -qxlcompatmacros
|
|
|
|
# endif
|
|
|
|
#endif
|
2018-08-05 09:39:42 +00:00
|
|
|
|
2018-11-19 07:28:29 +00:00
|
|
|
#####################################################################
|
|
|
|
# Looking for a POWER8 option
|
|
|
|
|
2018-11-27 07:54:26 +00:00
|
|
|
TPROG = TestPrograms/test_ppc_power9.cxx
|
2018-11-15 01:01:05 +00:00
|
|
|
TOPT = $(POWER9_FLAG)
|
2018-11-21 21:25:34 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
2018-11-19 01:49:55 +00:00
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-30 14:12:35 +00:00
|
|
|
# DARN_FLAG = $(POWER9_FLAG)
|
2018-11-15 01:01:05 +00:00
|
|
|
else
|
|
|
|
POWER9_FLAG =
|
|
|
|
endif
|
2018-08-05 09:39:42 +00:00
|
|
|
|
2018-11-15 01:01:05 +00:00
|
|
|
TPROG = TestPrograms/test_ppc_power8.cxx
|
|
|
|
TOPT = $(POWER8_FLAG)
|
2018-11-21 21:25:34 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
2018-11-19 01:49:55 +00:00
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-15 01:01:05 +00:00
|
|
|
BLAKE2B_FLAG = $(POWER8_FLAG)
|
2018-11-29 00:58:58 +00:00
|
|
|
CRC_FLAG = $(POWER8_FLAG)
|
|
|
|
GCM_FLAG = $(POWER8_FLAG)
|
|
|
|
AES_FLAG = $(POWER8_FLAG)
|
|
|
|
SHA_FLAG = $(POWER8_FLAG)
|
|
|
|
SHACAL2_FLAG = $(POWER8_FLAG)
|
2018-11-15 01:01:05 +00:00
|
|
|
SIMON128_FLAG = $(POWER8_FLAG)
|
|
|
|
SPECK128_FLAG = $(POWER8_FLAG)
|
|
|
|
else
|
|
|
|
POWER8_FLAG =
|
|
|
|
endif
|
2018-11-14 13:19:39 +00:00
|
|
|
|
2018-11-19 07:28:29 +00:00
|
|
|
#####################################################################
|
|
|
|
# Looking for a POWER7 option
|
|
|
|
|
2018-11-15 01:01:05 +00:00
|
|
|
TPROG = TestPrograms/test_ppc_power7.cxx
|
|
|
|
TOPT = $(POWER7_FLAG)
|
2018-11-21 21:25:34 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
2018-11-19 01:49:55 +00:00
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-15 01:01:05 +00:00
|
|
|
ARIA_FLAG = $(POWER7_FLAG)
|
|
|
|
BLAKE2S_FLAG = $(POWER7_FLAG)
|
|
|
|
CHACHA_FLAG = $(POWER7_FLAG)
|
|
|
|
CHAM_FLAG = $(POWER7_FLAG)
|
|
|
|
LEA_FLAG = $(POWER7_FLAG)
|
|
|
|
SIMECK_FLAG = $(POWER7_FLAG)
|
|
|
|
SIMON64_FLAG = $(POWER7_FLAG)
|
|
|
|
SPECK64_FLAG = $(POWER7_FLAG)
|
|
|
|
else
|
|
|
|
POWER7_FLAG =
|
|
|
|
endif
|
2018-11-14 13:19:39 +00:00
|
|
|
|
2018-11-19 07:28:29 +00:00
|
|
|
#####################################################################
|
|
|
|
# Looking for an Altivec option
|
|
|
|
|
2018-11-15 01:01:05 +00:00
|
|
|
TPROG = TestPrograms/test_ppc_altivec.cxx
|
2018-11-29 00:58:58 +00:00
|
|
|
TOPT = $(ALTIVEC_FLAG)
|
2018-11-21 21:25:34 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
2018-11-29 00:58:58 +00:00
|
|
|
ifneq ($(strip $(HAVE_OPT)),0)
|
|
|
|
ALTIVEC_FLAG =
|
2018-11-15 01:01:05 +00:00
|
|
|
endif
|
2018-11-14 13:19:39 +00:00
|
|
|
|
2018-11-29 00:58:58 +00:00
|
|
|
# XLC fixup
|
|
|
|
ifeq ($(XLC_COMPILER)$(ALTIVEC_FLAG),1)
|
|
|
|
TPROG = TestPrograms/test_ppc_altivec.cxx
|
|
|
|
TOPT = $(POWER4_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
ALTIVEC_FLAG = $(POWER4_FLAG)
|
|
|
|
else
|
|
|
|
TPROG = TestPrograms/test_ppc_altivec.cxx
|
|
|
|
TOPT = $(POWER5_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
ALTIVEC_FLAG = $(POWER5_FLAG)
|
|
|
|
else
|
|
|
|
TPROG = TestPrograms/test_ppc_altivec.cxx
|
|
|
|
TOPT = $(POWER6_FLAG)
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
ALTIVEC_FLAG = $(POWER6_FLAG)
|
|
|
|
else
|
|
|
|
ALTIVEC_FLAG =
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
2018-11-19 20:23:07 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-19 07:28:29 +00:00
|
|
|
#####################################################################
|
|
|
|
# Fixups for algorithms that can drop to a lower ISA, if needed
|
|
|
|
|
2018-11-17 20:28:30 +00:00
|
|
|
# Drop to Power7 if Power8 is not available.
|
2018-11-17 05:47:17 +00:00
|
|
|
ifeq ($(POWER8_FLAG),)
|
2018-11-29 00:58:58 +00:00
|
|
|
ifneq ($(POWER7_FLAG),)
|
|
|
|
GCM_FLAG = $(POWER7_FLAG)
|
|
|
|
endif
|
2018-11-17 05:47:17 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-17 20:28:30 +00:00
|
|
|
# Drop to Power4 if Power7 not available
|
|
|
|
ifeq ($(POWER7_FLAG),)
|
2018-11-29 00:58:58 +00:00
|
|
|
ifneq ($(ALTIVEC_FLAG),)
|
|
|
|
BLAKE2S_FLAG = $(ALTIVEC_FLAG)
|
|
|
|
CHACHA_FLAG = $(ALTIVEC_FLAG)
|
|
|
|
SIMON64_FLAG = $(ALTIVEC_FLAG)
|
|
|
|
SPECK64_FLAG = $(ALTIVEC_FLAG)
|
|
|
|
endif
|
2018-11-15 01:01:05 +00:00
|
|
|
endif
|
2018-11-14 13:19:39 +00:00
|
|
|
|
2018-11-19 07:28:29 +00:00
|
|
|
#####################################################################
|
|
|
|
# Fixups for missing ISAs
|
|
|
|
|
2018-08-05 09:39:42 +00:00
|
|
|
ifeq ($(ALTIVEC_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ALTIVEC
|
2018-11-29 00:58:58 +00:00
|
|
|
else ifeq ($(POWER8_FLAG)$(POWER7_FLAG),)
|
2018-08-05 09:39:42 +00:00
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_POWER7
|
2018-11-29 00:58:58 +00:00
|
|
|
else ifeq ($(POWER8_FLAG),)
|
2018-08-05 09:39:42 +00:00
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_POWER8
|
2018-11-27 07:54:26 +00:00
|
|
|
else ifeq ($(POWER9_FLAG),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_POWER9
|
2017-10-18 00:47:14 +00:00
|
|
|
endif
|
2018-11-19 07:28:29 +00:00
|
|
|
|
2018-11-12 19:59:36 +00:00
|
|
|
# DETECT_FEATURES
|
2017-09-10 00:33:06 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
# IBM XL C/C++ compiler
|
2017-09-09 21:22:42 +00:00
|
|
|
ifeq ($(XLC_COMPILER),1)
|
2018-11-14 13:19:39 +00:00
|
|
|
ifeq ($(findstring -qmaxmem,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -qmaxmem=-1
|
|
|
|
endif
|
2017-09-09 21:22:42 +00:00
|
|
|
# http://www-01.ibm.com/support/docview.wss?uid=swg21007500
|
|
|
|
ifeq ($(findstring -qrtti,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -qrtti
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2018-11-11 06:14:43 +00:00
|
|
|
# IS_PPC32, IS_PPC64
|
|
|
|
endif
|
2016-01-24 22:02:16 +00:00
|
|
|
|
|
|
|
###########################################################
|
|
|
|
##### Common #####
|
|
|
|
###########################################################
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-07-29 18:37:25 +00:00
|
|
|
# Add -fPIC for targets *except* X86, X32, Cygwin or MinGW
|
|
|
|
ifeq ($(IS_X86)$(IS_CYGWIN)$(IS_MINGW),000)
|
2018-11-21 20:16:55 +00:00
|
|
|
ifeq ($(findstring -fpic,$(CXXFLAGS))$(findstring -fPIC,$(CXXFLAGS)),)
|
2018-11-11 06:14:43 +00:00
|
|
|
CXXFLAGS += -fPIC
|
|
|
|
endif
|
2018-07-29 18:37:25 +00:00
|
|
|
endif
|
|
|
|
|
2017-08-31 14:08:18 +00:00
|
|
|
# Use -pthread whenever it is available. See http://www.hpl.hp.com/techreports/2004/HPL-2004-209.pdf
|
|
|
|
# http://stackoverflow.com/questions/2127797/gcc-significance-of-pthread-flag-when-compiling
|
2018-11-13 19:02:40 +00:00
|
|
|
ifeq ($(DETECT_FEATURES),1)
|
2018-11-21 20:16:55 +00:00
|
|
|
ifeq ($(XLC_COMPILER),1)
|
|
|
|
ifeq ($(findstring -qthreaded,$(CXXFLAGS)),)
|
|
|
|
TPROG = TestPrograms/test_pthreads.cxx
|
|
|
|
TOPT = -qthreaded
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-21 20:16:55 +00:00
|
|
|
CXXFLAGS += -qthreaded
|
|
|
|
endif # CXXFLAGS
|
|
|
|
endif # qthreaded
|
|
|
|
else
|
|
|
|
ifeq ($(findstring -pthread,$(CXXFLAGS)),)
|
|
|
|
TPROG = TestPrograms/test_pthreads.cxx
|
|
|
|
TOPT = -pthread
|
2018-12-01 08:16:54 +00:00
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
2018-11-21 20:16:55 +00:00
|
|
|
CXXFLAGS += -pthread
|
|
|
|
endif # CXXFLAGS
|
|
|
|
endif # pthread
|
|
|
|
endif # XLC/GCC and friends
|
2018-11-13 19:02:40 +00:00
|
|
|
endif # DETECT_FEATURES
|
2017-08-31 14:08:18 +00:00
|
|
|
|
2018-09-09 07:44:50 +00:00
|
|
|
# Remove -fPIC if present. SunCC use -KPIC, and needs the larger GOT table
|
|
|
|
# https://docs.oracle.com/cd/E19205-01/819-5267/bkbaq/index.html
|
2018-07-29 18:37:25 +00:00
|
|
|
ifeq ($(SUN_COMPILER),1)
|
|
|
|
CXXFLAGS := $(subst -fPIC,-KPIC,$(CXXFLAGS))
|
2018-09-09 07:44:50 +00:00
|
|
|
CXXFLAGS := $(subst -fpic,-KPIC,$(CXXFLAGS))
|
2018-07-29 18:37:25 +00:00
|
|
|
endif
|
|
|
|
|
2018-11-21 20:16:55 +00:00
|
|
|
# Remove -fPIC if present. IBM XL C/C++ use -qpic
|
|
|
|
ifeq ($(XLC_COMPILER),1)
|
|
|
|
CXXFLAGS := $(subst -fPIC,-qpic,$(CXXFLAGS))
|
|
|
|
CXXFLAGS := $(subst -fpic,-qpic,$(CXXFLAGS))
|
|
|
|
endif
|
|
|
|
|
2018-11-13 19:02:40 +00:00
|
|
|
# Add -xregs=no%appl SPARC. SunCC should not use certain registers in library code.
|
2018-09-09 07:01:10 +00:00
|
|
|
# https://docs.oracle.com/cd/E18659_01/html/821-1383/bkamt.html
|
|
|
|
ifeq ($(IS_SUN)$(SUN_COMPILER),11)
|
|
|
|
ifneq ($(IS_SPARC32)$(IS_SPARC64),00)
|
|
|
|
ifeq ($(findstring -xregs=no%appl,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -xregs=no%appl
|
|
|
|
endif # -xregs
|
|
|
|
endif # Sparc
|
|
|
|
endif # SunOS
|
|
|
|
|
2017-09-17 02:09:50 +00:00
|
|
|
# Add -pipe for everything except IBM XL C/C++, SunCC and ARM.
|
2017-09-09 19:10:32 +00:00
|
|
|
# Allow ARM-64 because they seems to have >1 GB of memory
|
2017-09-17 02:09:50 +00:00
|
|
|
ifeq ($(XLC_COMPILER)$(SUN_COMPILER)$(IS_ARM32),000)
|
2017-08-31 14:08:18 +00:00
|
|
|
ifeq ($(findstring -save-temps,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -pipe
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2017-04-23 16:11:08 +00:00
|
|
|
# For SunOS, create a Mapfile that allows our object files
|
2017-08-17 16:33:43 +00:00
|
|
|
# to contain additional bits (like SSE4 and AES on old Xeon)
|
2017-04-23 16:11:08 +00:00
|
|
|
# http://www.oracle.com/technetwork/server-storage/solaris/hwcap-modification-139536.html
|
|
|
|
ifeq ($(IS_SUN)$(SUN_COMPILER),11)
|
2018-01-27 18:05:23 +00:00
|
|
|
ifneq ($(IS_X86)$(IS_X64),00)
|
2017-08-31 14:08:18 +00:00
|
|
|
ifeq ($(findstring -DCRYPTOPP_DISABLE_ASM,$(CXXFLAGS)),)
|
2017-11-13 03:48:51 +00:00
|
|
|
LDFLAGS += -M cryptopp.mapfile
|
2017-08-31 14:08:18 +00:00
|
|
|
endif # No CRYPTOPP_DISABLE_ASM
|
|
|
|
endif # X86/X32/X64
|
2017-04-23 16:11:08 +00:00
|
|
|
endif # SunOS
|
|
|
|
|
2018-12-04 16:05:16 +00:00
|
|
|
# TODO: can we remove this since removing sockets?
|
2015-07-31 12:09:59 +00:00
|
|
|
ifneq ($(IS_MINGW),0)
|
2017-08-31 14:08:18 +00:00
|
|
|
LDLIBS += -lws2_32
|
2015-11-05 06:59:46 +00:00
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-12-04 16:05:16 +00:00
|
|
|
# TODO: can we remove this since removing sockets?
|
2016-06-09 01:41:45 +00:00
|
|
|
ifneq ($(IS_SUN),0)
|
2017-08-31 14:08:18 +00:00
|
|
|
LDLIBS += -lnsl -lsocket
|
2016-06-09 01:41:45 +00:00
|
|
|
endif
|
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
ifeq ($(IS_LINUX),1)
|
2017-08-31 14:08:18 +00:00
|
|
|
ifeq ($(findstring -fopenmp,$(CXXFLAGS)),-fopenmp)
|
|
|
|
ifeq ($(findstring -lgomp,$(LDLIBS)),)
|
|
|
|
LDLIBS += -lgomp
|
|
|
|
endif # LDLIBS
|
|
|
|
endif # OpenMP
|
2015-11-05 06:59:46 +00:00
|
|
|
endif # IS_LINUX
|
|
|
|
|
2016-06-09 04:51:23 +00:00
|
|
|
# Add -errtags=yes to get the name for a warning suppression
|
2015-07-31 12:09:59 +00:00
|
|
|
ifneq ($(SUN_COMPILER),0) # override flags for CC Sun C++ compiler
|
2016-06-15 09:02:28 +00:00
|
|
|
# Add to all Solaris
|
2016-07-08 22:32:12 +00:00
|
|
|
CXXFLAGS += -template=no%extdef
|
2017-08-29 12:57:04 +00:00
|
|
|
SUN_CC10_BUGGY := $(shell $(CXX) -V 2>&1 | $(GREP) -c -E "CC: Sun .* 5\.10 .* (2009|2010/0[1-4])")
|
2015-07-31 12:09:59 +00:00
|
|
|
ifneq ($(SUN_CC10_BUGGY),0)
|
2018-11-08 21:20:31 +00:00
|
|
|
# -DCRYPTOPP_INCLUDE_VECTOR_CC is needed for Sun Studio 12u1 Sun C++ 5.10 SunOS_i386 128229-02 2009/09/21
|
|
|
|
# and was fixed in May 2010. Remove it if you get "already had a body defined" errors in vector.cc
|
2015-07-31 12:09:59 +00:00
|
|
|
CXXFLAGS += -DCRYPTOPP_INCLUDE_VECTOR_CC
|
2015-11-05 06:59:46 +00:00
|
|
|
endif
|
2016-06-09 01:41:45 +00:00
|
|
|
AR = $(CXX)
|
|
|
|
ARFLAGS = -xar -o
|
|
|
|
RANLIB = true
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2017-04-17 04:20:22 +00:00
|
|
|
# No ASM for Travis testing
|
|
|
|
ifeq ($(findstring no-asm,$(MAKECMDGOALS)),no-asm)
|
2018-12-04 16:05:16 +00:00
|
|
|
ifeq ($(findstring -DCRYPTOPP_DISABLE_ASM,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
|
|
|
endif # CXXFLAGS
|
2017-04-17 04:20:22 +00:00
|
|
|
endif # No ASM
|
|
|
|
|
2017-08-23 20:13:20 +00:00
|
|
|
# Native build testing. Issue 'make native'.
|
|
|
|
ifeq ($(findstring native,$(MAKECMDGOALS)),native)
|
2018-12-04 16:05:16 +00:00
|
|
|
NATIVE_OPT =
|
|
|
|
|
|
|
|
# Try GCC and compatibles first
|
|
|
|
TPROG = TestPrograms/test_cxx.cxx
|
|
|
|
TOPT = -march=native
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
NATIVE_OPT = -march=native
|
|
|
|
endif # NATIVE_OPT
|
|
|
|
|
|
|
|
# Try SunCC next
|
|
|
|
ifeq ($(NATIVE_OPT),)
|
|
|
|
TOPT = -native
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
NATIVE_OPT = -native
|
|
|
|
endif # NATIVE_OPT
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq ($(NATIVE_OPT),)
|
|
|
|
CXXFLAGS += $(NATIVE_OPT)
|
|
|
|
endif
|
|
|
|
|
2017-08-23 20:13:20 +00:00
|
|
|
endif # Native
|
|
|
|
|
2017-05-22 00:45:08 +00:00
|
|
|
# Undefined Behavior Sanitizer (UBsan) testing. Issue 'make ubsan'.
|
2015-11-05 06:59:46 +00:00
|
|
|
ifeq ($(findstring ubsan,$(MAKECMDGOALS)),ubsan)
|
2017-08-24 23:17:21 +00:00
|
|
|
CXXFLAGS := $(CXXFLAGS:-g%=-g3)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-O%=-O1)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-xO%=-xO1)
|
|
|
|
ifeq ($(findstring -fsanitize=undefined,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -fsanitize=undefined
|
|
|
|
endif # CXXFLAGS
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_COVERAGE,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_COVERAGE
|
|
|
|
endif # CXXFLAGS
|
2015-11-05 06:59:46 +00:00
|
|
|
endif # UBsan
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# Address Sanitizer (Asan) testing. Issue 'make asan'.
|
2015-11-05 06:59:46 +00:00
|
|
|
ifeq ($(findstring asan,$(MAKECMDGOALS)),asan)
|
2017-08-24 23:17:21 +00:00
|
|
|
CXXFLAGS := $(CXXFLAGS:-g%=-g3)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-O%=-O1)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-xO%=-xO1)
|
|
|
|
ifeq ($(findstring -fsanitize=address,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -fsanitize=address
|
|
|
|
endif # CXXFLAGS
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_COVERAGE,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_COVERAGE
|
|
|
|
endif # CXXFLAGS
|
|
|
|
ifeq ($(findstring -fno-omit-frame-pointer,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -fno-omit-frame-pointer
|
|
|
|
endif # CXXFLAGS
|
2015-11-05 06:59:46 +00:00
|
|
|
endif # Asan
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# LD gold linker testing. Triggered by 'LD=ld.gold'.
|
2015-11-05 06:59:46 +00:00
|
|
|
ifeq ($(findstring ld.gold,$(LD)),ld.gold)
|
2017-08-24 23:17:21 +00:00
|
|
|
ifeq ($(findstring -fuse-ld=gold,$(CXXFLAGS)),)
|
2018-01-02 06:13:59 +00:00
|
|
|
LD_GOLD = $(shell command -v ld.gold)
|
|
|
|
ELF_FORMAT := $(shell file $(LD_GOLD) 2>&1 | cut -d":" -f 2 | $(GREP) -i -c "elf")
|
2017-08-24 23:17:21 +00:00
|
|
|
ifneq ($(ELF_FORMAT),0)
|
|
|
|
LDFLAGS += -fuse-ld=gold
|
|
|
|
endif # ELF/ELF64
|
|
|
|
endif # CXXFLAGS
|
2015-11-05 06:59:46 +00:00
|
|
|
endif # Gold
|
|
|
|
|
2017-05-27 07:42:50 +00:00
|
|
|
# lcov code coverage. Issue 'make coverage'.
|
2017-05-27 11:02:44 +00:00
|
|
|
ifneq ($(filter lcov coverage,$(MAKECMDGOALS)),)
|
2017-08-24 23:17:21 +00:00
|
|
|
CXXFLAGS := $(CXXFLAGS:-g%=-g3)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-O%=-O1)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-xO%=-xO1)
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_COVERAGE,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_COVERAGE
|
|
|
|
endif # CRYPTOPP_COVERAGE
|
|
|
|
ifeq ($(findstring -coverage,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -coverage
|
|
|
|
endif # -coverage
|
2017-05-27 07:42:50 +00:00
|
|
|
endif # GCC code coverage
|
|
|
|
|
|
|
|
# gcov code coverage for Travis. Issue 'make codecov'.
|
2017-05-27 11:02:44 +00:00
|
|
|
ifneq ($(filter gcov codecov,$(MAKECMDGOALS)),)
|
2017-08-24 23:17:21 +00:00
|
|
|
CXXFLAGS := $(CXXFLAGS:-g%=-g3)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-O%=-O1)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-xO%=-xO1)
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_COVERAGE,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_COVERAGE
|
|
|
|
endif # CRYPTOPP_COVERAGE
|
|
|
|
ifeq ($(findstring -coverage,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -coverage
|
|
|
|
endif # -coverage
|
2015-12-29 09:50:15 +00:00
|
|
|
endif # GCC code coverage
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2017-05-07 02:54:49 +00:00
|
|
|
# Valgrind testing. Issue 'make valgrind'.
|
|
|
|
ifneq ($(filter valgrind,$(MAKECMDGOALS)),)
|
2017-08-24 23:17:21 +00:00
|
|
|
# Tune flags; see http://valgrind.org/docs/manual/quick-start.html
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-g%=-g3)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-O%=-O1)
|
|
|
|
CXXFLAGS := $(CXXFLAGS:-xO%=-xO1)
|
|
|
|
ifeq ($(findstring -DCRYPTOPP_VALGRIND,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -DCRYPTOPP_VALGRIND
|
|
|
|
endif # -DCRYPTOPP_VALGRIND
|
2017-05-07 02:54:49 +00:00
|
|
|
endif # Valgrind
|
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# Debug testing on GNU systems. Triggered by -DDEBUG.
|
2016-06-17 10:36:22 +00:00
|
|
|
# Newlib test due to http://sourceware.org/bugzilla/show_bug.cgi?id=20268
|
2015-11-05 06:59:46 +00:00
|
|
|
ifneq ($(filter -DDEBUG -DDEBUG=1,$(CXXFLAGS)),)
|
2018-11-11 06:14:43 +00:00
|
|
|
TPROG = TestPrograms/test_cxx.cxx
|
2018-11-13 19:02:40 +00:00
|
|
|
USING_GLIBCXX := $(shell $(CXX) $(CXXFLAGS) -E $(TPROG) -o $(TOUT) 2>&1 | $(GREP) -i -c "__GLIBCXX__")
|
2017-08-24 23:17:21 +00:00
|
|
|
ifneq ($(USING_GLIBCXX),0)
|
|
|
|
ifeq ($(HAS_NEWLIB),0)
|
|
|
|
ifeq ($(findstring -D_GLIBCXX_DEBUG,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -D_GLIBCXX_DEBUG
|
|
|
|
endif # CXXFLAGS
|
|
|
|
endif # HAS_NEWLIB
|
|
|
|
endif # USING_GLIBCXX
|
2018-11-22 01:19:06 +00:00
|
|
|
|
|
|
|
ifeq ($(XLC_COMPILER),1)
|
|
|
|
TPROG = TestPrograms/test_cxx.cxx
|
|
|
|
TOPT = -qheapdebug -qro
|
|
|
|
HAVE_OPT = $(shell $(CXX) $(TCXXFLAGS) $(ZOPT) $(TOPT) $(TPROG) -o $(TOUT) 2>&1 | tr ' ' '\n' | wc -l)
|
|
|
|
ifeq ($(strip $(HAVE_OPT)),0)
|
|
|
|
CXXFLAGS += -qheapdebug -qro
|
|
|
|
endif # CXXFLAGS
|
|
|
|
endif # XLC_COMPILER
|
|
|
|
endif # Debug build
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# Dead code stripping. Issue 'make lean'.
|
|
|
|
ifeq ($(findstring lean,$(MAKECMDGOALS)),lean)
|
2017-08-24 23:17:21 +00:00
|
|
|
ifeq ($(findstring -ffunction-sections,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -ffunction-sections
|
|
|
|
endif # CXXFLAGS
|
|
|
|
ifeq ($(findstring -fdata-sections,$(CXXFLAGS)),)
|
|
|
|
CXXFLAGS += -fdata-sections
|
|
|
|
endif # CXXFLAGS
|
|
|
|
ifneq ($(IS_DARWIN),0)
|
|
|
|
ifeq ($(findstring -Wl,-dead_strip,$(LDFLAGS)),)
|
|
|
|
LDFLAGS += -Wl,-dead_strip
|
|
|
|
endif # CXXFLAGS
|
|
|
|
else # BSD, Linux and Unix
|
|
|
|
ifeq ($(findstring -Wl,--gc-sections,$(LDFLAGS)),)
|
|
|
|
LDFLAGS += -Wl,--gc-sections
|
|
|
|
endif # LDFLAGS
|
|
|
|
endif # MAKECMDGOALS
|
2016-01-04 23:24:18 +00:00
|
|
|
endif # Dead code stripping
|
|
|
|
|
2016-01-24 22:02:16 +00:00
|
|
|
# For Shared Objects, Diff, Dist/Zip rules
|
2017-08-29 12:57:04 +00:00
|
|
|
LIB_VER := $(shell $(GREP) "define CRYPTOPP_VERSION" config.h | cut -d" " -f 3)
|
2016-01-24 22:02:16 +00:00
|
|
|
LIB_MAJOR := $(shell echo $(LIB_VER) | cut -c 1)
|
|
|
|
LIB_MINOR := $(shell echo $(LIB_VER) | cut -c 2)
|
|
|
|
LIB_PATCH := $(shell echo $(LIB_VER) | cut -c 3)
|
|
|
|
|
|
|
|
ifeq ($(strip $(LIB_PATCH)),)
|
2017-08-24 23:17:21 +00:00
|
|
|
LIB_PATCH := 0
|
2016-01-24 22:02:16 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
2018-02-20 15:05:52 +00:00
|
|
|
# Different patchlevels and minors are compatible since 6.1
|
|
|
|
SOLIB_COMPAT_SUFFIX=.$(LIB_MAJOR)
|
2018-08-19 10:10:30 +00:00
|
|
|
# Linux uses -Wl,-soname
|
|
|
|
ifeq ($(IS_LINUX),1)
|
2018-08-19 11:04:19 +00:00
|
|
|
# Linux uses full version suffix for shared library
|
|
|
|
SOLIB_VERSION_SUFFIX=.$(LIB_MAJOR).$(LIB_MINOR).$(LIB_PATCH)
|
2016-01-24 22:02:16 +00:00
|
|
|
SOLIB_FLAGS=-Wl,-soname,libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
2018-08-19 10:10:30 +00:00
|
|
|
endif
|
|
|
|
# Solaris uses -Wl,-h
|
|
|
|
ifeq ($(IS_SUN),1)
|
2018-08-19 11:04:19 +00:00
|
|
|
# Solaris uses major version suffix for shared library, but we use major.minor
|
|
|
|
# The minor version allows previous version to remain and not overwritten.
|
|
|
|
# https://blogs.oracle.com/solaris/how-to-name-a-solaris-shared-object-v2
|
|
|
|
SOLIB_VERSION_SUFFIX=.$(LIB_MAJOR).$(LIB_MINOR)
|
2018-08-19 10:10:30 +00:00
|
|
|
SOLIB_FLAGS=-Wl,-h,libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
|
|
|
endif
|
2016-01-24 22:02:16 +00:00
|
|
|
endif # HAS_SOLIB_VERSION
|
|
|
|
|
2018-11-13 19:02:40 +00:00
|
|
|
###########################################################
|
|
|
|
##### Temp file cleanup #####
|
|
|
|
###########################################################
|
|
|
|
|
|
|
|
# After this point no more test programs should be run.
|
|
|
|
# https://github.com/weidai11/cryptopp/issues/738
|
|
|
|
ifeq ($(findstring /dev/null,$(TOUT)),)
|
|
|
|
# $(info TOUT is not /dev/null, cleaning $(TOUT))
|
|
|
|
ifeq ($(wildcard $(TOUT)),$(TOUT))
|
|
|
|
UNUSED := $(shell $(RM) $(TOUT) 2>/dev/null)
|
|
|
|
endif
|
|
|
|
ifeq ($(wildcard $(TOUT).dSYM/),$(TOUT).dSYM/)
|
|
|
|
UNUSED := $(shell $(RM) -r $(TOUT).dSYM/ 2>/dev/null)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2016-01-24 22:02:16 +00:00
|
|
|
###########################################################
|
|
|
|
##### Source and object files #####
|
|
|
|
###########################################################
|
|
|
|
|
2016-09-15 01:31:10 +00:00
|
|
|
# List cryptlib.cpp first, then cpu.cpp, then integer.cpp to tame C++ static initialization problems.
|
2017-05-19 22:34:08 +00:00
|
|
|
SRCS := cryptlib.cpp cpu.cpp integer.cpp $(filter-out cryptlib.cpp cpu.cpp integer.cpp pch.cpp simple.cpp winpipes.cpp cryptlib_bds.cpp,$(sort $(wildcard *.cpp)))
|
2017-11-01 22:25:44 +00:00
|
|
|
# For Makefile.am; resource.h is Windows
|
|
|
|
INCL := $(filter-out resource.h,$(sort $(wildcard *.h)))
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
ifneq ($(IS_MINGW),0)
|
2017-11-01 22:25:44 +00:00
|
|
|
INCL += resource.h
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2018-07-11 10:59:44 +00:00
|
|
|
# Cryptogams AES for ARMv4 and above. We couple to ARMv7.
|
2018-12-01 15:42:20 +00:00
|
|
|
# Avoid iOS. It cannot consume the assembly.
|
2018-07-11 10:59:44 +00:00
|
|
|
ifeq ($(IS_ARM32),1)
|
2018-12-01 15:42:20 +00:00
|
|
|
CRYPTOGAMS_AES_FLAG = -march=armv7-a
|
|
|
|
CRYPTOGAMS_AES_FLAG += -Wa,--noexecstack
|
|
|
|
SRCS += aes_armv4.S
|
2018-07-11 10:59:44 +00:00
|
|
|
endif
|
|
|
|
|
2016-09-15 01:31:10 +00:00
|
|
|
# List cryptlib.cpp first, then cpu.cpp, then integer.cpp to tame C++ static initialization problems.
|
2015-11-05 06:59:46 +00:00
|
|
|
OBJS := $(SRCS:.cpp=.o)
|
2018-07-09 10:19:58 +00:00
|
|
|
OBJS := $(OBJS:.S=.o)
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-09-15 01:31:10 +00:00
|
|
|
# List test.cpp first to tame C++ static initialization problems.
|
2018-07-30 00:30:19 +00:00
|
|
|
TESTSRCS := adhoc.cpp test.cpp bench1.cpp bench2.cpp bench3.cpp datatest.cpp dlltest.cpp fipsalgt.cpp validat0.cpp validat1.cpp validat2.cpp validat3.cpp validat4.cpp validat5.cpp validat6.cpp validat7.cpp validat8.cpp validat9.cpp validat10.cpp regtest1.cpp regtest2.cpp regtest3.cpp regtest4.cpp
|
2017-11-01 22:25:44 +00:00
|
|
|
TESTINCL := bench.h factory.h validate.h
|
2018-07-09 10:19:58 +00:00
|
|
|
|
2017-11-01 22:25:44 +00:00
|
|
|
# Test objects
|
2015-12-25 21:06:43 +00:00
|
|
|
TESTOBJS := $(TESTSRCS:.cpp=.o)
|
2015-11-05 06:59:46 +00:00
|
|
|
LIBOBJS := $(filter-out $(TESTOBJS),$(OBJS))
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-07-09 10:19:58 +00:00
|
|
|
# In Crypto++ 5.6.2 these were the source and object files for the FIPS DLL.
|
|
|
|
# Since the library is on the Historical Validation List we add all files.
|
|
|
|
# The 5.6.2 list is at https://github.com/weidai11/cryptopp/blob/789f81f048c9.
|
|
|
|
DLLSRCS := $(SRCS)
|
2015-11-05 06:59:46 +00:00
|
|
|
DLLOBJS := $(DLLSRCS:.cpp=.export.o)
|
2018-07-09 10:19:58 +00:00
|
|
|
DLLOBJS := $(DLLOBJS:.S=.export.o)
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
# Import lib testing
|
|
|
|
LIBIMPORTOBJS := $(LIBOBJS:.o=.import.o)
|
|
|
|
TESTIMPORTOBJS := $(TESTOBJS:.o=.import.o)
|
|
|
|
DLLTESTOBJS := dlltest.dllonly.o
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-01-24 22:02:16 +00:00
|
|
|
###########################################################
|
|
|
|
##### Targets and Recipes #####
|
|
|
|
###########################################################
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-01-27 18:05:23 +00:00
|
|
|
# Default builds program with static library only
|
|
|
|
.PHONY: default
|
|
|
|
default: cryptest.exe
|
|
|
|
|
2018-07-31 17:33:57 +00:00
|
|
|
.PHONY: all static dynamic
|
2018-01-27 18:05:23 +00:00
|
|
|
all: static dynamic cryptest.exe
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
ifneq ($(IS_DARWIN),0)
|
2018-07-31 17:33:57 +00:00
|
|
|
static: libcryptopp.a
|
|
|
|
shared dynamic dylib: libcryptopp.dylib
|
2015-07-31 12:09:59 +00:00
|
|
|
else
|
2018-07-31 17:33:57 +00:00
|
|
|
static: libcryptopp.a
|
|
|
|
shared dynamic: libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
|
|
|
|
2017-08-17 16:33:43 +00:00
|
|
|
.PHONY: dep deps depend
|
|
|
|
dep deps depend GNUmakefile.deps:
|
2018-10-26 15:10:07 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_DISABLE_ASM) -MM *.cpp > GNUmakefile.deps
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# CXXFLAGS are tuned earlier.
|
2017-08-23 20:13:20 +00:00
|
|
|
.PHONY: native no-asm asan ubsan
|
2018-01-27 18:05:23 +00:00
|
|
|
native no-asm asan ubsan: cryptest.exe
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# CXXFLAGS are tuned earlier. Applications must use linker flags
|
|
|
|
# -Wl,--gc-sections (Linux and Unix) or -Wl,-dead_strip (OS X)
|
|
|
|
.PHONY: lean
|
|
|
|
lean: static dynamic cryptest.exe
|
|
|
|
|
|
|
|
# May want to export CXXFLAGS="-g3 -O1"
|
2017-05-27 11:02:44 +00:00
|
|
|
.PHONY: lcov coverage
|
2018-01-27 18:05:23 +00:00
|
|
|
lcov coverage: cryptest.exe
|
2017-03-10 06:53:51 +00:00
|
|
|
@-$(RM) -r ./TestCoverage/
|
2015-12-28 12:06:50 +00:00
|
|
|
lcov --base-directory . --directory . --zerocounters -q
|
|
|
|
./cryptest.exe v
|
2015-12-29 09:50:15 +00:00
|
|
|
./cryptest.exe tv all
|
2015-12-28 12:06:50 +00:00
|
|
|
lcov --base-directory . --directory . -c -o cryptest.info
|
2017-05-05 21:21:08 +00:00
|
|
|
lcov --remove cryptest.info "adhoc.cpp" "wait.*" "network.*" "socketft.*" "fips140.*" "*test.*" "bench*.cpp" "validat*.*" "/usr/*" -o cryptest.info
|
2015-12-28 12:06:50 +00:00
|
|
|
genhtml -o ./TestCoverage/ -t "cryptest.exe test coverage" --num-spaces 4 cryptest.info
|
|
|
|
|
2017-05-27 07:42:50 +00:00
|
|
|
# Travis CI and CodeCov rule
|
2017-05-27 11:02:44 +00:00
|
|
|
.PHONY: gcov codecov
|
2018-01-27 18:05:23 +00:00
|
|
|
gcov codecov: cryptest.exe
|
2017-05-27 07:42:50 +00:00
|
|
|
@-$(RM) -r ./TestCoverage/
|
|
|
|
./cryptest.exe v
|
|
|
|
./cryptest.exe tv all
|
2017-05-27 11:18:48 +00:00
|
|
|
gcov -r $(SRCS)
|
2017-05-27 07:42:50 +00:00
|
|
|
|
|
|
|
# Should use CXXFLAGS="-g3 -O1"
|
2017-05-07 02:54:49 +00:00
|
|
|
.PHONY: valgrind
|
2018-01-27 18:05:23 +00:00
|
|
|
valgrind: cryptest.exe
|
2017-11-29 11:52:43 +00:00
|
|
|
valgrind --track-origins=yes --suppressions=cryptopp.supp ./cryptest.exe v
|
2017-05-07 02:54:49 +00:00
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
.PHONY: test check
|
|
|
|
test check: cryptest.exe
|
|
|
|
./cryptest.exe v
|
|
|
|
|
2016-01-04 23:24:18 +00:00
|
|
|
# Used to generate list of source files for Autotools, CMakeList, Android.mk, etc
|
2015-12-25 21:06:43 +00:00
|
|
|
.PHONY: sources
|
2016-11-01 09:07:57 +00:00
|
|
|
sources: adhoc.cpp
|
2018-07-09 10:19:58 +00:00
|
|
|
$(info ***** Library sources *****)
|
|
|
|
$(info $(filter-out $(TESTSRCS),$(SRCS)))
|
2015-12-25 21:06:43 +00:00
|
|
|
$(info )
|
2018-07-09 10:19:58 +00:00
|
|
|
$(info ***** Library headers *****)
|
|
|
|
$(info $(filter-out $(TESTINCL),$(INCL)))
|
2017-11-01 22:25:44 +00:00
|
|
|
$(info )
|
2018-07-09 10:19:58 +00:00
|
|
|
$(info ***** Test sources *****)
|
|
|
|
$(info $(TESTSRCS))
|
2017-11-01 22:25:44 +00:00
|
|
|
$(info )
|
2018-07-25 04:11:09 +00:00
|
|
|
$(info ***** Test headers *****)
|
|
|
|
$(info $(TESTINCL))
|
2015-12-25 21:06:43 +00:00
|
|
|
|
2015-11-18 20:35:35 +00:00
|
|
|
# Directory we want (can't specify on Doygen command line)
|
|
|
|
DOCUMENT_DIRECTORY := ref$(LIB_VER)
|
|
|
|
# Directory Doxygen uses (specified in Doygen config file)
|
|
|
|
ifeq ($(wildcard Doxyfile),Doxyfile)
|
2017-08-29 12:57:04 +00:00
|
|
|
DOXYGEN_DIRECTORY := $(strip $(shell $(GREP) "OUTPUT_DIRECTORY" Doxyfile | $(GREP) -v "\#" | cut -d "=" -f 2))
|
2015-11-05 06:59:46 +00:00
|
|
|
endif
|
2015-11-25 20:20:37 +00:00
|
|
|
# Default directory (in case its missing in the config file)
|
2015-11-23 00:17:15 +00:00
|
|
|
ifeq ($(strip $(DOXYGEN_DIRECTORY)),)
|
|
|
|
DOXYGEN_DIRECTORY := html-docs
|
2015-11-05 06:59:46 +00:00
|
|
|
endif
|
|
|
|
|
2015-12-25 21:06:43 +00:00
|
|
|
# Builds the documentation. Directory name is ref563, ref570, etc.
|
2015-11-05 06:59:46 +00:00
|
|
|
.PHONY: docs html
|
|
|
|
docs html:
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -r $(DOXYGEN_DIRECTORY)/ $(DOCUMENT_DIRECTORY)/ html-docs/
|
|
|
|
@-$(RM) CryptoPPRef.zip
|
2015-11-05 06:59:46 +00:00
|
|
|
doxygen Doxyfile -d CRYPTOPP_DOXYGEN_PROCESSING
|
2015-12-26 11:45:59 +00:00
|
|
|
$(MV) $(DOXYGEN_DIRECTORY)/ $(DOCUMENT_DIRECTORY)/
|
2015-11-18 20:35:35 +00:00
|
|
|
zip -9 CryptoPPRef.zip -x ".*" -x "*/.*" -r $(DOCUMENT_DIRECTORY)/
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
2017-03-10 06:53:51 +00:00
|
|
|
-$(RM) adhoc.cpp.o adhoc.cpp.proto.o $(LIBOBJS) rdrand-*.o $(TESTOBJS) $(DLLOBJS) $(LIBIMPORTOBJS) $(TESTIMPORTOBJS) $(DLLTESTOBJS)
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) libcryptopp.a libcryptopp.dylib cryptopp.dll libcryptopp.dll.a libcryptopp.import.a
|
|
|
|
@-$(RM) libcryptopp.so libcryptopp.so$(SOLIB_COMPAT_SUFFIX) libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
2017-08-31 16:15:39 +00:00
|
|
|
@-$(RM) cryptest.exe dlltest.exe cryptest.import.exe cryptest.info ct et
|
2017-11-05 08:42:39 +00:00
|
|
|
@-$(RM) *.la *.lo *.gcov *.gcno *.gcda *.stackdump core core-*
|
2018-11-13 19:02:40 +00:00
|
|
|
@-$(RM) /tmp/adhoc.exe
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -r /tmp/cryptopp_test/
|
2018-11-13 19:02:40 +00:00
|
|
|
@-$(RM) -r *.exe.dSYM/ *.dylib.dSYM/
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -r cov-int/
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-07-28 13:21:31 +00:00
|
|
|
.PHONY: autotools-clean
|
|
|
|
autotools-clean:
|
|
|
|
@-$(RM) -f configure.ac configure configure.in Makefile.am Makefile.in Makefile
|
2018-07-28 16:38:15 +00:00
|
|
|
@-$(RM) -f config.guess config.status config.sub config.h.in compile depcomp
|
|
|
|
@-$(RM) -f install-sh stamp-h1 ar-lib *.lo *.la *.m4 local.* lt*.sh missing
|
|
|
|
@-$(RM) -f cryptest cryptestcwd libtool* libcryptopp.la libcryptopp.pc*
|
2018-07-28 13:21:31 +00:00
|
|
|
@-$(RM) -rf m4/ auto*.cache/ .deps/ .libs/
|
|
|
|
|
|
|
|
.PHONY: cmake-clean
|
|
|
|
cmake-clean:
|
|
|
|
@-$(RM) -f cryptopp-config.cmake CMakeLists.txt
|
|
|
|
@-$(RM) -rf cmake_build/
|
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
.PHONY: distclean
|
2018-11-13 19:02:40 +00:00
|
|
|
distclean: clean autotools-clean cmake-clean
|
2018-07-28 13:31:41 +00:00
|
|
|
-$(RM) adhoc.cpp adhoc.cpp.copied GNUmakefile.deps benchmarks.html cryptest.txt
|
|
|
|
@-$(RM) cryptest-*.txt cryptopp.tgz libcryptopp.pc *.o *.bc *.ii *~
|
2018-07-09 10:19:58 +00:00
|
|
|
@-$(RM) -r cryptlib.lib cryptest.exe *.suo *.sdf *.pdb Win32/ x64/ ipch/
|
2018-08-05 00:18:50 +00:00
|
|
|
@-$(RM) -r $(LIBOBJS:.o=.obj) $(TESTOBJS:.o=.obj)
|
|
|
|
@-$(RM) -r $(LIBOBJS:.o=.lst) $(TESTOBJS:.o=.lst)
|
|
|
|
@-$(RM) -r TestCoverage/ ref*/
|
2018-07-28 13:21:31 +00:00
|
|
|
@-$(RM) cryptopp$(LIB_VER)\.* CryptoPPRef.zip
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-05-06 04:10:38 +00:00
|
|
|
# Install cryptest.exe, libcryptopp.a, libcryptopp.so and libcryptopp.pc.
|
|
|
|
# The library install was broken-out into its own recipe at GH #653.
|
2015-07-31 12:09:59 +00:00
|
|
|
.PHONY: install
|
2018-05-06 04:10:38 +00:00
|
|
|
install: cryptest.exe install-lib
|
2018-02-05 13:54:13 +00:00
|
|
|
@-$(MKDIR) $(DESTDIR)$(BINDIR)
|
|
|
|
$(INSTALL_PROGRAM) cryptest.exe $(DESTDIR)$(BINDIR)
|
|
|
|
@-$(MKDIR) $(DESTDIR)$(DATADIR)/cryptopp/TestData
|
|
|
|
@-$(MKDIR) $(DESTDIR)$(DATADIR)/cryptopp/TestVectors
|
|
|
|
$(INSTALL_DATA) TestData/*.dat $(DESTDIR)$(DATADIR)/cryptopp/TestData
|
|
|
|
$(INSTALL_DATA) TestVectors/*.txt $(DESTDIR)$(DATADIR)/cryptopp/TestVectors
|
2018-05-06 04:10:38 +00:00
|
|
|
|
|
|
|
# A recipe to install only the library, and not cryptest.exe. Also
|
|
|
|
# see https://github.com/weidai11/cryptopp/issues/653. Some users
|
|
|
|
# already have a libcryptopp.pc. Install the *.pc file if the file
|
|
|
|
# is present. If you want one, then issue 'make libcryptopp.pc'.
|
|
|
|
.PHONY: install-lib
|
|
|
|
install-lib:
|
|
|
|
@-$(MKDIR) $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
|
|
$(INSTALL_DATA) *.h $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
|
|
ifneq ($(wildcard libcryptopp.a),)
|
|
|
|
@-$(MKDIR) $(DESTDIR)$(LIBDIR)
|
|
|
|
$(INSTALL_DATA) libcryptopp.a $(DESTDIR)$(LIBDIR)
|
2015-12-25 21:06:43 +00:00
|
|
|
endif
|
|
|
|
ifneq ($(wildcard libcryptopp.dylib),)
|
2018-02-05 13:54:13 +00:00
|
|
|
@-$(MKDIR) $(DESTDIR)$(LIBDIR)
|
2018-02-05 14:03:21 +00:00
|
|
|
$(INSTALL_PROGRAM) libcryptopp.dylib $(DESTDIR)$(LIBDIR)
|
2015-12-29 11:32:45 +00:00
|
|
|
-install_name_tool -id $(DESTDIR)$(LIBDIR)/libcryptopp.dylib $(DESTDIR)$(LIBDIR)/libcryptopp.dylib
|
2015-12-25 21:06:43 +00:00
|
|
|
endif
|
2015-11-08 20:29:56 +00:00
|
|
|
ifneq ($(wildcard libcryptopp.so$(SOLIB_VERSION_SUFFIX)),)
|
2018-02-05 13:54:13 +00:00
|
|
|
@-$(MKDIR) $(DESTDIR)$(LIBDIR)
|
2018-02-05 14:03:21 +00:00
|
|
|
$(INSTALL_PROGRAM) libcryptopp.so$(SOLIB_VERSION_SUFFIX) $(DESTDIR)$(LIBDIR)
|
2015-11-08 20:29:56 +00:00
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
2017-12-16 14:07:23 +00:00
|
|
|
-$(LN) libcryptopp.so$(SOLIB_VERSION_SUFFIX) $(DESTDIR)$(LIBDIR)/libcryptopp.so
|
2015-12-29 11:32:45 +00:00
|
|
|
$(LDCONF) $(DESTDIR)$(LIBDIR)
|
2015-11-08 20:29:56 +00:00
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
endif
|
2018-02-05 13:54:13 +00:00
|
|
|
ifneq ($(wildcard libcryptopp.pc),)
|
|
|
|
@-$(MKDIR) $(DESTDIR)$(LIBDIR)/pkgconfig
|
|
|
|
$(INSTALL_DATA) libcryptopp.pc $(DESTDIR)$(LIBDIR)/pkgconfig/libcryptopp.pc
|
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
.PHONY: remove uninstall
|
|
|
|
remove uninstall:
|
2015-12-29 11:32:45 +00:00
|
|
|
-$(RM) -r $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
|
|
-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.a
|
|
|
|
-$(RM) $(DESTDIR)$(BINDIR)/cryptest.exe
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.dylib
|
|
|
|
@-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
|
|
|
@-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
|
|
|
@-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.so
|
2018-02-05 13:54:13 +00:00
|
|
|
@-$(RM) $(DESTDIR)$(LIBDIR)/pkgconfig/libcryptopp.pc
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -r $(DESTDIR)$(DATADIR)/cryptopp
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-02-05 14:03:21 +00:00
|
|
|
libcryptopp.a: $(LIBOBJS)
|
2015-07-31 12:09:59 +00:00
|
|
|
$(AR) $(ARFLAGS) $@ $(LIBOBJS)
|
2016-06-15 09:02:28 +00:00
|
|
|
ifeq ($(IS_SUN),0)
|
2015-07-31 12:09:59 +00:00
|
|
|
$(RANLIB) $@
|
2016-06-15 09:02:28 +00:00
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2015-12-31 21:05:14 +00:00
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
2015-12-26 11:00:31 +00:00
|
|
|
.PHONY: libcryptopp.so
|
2016-05-09 06:59:16 +00:00
|
|
|
libcryptopp.so: libcryptopp.so$(SOLIB_VERSION_SUFFIX) | so_warning
|
2015-12-31 21:05:14 +00:00
|
|
|
endif
|
2015-12-26 11:00:31 +00:00
|
|
|
|
2016-05-09 06:59:16 +00:00
|
|
|
libcryptopp.so$(SOLIB_VERSION_SUFFIX): $(LIBOBJS)
|
2017-09-09 20:24:01 +00:00
|
|
|
ifeq ($(XLC_COMPILER),1)
|
|
|
|
$(CXX) -qmkshrobj $(SOLIB_FLAGS) -o $@ $(strip $(CXXFLAGS)) $(LDFLAGS) $(LIBOBJS) $(LDLIBS)
|
|
|
|
else
|
2018-01-27 18:05:23 +00:00
|
|
|
$(CXX) -shared $(SOLIB_FLAGS) -o $@ $(strip $(CXXFLAGS)) $(LDFLAGS) $(LIBOBJS) $(LDLIBS)
|
2017-09-09 20:24:01 +00:00
|
|
|
endif
|
2015-11-08 20:29:56 +00:00
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
|
|
-$(LN) libcryptopp.so$(SOLIB_VERSION_SUFFIX) libcryptopp.so
|
|
|
|
-$(LN) libcryptopp.so$(SOLIB_VERSION_SUFFIX) libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-02-05 14:03:21 +00:00
|
|
|
libcryptopp.dylib: $(LIBOBJS)
|
2016-10-26 22:24:32 +00:00
|
|
|
$(CXX) -dynamiclib -o $@ $(strip $(CXXFLAGS)) -install_name "$@" -current_version "$(LIB_MAJOR).$(LIB_MINOR).$(LIB_PATCH)" -compatibility_version "$(LIB_MAJOR).$(LIB_MINOR)" -headerpad_max_install_names $(LDFLAGS) $(LIBOBJS)
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2018-07-31 17:33:57 +00:00
|
|
|
cryptest.exe:libcryptopp.a $(TESTOBJS)
|
2016-10-26 22:24:32 +00:00
|
|
|
$(CXX) -o $@ $(strip $(CXXFLAGS)) $(TESTOBJS) ./libcryptopp.a $(LDFLAGS) $(LDLIBS)
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2015-12-28 12:06:50 +00:00
|
|
|
# Makes it faster to test changes
|
|
|
|
nolib: $(OBJS)
|
2017-03-13 19:57:47 +00:00
|
|
|
$(CXX) -o ct $(strip $(CXXFLAGS)) $(OBJS) $(LDFLAGS) $(LDLIBS)
|
2015-07-31 12:09:59 +00:00
|
|
|
|
|
|
|
dll: cryptest.import.exe dlltest.exe
|
|
|
|
|
|
|
|
cryptopp.dll: $(DLLOBJS)
|
2016-10-26 22:24:32 +00:00
|
|
|
$(CXX) -shared -o $@ $(strip $(CXXFLAGS)) $(DLLOBJS) $(LDFLAGS) $(LDLIBS) -Wl,--out-implib=libcryptopp.dll.a
|
2015-07-31 12:09:59 +00:00
|
|
|
|
|
|
|
libcryptopp.import.a: $(LIBIMPORTOBJS)
|
|
|
|
$(AR) $(ARFLAGS) $@ $(LIBIMPORTOBJS)
|
2016-06-15 09:02:28 +00:00
|
|
|
ifeq ($(IS_SUN),0)
|
2015-07-31 12:09:59 +00:00
|
|
|
$(RANLIB) $@
|
2016-06-15 09:02:28 +00:00
|
|
|
endif
|
2015-07-31 12:09:59 +00:00
|
|
|
|
|
|
|
cryptest.import.exe: cryptopp.dll libcryptopp.import.a $(TESTIMPORTOBJS)
|
2016-10-26 22:24:32 +00:00
|
|
|
$(CXX) -o $@ $(strip $(CXXFLAGS)) $(TESTIMPORTOBJS) -L. -lcryptopp.dll -lcryptopp.import $(LDFLAGS) $(LDLIBS)
|
2015-07-31 12:09:59 +00:00
|
|
|
|
|
|
|
dlltest.exe: cryptopp.dll $(DLLTESTOBJS)
|
2016-10-26 22:24:32 +00:00
|
|
|
$(CXX) -o $@ $(strip $(CXXFLAGS)) $(DLLTESTOBJS) -L. -lcryptopp.dll $(LDFLAGS) $(LDLIBS)
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2018-02-05 14:03:21 +00:00
|
|
|
# Some users already have a libcryptopp.pc. We install it if the file
|
|
|
|
# is present. If you want one, then issue 'make libcryptopp.pc'. Be sure
|
|
|
|
# to use/verify PREFIX and LIBDIR below after writing the file.
|
2018-02-05 13:54:13 +00:00
|
|
|
libcryptopp.pc:
|
|
|
|
@echo '# Crypto++ package configuration file' > libcryptopp.pc
|
|
|
|
@echo '' >> libcryptopp.pc
|
|
|
|
@echo 'prefix=$(PREFIX)' >> libcryptopp.pc
|
|
|
|
@echo 'libdir=$(LIBDIR)' >> libcryptopp.pc
|
|
|
|
@echo 'includedir=$${prefix}/include' >> libcryptopp.pc
|
|
|
|
@echo '' >> libcryptopp.pc
|
|
|
|
@echo 'Name: Crypto++' >> libcryptopp.pc
|
|
|
|
@echo 'Description: Crypto++ cryptographic library' >> libcryptopp.pc
|
2018-04-08 19:58:25 +00:00
|
|
|
@echo 'Version: 7.1' >> libcryptopp.pc
|
2018-02-05 13:54:13 +00:00
|
|
|
@echo 'URL: https://cryptopp.com/' >> libcryptopp.pc
|
|
|
|
@echo '' >> libcryptopp.pc
|
|
|
|
@echo 'Cflags: -I$${includedir}' >> libcryptopp.pc
|
|
|
|
@echo 'Libs: -L$${libdir} -lcryptopp' >> libcryptopp.pc
|
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
# This recipe prepares the distro files
|
2018-11-13 19:02:40 +00:00
|
|
|
TEXT_FILES := *.h *.cpp adhoc.cpp License.txt Readme.txt Install.txt Filelist.txt Doxyfile cryptest* cryptlib* dlltest* cryptdll* *.sln *.s *.S *.vcxproj *.filters cryptopp.rc TestVectors/*.txt TestData/*.dat TestPrograms/*.cxx TestScripts/*.sh TestScripts/*.cmd
|
|
|
|
EXEC_FILES := GNUmakefile GNUmakefile-cross TestData/ TestVectors/ TestScripts/ TestPrograms/
|
2015-11-18 20:35:35 +00:00
|
|
|
|
|
|
|
ifeq ($(wildcard Filelist.txt),Filelist.txt)
|
|
|
|
DIST_FILES := $(shell cat Filelist.txt)
|
|
|
|
endif
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2016-09-24 03:30:44 +00:00
|
|
|
.PHONY: trim
|
2017-08-17 16:33:43 +00:00
|
|
|
trim:
|
2016-09-24 03:30:44 +00:00
|
|
|
ifneq ($(IS_DARWIN),0)
|
2018-11-11 06:14:43 +00:00
|
|
|
sed -i '' -e's/[[:space:]]*$$//' *.supp *.txt *.sh .*.yml *.h *.cpp *.asm *.s *.S
|
|
|
|
sed -i '' -e's/[[:space:]]*$$//' *.sln *.vcxproj *.filters GNUmakefile GNUmakefile-cross
|
|
|
|
sed -i '' -e's/[[:space:]]*$$//' TestData/*.dat TestVectors/*.txt TestPrograms/*.cxx TestScripts/*.*
|
2016-09-24 03:30:44 +00:00
|
|
|
make convert
|
|
|
|
else
|
2018-11-11 06:14:43 +00:00
|
|
|
sed -i -e's/[[:space:]]*$$//' *.supp *.txt *.sh .*.yml *.h *.cpp *.asm *.s *.S
|
|
|
|
sed -i -e's/[[:space:]]*$$//' *.sln *.vcxproj *.filters GNUmakefile GNUmakefile-cross
|
|
|
|
sed -i -e's/[[:space:]]*$$//' TestData/*.dat TestVectors/*.txt TestPrograms/*.cxx TestScripts/*.*
|
2016-09-24 03:30:44 +00:00
|
|
|
make convert
|
|
|
|
endif
|
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
.PHONY: convert
|
|
|
|
convert:
|
2018-11-11 06:14:43 +00:00
|
|
|
@-$(CHMOD) 0700 TestVectors/ TestData/ TestPrograms/ TestScripts/
|
|
|
|
@-$(CHMOD) 0600 $(TEXT_FILES) *.supp .*.yml *.asm *.s *.zip TestVectors/*.txt TestData/*.dat TestPrograms/*.cxx TestScripts/*.*
|
2017-11-05 12:21:09 +00:00
|
|
|
@-$(CHMOD) 0700 $(EXEC_FILES) *.sh *.cmd TestScripts/*.sh TestScripts/*.cmd
|
|
|
|
@-$(CHMOD) 0700 *.cmd *.sh GNUmakefile GNUmakefile-cross TestScripts/*.sh
|
2017-09-17 01:09:40 +00:00
|
|
|
-unix2dos --keepdate --quiet $(TEXT_FILES) .*.yml *.asm *.cmd TestScripts/*.*
|
2018-11-13 19:02:40 +00:00
|
|
|
-dos2unix --keepdate --quiet GNUmakefile* *.supp *.s *.S *.sh *.mapfile TestScripts/*.sh
|
2015-11-23 00:17:15 +00:00
|
|
|
ifneq ($(IS_DARWIN),0)
|
2017-03-09 09:01:36 +00:00
|
|
|
@-xattr -c *
|
2015-11-23 00:17:15 +00:00
|
|
|
endif
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2015-12-29 11:32:45 +00:00
|
|
|
# Build the ZIP file with source files. No documentation.
|
2015-11-05 06:59:46 +00:00
|
|
|
.PHONY: zip dist
|
2015-12-25 21:06:43 +00:00
|
|
|
zip dist: | distclean convert
|
2015-11-05 06:59:46 +00:00
|
|
|
zip -q -9 cryptopp$(LIB_VER).zip $(DIST_FILES)
|
2015-11-18 20:35:35 +00:00
|
|
|
|
2015-12-29 11:32:45 +00:00
|
|
|
# Build the ISO to transfer the ZIP to old distros via CDROM
|
2015-12-25 21:06:43 +00:00
|
|
|
.PHONY: iso
|
|
|
|
iso: | zip
|
|
|
|
ifneq ($(IS_DARWIN),0)
|
2018-02-05 13:54:13 +00:00
|
|
|
$(MKDIR) $(PWD)/cryptopp$(LIB_VER)
|
2015-12-26 11:45:59 +00:00
|
|
|
$(CP) cryptopp$(LIB_VER).zip $(PWD)/cryptopp$(LIB_VER)
|
2015-12-25 21:06:43 +00:00
|
|
|
hdiutil makehybrid -iso -joliet -o cryptopp$(LIB_VER).iso $(PWD)/cryptopp$(LIB_VER)
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -r $(PWD)/cryptopp$(LIB_VER)
|
2015-12-25 21:06:43 +00:00
|
|
|
else ifneq ($(IS_LINUX),0)
|
2018-02-05 13:54:13 +00:00
|
|
|
$(MKDIR) $(PWD)/cryptopp$(LIB_VER)
|
2015-12-26 11:45:59 +00:00
|
|
|
$(CP) cryptopp$(LIB_VER).zip $(PWD)/cryptopp$(LIB_VER)
|
2015-12-25 21:06:43 +00:00
|
|
|
genisoimage -q -o cryptopp$(LIB_VER).iso $(PWD)/cryptopp$(LIB_VER)
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -r $(PWD)/cryptopp$(LIB_VER)
|
2015-12-25 21:06:43 +00:00
|
|
|
endif
|
|
|
|
|
2017-03-08 20:45:38 +00:00
|
|
|
# CRYPTOPP_CPU_FREQ in GHz
|
|
|
|
CRYPTOPP_CPU_FREQ ?= 0.0
|
2015-11-18 20:35:35 +00:00
|
|
|
.PHONY: bench benchmark benchmarks
|
|
|
|
bench benchmark benchmarks: cryptest.exe
|
2017-03-09 09:01:36 +00:00
|
|
|
@-$(RM) -f benchmarks.html
|
2017-03-08 20:45:38 +00:00
|
|
|
./cryptest.exe b 2 $(CRYPTOPP_CPU_FREQ)
|
2015-11-05 06:59:46 +00:00
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
adhoc.cpp: adhoc.cpp.proto
|
|
|
|
ifeq ($(wildcard adhoc.cpp),)
|
|
|
|
cp adhoc.cpp.proto adhoc.cpp
|
|
|
|
else
|
|
|
|
touch adhoc.cpp
|
|
|
|
endif
|
|
|
|
|
2015-11-05 06:59:46 +00:00
|
|
|
# Include dependencies, if present. You must issue `make deps` to create them.
|
|
|
|
ifeq ($(wildcard GNUmakefile.deps),GNUmakefile.deps)
|
|
|
|
-include GNUmakefile.deps
|
|
|
|
endif # Dependencies
|
|
|
|
|
2018-07-28 02:00:28 +00:00
|
|
|
# Cryptogams ARM asm implementation.
|
2018-11-10 13:00:14 +00:00
|
|
|
aes_armv4.o : aes_armv4.S
|
2018-07-28 22:45:37 +00:00
|
|
|
$(CC) $(strip $(CXXFLAGS) $(CRYPTOGAMS_AES_FLAG) -mfloat-abi=$(FP_ABI) -c) $<
|
2018-07-11 10:59:44 +00:00
|
|
|
|
2017-11-05 08:38:19 +00:00
|
|
|
# SSSE3 or NEON available
|
2018-11-10 13:00:14 +00:00
|
|
|
aria_simd.o : aria_simd.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(ARIA_FLAG) -c) $<
|
|
|
|
|
2018-11-02 23:09:36 +00:00
|
|
|
# SSE, NEON or POWER7 available
|
2018-11-10 13:00:14 +00:00
|
|
|
blake2s_simd.o : blake2s_simd.cpp
|
2018-11-02 23:09:36 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(BLAKE2S_FLAG) -c) $<
|
|
|
|
|
|
|
|
# SSE, NEON or POWER8 available
|
2018-11-10 13:00:14 +00:00
|
|
|
blake2b_simd.o : blake2b_simd.cpp
|
2018-11-02 23:09:36 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(BLAKE2B_FLAG) -c) $<
|
2017-08-17 16:33:43 +00:00
|
|
|
|
2018-10-24 15:00:35 +00:00
|
|
|
# SSE2 or NEON available
|
2018-11-10 13:00:14 +00:00
|
|
|
chacha_simd.o : chacha_simd.cpp
|
2018-10-24 15:00:35 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(CHACHA_FLAG) -c) $<
|
|
|
|
|
2018-11-08 21:20:31 +00:00
|
|
|
# AVX2 available
|
2018-11-10 13:00:14 +00:00
|
|
|
chacha_avx.o : chacha_avx.cpp
|
2018-11-08 21:20:31 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(CHACHA_AVX2_FLAG) -c) $<
|
|
|
|
|
2018-06-19 22:03:28 +00:00
|
|
|
# SSSE3 available
|
2018-11-10 13:00:14 +00:00
|
|
|
cham_simd.o : cham_simd.cpp
|
2018-06-19 22:03:28 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(CHAM_FLAG) -c) $<
|
|
|
|
|
2018-11-27 07:54:26 +00:00
|
|
|
# Power9 available
|
|
|
|
darn.o : darn.cpp
|
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(DARN_FLAG) -c) $<
|
|
|
|
|
2017-09-13 01:23:23 +00:00
|
|
|
# SSE2 on i586
|
2018-11-10 13:00:14 +00:00
|
|
|
sse_simd.o : sse_simd.cpp
|
2018-12-01 08:16:54 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SSE2_FLAG) -c) $<
|
2017-09-13 01:23:23 +00:00
|
|
|
|
2017-08-17 16:33:43 +00:00
|
|
|
# SSE4.2 or ARMv8a available
|
2018-11-10 13:00:14 +00:00
|
|
|
crc_simd.o : crc_simd.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(CRC_FLAG) -c) $<
|
|
|
|
|
|
|
|
# PCLMUL or ARMv7a/ARMv8a available
|
2018-11-10 13:00:14 +00:00
|
|
|
gcm_simd.o : gcm_simd.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(GCM_FLAG) -c) $<
|
|
|
|
|
2018-06-22 20:26:27 +00:00
|
|
|
# SSSE3 available
|
2018-11-10 13:00:14 +00:00
|
|
|
lea_simd.o : lea_simd.cpp
|
2018-06-22 20:26:27 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(LEA_FLAG) -c) $<
|
|
|
|
|
2017-09-11 07:05:04 +00:00
|
|
|
# NEON available
|
2018-11-10 13:00:14 +00:00
|
|
|
neon_simd.o : neon_simd.cpp
|
2017-09-11 07:05:04 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(NEON_FLAG) -c) $<
|
|
|
|
|
2018-11-18 21:35:02 +00:00
|
|
|
# AltiVec available
|
2018-11-10 13:00:14 +00:00
|
|
|
ppc_simd.o : ppc_simd.cpp
|
2017-09-11 07:05:04 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(ALTIVEC_FLAG) -c) $<
|
|
|
|
|
2018-11-18 21:35:02 +00:00
|
|
|
# Power7 available
|
|
|
|
ppc_power7.o : ppc_power7.cpp
|
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(POWER7_FLAG) -c) $<
|
|
|
|
|
|
|
|
# Power8 available
|
|
|
|
ppc_power8.o : ppc_power8.cpp
|
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(POWER8_FLAG) -c) $<
|
|
|
|
|
2018-11-27 07:54:26 +00:00
|
|
|
# Power9 available
|
|
|
|
ppc_power9.o : ppc_power9.cpp
|
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(POWER9_FLAG) -c) $<
|
|
|
|
|
2017-08-17 16:33:43 +00:00
|
|
|
# AESNI or ARMv7a/ARMv8a available
|
2018-11-10 13:00:14 +00:00
|
|
|
rijndael_simd.o : rijndael_simd.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(AES_FLAG) -c) $<
|
|
|
|
|
|
|
|
# SSE4.2/SHA-NI or ARMv8a available
|
2018-11-10 13:00:14 +00:00
|
|
|
sha_simd.o : sha_simd.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SHA_FLAG) -c) $<
|
|
|
|
|
2018-12-01 15:42:20 +00:00
|
|
|
sha3_simd.o : sha3_simd.cpp
|
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SHA3_FLAG) -c) $<
|
|
|
|
|
2017-08-17 16:33:43 +00:00
|
|
|
# SSE4.2/SHA-NI or ARMv8a available
|
2018-11-10 13:00:14 +00:00
|
|
|
shacal2_simd.o : shacal2_simd.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SHA_FLAG) -c) $<
|
|
|
|
|
2018-07-01 07:11:00 +00:00
|
|
|
# SSSE3 or NEON available
|
2018-11-10 13:00:14 +00:00
|
|
|
simeck_simd.o : simeck_simd.cpp
|
2018-07-01 07:11:00 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SIMECK_FLAG) -c) $<
|
|
|
|
|
2018-08-15 13:59:40 +00:00
|
|
|
# SSE4.1, NEON or POWER7 available
|
2018-11-10 13:00:14 +00:00
|
|
|
simon64_simd.o : simon64_simd.cpp
|
2018-08-15 13:59:40 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SIMON64_FLAG) -c) $<
|
2018-02-19 04:23:50 +00:00
|
|
|
|
2018-08-15 13:59:40 +00:00
|
|
|
# SSSE3, NEON or POWER8 available
|
2018-11-10 13:00:14 +00:00
|
|
|
simon128_simd.o : simon128_simd.cpp
|
2018-08-15 13:59:40 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SIMON128_FLAG) -c) $<
|
|
|
|
|
|
|
|
# SSE4.1, NEON or POWER7 available
|
2018-11-10 13:00:14 +00:00
|
|
|
speck64_simd.o : speck64_simd.cpp
|
2018-08-15 13:59:40 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SPECK64_FLAG) -c) $<
|
|
|
|
|
|
|
|
# SSSE3, NEON or POWER8 available
|
2018-11-10 13:00:14 +00:00
|
|
|
speck128_simd.o : speck128_simd.cpp
|
2018-08-15 13:59:40 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SPECK128_FLAG) -c) $<
|
2018-02-19 04:23:50 +00:00
|
|
|
|
2018-11-11 06:14:43 +00:00
|
|
|
# ARMv8.4 available
|
|
|
|
sm3_simd.o : sm3_simd.cpp
|
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SM3_FLAG) -c) $<
|
|
|
|
|
2018-07-13 12:33:13 +00:00
|
|
|
# AESNI available
|
2018-11-10 13:00:14 +00:00
|
|
|
sm4_simd.o : sm4_simd.cpp
|
2018-07-13 12:33:13 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(SM4_FLAG) -c) $<
|
|
|
|
|
2018-07-09 10:19:58 +00:00
|
|
|
# IBM XLC -O3 optimization bug
|
|
|
|
ifeq ($(XLC_COMPILER),1)
|
|
|
|
sm3.o : sm3.cpp
|
|
|
|
$(CXX) $(strip $(subst -O3,-O2,$(CXXFLAGS)) -c) $<
|
|
|
|
endif
|
|
|
|
|
2017-05-22 00:45:08 +00:00
|
|
|
# Don't build Rijndael with UBsan. Too much noise due to unaligned data accesses.
|
|
|
|
ifneq ($(findstring -fsanitize=undefined,$(CXXFLAGS)),)
|
|
|
|
rijndael.o : rijndael.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(subst -fsanitize=undefined,,$(CXXFLAGS)) -c) $<
|
2017-05-22 00:45:08 +00:00
|
|
|
endif
|
|
|
|
|
2016-01-03 20:30:59 +00:00
|
|
|
# Only use CRYPTOPP_DATA_DIR if its not set in CXXFLAGS
|
2016-10-26 22:24:32 +00:00
|
|
|
ifeq ($(findstring -DCRYPTOPP_DATA_DIR, $(strip $(CXXFLAGS))),)
|
2016-01-03 20:30:59 +00:00
|
|
|
ifneq ($(strip $(CRYPTOPP_DATA_DIR)),)
|
|
|
|
validat%.o : validat%.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c) $<
|
2016-01-03 20:30:59 +00:00
|
|
|
bench%.o : bench%.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c) $<
|
2016-01-03 20:30:59 +00:00
|
|
|
datatest.o : datatest.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c) $<
|
2016-01-03 20:30:59 +00:00
|
|
|
test.o : test.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c) $<
|
2016-01-03 20:30:59 +00:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2018-10-30 10:20:31 +00:00
|
|
|
validat1.o : validat1.cpp
|
2018-08-07 02:19:59 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) $(ALTIVEC_FLAG) -c) $<
|
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
%.dllonly.o : %.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_DLL_ONLY -c) $< -o $@
|
2015-07-31 12:09:59 +00:00
|
|
|
|
|
|
|
%.import.o : %.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_IMPORTS -c) $< -o $@
|
2015-07-31 12:09:59 +00:00
|
|
|
|
|
|
|
%.export.o : %.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -DCRYPTOPP_EXPORTS -c) $< -o $@
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-07-20 07:03:01 +00:00
|
|
|
%.bc : %.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -c) $<
|
2016-07-20 07:03:01 +00:00
|
|
|
|
2015-07-31 12:09:59 +00:00
|
|
|
%.o : %.cpp
|
2017-08-17 16:33:43 +00:00
|
|
|
$(CXX) $(strip $(CXXFLAGS) -c) $<
|
2015-07-31 12:09:59 +00:00
|
|
|
|
2016-05-09 06:59:16 +00:00
|
|
|
.PHONY: so_warning
|
|
|
|
so_warning:
|
2015-11-25 04:14:53 +00:00
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
|
|
$(info WARNING: Only the symlinks to the shared-object library have been updated.)
|
|
|
|
$(info WARNING: If the library is installed in a system directory you will need)
|
|
|
|
$(info WARNING: to run 'ldconfig' to update the shared-object library cache.)
|
|
|
|
$(info )
|
|
|
|
endif
|