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
|
2020-12-17 18:17:32 +00:00
|
|
|
WARNING_CFLAGS ?= -Wall -Wextra -Wformat=2 -Wno-format-nonliteral
|
2015-02-18 15:47:52 +00:00
|
|
|
LDFLAGS ?=
|
2015-02-18 15:55:05 +00:00
|
|
|
|
2020-07-02 13:58:37 +00:00
|
|
|
# Include ../include for public headers and . for private headers.
|
|
|
|
# Note that . needs to be included explicitly for the sake of library
|
|
|
|
# files that are not in the /library directory (which currently means
|
|
|
|
# under /3rdparty).
|
2020-06-03 00:25:17 +00:00
|
|
|
LOCAL_CFLAGS = $(WARNING_CFLAGS) -I. -I../include -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
|
|
|
|
2021-04-21 23:01:56 +00:00
|
|
|
PERL ?= perl
|
|
|
|
|
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
|
|
|
|
2020-03-10 13:25:34 +00:00
|
|
|
SOEXT_TLS=so.13
|
|
|
|
SOEXT_X509=so.1
|
2020-12-09 01:12:58 +00:00
|
|
|
SOEXT_CRYPTO=so.6
|
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
|
|
|
|
2020-04-03 09:50:59 +00:00
|
|
|
OBJS_CRYPTO= \
|
|
|
|
aes.o \
|
|
|
|
aesni.o \
|
|
|
|
arc4.o \
|
|
|
|
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 \
|
|
|
|
cmac.o \
|
|
|
|
ctr_drbg.o \
|
|
|
|
des.o \
|
|
|
|
dhm.o \
|
|
|
|
ecdh.o \
|
|
|
|
ecdsa.o \
|
|
|
|
ecjpake.o \
|
|
|
|
ecp.o \
|
|
|
|
ecp_curves.o \
|
|
|
|
entropy.o \
|
|
|
|
entropy_poll.o \
|
|
|
|
error.o \
|
|
|
|
gcm.o \
|
|
|
|
hkdf.o \
|
|
|
|
hmac_drbg.o \
|
|
|
|
md.o \
|
|
|
|
md2.o \
|
|
|
|
md4.o \
|
|
|
|
md5.o \
|
|
|
|
memory_buffer_alloc.o \
|
2021-02-22 15:03:37 +00:00
|
|
|
mps_reader.o \
|
|
|
|
mps_trace.o \
|
2020-04-03 09:50:59 +00:00
|
|
|
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 \
|
|
|
|
psa_crypto.o \
|
2021-03-17 15:55:43 +00:00
|
|
|
psa_crypto_aead.o \
|
2021-03-08 15:46:35 +00:00
|
|
|
psa_crypto_cipher.o \
|
2021-01-28 15:07:56 +00:00
|
|
|
psa_crypto_client.o \
|
2020-07-16 18:28:36 +00:00
|
|
|
psa_crypto_driver_wrappers.o \
|
2020-11-25 14:25:26 +00:00
|
|
|
psa_crypto_ecp.o \
|
2021-02-18 15:18:32 +00:00
|
|
|
psa_crypto_hash.o \
|
2021-03-19 14:24:23 +00:00
|
|
|
psa_crypto_mac.o \
|
2020-11-25 14:25:26 +00:00
|
|
|
psa_crypto_rsa.o \
|
2020-04-03 09:50:59 +00:00
|
|
|
psa_crypto_se.o \
|
|
|
|
psa_crypto_slot_management.o \
|
|
|
|
psa_crypto_storage.o \
|
|
|
|
psa_its_file.o \
|
|
|
|
ripemd160.o \
|
|
|
|
rsa.o \
|
2021-03-09 16:04:12 +00:00
|
|
|
rsa_alt_helpers.o \
|
2020-04-03 09:50:59 +00:00
|
|
|
sha1.o \
|
|
|
|
sha256.o \
|
|
|
|
sha512.o \
|
|
|
|
threading.o \
|
|
|
|
timing.o \
|
|
|
|
version.o \
|
|
|
|
version_features.o \
|
|
|
|
xtea.o \
|
|
|
|
# This line is intentionally left blank
|
2019-04-26 10:59:31 +00:00
|
|
|
|
2018-12-14 13:07:50 +00:00
|
|
|
include ../3rdparty/Makefile.inc
|
|
|
|
LOCAL_CFLAGS+=$(THIRDPARTY_INCLUDES)
|
2019-02-15 13:35:04 +00:00
|
|
|
OBJS_CRYPTO+=$(THIRDPARTY_CRYPTO_OBJECTS)
|
2015-06-24 09:54:19 +00:00
|
|
|
|
2020-04-03 09:50:59 +00:00
|
|
|
OBJS_X509= \
|
|
|
|
x509.o \
|
|
|
|
x509_create.o \
|
|
|
|
x509_crl.o \
|
|
|
|
x509_crt.o \
|
|
|
|
x509_csr.o \
|
|
|
|
x509write_crt.o \
|
|
|
|
x509write_csr.o \
|
|
|
|
# This line is intentionally left blank
|
|
|
|
|
|
|
|
OBJS_TLS= \
|
|
|
|
debug.o \
|
|
|
|
net_sockets.o \
|
|
|
|
ssl_cache.o \
|
|
|
|
ssl_ciphersuites.o \
|
|
|
|
ssl_cli.o \
|
|
|
|
ssl_cookie.o \
|
|
|
|
ssl_msg.o \
|
|
|
|
ssl_srv.o \
|
|
|
|
ssl_ticket.o \
|
|
|
|
ssl_tls.o \
|
2020-08-21 12:20:06 +00:00
|
|
|
ssl_tls13_keys.o \
|
2020-04-03 09:50:59 +00:00
|
|
|
# This line is intentionally left blank
|
2015-06-24 09:54:19 +00:00
|
|
|
|
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
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
static: libmbedcrypto.a libmbedx509.a libmbedtls.a
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
shared: libmbedcrypto.$(DLEXT) libmbedx509.$(DLEXT) libmbedtls.$(DLEXT)
|
2015-01-23 12:51:33 +00:00
|
|
|
|
2015-06-24 11:06:24 +00:00
|
|
|
# tls
|
|
|
|
libmbedtls.a: $(OBJS_TLS)
|
2010-03-24 06:46:47 +00:00
|
|
|
echo " AR $@"
|
2018-05-23 08:19:54 +00:00
|
|
|
$(AR) $(ARFLAGS) $@ $(OBJS_TLS)
|
|
|
|
ifdef APPLE_BUILD
|
2018-06-19 16:25:34 +00:00
|
|
|
ifneq ($(APPLE_BUILD),0)
|
2010-03-24 06:46:47 +00:00
|
|
|
echo " RL $@"
|
2018-05-23 08:19:54 +00:00
|
|
|
$(RL) $(RLFLAGS) $@
|
|
|
|
endif
|
2018-06-19 16:25:34 +00:00
|
|
|
endif
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2015-08-10 08:17:32 +00:00
|
|
|
libmbedtls.$(SOEXT_TLS): $(OBJS_TLS) libmbedx509.so
|
2010-03-24 06:46:47 +00:00
|
|
|
echo " LD $@"
|
2015-08-10 08:17:32 +00:00
|
|
|
$(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2015-06-25 09:54:52 +00:00
|
|
|
libmbedtls.so: libmbedtls.$(SOEXT_TLS)
|
|
|
|
echo " LN $@ -> $<"
|
|
|
|
ln -sf $< $@
|
2013-11-05 10:27:12 +00:00
|
|
|
|
2018-02-20 02:58:19 +00:00
|
|
|
libmbedtls.dylib: $(OBJS_TLS) libmbedx509.dylib
|
2015-06-24 11:06:24 +00:00
|
|
|
echo " LD $@"
|
2018-02-20 02:58:19 +00:00
|
|
|
$(CC) -dynamiclib -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2015-08-07 10:07:16 +00:00
|
|
|
libmbedtls.dll: $(OBJS_TLS) libmbedx509.dll
|
2015-06-24 11:06:24 +00:00
|
|
|
echo " LD $@"
|
2015-08-07 10:07:16 +00:00
|
|
|
$(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_TLS) -lws2_32 -lwinmm -lgdi32 -L. -lmbedcrypto -lmbedx509 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
|
2015-06-24 11:06:24 +00:00
|
|
|
|
|
|
|
# x509
|
|
|
|
libmbedx509.a: $(OBJS_X509)
|
|
|
|
echo " AR $@"
|
2018-05-23 08:19:54 +00:00
|
|
|
$(AR) $(ARFLAGS) $@ $(OBJS_X509)
|
|
|
|
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
|
|
|
|
2020-02-26 18:05:19 +00:00
|
|
|
libmbedx509.$(SOEXT_X509): $(OBJS_X509) libmbedcrypto.so
|
2015-06-24 11:06:24 +00:00
|
|
|
echo " LD $@"
|
2015-08-10 08:17:32 +00:00
|
|
|
$(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2015-06-25 09:54:52 +00:00
|
|
|
libmbedx509.so: libmbedx509.$(SOEXT_X509)
|
|
|
|
echo " LN $@ -> $<"
|
|
|
|
ln -sf $< $@
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2020-02-26 18:05:19 +00:00
|
|
|
libmbedx509.dylib: $(OBJS_X509) libmbedcrypto.dylib
|
2015-06-24 11:06:24 +00:00
|
|
|
echo " LD $@"
|
2018-02-20 02:58:19 +00:00
|
|
|
$(CC) -dynamiclib -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
|
2015-06-24 11:06:24 +00:00
|
|
|
|
2020-02-26 18:05:19 +00:00
|
|
|
libmbedx509.dll: $(OBJS_X509) libmbedcrypto.dll
|
2010-03-24 06:46:47 +00:00
|
|
|
echo " LD $@"
|
2015-08-07 10:07:16 +00:00
|
|
|
$(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_X509) -lws2_32 -lwinmm -lgdi32 -L. -lmbedcrypto -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
|
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 $< $@
|
2011-06-21 08:59:44 +00:00
|
|
|
|
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)
|
2019-10-07 13:19:18 +00:00
|
|
|
|
2010-03-24 06:46:47 +00:00
|
|
|
.c.o:
|
2012-04-05 13:22:07 +00:00
|
|
|
echo " CC $<"
|
2018-10-25 11:47:03 +00:00
|
|
|
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
|
2009-01-03 21:22:43 +00:00
|
|
|
|
2021-04-21 23:01:56 +00:00
|
|
|
.PHONY: generated_files
|
|
|
|
GENERATED_FILES = error.c version_features.c
|
|
|
|
generated_files: $(GENERATED_FILES)
|
|
|
|
|
|
|
|
error.c: ../scripts/generate_errors.pl
|
|
|
|
error.c: ../scripts/data_files/error.fmt
|
2021-04-22 12:50:16 +00:00
|
|
|
error.c: $(filter-out %config%,$(wildcard ../include/mbedtls/*.h))
|
2021-04-21 23:01:56 +00:00
|
|
|
error.c:
|
|
|
|
echo " Gen $@"
|
|
|
|
$(PERL) ../scripts/generate_errors.pl
|
|
|
|
|
|
|
|
version_features.c: ../scripts/generate_features.pl
|
|
|
|
version_features.c: ../scripts/data_files/version_features.fmt
|
2021-04-22 12:50:16 +00:00
|
|
|
## The generated file only depends on the options that are present in config.h,
|
|
|
|
## not on which options are set. To avoid regenerating this file all the time
|
|
|
|
## when switching between configurations, don't declare config.h as a
|
|
|
|
## dependency. Remove this file from your working tree if you've just added or
|
|
|
|
## removed an option in config.h.
|
|
|
|
#version_features.c: ../include/mbedtls/config.h
|
2021-04-21 23:01:56 +00:00
|
|
|
version_features.c:
|
|
|
|
echo " Gen $@"
|
|
|
|
$(PERL) ../scripts/generate_features.pl
|
|
|
|
|
2009-01-03 21:22:43 +00:00
|
|
|
clean:
|
2012-05-10 21:26:28 +00:00
|
|
|
ifndef WINDOWS
|
2020-03-09 16:48:13 +00:00
|
|
|
rm -f *.o libmbed*
|
2020-03-10 09:36:19 +00:00
|
|
|
rm -f $(THIRDPARTY_CRYPTO_OBJECTS)
|
2015-06-24 11:06:24 +00:00
|
|
|
else
|
2019-08-30 13:51:55 +00:00
|
|
|
if exist *.o del /Q /F *.o
|
|
|
|
if exist libmbed* del /Q /F libmbed*
|
2020-03-10 09:36:19 +00:00
|
|
|
del /Q /F del_errors_out_if_the_file_list_is_empty_but_not_if_a_file_does_not_exist $(subst /,\,$(THIRDPARTY_CRYPTO_OBJECTS))
|
2012-05-10 21:26:28 +00:00
|
|
|
endif
|
2021-04-21 23:01:56 +00:00
|
|
|
|
|
|
|
neat: clean
|
|
|
|
ifndef WINDOWS
|
|
|
|
rm -f $(GENERATED_FILES)
|
|
|
|
else
|
|
|
|
for %f in ($(subst /,\,$(GENERATED_FILES))) if exist %f del /Q /F %f
|
|
|
|
endif
|