########################################################### ##### 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 := bench1.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 shacal2.cpp md5.cpp shark.cpp zinflate.cpp gf2n.cpp salsa.cpp xtr.cpp oaep.cpp polynomi.cpp rc2.cpp default.cpp wait.cpp wake.cpp twofish.cpp iterhash.cpp adler32.cpp elgamal.cpp marss.cpp blowfish.cpp ecp.cpp filters.cpp strciphr.cpp camellia.cpp ida.cpp zlib.cpp des.cpp crc.cpp algparam.cpp dessp.cpp tea.cpp eax.cpp network.cpp emsa2.cpp pkcspad.cpp squaretb.cpp idea.cpp authenc.cpp hmac.cpp zdeflate.cpp xtrcrypt.cpp queue.cpp mars.cpp rc5.cpp blake2.cpp hrtimer.cpp eprecomp.cpp hex.cpp dsa.cpp sha.cpp fips140.cpp gzip.cpp seal.cpp files.cpp base32.cpp vmac.cpp tigertab.cpp sharkbox.cpp safer.cpp randpool.cpp esign.cpp arc4.cpp osrng.cpp skipjack.cpp seed.cpp integer.cpp sha3.cpp sosemanuk.cpp bfinit.cpp rabin.cpp 3way.cpp rw.cpp rdrand.cpp rsa.cpp rdtables.cpp gost.cpp socketft.cpp tftables.cpp nbtheory.cpp panama.cpp modes.cpp rijndael.cpp casts.cpp chacha.cpp gfpcrypt.cpp poly1305.cpp dll.cpp ec2n.cpp blumshub.cpp algebra.cpp basecode.cpp base64.cpp cbcmac.cpp rc6.cpp dh2.cpp gf256.cpp mqueue.cpp misc.cpp pssr.cpp channels.cpp tiger.cpp cast.cpp rng.cpp square.cpp asn.cpp whrlpool.cpp md4.cpp dh.cpp ccm.cpp md2.cpp mqv.cpp gf2_32.cpp ttmac.cpp luc.cpp trdlocal.cpp pubkey.cpp gcm.cpp ripemd.cpp eccrypto.cpp serpent.cpp cmac.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-* -$(RM) /tmp/adhoc.exe ifneq ($(wildcard /tmp/cryptopp_test/),) -$(RM) -r /tmp/cryptopp_test/ endif ifneq ($(wildcard *.exe.dSYM),) -$(RM) -r *.exe.dSYM/ 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) cryptopp.tgz *.o *.ii *.s *~ ifneq ($(wildcard CMakeFiles/),) -$(RM) -r CMakeFiles/ endif ifneq ($(wildcard $(DOCUMENT_DIRECTORY)/),) -$(RM) -r $(DOCUMENT_DIRECTORY)/ endif ifneq ($(wildcard TestCoverage/),) -$(RM) -r TestCoverage/ 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 "" >> benchmarks.html echo "" >> benchmarks.html echo "" >> benchmarks.html echo "Speed Comparison of Popular Crypto Algorithms" >> benchmarks.html echo "" >> benchmarks.html echo "" >> benchmarks.html echo "

Crypto++" $(LIB_MAJOR).$(LIB_MINOR).$(LIB_PATCH) "Benchmarks

" >> benchmarks.html echo "

Here are speed benchmarks for some commonly used cryptographic algorithms.

" >> benchmarks.html ./cryptest.exe b 3 $(CRYPTOPP_CPU_SPEED) >> benchmarks.html echo "" >> benchmarks.html echo "" >> 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 $< 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