mirror of
https://github.com/shadps4-emu/ext-cryptopp.git
synced 2024-11-24 02:19:41 +00:00
696 lines
26 KiB
Makefile
Executable File
696 lines
26 KiB
Makefile
Executable File
###########################################################
|
|
##### General Variables #####
|
|
###########################################################
|
|
|
|
# Base CXXFLAGS used if the user did not specify them
|
|
CXXFLAGS ?= -DNDEBUG -g2 -O2
|
|
|
|
AR ?= ar
|
|
ARFLAGS ?= -cr # ar needs the dash on OpenBSD
|
|
RANLIB ?= ranlib
|
|
|
|
CP ?= cp
|
|
MV ?= mv
|
|
CHMOD ?= chmod
|
|
MKDIR ?= mkdir
|
|
EGREP ?= egrep
|
|
LN ?= ln -sf
|
|
LDCONF ?= /sbin/ldconfig -n
|
|
|
|
UNAME := $(shell uname)
|
|
IS_X86 := $(shell uname -m | $(EGREP) -v "x86_64" | $(EGREP) -i -c "i.86|x86|i86")
|
|
IS_X32 ?= 0
|
|
IS_X86_64 := $(shell uname -m | $(EGREP) -i -c "(_64|d64)")
|
|
IS_PPC := $(shell uname -m | $(EGREP) -i -c "ppc|power")
|
|
IS_AARCH64 := $(shell uname -m | $(EGREP) -i -c "aarch64")
|
|
|
|
IS_SUN := $(shell uname | $(EGREP) -i -c "SunOS")
|
|
IS_LINUX := $(shell $(CXX) -dumpmachine 2>&1 | $(EGREP) -i -c "Linux")
|
|
IS_MINGW := $(shell $(CXX) -dumpmachine 2>&1 | $(EGREP) -i -c "MinGW")
|
|
IS_CYGWIN := $(shell $(CXX) -dumpmachine 2>&1 | $(EGREP) -i -c "Cygwin")
|
|
IS_DARWIN := $(shell $(CXX) -dumpmachine 2>&1 | $(EGREP) -i -c "Darwin")
|
|
IS_NETBSD := $(shell $(CXX) -dumpmachine 2>&1 | $(EGREP) -i -c "NetBSD")
|
|
|
|
SUN_COMPILER := $(shell $(CXX) -V 2>&1 | $(EGREP) -i -c "CC: Sun")
|
|
GCC_COMPILER := $(shell $(CXX) --version 2>&1 | $(EGREP) -i -c "(gcc|g\+\+)")
|
|
CLANG_COMPILER := $(shell $(CXX) --version 2>&1 | $(EGREP) -i -c "clang")
|
|
INTEL_COMPILER := $(shell $(CXX) --version 2>&1 | $(EGREP) -c "\(ICC\)")
|
|
MACPORTS_COMPILER := $(shell $(CXX) --version 2>&1 | $(EGREP) -i -c "macports")
|
|
|
|
HAS_SOLIB_VERSION := $(IS_LINUX)
|
|
|
|
# Default prefix for make install
|
|
ifeq ($(PREFIX),)
|
|
PREFIX = /usr/local
|
|
endif
|
|
|
|
# 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)
|
|
CXX := g++
|
|
endif
|
|
|
|
# We honor ARFLAGS, but the "v" option used by default causes a noisy make
|
|
ifeq ($(ARFLAGS),rv)
|
|
ARFLAGS = r
|
|
endif
|
|
|
|
###########################################################
|
|
##### X86/X32/X64 Options #####
|
|
###########################################################
|
|
|
|
ifneq ($(IS_X86)$(IS_X32)$(IS_X86_64),000)
|
|
|
|
IS_GCC_29 := $(shell $(CXX) -v 2>&1 | $(EGREP) -i -c gcc-9[0-9][0-9])
|
|
GCC42_OR_LATER := $(shell $(CXX) -v 2>&1 | $(EGREP) -i -c "gcc version (4\.[2-9]|[5-9]\.)")
|
|
GCC46_OR_LATER := $(shell $(CXX) -v 2>&1 | $(EGREP) -i -c "gcc version (4\.[6-9]|[5-9]\.)")
|
|
GCC48_OR_LATER := $(shell $(CXX) -v 2>&1 | $(EGREP) -i -c "gcc version (4\.[8-9]|[5-9]\.)")
|
|
GCC49_OR_LATER := $(shell $(CXX) -v 2>&1 | $(EGREP) -i -c "gcc version (4\.9|[5-9]\.)")
|
|
|
|
ICC111_OR_LATER := $(shell $(CXX) --version 2>&1 | $(EGREP) -c "\(ICC\) ([2-9][0-9]|1[2-9]|11\.[1-9])")
|
|
GAS210_OR_LATER := $(shell $(CXX) -xc -c /dev/null -Wa,-v -o/dev/null 2>&1 | $(EGREP) -c "GNU assembler version (2\.[1-9][0-9]|[3-9])")
|
|
GAS217_OR_LATER := $(shell $(CXX) -xc -c /dev/null -Wa,-v -o/dev/null 2>&1 | $(EGREP) -c "GNU assembler version (2\.1[7-9]|2\.[2-9]|[3-9])")
|
|
GAS219_OR_LATER := $(shell $(CXX) -xc -c /dev/null -Wa,-v -o/dev/null 2>&1 | $(EGREP) -c "GNU assembler version (2\.19|2\.[2-9]|[3-9])")
|
|
|
|
# Add -fPIC for targets *except* X86, X32, Cygwin or MinGW
|
|
ifeq ($(IS_X86)$(IS_X32)$(IS_CYGWIN)$(IS_MINGW),0000)
|
|
ifeq ($(findstring -fPIC,$(CXXFLAGS)),)
|
|
CXXFLAGS += -fPIC
|
|
endif
|
|
endif
|
|
|
|
# Guard use of -march=native
|
|
ifeq ($(GCC42_OR_LATER)$(IS_NETBSD),10)
|
|
CXXFLAGS += -march=native
|
|
else ifeq ($(CLANG_COMPILER),1)
|
|
CXXFLAGS += -march=native
|
|
else ifeq ($(INTEL_COMPILER),1)
|
|
CXXFLAGS += -march=native
|
|
else
|
|
# GCC 3.3 and "unknown option -march="
|
|
# Ubuntu GCC 4.1 compiler crash with -march=native
|
|
# NetBSD GCC 4.8 compiler and "bad value (native) for -march= switch"
|
|
# Sun compiler from legacy
|
|
ifneq ($(IS_X86_64),0)
|
|
CXXFLAGS += -m64
|
|
else
|
|
CXXFLAGS += -m32
|
|
endif # X86/X32/X64
|
|
endif
|
|
|
|
# Aligned access required at -O3 for GCC due to vectorization (circa 08/2008). Expect other compilers to do the same.
|
|
UNALIGNED_ACCESS := $(shell $(EGREP) -c "^[[:space:]]*//[[:space:]]*\#[[:space:]]*define[[:space:]]*CRYPTOPP_NO_UNALIGNED_DATA_ACCESS" config.h)
|
|
ifeq ($(findstring -O3,$(CXXFLAGS)),-O3)
|
|
ifneq ($(UNALIGNED_ACCESS),0)
|
|
ifeq ($(GCC46_OR_LATER),1)
|
|
ifeq ($(findstring -DCRYPTOPP_NO_UNALIGNED_DATA_ACCESS,$(CXXFLAGS)),)
|
|
CXXFLAGS += -DCRYPTOPP_NO_UNALIGNED_DATA_ACCESS
|
|
endif # CRYPTOPP_NO_UNALIGNED_DATA_ACCESS
|
|
endif # GCC 4.6
|
|
endif # UNALIGNED_ACCESS
|
|
endif # Vectorization
|
|
|
|
ifneq ($(INTEL_COMPILER),0)
|
|
CXXFLAGS += -wd68 -wd186 -wd279 -wd327 -wd161 -wd3180
|
|
ifeq ($(ICC111_OR_LATER),0)
|
|
# "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
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
|
endif
|
|
endif
|
|
|
|
ifeq ($(GCC_COMPILER)$(GAS210_OR_LATER),10) # .intel_syntax wasn't supported until GNU assembler 2.10
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_ASM
|
|
else
|
|
ifeq ($(GCC_COMPILER)$(GAS217_OR_LATER),10)
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_SSSE3
|
|
else
|
|
ifeq ($(GCC_COMPILER)$(GAS219_OR_LATER),10)
|
|
CXXFLAGS += -DCRYPTOPP_DISABLE_AESNI
|
|
endif
|
|
endif
|
|
|
|
ifneq ($(IS_SUN),0)
|
|
CXXFLAGS += -Wa,--divide # allow use of "/" operator
|
|
endif
|
|
endif
|
|
|
|
ifeq ($(UNAME),) # for DJGPP, where uname doesn't exist
|
|
CXXFLAGS += -mbnu210
|
|
else ifneq ($(findstring -save-temps,$(CXXFLAGS)),-save-temps)
|
|
CXXFLAGS += -pipe
|
|
endif
|
|
|
|
else
|
|
|
|
###########################################################
|
|
##### Not X86/X32/X64 #####
|
|
###########################################################
|
|
|
|
# Add PIC
|
|
ifeq ($(findstring -fPIC,$(CXXFLAGS)),)
|
|
CXXFLAGS += -fPIC
|
|
endif
|
|
|
|
# Add -pipe for everything except ARM
|
|
ifneq ($(IS_PPC),0)
|
|
ifeq ($(findstring -save-temps,$(CXXFLAGS)),)
|
|
CXXFLAGS += -pipe
|
|
endif
|
|
endif
|
|
|
|
endif # IS_X86
|
|
|
|
###########################################################
|
|
##### Common #####
|
|
###########################################################
|
|
|
|
ifneq ($(IS_MINGW),0)
|
|
LDLIBS += -lws2_32
|
|
endif
|
|
|
|
ifeq ($(IS_LINUX),1)
|
|
LDFLAGS += -pthread
|
|
ifeq ($(findstring -fopenmp,$(CXXFLAGS)),-fopenmp)
|
|
ifeq ($(findstring -lgomp,$(LDLIBS)),)
|
|
LDLIBS += -lgomp
|
|
endif # LDLIBS
|
|
endif # OpenMP
|
|
endif # IS_LINUX
|
|
|
|
ifneq ($(IS_DARWIN),0)
|
|
AR = libtool
|
|
ARFLAGS = -static -o
|
|
CXX ?= c++
|
|
ifeq ($(IS_GCC_29),1)
|
|
CXXFLAGS += -fno-coalesce-templates -fno-coalesce-static-vtables
|
|
LDLIBS += -lstdc++
|
|
LDFLAGS += -flat_namespace -undefined suppress -m
|
|
endif
|
|
endif
|
|
|
|
ifneq ($(IS_SUN),0)
|
|
LDLIBS += -lnsl -lsocket
|
|
M32OR64 = -m$(shell isainfo -b)
|
|
endif
|
|
|
|
ifneq ($(SUN_COMPILER),0) # override flags for CC Sun C++ compiler
|
|
CXXFLAGS ?= -DNDEBUG -O -g0 -native -template=no%extdef $(M32OR64)
|
|
LDFLAGS =
|
|
AR = $(CXX)
|
|
ARFLAGS = -xar -o
|
|
RANLIB = true
|
|
SUN_CC10_BUGGY := $(shell $(CXX) -V 2>&1 | $(EGREP) -c "CC: Sun .* 5\.10 .* (2009|2010/0[1-4])")
|
|
ifneq ($(SUN_CC10_BUGGY),0)
|
|
# -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
|
|
CXXFLAGS += -DCRYPTOPP_INCLUDE_VECTOR_CC
|
|
endif
|
|
endif
|
|
|
|
# Undefined Behavior Sanitizer (UBsan) testing. There's no sense in
|
|
# allowing unaligned data access. There will too many findings.
|
|
ifeq ($(findstring ubsan,$(MAKECMDGOALS)),ubsan)
|
|
ifeq ($(findstring -fsanitize=undefined,$(CXXFLAGS)),)
|
|
CXXFLAGS += -fsanitize=undefined
|
|
endif # CXXFLAGS
|
|
ifeq ($(findstring -DCRYPTOPP_NO_UNALIGNED_DATA_ACCESS,$(CXXFLAGS)),)
|
|
CXXFLAGS += -DCRYPTOPP_NO_UNALIGNED_DATA_ACCESS
|
|
endif # CXXFLAGS
|
|
endif # UBsan
|
|
|
|
# Address Sanitizer (Asan) testing. Issue 'make asan'.
|
|
ifeq ($(findstring asan,$(MAKECMDGOALS)),asan)
|
|
ifeq ($(findstring -fsanitize=address,$(CXXFLAGS)),)
|
|
CXXFLAGS += -fsanitize=address
|
|
endif # CXXFLAGS
|
|
ifeq ($(findstring -fno-omit-frame-pointer,$(CXXFLAGS)),)
|
|
CXXFLAGS += -fno-omit-frame-pointer
|
|
endif # CXXFLAGS
|
|
endif # Asan
|
|
|
|
# LD gold linker testing. Triggered by 'LD=ld.gold'.
|
|
ifeq ($(findstring ld.gold,$(LD)),ld.gold)
|
|
ifeq ($(findstring -Wl,-fuse-ld=gold,$(LDFLAGS)),)
|
|
ELF_FORMAT := $(shell file `which ld.gold` 2>&1 | cut -d":" -f 2 | $(EGREP) -i -c "elf")
|
|
ifneq ($(ELF_FORMAT),0)
|
|
LDFLAGS += -Wl,-fuse-ld=gold
|
|
endif # ELF/ELF64
|
|
endif # CXXFLAGS
|
|
endif # Gold
|
|
|
|
# Aligned access testing. Issue 'make aligned'.
|
|
ifneq ($(filter align aligned,$(MAKECMDGOALS)),)
|
|
ifeq ($(findstring -DCRYPTOPP_NO_UNALIGNED_DATA_ACCESS,$(CXXFLAGS)),)
|
|
CXXFLAGS += -DCRYPTOPP_NO_UNALIGNED_DATA_ACCESS
|
|
endif # CXXFLAGS
|
|
endif # Aligned access
|
|
|
|
# GCC code coverage. Issue 'make coverage'.
|
|
ifneq ($(filter coverage,$(MAKECMDGOALS)),)
|
|
ifeq ($(findstring -coverage,$(CXXFLAGS)),)
|
|
CXXFLAGS += -coverage
|
|
endif # -coverage
|
|
endif # GCC code coverage
|
|
|
|
# Debug testing on GNU systems. Triggered by -DDEBUG.
|
|
ifneq ($(filter -DDEBUG -DDEBUG=1,$(CXXFLAGS)),)
|
|
USING_GLIBCXX := $(shell $(CXX) -x c++ $(CXXFLAGS) -E adhoc.cpp.proto 2>&1 | $(EGREP) -i -c "__GLIBCXX__")
|
|
ifneq ($(USING_GLIBCXX),0)
|
|
ifeq ($(findstring -D_GLIBCXX_DEBUG,$(CXXFLAGS)),)
|
|
CXXFLAGS += -D_GLIBCXX_DEBUG
|
|
endif # CXXFLAGS
|
|
ifeq ($(findstring -D_GLIBCXX_CONCEPT_CHECKS,$(CXXFLAGS)),)
|
|
CXXFLAGS += -D_GLIBCXX_CONCEPT_CHECKS
|
|
endif # CXXFLAGS
|
|
endif # USING_GLIBCXX
|
|
endif # GNU Debug build
|
|
|
|
# Dead code stripping. Issue 'make lean'.
|
|
ifeq ($(findstring lean,$(MAKECMDGOALS)),lean)
|
|
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
|
|
endif # Dead code stripping
|
|
|
|
# For Shared Objects, Diff, Dist/Zip rules
|
|
LIB_VER := $(shell $(EGREP) "define CRYPTOPP_VERSION" config.h | cut -d" " -f 3)
|
|
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)),)
|
|
LIB_PATCH := 0
|
|
endif
|
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
# Full version suffix for shared library
|
|
SOLIB_VERSION_SUFFIX=.$(LIB_MAJOR).$(LIB_MINOR).$(LIB_PATCH)
|
|
# Different patchlevels are compatible, minor versions are not
|
|
SOLIB_COMPAT_SUFFIX=.$(LIB_MAJOR).$(LIB_MINOR)
|
|
SOLIB_FLAGS=-Wl,-soname,libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
|
endif # HAS_SOLIB_VERSION
|
|
|
|
###########################################################
|
|
##### Source and object files #####
|
|
###########################################################
|
|
|
|
# List cryptlib.cpp first and cpu.cpp second in an attempt to tame C++ static initialization problems.
|
|
# The issue spills into POD data types of cpu.cpp due to the storage class of the bools, so cpu.cpp
|
|
# is the second candidate for explicit initialization order.
|
|
SRCS := cryptlib.cpp cpu.cpp $(filter-out cryptlib.cpp cpu.cpp pch.cpp simple.cpp winpipes.cpp cryptlib_bds.cpp,$(wildcard *.cpp))
|
|
|
|
# No need for CPU or RDRAND on non-X86 systems. X32 is represented with X64.
|
|
ifeq ($(IS_X86)$(IS_X86_64),00)
|
|
SRCS := $(filter-out cpu.cpp rdrand.cpp, $(SRCS))
|
|
endif
|
|
|
|
ifneq ($(IS_MINGW),0)
|
|
SRCS += winpipes.cpp
|
|
endif
|
|
|
|
# List of objects with crytlib.o and cpu.o at the first and second index position
|
|
OBJS := $(SRCS:.cpp=.o)
|
|
|
|
# test.o needs to be after bench.o for cygwin 1.1.4 (possible ld bug?)
|
|
TESTSRCS := bench.cpp bench2.cpp test.cpp validat1.cpp validat2.cpp validat3.cpp adhoc.cpp datatest.cpp regtest.cpp fipsalgt.cpp dlltest.cpp
|
|
TESTOBJS := $(TESTSRCS:.cpp=.o)
|
|
LIBOBJS := $(filter-out $(TESTOBJS),$(OBJS))
|
|
|
|
# List cryptlib.cpp first in an attempt to tame C++ static initialization problems
|
|
DLLSRCS := cryptlib.cpp cpu.cpp 3way.cpp adler32.cpp algebra.cpp algparam.cpp arc4.cpp asn.cpp authenc.cpp base32.cpp base64.cpp basecode.cpp bfinit.cpp blowfish.cpp blumshub.cpp camellia.cpp cast.cpp casts.cpp cbcmac.cpp ccm.cpp channels.cpp cmac.cpp crc.cpp default.cpp des.cpp dessp.cpp dh.cpp dh2.cpp dll.cpp dsa.cpp eax.cpp ec2n.cpp eccrypto.cpp ecp.cpp elgamal.cpp emsa2.cpp eprecomp.cpp esign.cpp files.cpp filters.cpp fips140.cpp gcm.cpp gf256.cpp gf2_32.cpp gf2n.cpp gfpcrypt.cpp gost.cpp gzip.cpp hex.cpp hmac.cpp hrtimer.cpp ida.cpp idea.cpp integer.cpp iterhash.cpp luc.cpp mars.cpp marss.cpp md2.cpp md4.cpp md5.cpp misc.cpp modes.cpp mqueue.cpp mqv.cpp nbtheory.cpp network.cpp oaep.cpp osrng.cpp panama.cpp pkcspad.cpp polynomi.cpp pssr.cpp pubkey.cpp queue.cpp rabin.cpp randpool.cpp rc2.cpp rc5.cpp rc6.cpp rdrand.cpp rdtables.cpp rijndael.cpp ripemd.cpp rng.cpp rsa.cpp rw.cpp safer.cpp salsa.cpp seal.cpp seed.cpp serpent.cpp sha.cpp sha3.cpp shacal2.cpp shark.cpp sharkbox.cpp skipjack.cpp socketft.cpp sosemanuk.cpp square.cpp squaretb.cpp strciphr.cpp tea.cpp tftables.cpp tiger.cpp tigertab.cpp trdlocal.cpp ttmac.cpp twofish.cpp vmac.cpp wait.cpp wake.cpp whrlpool.cpp xtr.cpp xtrcrypt.cpp zdeflate.cpp zinflate.cpp zlib.cpp winpipes.cpp
|
|
DLLOBJS := $(DLLSRCS:.cpp=.export.o)
|
|
|
|
# Import lib testing
|
|
LIBIMPORTOBJS := $(LIBOBJS:.o=.import.o)
|
|
TESTIMPORTOBJS := $(TESTOBJS:.o=.import.o)
|
|
DLLTESTOBJS := dlltest.dllonly.o
|
|
|
|
###########################################################
|
|
##### Targets and Recipes #####
|
|
###########################################################
|
|
|
|
.PHONY: all
|
|
all: cryptest.exe
|
|
|
|
ifneq ($(IS_DARWIN),0)
|
|
static: libcryptopp.a
|
|
shared dynamic dylib: libcryptopp.dylib
|
|
else
|
|
static: libcryptopp.a
|
|
shared dynamic: libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
|
endif
|
|
|
|
.PHONY: deps
|
|
deps GNUmakefile.deps:
|
|
$(CXX) $(CXXFLAGS) -MM *.cpp > GNUmakefile.deps
|
|
|
|
# CXXFLAGS are tuned earlier.
|
|
.PHONY: asan ubsan align aligned
|
|
asan ubsan align aligned: libcryptopp.a cryptest.exe
|
|
|
|
# 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"
|
|
.PHONY: coverage
|
|
coverage: libcryptopp.a cryptest.exe
|
|
lcov --base-directory . --directory . --zerocounters -q
|
|
./cryptest.exe v
|
|
./cryptest.exe tv all
|
|
lcov --base-directory . --directory . -c -o cryptest.info
|
|
lcov --remove cryptest.info "*test.*" "bench*.cpp" "validat*.*" "/usr/*" -o cryptest.info
|
|
rm -rf ./TestCoverage/
|
|
genhtml -o ./TestCoverage/ -t "cryptest.exe test coverage" --num-spaces 4 cryptest.info
|
|
|
|
.PHONY: test check
|
|
test check: cryptest.exe
|
|
./cryptest.exe v
|
|
|
|
# Used to generate list of source files for Autotools, CMakeList, Android.mk, etc
|
|
.PHONY: sources
|
|
sources:
|
|
$(info Library sources: $(filter-out fipstest.cpp $(TESTSRCS),$(SRCS)))
|
|
$(info )
|
|
$(info Test sources: $(TESTSRCS))
|
|
|
|
# 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)
|
|
DOXYGEN_DIRECTORY := $(strip $(shell $(EGREP) "OUTPUT_DIRECTORY" Doxyfile | grep -v "\#" | cut -d "=" -f 2))
|
|
endif
|
|
# Default directory (in case its missing in the config file)
|
|
ifeq ($(strip $(DOXYGEN_DIRECTORY)),)
|
|
DOXYGEN_DIRECTORY := html-docs
|
|
endif
|
|
|
|
# Builds the documentation. Directory name is ref563, ref570, etc.
|
|
.PHONY: docs html
|
|
docs html:
|
|
-$(RM) -r $(DOXYGEN_DIRECTORY)/ $(DOCUMENT_DIRECTORY)/ html-docs/
|
|
doxygen Doxyfile -d CRYPTOPP_DOXYGEN_PROCESSING
|
|
$(MV) $(DOXYGEN_DIRECTORY)/ $(DOCUMENT_DIRECTORY)/
|
|
-$(RM) CryptoPPRef.zip
|
|
zip -9 CryptoPPRef.zip -x ".*" -x "*/.*" -r $(DOCUMENT_DIRECTORY)/
|
|
|
|
.PHONY: clean
|
|
clean:
|
|
-$(RM) libcryptopp.a libcryptopp.so$(SOLIB_VERSION_SUFFIX) libcryptopp.dylib cryptopp.dll libcryptopp.dll.a libcryptopp.import.a
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
-$(RM) libcryptopp.so libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
|
endif
|
|
-$(RM) adhoc.cpp.o adhoc.cpp.proto.o $(LIBOBJS) $(TESTOBJS) $(DLLOBJS) $(LIBIMPORTOBJS) $(TESTIMPORTOBJS) $(DLLTESTOBJS)
|
|
-$(RM) cryptest.exe dlltest.exe cryptest.import.exe cryptest.info ct rdrand-???.o
|
|
-$(RM) *.gcno *.gcda *.stackdump core-*
|
|
ifneq ($(wildcard *.exe.dSYM),)
|
|
-$(RM) -r *.exe.dSYM/
|
|
endif
|
|
ifneq ($(wildcard $(DOCUMENT_DIRECTORY)/),)
|
|
-$(RM) -r $(DOCUMENT_DIRECTORY)/
|
|
endif
|
|
ifneq ($(wildcard TestCoverage/),)
|
|
-$(RM) -r TestCoverage/
|
|
endif
|
|
ifneq ($(wildcard cov-int/),)
|
|
-$(RM) -r cov-int/
|
|
endif
|
|
|
|
.PHONY: distclean
|
|
distclean: clean
|
|
-$(RM) adhoc.cpp adhoc.cpp.copied GNUmakefile.deps benchmarks.html cryptest.txt cryptest-*.txt
|
|
-$(RM) CMakeCache.txt Makefile CTestTestfile.cmake cmake_install.cmake cryptopp-config-version.cmake
|
|
-$(RM) *.o *.ii *.s *~
|
|
ifneq ($(wildcard CMakeFiles/),)
|
|
-$(RM) -r CMakeFiles/
|
|
endif
|
|
ifneq ($(wildcard cryptopp$(LIB_VER)\.*),)
|
|
-$(RM) cryptopp$(LIB_VER)\.*
|
|
endif
|
|
ifneq ($(wildcard $(DOC_DIRECTORY)),)
|
|
-$(RM) -r $(DOC_DIRECTORY)
|
|
endif
|
|
ifneq ($(wildcard CryptoPPRef.zip),)
|
|
-$(RM) CryptoPPRef.zip
|
|
endif
|
|
|
|
.PHONY: install
|
|
install:
|
|
$(MKDIR) -p $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
$(CP) *.h $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
-$(CHMOD) 0755 $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
-$(CHMOD) 0644 $(DESTDIR)$(INCLUDEDIR)/cryptopp/*.h
|
|
ifneq ($(wildcard libcryptopp.a),)
|
|
$(MKDIR) -p $(DESTDIR)$(LIBDIR)
|
|
$(CP) libcryptopp.a $(DESTDIR)$(LIBDIR)
|
|
-$(CHMOD) 0644 $(DESTDIR)$(LIBDIR)/libcryptopp.a
|
|
endif
|
|
ifneq ($(wildcard cryptest.exe),)
|
|
$(MKDIR) -p $(DESTDIR)$(BINDIR)
|
|
$(CP) cryptest.exe $(DESTDIR)$(BINDIR)
|
|
-$(CHMOD) 0755 $(DESTDIR)$(BINDIR)/cryptest.exe
|
|
$(MKDIR) -p $(DESTDIR)$(DATADIR)/cryptopp
|
|
$(CP) -r TestData $(DESTDIR)$(DATADIR)/cryptopp
|
|
$(CP) -r TestVectors $(DESTDIR)$(DATADIR)/cryptopp
|
|
-$(CHMOD) 0755 $(DESTDIR)$(DATADIR)/cryptopp
|
|
-$(CHMOD) 0755 $(DESTDIR)$(DATADIR)/cryptopp/TestData
|
|
-$(CHMOD) 0755 $(DESTDIR)$(DATADIR)/cryptopp/TestVectors
|
|
-$(CHMOD) 0644 $(DESTDIR)$(DATADIR)/cryptopp/TestData/*.dat
|
|
-$(CHMOD) 0644 $(DESTDIR)$(DATADIR)/cryptopp/TestVectors/*.txt
|
|
endif
|
|
ifneq ($(wildcard libcryptopp.dylib),)
|
|
$(MKDIR) -p $(DESTDIR)$(LIBDIR)
|
|
$(CP) libcryptopp.dylib $(DESTDIR)$(LIBDIR)
|
|
-install_name_tool -id $(DESTDIR)$(LIBDIR)/libcryptopp.dylib $(DESTDIR)$(LIBDIR)/libcryptopp.dylib
|
|
-$(CHMOD) 0755 $(DESTDIR)$(LIBDIR)/libcryptopp.dylib
|
|
endif
|
|
ifneq ($(wildcard libcryptopp.so$(SOLIB_VERSION_SUFFIX)),)
|
|
$(MKDIR) -p $(DESTDIR)$(LIBDIR)
|
|
$(CP) libcryptopp.so$(SOLIB_VERSION_SUFFIX) $(DESTDIR)$(LIBDIR)
|
|
-$(CHMOD) 0755 $(DESTDIR)$(LIBDIR)/libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
-$(LN) -sf libcryptopp.so$(SOLIB_VERSION_SUFFIX) $(DESTDIR)$(LIBDIR)/libcryptopp.so
|
|
$(LDCONF) $(DESTDIR)$(LIBDIR)
|
|
endif
|
|
endif
|
|
|
|
.PHONY: remove uninstall
|
|
remove uninstall:
|
|
-$(RM) -r $(DESTDIR)$(INCLUDEDIR)/cryptopp
|
|
-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.a
|
|
-$(RM) $(DESTDIR)$(BINDIR)/cryptest.exe
|
|
-$(RM) -r $(DESTDIR)$(DATADIR)/cryptopp
|
|
ifneq ($(IS_DARWIN),0)
|
|
-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.dylib
|
|
else
|
|
-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.so$(SOLIB_COMPAT_SUFFIX)
|
|
-$(RM) $(DESTDIR)$(LIBDIR)/libcryptopp.so
|
|
$(LDCONF) $(DESTDIR)$(LIBDIR)
|
|
endif
|
|
endif
|
|
|
|
libcryptopp.a: $(LIBOBJS) | public_service
|
|
$(AR) $(ARFLAGS) $@ $(LIBOBJS)
|
|
$(RANLIB) $@
|
|
|
|
ifeq ($(HAS_SOLIB_VERSION),1)
|
|
.PHONY: libcryptopp.so
|
|
libcryptopp.so: libcryptopp.so$(SOLIB_VERSION_SUFFIX)
|
|
endif
|
|
|
|
libcryptopp.so$(SOLIB_VERSION_SUFFIX): $(LIBOBJS) | public_service
|
|
$(CXX) -shared $(SOLIB_FLAGS) -o $@ $(CXXFLAGS) $(LDFLAGS) $(LIBOBJS) $(LDLIBS)
|
|
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
|
|
|
|
libcryptopp.dylib: $(LIBOBJS)
|
|
$(CXX) -dynamiclib -o $@ $(CXXFLAGS) -install_name "$@" -current_version "$(LIB_MAJOR).$(LIB_MINOR).$(LIB_PATCH)" -compatibility_version "$(LIB_MAJOR).$(LIB_MINOR)" -headerpad_max_install_names $(LDFLAGS) $(LIBOBJS)
|
|
|
|
cryptest.exe: libcryptopp.a $(TESTOBJS) | public_service
|
|
$(CXX) -o $@ $(CXXFLAGS) $(TESTOBJS) ./libcryptopp.a $(LDFLAGS) $(LDLIBS)
|
|
|
|
# Makes it faster to test changes
|
|
nolib: $(OBJS)
|
|
$(CXX) -o ct $(CXXFLAGS) $(OBJS) $(LDFLAGS) $(LDLIBS)
|
|
|
|
dll: cryptest.import.exe dlltest.exe
|
|
|
|
cryptopp.dll: $(DLLOBJS)
|
|
$(CXX) -shared -o $@ $(CXXFLAGS) $(DLLOBJS) $(LDFLAGS) $(LDLIBS) -Wl,--out-implib=libcryptopp.dll.a
|
|
|
|
libcryptopp.import.a: $(LIBIMPORTOBJS)
|
|
$(AR) $(ARFLAGS) $@ $(LIBIMPORTOBJS)
|
|
$(RANLIB) $@
|
|
|
|
cryptest.import.exe: cryptopp.dll libcryptopp.import.a $(TESTIMPORTOBJS)
|
|
$(CXX) -o $@ $(CXXFLAGS) $(TESTIMPORTOBJS) -L. -lcryptopp.dll -lcryptopp.import $(LDFLAGS) $(LDLIBS)
|
|
|
|
dlltest.exe: cryptopp.dll $(DLLTESTOBJS)
|
|
$(CXX) -o $@ $(CXXFLAGS) $(DLLTESTOBJS) -L. -lcryptopp.dll $(LDFLAGS) $(LDLIBS)
|
|
|
|
# This recipe prepares the distro files
|
|
TEXT_FILES := *.h *.cpp adhoc.cpp.proto License.txt Readme.txt Install.txt Filelist.txt CMakeLists.txt config.recommend Doxyfile cryptest* cryptlib* dlltest* cryptdll* *.sln *.vcproj *.dsw *.dsp cryptopp.rc TestVectors/*.txt TestData/*.dat
|
|
EXEC_FILES := GNUmakefile GNUmakefile-cross TestData/ TestVectors/
|
|
|
|
ifeq ($(wildcard Filelist.txt),Filelist.txt)
|
|
DIST_FILES := $(shell cat Filelist.txt)
|
|
endif
|
|
|
|
.PHONY: convert
|
|
convert:
|
|
-$(CHMOD) 0700 TestVectors/ TestData/
|
|
-$(CHMOD) 0600 $(TEXT_FILES) *.asm *.S *.zip *.cmake
|
|
-$(CHMOD) 0700 $(EXEC_FILES) *.sh *.cmd
|
|
-$(CHMOD) 0700 *.cmd *.sh GNUmakefile GNUmakefile-cross
|
|
-unix2dos --keepdate --quiet $(TEXT_FILES) *.asm *.cmd *.cmake
|
|
-dos2unix --keepdate --quiet GNUmakefile GNUmakefile-cross *.S *.sh
|
|
ifneq ($(IS_DARWIN),0)
|
|
-xattr -c *
|
|
endif
|
|
|
|
# Build the ZIP file with source files. No documentation.
|
|
.PHONY: zip dist
|
|
zip dist: | distclean convert
|
|
zip -q -9 cryptopp$(LIB_VER).zip $(DIST_FILES)
|
|
|
|
# Build the ISO to transfer the ZIP to old distros via CDROM
|
|
.PHONY: iso
|
|
iso: | zip
|
|
ifneq ($(IS_DARWIN),0)
|
|
$(MKDIR) -p $(PWD)/cryptopp$(LIB_VER)
|
|
$(CP) cryptopp$(LIB_VER).zip $(PWD)/cryptopp$(LIB_VER)
|
|
hdiutil makehybrid -iso -joliet -o cryptopp$(LIB_VER).iso $(PWD)/cryptopp$(LIB_VER)
|
|
-$(RM) -r $(PWD)/cryptopp$(LIB_VER)
|
|
else ifneq ($(IS_LINUX),0)
|
|
$(MKDIR) -p $(PWD)/cryptopp$(LIB_VER)
|
|
$(CP) cryptopp$(LIB_VER).zip $(PWD)/cryptopp$(LIB_VER)
|
|
genisoimage -q -o cryptopp$(LIB_VER).iso $(PWD)/cryptopp$(LIB_VER)
|
|
-$(RM) -r $(PWD)/cryptopp$(LIB_VER)
|
|
endif
|
|
|
|
CRYPTOPP_CPU_SPEED ?= 2.4e+09
|
|
.PHONY: bench benchmark benchmarks
|
|
bench benchmark benchmarks: cryptest.exe
|
|
rm -f benchmarks.html
|
|
echo "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"http://www.w3.org/TR/REC-html40/loose.dtd\">" >> benchmarks.html
|
|
echo "<HTML>" >> benchmarks.html
|
|
echo "<HEAD>" >> benchmarks.html
|
|
echo "<TITLE>Speed Comparison of Popular Crypto Algorithms</TITLE>" >> benchmarks.html
|
|
echo "</HEAD>" >> benchmarks.html
|
|
echo "<BODY>" >> benchmarks.html
|
|
echo "<H1><a href=\"http://www.cryptopp.com\">Crypto++</a>" $(LIB_MAJOR).$(LIB_MINOR).$(LIB_PATCH) "Benchmarks</H1>" >> benchmarks.html
|
|
echo "<P>Here are speed benchmarks for some commonly used cryptographic algorithms.</P>" >> benchmarks.html
|
|
./cryptest.exe b 3 $(CRYPTOPP_CPU_SPEED) >> benchmarks.html
|
|
echo "</BODY>" >> benchmarks.html
|
|
echo "</HTML>" >> benchmarks.html
|
|
|
|
adhoc.cpp: adhoc.cpp.proto
|
|
ifeq ($(wildcard adhoc.cpp),)
|
|
cp adhoc.cpp.proto adhoc.cpp
|
|
else
|
|
touch adhoc.cpp
|
|
endif
|
|
|
|
# Include dependencies, if present. You must issue `make deps` to create them.
|
|
ifeq ($(wildcard GNUmakefile.deps),GNUmakefile.deps)
|
|
-include GNUmakefile.deps
|
|
endif # Dependencies
|
|
|
|
# MacPorts/GCC issue with init_priority. Apple/GCC and Fink/GCC are fine; limit to MacPorts.
|
|
# Also see http://lists.macosforge.org/pipermail/macports-users/2015-September/039223.html
|
|
ifeq ($(GCC_COMPILER)$(MACPORTS_COMPILER),11)
|
|
ifeq ($(findstring -DMACPORTS_GCC_COMPILER,$(CXXFLAGS)),)
|
|
cryptlib.o:
|
|
$(CXX) $(CXXFLAGS) -DMACPORTS_GCC_COMPILER=1 -c cryptlib.cpp
|
|
cpu.o:
|
|
$(CXX) $(CXXFLAGS) -DMACPORTS_GCC_COMPILER=1 -c cpu.cpp
|
|
endif
|
|
endif
|
|
|
|
# Only use CRYPTOPP_DATA_DIR if its not set in CXXFLAGS
|
|
ifeq ($(findstring -DCRYPTOPP_DATA_DIR,$(CXXFLAGS)),)
|
|
ifneq ($(strip $(CRYPTOPP_DATA_DIR)),)
|
|
validat%.o : validat%.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c $<
|
|
bench.o : bench.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c $<
|
|
bench%.o : bench%.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c $<
|
|
datatest.o : datatest.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c $<
|
|
test.o : test.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_DATA_DIR=\"$(CRYPTOPP_DATA_DIR)\" -c $<
|
|
endif
|
|
endif
|
|
|
|
%.dllonly.o : %.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_DLL_ONLY -c $< -o $@
|
|
|
|
%.import.o : %.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_IMPORTS -c $< -o $@
|
|
|
|
%.export.o : %.cpp
|
|
$(CXX) $(CXXFLAGS) -DCRYPTOPP_EXPORTS -c $< -o $@
|
|
|
|
%.o : %.cpp
|
|
$(CXX) $(CXXFLAGS) -c $<
|
|
|
|
# Warn of potential configuration issues. They will go away after 5.6.3.
|
|
UNALIGNED_ACCESS := $(shell $(EGREP) -c "^[[:space:]]*//[[:space:]]*\#[[:space:]]*define[[:space:]]*CRYPTOPP_NO_UNALIGNED_DATA_ACCESS" config.h)
|
|
NO_INIT_PRIORITY := $(shell $(EGREP) -c "^[[:space:]]*//[[:space:]]*\#[[:space:]]*define[[:space:]]*CRYPTOPP_INIT_PRIORITY" config.h)
|
|
COMPATIBILITY_562 := $(shell $(EGREP) -c "^[[:space:]]*\#[[:space:]]*define[[:space:]]*CRYPTOPP_MAINTAIN_BACKWARDS_COMPATIBILITY_562" config.h)
|
|
.PHONY: public_service
|
|
public_service:
|
|
ifneq ($(UNALIGNED_ACCESS),0)
|
|
$(info WARNING: CRYPTOPP_NO_UNALIGNED_DATA_ACCESS is not defined in config.h.)
|
|
endif
|
|
ifneq ($(NO_INIT_PRIORITY),0)
|
|
$(info WARNING: CRYPTOPP_INIT_PRIORITY is not defined in config.h.)
|
|
endif
|
|
ifneq ($(COMPATIBILITY_562),0)
|
|
$(info WARNING: CRYPTOPP_MAINTAIN_BACKWARDS_COMPATIBILITY_562 is defined in config.h.)
|
|
endif
|
|
ifneq ($(UNALIGNED_ACCESS)$(NO_INIT_PRIORITY)$(COMPATIBILITY_562),000)
|
|
$(info WARNING: You should make these changes in config.h, and not CXXFLAGS.)
|
|
$(info WARNING: You can 'mv config.recommend config.h', but it breaks versioning.)
|
|
$(info WARNING: See http://cryptopp.com/wiki/config.h for more details.)
|
|
$(info )
|
|
endif
|
|
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
|