blob: e0141bfbe7db536ae4d319247e9bcf96e95c94db [file] [log] [blame]
Paul Bakker5121ce52009-01-03 21:22:43 +00001
Manuel Pégourié-Gonnard7f809972015-03-09 17:05:11 +00002# Also see "include/mbedtls/config.h"
Paul Bakker5121ce52009-01-03 21:22:43 +00003
Alon Bar-Levf7a9f302015-02-18 17:55:05 +02004CFLAGS ?= -O2
5WARNING_CFLAGS ?= -Wall -W -Wdeclaration-after-statement
Alon Bar-Levada41052015-02-18 17:47:52 +02006LDFLAGS ?=
Alon Bar-Levf7a9f302015-02-18 17:55:05 +02007
Arto Kinnunen5e639ed2019-09-25 17:08:39 +03008# Check test environment. If ../library is available then Mbed TLS is used.
9# Otherwise Mbed OS environment is used.
Arto Kinnunen83078022019-09-25 16:10:04 +030010DIR_FOR_MBED_TLS_ENV=../library
11ifneq "$(wildcard $(DIR_FOR_MBED_TLS_ENV) )" ""
12 # Set include dirs for Mbed TLS test environment
13 INCLUDE_DIRS=-I../include
14else
15 # Set include dirs for Mbed OS test environment
16 INCLUDE_DIRS=-I.. -I../inc
17endif
18
19LOCAL_CFLAGS = $(WARNING_CFLAGS) $(INCLUDE_DIRS) -D_FILE_OFFSET_BITS=64
20ifdef MBEDTLS_CONFIG_FILE
21LOCAL_CFLAGS += "-DMBEDTLS_CONFIG_FILE=\"${MBEDTLS_CONFIG_FILE}\""
22endif
23
Alon Bar-Levada41052015-02-18 17:47:52 +020024LOCAL_LDFLAGS =
Paul Bakker5121ce52009-01-03 21:22:43 +000025
Paul Bakkerc7ffd362012-04-05 12:08:29 +000026ifdef DEBUG
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020027LOCAL_CFLAGS += -g3
Paul Bakkerc7ffd362012-04-05 12:08:29 +000028endif
29
Paul Bakkerad7eca22010-03-24 06:46:47 +000030# MicroBlaze specific options:
31# CFLAGS += -mno-xl-soft-mul -mxl-barrel-shift
Paul Bakker5121ce52009-01-03 21:22:43 +000032
Paul Bakkerad7eca22010-03-24 06:46:47 +000033# To compile on Plan9:
34# CFLAGS += -D_BSD_EXTENSION
Paul Bakker5121ce52009-01-03 21:22:43 +000035
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000036# if were running on Windows build for Windows
37ifdef WINDOWS
38WINDOWS_BUILD=1
Andres Amaya Garciac471cd72018-06-13 09:28:04 +010039else ifeq ($(shell uname -s),Darwin)
Andres Amaya Garciae3402ce2018-06-20 10:43:21 +010040ifeq ($(AR),ar)
Andres Amaya Garcia1d937592018-06-13 10:04:58 +010041APPLE_BUILD ?= 1
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000042endif
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000043endif
44
Paul Bakkerad7eca22010-03-24 06:46:47 +000045# To compile as a shared library:
Paul Bakker9a736322012-11-14 12:39:52 +000046ifdef SHARED
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000047# all code is position-indep with mingw, avoid warning about useless flag
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000048ifndef WINDOWS_BUILD
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020049LOCAL_CFLAGS += -fPIC -fpic
Paul Bakker9a736322012-11-14 12:39:52 +000050endif
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000051endif
Paul Bakker5121ce52009-01-03 21:22:43 +000052
Simon Butcher4d075cd2018-08-31 15:59:10 +010053SOEXT_TLS=so.12
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +020054SOEXT_X509=so.0
Simon Butcher2fcd3e42018-06-18 14:39:06 +010055SOEXT_CRYPTO=so.3
Paul Bakker33aac372011-08-13 11:47:41 +000056
Antonin Décimod5f47592019-01-23 15:24:37 +010057# Set AR_DASH= (empty string) to use an ar implementation that does not accept
Andres Amaya Garciaceed91b2018-03-25 23:48:39 +010058# the - prefix for command line options (e.g. llvm-ar)
59AR_DASH ?= -
Paul Bakker5121ce52009-01-03 21:22:43 +000060
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010061ARFLAGS = $(AR_DASH)src
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010062ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010063ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010064ARFLAGS = $(AR_DASH)Src
65RLFLAGS = -no_warning_for_no_symbols -c
66RL ?= ranlib
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010067endif
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010068endif
69
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010070DLEXT ?= so
Alon Bar-Lev18ba0cc2015-02-14 01:04:58 +020071ifdef WINDOWS_BUILD
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010072# Windows shared library extension:
73DLEXT = dll
74else ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010075ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010076# Mac OS X shared library extension:
77DLEXT = dylib
Paul Bakkercd5b5292012-05-10 20:49:10 +000078endif
Paul Bakker6083fd22011-12-03 21:45:14 +000079endif
Paul Bakkerbdb912d2012-02-13 23:11:30 +000080
Jarno Lamsa337dad92019-04-25 11:00:41 +030081VPATH = ../tinycrypt
82
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020083OBJS_CRYPTO= aes.o aesni.o arc4.o \
Manuel Pégourié-Gonnard39b19042018-06-07 12:01:33 +020084 aria.o asn1parse.o asn1write.o \
85 base64.o bignum.o blowfish.o \
86 camellia.o ccm.o chacha20.o \
87 chachapoly.o cipher.o cipher_wrap.o \
Brian Murray8262ac32016-05-17 10:17:31 -070088 cmac.o ctr_drbg.o des.o \
89 dhm.o ecdh.o ecdsa.o \
90 ecjpake.o ecp.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020091 ecp_curves.o entropy.o entropy_poll.o \
92 error.o gcm.o havege.o \
Thomas Fossati656864b2016-07-17 08:51:22 +010093 hkdf.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020094 hmac_drbg.o md.o md2.o \
Hanno Becker0e7fc312019-07-17 11:23:12 +010095 md4.o md5.o \
Ron Eldorcb349ac2018-07-15 09:29:47 +030096 memory_buffer_alloc.o nist_kw.o \
97 oid.o padlock.o pem.o \
Manuel Pégourié-Gonnard4ed179f2019-09-19 10:45:14 +020098 pk.o pkcs12.o \
Ron Eldorcb349ac2018-07-15 09:29:47 +030099 pkcs5.o pkparse.o pkwrite.o \
100 platform.o platform_util.o poly1305.o \
Daniel Kingadc32c02016-05-16 18:25:45 -0300101 ripemd160.o rsa_internal.o rsa.o \
102 sha1.o sha256.o sha512.o \
103 threading.o timing.o version.o \
Jarno Lamsa337dad92019-04-25 11:00:41 +0300104 version_features.o xtea.o \
105 ecc.o ecc_dh.o ecc_dsa.o
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200106
107OBJS_X509= certs.o pkcs11.o x509.o \
108 x509_create.o x509_crl.o x509_crt.o \
109 x509_csr.o x509write_crt.o x509write_csr.o
110
Andres AG788aa4a2016-09-14 14:32:09 +0100111OBJS_TLS= debug.o net_sockets.o \
112 ssl_cache.o ssl_ciphersuites.o \
113 ssl_cli.o ssl_cookie.o \
114 ssl_srv.o ssl_ticket.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200115 ssl_tls.o
116
Paul Bakkerad7eca22010-03-24 06:46:47 +0000117.SILENT:
Paul Bakker5121ce52009-01-03 21:22:43 +0000118
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200119.PHONY: all static shared clean
120
Paul Bakker9a736322012-11-14 12:39:52 +0000121ifndef SHARED
Paul Bakker3783d6d2011-07-13 11:25:36 +0000122all: static
Paul Bakker9a736322012-11-14 12:39:52 +0000123else
Manuel Pégourié-Gonnard04a81d52015-01-27 11:24:05 +0100124all: shared static
Paul Bakker9a736322012-11-14 12:39:52 +0000125endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000126
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200127static: libmbedcrypto.a libmbedx509.a libmbedtls.a
Paul Bakker5121ce52009-01-03 21:22:43 +0000128
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200129shared: libmbedcrypto.$(DLEXT) libmbedx509.$(DLEXT) libmbedtls.$(DLEXT)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000130
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200131# tls
132libmbedtls.a: $(OBJS_TLS)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000133 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100134 $(AR) $(ARFLAGS) $@ $(OBJS_TLS)
135ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100136ifneq ($(APPLE_BUILD),0)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000137 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100138 $(RL) $(RLFLAGS) $@
139endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100140endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000141
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200142libmbedtls.$(SOEXT_TLS): $(OBJS_TLS) libmbedx509.so
Paul Bakkerad7eca22010-03-24 06:46:47 +0000143 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200144 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000145
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200146libmbedtls.so: libmbedtls.$(SOEXT_TLS)
147 echo " LN $@ -> $<"
148 ln -sf $< $@
Paul Bakkerb0763142013-11-05 11:27:12 +0100149
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900150libmbedtls.dylib: $(OBJS_TLS) libmbedx509.dylib
Paul Bakkerad7eca22010-03-24 06:46:47 +0000151 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900152 $(CC) -dynamiclib -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000153
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200154libmbedtls.dll: $(OBJS_TLS) libmbedx509.dll
Paul Bakkerb0763142013-11-05 11:27:12 +0100155 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200156 $(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_TLS) -lws2_32 -lwinmm -lgdi32 -L. -lmbedcrypto -lmbedx509 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200157
158# x509
159libmbedx509.a: $(OBJS_X509)
160 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100161 $(AR) $(ARFLAGS) $@ $(OBJS_X509)
162ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100163ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200164 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100165 $(RL) $(RLFLAGS) $@
166endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100167endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200168
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200169libmbedx509.$(SOEXT_X509): $(OBJS_X509) libmbedcrypto.so
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200170 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200171 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200172
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200173libmbedx509.so: libmbedx509.$(SOEXT_X509)
174 echo " LN $@ -> $<"
175 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200176
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900177libmbedx509.dylib: $(OBJS_X509) libmbedcrypto.dylib
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200178 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900179 $(CC) -dynamiclib -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200180
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200181libmbedx509.dll: $(OBJS_X509) libmbedcrypto.dll
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200182 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200183 $(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_X509) -lws2_32 -lwinmm -lgdi32 -L. -lmbedcrypto -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200184
185# crypto
186libmbedcrypto.a: $(OBJS_CRYPTO)
187 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100188 $(AR) $(ARFLAGS) $@ $(OBJS_CRYPTO)
189ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100190ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200191 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100192 $(RL) $(RLFLAGS) $@
193endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100194endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200195
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200196libmbedcrypto.$(SOEXT_CRYPTO): $(OBJS_CRYPTO)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200197 echo " LD $@"
Manuel Pégourié-Gonnard574ae182015-06-25 14:30:22 +0200198 $(CC) -shared -Wl,-soname,$@ $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200199
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200200libmbedcrypto.so: libmbedcrypto.$(SOEXT_CRYPTO)
201 echo " LN $@ -> $<"
202 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200203
204libmbedcrypto.dylib: $(OBJS_CRYPTO)
205 echo " LD $@"
206 $(CC) -dynamiclib $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
207
208libmbedcrypto.dll: $(OBJS_CRYPTO)
209 echo " LD $@"
Manuel Pégourié-Gonnard8018c282015-08-07 11:55:56 +0200210 $(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_CRYPTO) -lws2_32 -lwinmm -lgdi32 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
Paul Bakkera585beb2011-06-21 08:59:44 +0000211
Paul Bakkerad7eca22010-03-24 06:46:47 +0000212.c.o:
Paul Bakker96d42da2012-04-05 13:22:07 +0000213 echo " CC $<"
Alon Bar-Levf7a9f302015-02-18 17:55:05 +0200214 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -c $<
Paul Bakker5121ce52009-01-03 21:22:43 +0000215
216clean:
Paul Bakker62f88dc2012-05-10 21:26:28 +0000217ifndef WINDOWS
Manuel Pégourié-Gonnard80eaddf2019-07-30 14:59:54 +0200218 rm -f *.o *.su libmbed*
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200219else
Manuel Pégourié-Gonnard80eaddf2019-07-30 14:59:54 +0200220 del /Q /F *.o *.su libmbed*
Paul Bakker62f88dc2012-05-10 21:26:28 +0000221endif