blob: 3058a31c965fb575042bbccabe754e06a86c9b30 [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
Jaeden Ameroc6e4ab02018-11-01 16:56:08 +00008CRYPTO_INCLUDES ?= -I../include
9LOCAL_CFLAGS = $(WARNING_CFLAGS) $(CRYPTO_INCLUDES) -D_FILE_OFFSET_BITS=64
Alon Bar-Levada41052015-02-18 17:47:52 +020010LOCAL_LDFLAGS =
Paul Bakker5121ce52009-01-03 21:22:43 +000011
Paul Bakkerc7ffd362012-04-05 12:08:29 +000012ifdef DEBUG
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020013LOCAL_CFLAGS += -g3
Paul Bakkerc7ffd362012-04-05 12:08:29 +000014endif
15
Paul Bakkerad7eca22010-03-24 06:46:47 +000016# MicroBlaze specific options:
17# CFLAGS += -mno-xl-soft-mul -mxl-barrel-shift
Paul Bakker5121ce52009-01-03 21:22:43 +000018
Paul Bakkerad7eca22010-03-24 06:46:47 +000019# To compile on Plan9:
20# CFLAGS += -D_BSD_EXTENSION
Paul Bakker5121ce52009-01-03 21:22:43 +000021
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000022# if were running on Windows build for Windows
23ifdef WINDOWS
24WINDOWS_BUILD=1
Andres Amaya Garciac471cd72018-06-13 09:28:04 +010025else ifeq ($(shell uname -s),Darwin)
Andres Amaya Garciae3402ce2018-06-20 10:43:21 +010026ifeq ($(AR),ar)
Andres Amaya Garcia1d937592018-06-13 10:04:58 +010027APPLE_BUILD ?= 1
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000028endif
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000029endif
30
Paul Bakkerad7eca22010-03-24 06:46:47 +000031# To compile as a shared library:
Paul Bakker9a736322012-11-14 12:39:52 +000032ifdef SHARED
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000033# all code is position-indep with mingw, avoid warning about useless flag
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000034ifndef WINDOWS_BUILD
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020035LOCAL_CFLAGS += -fPIC -fpic
Paul Bakker9a736322012-11-14 12:39:52 +000036endif
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000037endif
Paul Bakker5121ce52009-01-03 21:22:43 +000038
Simon Butcher4d075cd2018-08-31 15:59:10 +010039SOEXT_TLS=so.12
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +020040SOEXT_X509=so.0
Simon Butcher2fcd3e42018-06-18 14:39:06 +010041SOEXT_CRYPTO=so.3
Paul Bakker33aac372011-08-13 11:47:41 +000042
Antonin Décimo36e89b52019-01-23 15:24:37 +010043# Set AR_DASH= (empty string) to use an ar implementation that does not accept
Andres Amaya Garciaceed91b2018-03-25 23:48:39 +010044# the - prefix for command line options (e.g. llvm-ar)
45AR_DASH ?= -
Paul Bakker5121ce52009-01-03 21:22:43 +000046
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010047ARFLAGS = $(AR_DASH)src
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010048ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010049ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010050ARFLAGS = $(AR_DASH)Src
51RLFLAGS = -no_warning_for_no_symbols -c
52RL ?= ranlib
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010053endif
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010054endif
55
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010056DLEXT ?= so
Alon Bar-Lev18ba0cc2015-02-14 01:04:58 +020057ifdef WINDOWS_BUILD
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010058# Windows shared library extension:
59DLEXT = dll
60else ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010061ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010062# Mac OS X shared library extension:
63DLEXT = dylib
Paul Bakkercd5b5292012-05-10 20:49:10 +000064endif
Paul Bakker6083fd22011-12-03 21:45:14 +000065endif
Paul Bakkerbdb912d2012-02-13 23:11:30 +000066
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020067OBJS_CRYPTO= aes.o aesni.o arc4.o \
Manuel Pégourié-Gonnard39b19042018-06-07 12:01:33 +020068 aria.o asn1parse.o asn1write.o \
69 base64.o bignum.o blowfish.o \
70 camellia.o ccm.o chacha20.o \
71 chachapoly.o cipher.o cipher_wrap.o \
Brian Murray8262ac32016-05-17 10:17:31 -070072 cmac.o ctr_drbg.o des.o \
73 dhm.o ecdh.o ecdsa.o \
74 ecjpake.o ecp.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020075 ecp_curves.o entropy.o entropy_poll.o \
Jaeden Amero92da0bd2019-04-26 11:59:31 +010076 gcm.o havege.o \
Thomas Fossati656864b2016-07-17 08:51:22 +010077 hkdf.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020078 hmac_drbg.o md.o md2.o \
79 md4.o md5.o md_wrap.o \
Ron Eldorcb349ac2018-07-15 09:29:47 +030080 memory_buffer_alloc.o nist_kw.o \
81 oid.o padlock.o pem.o \
82 pk.o pk_wrap.o pkcs12.o \
83 pkcs5.o pkparse.o pkwrite.o \
84 platform.o platform_util.o poly1305.o \
Gilles Peskinee59236f2018-01-27 23:32:46 +010085 psa_crypto.o \
Gilles Peskine961849f2018-11-30 18:54:54 +010086 psa_crypto_slot_management.o \
Darryl Greendb2b8db2018-06-15 13:06:04 +010087 psa_crypto_storage.o \
Gilles Peskine6194dc22018-11-16 22:24:15 +010088 psa_its_file.o \
Daniel Kingadc32c02016-05-16 18:25:45 -030089 ripemd160.o rsa_internal.o rsa.o \
90 sha1.o sha256.o sha512.o \
Jaeden Amero92da0bd2019-04-26 11:59:31 +010091 threading.o timing.o \
92 xtea.o
93
94# For files generated by the parent project (Mbed TLS) when building Mbed
95# Crypto as a submodule, ensure that the parent project instance is used.
96ifeq ($(USE_CRYPTO_SUBMODULE), 1)
97OBJS_CRYPTO += ../../library/error.o
98OBJS_CRYPTO += ../../library/version.o
99OBJS_CRYPTO += ../../library/version_features.o
100else
101OBJS_CRYPTO += error.o
102OBJS_CRYPTO += version.o
103OBJS_CRYPTO += version_features.o
104endif
105
106$(info $(OBJS_CRYPTO))
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200107
108OBJS_X509= certs.o pkcs11.o x509.o \
109 x509_create.o x509_crl.o x509_crt.o \
110 x509_csr.o x509write_crt.o x509write_csr.o
111
Andres AG788aa4a2016-09-14 14:32:09 +0100112OBJS_TLS= debug.o net_sockets.o \
113 ssl_cache.o ssl_ciphersuites.o \
114 ssl_cli.o ssl_cookie.o \
115 ssl_srv.o ssl_ticket.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200116 ssl_tls.o
117
Paul Bakkerad7eca22010-03-24 06:46:47 +0000118.SILENT:
Paul Bakker5121ce52009-01-03 21:22:43 +0000119
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200120.PHONY: all static shared clean
121
Paul Bakker9a736322012-11-14 12:39:52 +0000122ifndef SHARED
Paul Bakker3783d6d2011-07-13 11:25:36 +0000123all: static
Paul Bakker9a736322012-11-14 12:39:52 +0000124else
Manuel Pégourié-Gonnard04a81d52015-01-27 11:24:05 +0100125all: shared static
Paul Bakker9a736322012-11-14 12:39:52 +0000126endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000127
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200128static: libmbedcrypto.a libmbedx509.a libmbedtls.a
Paul Bakker5121ce52009-01-03 21:22:43 +0000129
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200130shared: libmbedcrypto.$(DLEXT) libmbedx509.$(DLEXT) libmbedtls.$(DLEXT)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000131
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200132# tls
133libmbedtls.a: $(OBJS_TLS)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000134 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100135 $(AR) $(ARFLAGS) $@ $(OBJS_TLS)
136ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100137ifneq ($(APPLE_BUILD),0)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000138 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100139 $(RL) $(RLFLAGS) $@
140endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100141endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000142
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200143libmbedtls.$(SOEXT_TLS): $(OBJS_TLS) libmbedx509.so
Paul Bakkerad7eca22010-03-24 06:46:47 +0000144 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200145 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000146
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200147libmbedtls.so: libmbedtls.$(SOEXT_TLS)
148 echo " LN $@ -> $<"
149 ln -sf $< $@
Paul Bakkerb0763142013-11-05 11:27:12 +0100150
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900151libmbedtls.dylib: $(OBJS_TLS) libmbedx509.dylib
Paul Bakkerad7eca22010-03-24 06:46:47 +0000152 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900153 $(CC) -dynamiclib -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000154
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200155libmbedtls.dll: $(OBJS_TLS) libmbedx509.dll
Paul Bakkerb0763142013-11-05 11:27:12 +0100156 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200157 $(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 +0200158
159# x509
160libmbedx509.a: $(OBJS_X509)
161 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100162 $(AR) $(ARFLAGS) $@ $(OBJS_X509)
163ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100164ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200165 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100166 $(RL) $(RLFLAGS) $@
167endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100168endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200169
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200170libmbedx509.$(SOEXT_X509): $(OBJS_X509) libmbedcrypto.so
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200171 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200172 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200173
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200174libmbedx509.so: libmbedx509.$(SOEXT_X509)
175 echo " LN $@ -> $<"
176 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200177
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900178libmbedx509.dylib: $(OBJS_X509) libmbedcrypto.dylib
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200179 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900180 $(CC) -dynamiclib -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200181
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200182libmbedx509.dll: $(OBJS_X509) libmbedcrypto.dll
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200183 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200184 $(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 +0200185
186# crypto
187libmbedcrypto.a: $(OBJS_CRYPTO)
188 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100189 $(AR) $(ARFLAGS) $@ $(OBJS_CRYPTO)
190ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100191ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200192 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100193 $(RL) $(RLFLAGS) $@
194endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100195endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200196
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200197libmbedcrypto.$(SOEXT_CRYPTO): $(OBJS_CRYPTO)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200198 echo " LD $@"
Manuel Pégourié-Gonnard574ae182015-06-25 14:30:22 +0200199 $(CC) -shared -Wl,-soname,$@ $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200200
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200201libmbedcrypto.so: libmbedcrypto.$(SOEXT_CRYPTO)
202 echo " LN $@ -> $<"
203 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200204
205libmbedcrypto.dylib: $(OBJS_CRYPTO)
206 echo " LD $@"
207 $(CC) -dynamiclib $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
208
209libmbedcrypto.dll: $(OBJS_CRYPTO)
210 echo " LD $@"
Manuel Pégourié-Gonnard8018c282015-08-07 11:55:56 +0200211 $(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 +0000212
Paul Bakkerad7eca22010-03-24 06:46:47 +0000213.c.o:
Paul Bakker96d42da2012-04-05 13:22:07 +0000214 echo " CC $<"
Jaeden Amero8df5de42019-04-26 12:24:48 +0100215 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -c $< -o $@
Paul Bakker5121ce52009-01-03 21:22:43 +0000216
217clean:
Paul Bakker62f88dc2012-05-10 21:26:28 +0000218ifndef WINDOWS
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200219 rm -f *.o libmbed*
220else
Darryl Green6c0f94c2018-10-17 16:12:33 +0100221 if exist *.o del /Q /F *.o
222 if exist libmbed* del /Q /F libmbed*
Paul Bakker62f88dc2012-05-10 21:26:28 +0000223endif