2009-01-03 21:22:43 +00:00
|
|
|
|
2015-03-09 17:05:11 +00:00
|
|
|
# Also see "include/mbedtls/config.h"
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2015-02-18 15:55:05 +00:00
|
|
|
CFLAGS ?= -O2
|
2019-07-02 18:03:01 +00:00
|
|
|
WARNING_CFLAGS ?= -Wall -Wextra
|
2015-02-18 15:47:52 +00:00
|
|
|
LDFLAGS ?=
|
2015-02-18 15:55:05 +00:00
|
|
|
|
2018-11-01 16:56:08 +00:00
|
|
|
CRYPTO_INCLUDES ?= -I../include
|
|
|
|
LOCAL_CFLAGS = $(WARNING_CFLAGS) $(CRYPTO_INCLUDES) -D_FILE_OFFSET_BITS=64
|
2015-02-18 15:47:52 +00:00
|
|
|
LOCAL_LDFLAGS =
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2012-04-05 12:08:29 +00:00
|
|
|
ifdef DEBUG
|
2015-02-18 15:55:05 +00:00
|
|
|
LOCAL_CFLAGS += -g3
|
2012-04-05 12:08:29 +00:00
|
|
|
endif
|
|
|
|
|
2010-03-24 06:46:47 +00:00
|
|
|
# MicroBlaze specific options:
|
|
|
|
# CFLAGS += -mno-xl-soft-mul -mxl-barrel-shift
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2010-03-24 06:46:47 +00:00
|
|
|
# To compile on Plan9:
|
|
|
|
# CFLAGS += -D_BSD_EXTENSION
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2018-10-25 11:47:03 +00:00
|
|
|
# Include directories for Everest code
|
2018-12-14 11:46:43 +00:00
|
|
|
LOCAL_CFLAGS+=-I../3rdparty/everest/include -I../3rdparty/everest/include/everest -I../3rdparty/everest/include/everest/kremlib
|
2018-10-25 11:47:03 +00:00
|
|
|
|
2015-02-18 13:42:26 +00:00
|
|
|
# if were running on Windows build for Windows
|
|
|
|
ifdef WINDOWS
|
|
|
|
WINDOWS_BUILD=1
|
2018-06-13 08:28:04 +00:00
|
|
|
else ifeq ($(shell uname -s),Darwin)
|
2018-06-20 09:43:21 +00:00
|
|
|
ifeq ($(AR),ar)
|
2018-06-13 09:04:58 +00:00
|
|
|
APPLE_BUILD ?= 1
|
2015-02-18 13:42:26 +00:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2010-03-24 06:46:47 +00:00
|
|
|
# To compile as a shared library:
|
2012-11-14 12:39:52 +00:00
|
|
|
ifdef SHARED
|
2015-02-13 13:34:08 +00:00
|
|
|
# all code is position-indep with mingw, avoid warning about useless flag
|
2015-02-18 13:42:26 +00:00
|
|
|
ifndef WINDOWS_BUILD
|
2015-02-18 15:55:05 +00:00
|
|
|
LOCAL_CFLAGS += -fPIC -fpic
|
2012-11-14 12:39:52 +00:00
|
|
|
endif
|
2015-02-13 13:34:08 +00:00
|
|
|
endif
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2018-06-18 13:39:06 +00:00
|
|
|
SOEXT_CRYPTO=so.3
|
2011-08-13 11:47:41 +00:00
|
|
|
|
2019-01-23 14:24:37 +00:00
|
|
|
# Set AR_DASH= (empty string) to use an ar implementation that does not accept
|
2018-03-25 22:48:39 +00:00
|
|
|
# the - prefix for command line options (e.g. llvm-ar)
|
|
|
|
AR_DASH ?= -
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2018-06-19 16:25:34 +00:00
|
|
|
ARFLAGS = $(AR_DASH)src
|
2018-05-23 08:19:54 +00:00
|
|
|
ifdef APPLE_BUILD
|
2018-06-19 16:25:34 +00:00
|
|
|
ifneq ($(APPLE_BUILD),0)
|
2018-05-23 08:19:54 +00:00
|
|
|
ARFLAGS = $(AR_DASH)Src
|
|
|
|
RLFLAGS = -no_warning_for_no_symbols -c
|
|
|
|
RL ?= ranlib
|
2018-06-19 16:25:34 +00:00
|
|
|
endif
|
2018-05-23 08:19:54 +00:00
|
|
|
endif
|
|
|
|
|
2018-06-19 16:25:34 +00:00
|
|
|
DLEXT ?= so
|
2015-02-13 23:04:58 +00:00
|
|
|
ifdef WINDOWS_BUILD
|
2018-05-23 08:19:54 +00:00
|
|
|
# Windows shared library extension:
|
|
|
|
DLEXT = dll
|
|
|
|
else ifdef APPLE_BUILD
|
2018-06-19 16:25:34 +00:00
|
|
|
ifneq ($(APPLE_BUILD),0)
|
2018-05-23 08:19:54 +00:00
|
|
|
# Mac OS X shared library extension:
|
|
|
|
DLEXT = dylib
|
2012-05-10 20:49:10 +00:00
|
|
|
endif
|
|
|
|
endif
|
2011-06-21 08:59:44 +00:00
|
|
|
|
2018-05-07 08:43:27 +00:00
|
|
|
OBJS_CRYPTO= aes.o aesni.o arc4.o \
|
2018-06-07 10:01:33 +00:00
|
|
|
aria.o asn1parse.o asn1write.o \
|
|
|
|
base64.o bignum.o blowfish.o \
|
|
|
|
camellia.o ccm.o chacha20.o \
|
|
|
|
chachapoly.o cipher.o cipher_wrap.o \
|
2016-05-17 17:17:31 +00:00
|
|
|
cmac.o ctr_drbg.o des.o \
|
|
|
|
dhm.o ecdh.o ecdsa.o \
|
|
|
|
ecjpake.o ecp.o \
|
2015-06-24 09:54:19 +00:00
|
|
|
ecp_curves.o entropy.o entropy_poll.o \
|
2019-04-26 10:59:31 +00:00
|
|
|
gcm.o havege.o \
|
2016-07-17 07:51:22 +00:00
|
|
|
hkdf.o \
|
2015-06-24 09:54:19 +00:00
|
|
|
hmac_drbg.o md.o md2.o \
|
|
|
|
md4.o md5.o md_wrap.o \
|
2018-07-15 06:29:47 +00:00
|
|
|
memory_buffer_alloc.o nist_kw.o \
|
|
|
|
oid.o padlock.o pem.o \
|
|
|
|
pk.o pk_wrap.o pkcs12.o \
|
|
|
|
pkcs5.o pkparse.o pkwrite.o \
|
|
|
|
platform.o platform_util.o poly1305.o \
|
2019-06-24 12:06:43 +00:00
|
|
|
psa_crypto.o psa_crypto_se.o \
|
2018-11-30 17:54:54 +00:00
|
|
|
psa_crypto_slot_management.o \
|
2018-06-15 12:06:04 +00:00
|
|
|
psa_crypto_storage.o \
|
2018-11-16 21:24:15 +00:00
|
|
|
psa_its_file.o \
|
2016-05-16 21:25:45 +00:00
|
|
|
ripemd160.o rsa_internal.o rsa.o \
|
|
|
|
sha1.o sha256.o sha512.o \
|
2019-04-26 10:59:31 +00:00
|
|
|
threading.o timing.o \
|
|
|
|
xtea.o
|
|
|
|
|
|
|
|
# For files generated by the parent project (Mbed TLS) when building Mbed
|
|
|
|
# Crypto as a submodule, ensure that the parent project instance is used.
|
|
|
|
ifeq ($(USE_CRYPTO_SUBMODULE), 1)
|
2019-05-22 12:53:00 +00:00
|
|
|
OBJS_CRYPTO += $(patsubst %.c,%.o, $(realpath ../../library/error.c))
|
|
|
|
OBJS_CRYPTO += $(patsubst %.c,%.o, $(realpath ../../library/version.c))
|
|
|
|
OBJS_CRYPTO += $(patsubst %.c,%.o, $(realpath ../../library/version_features.c))
|
2019-04-26 10:59:31 +00:00
|
|
|
else
|
|
|
|
OBJS_CRYPTO += error.o
|
|
|
|
OBJS_CRYPTO += version.o
|
|
|
|
OBJS_CRYPTO += version_features.o
|
|
|
|
endif
|
|
|
|
|
2018-10-25 11:47:03 +00:00
|
|
|
OBJS_CRYPTO+= \
|
|
|
|
../3rdparty/everest/library/everest.o \
|
|
|
|
../3rdparty/everest/library/Hacl_Curve25519.o \
|
|
|
|
../3rdparty/everest/library/x25519.o \
|
|
|
|
../3rdparty/everest/library/kremlib/FStar_UInt64_FStar_UInt32_FStar_UInt16_FStar_UInt8.o
|
|
|
|
|
2010-03-24 06:46:47 +00:00
|
|
|
.SILENT:
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
.PHONY: all static shared clean
|
|
|
|
|
2012-11-14 12:39:52 +00:00
|
|
|
ifndef SHARED
|
2011-07-13 11:25:36 +00:00
|
|
|
all: static
|
2012-11-14 12:39:52 +00:00
|
|
|
else
|
2015-01-27 10:24:05 +00:00
|
|
|
all: shared static
|
2012-11-14 12:39:52 +00:00
|
|
|
endif
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2018-11-02 10:11:31 +00:00
|
|
|
static: libmbedcrypto.a
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2018-11-02 10:11:31 +00:00
|
|
|
shared: libmbedcrypto.$(DLEXT)
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
# crypto
|
|
|
|
libmbedcrypto.a: $(OBJS_CRYPTO)
|
|
|
|
echo " AR $@"
|
2018-05-23 08:19:54 +00:00
|
|
|
$(AR) $(ARFLAGS) $@ $(OBJS_CRYPTO)
|
|
|
|
ifdef APPLE_BUILD
|
2018-06-19 16:25:34 +00:00
|
|
|
ifneq ($(APPLE_BUILD),0)
|
2015-06-24 11:06:24 +00:00
|
|
|
echo " RL $@"
|
2018-05-23 08:19:54 +00:00
|
|
|
$(RL) $(RLFLAGS) $@
|
|
|
|
endif
|
2018-06-19 16:25:34 +00:00
|
|
|
endif
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2015-06-25 09:54:52 +00:00
|
|
|
libmbedcrypto.$(SOEXT_CRYPTO): $(OBJS_CRYPTO)
|
2013-11-05 10:27:12 +00:00
|
|
|
echo " LD $@"
|
2015-06-25 12:30:22 +00:00
|
|
|
$(CC) -shared -Wl,-soname,$@ $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2015-06-25 09:54:52 +00:00
|
|
|
libmbedcrypto.so: libmbedcrypto.$(SOEXT_CRYPTO)
|
|
|
|
echo " LN $@ -> $<"
|
|
|
|
ln -sf $< $@
|
2015-06-24 11:06:24 +00:00
|
|
|
|
|
|
|
libmbedcrypto.dylib: $(OBJS_CRYPTO)
|
|
|
|
echo " LD $@"
|
|
|
|
$(CC) -dynamiclib $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
|
|
|
|
|
|
|
|
libmbedcrypto.dll: $(OBJS_CRYPTO)
|
|
|
|
echo " LD $@"
|
2015-08-07 09:55:56 +00:00
|
|
|
$(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_CRYPTO) -lws2_32 -lwinmm -lgdi32 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
|
2011-06-21 08:59:44 +00:00
|
|
|
|
2010-03-24 06:46:47 +00:00
|
|
|
.c.o:
|
2012-04-05 13:22:07 +00:00
|
|
|
echo " CC $<"
|
2019-04-26 11:24:48 +00:00
|
|
|
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) -c $< -o $@
|
2009-01-03 21:22:43 +00:00
|
|
|
|
|
|
|
clean:
|
2012-05-10 21:26:28 +00:00
|
|
|
ifndef WINDOWS
|
2018-10-25 11:47:03 +00:00
|
|
|
rm -f *.o libmbed* $(OBJS_CRYPTO)
|
2015-06-24 11:06:24 +00:00
|
|
|
else
|
2018-10-17 15:12:33 +00:00
|
|
|
if exist *.o del /Q /F *.o
|
|
|
|
if exist libmbed* del /Q /F libmbed*
|
2018-10-25 11:47:03 +00:00
|
|
|
if exist $(OBJS_CRYPTO) del /Q /F $(OBJS_CRYPTO)
|
2012-05-10 21:26:28 +00:00
|
|
|
endif
|
2018-10-25 11:47:03 +00:00
|
|
|
|