blob: f9cd468a5fc4ddb87a400af9bdeb2f1cbc857d0b [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
Gilles Peskine85aba472019-07-02 20:03:01 +02005WARNING_CFLAGS ?= -Wall -Wextra
Alon Bar-Levada41052015-02-18 17:47:52 +02006LDFLAGS ?=
Alon Bar-Levf7a9f302015-02-18 17:55:05 +02007
Gilles Peskine55d53532020-03-09 17:48:13 +01008LOCAL_CFLAGS = $(WARNING_CFLAGS) -I../include -D_FILE_OFFSET_BITS=64
Alon Bar-Levada41052015-02-18 17:47:52 +02009LOCAL_LDFLAGS =
Paul Bakker5121ce52009-01-03 21:22:43 +000010
Paul Bakkerc7ffd362012-04-05 12:08:29 +000011ifdef DEBUG
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020012LOCAL_CFLAGS += -g3
Paul Bakkerc7ffd362012-04-05 12:08:29 +000013endif
14
Paul Bakkerad7eca22010-03-24 06:46:47 +000015# MicroBlaze specific options:
16# CFLAGS += -mno-xl-soft-mul -mxl-barrel-shift
Paul Bakker5121ce52009-01-03 21:22:43 +000017
Paul Bakkerad7eca22010-03-24 06:46:47 +000018# To compile on Plan9:
19# CFLAGS += -D_BSD_EXTENSION
Paul Bakker5121ce52009-01-03 21:22:43 +000020
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000021# if were running on Windows build for Windows
22ifdef WINDOWS
23WINDOWS_BUILD=1
Andres Amaya Garciac471cd72018-06-13 09:28:04 +010024else ifeq ($(shell uname -s),Darwin)
Andres Amaya Garciae3402ce2018-06-20 10:43:21 +010025ifeq ($(AR),ar)
Andres Amaya Garcia1d937592018-06-13 10:04:58 +010026APPLE_BUILD ?= 1
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000027endif
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000028endif
29
Paul Bakkerad7eca22010-03-24 06:46:47 +000030# To compile as a shared library:
Paul Bakker9a736322012-11-14 12:39:52 +000031ifdef SHARED
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000032# all code is position-indep with mingw, avoid warning about useless flag
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000033ifndef WINDOWS_BUILD
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020034LOCAL_CFLAGS += -fPIC -fpic
Paul Bakker9a736322012-11-14 12:39:52 +000035endif
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000036endif
Paul Bakker5121ce52009-01-03 21:22:43 +000037
Gilles Peskined2e77b52020-03-10 14:25:34 +010038SOEXT_TLS=so.13
39SOEXT_X509=so.1
Janos Follath4c736fb2020-01-27 16:37:14 +000040SOEXT_CRYPTO=so.4
Paul Bakker33aac372011-08-13 11:47:41 +000041
Antonin Décimo36e89b52019-01-23 15:24:37 +010042# Set AR_DASH= (empty string) to use an ar implementation that does not accept
Andres Amaya Garciaceed91b2018-03-25 23:48:39 +010043# the - prefix for command line options (e.g. llvm-ar)
44AR_DASH ?= -
Paul Bakker5121ce52009-01-03 21:22:43 +000045
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010046ARFLAGS = $(AR_DASH)src
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010047ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010048ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010049ARFLAGS = $(AR_DASH)Src
50RLFLAGS = -no_warning_for_no_symbols -c
51RL ?= ranlib
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010052endif
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010053endif
54
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010055DLEXT ?= so
Alon Bar-Lev18ba0cc2015-02-14 01:04:58 +020056ifdef WINDOWS_BUILD
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010057# Windows shared library extension:
58DLEXT = dll
59else ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010060ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010061# Mac OS X shared library extension:
62DLEXT = dylib
Paul Bakkercd5b5292012-05-10 20:49:10 +000063endif
Paul Bakker6083fd22011-12-03 21:45:14 +000064endif
Paul Bakkerbdb912d2012-02-13 23:11:30 +000065
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020066OBJS_CRYPTO= aes.o aesni.o arc4.o \
Manuel Pégourié-Gonnard39b19042018-06-07 12:01:33 +020067 aria.o asn1parse.o asn1write.o \
68 base64.o bignum.o blowfish.o \
69 camellia.o ccm.o chacha20.o \
70 chachapoly.o cipher.o cipher_wrap.o \
Brian Murray8262ac32016-05-17 10:17:31 -070071 cmac.o ctr_drbg.o des.o \
72 dhm.o ecdh.o ecdsa.o \
73 ecjpake.o ecp.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020074 ecp_curves.o entropy.o entropy_poll.o \
Gilles Peskine55d53532020-03-09 17:48:13 +010075 error.o gcm.o havege.o \
Thomas Fossati656864b2016-07-17 08:51:22 +010076 hkdf.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020077 hmac_drbg.o md.o md2.o \
Gilles Peskine84867cf2019-07-19 15:46:03 +020078 md4.o md5.o \
Ron Eldorcb349ac2018-07-15 09:29:47 +030079 memory_buffer_alloc.o nist_kw.o \
80 oid.o padlock.o pem.o \
81 pk.o pk_wrap.o pkcs12.o \
82 pkcs5.o pkparse.o pkwrite.o \
83 platform.o platform_util.o poly1305.o \
Gilles Peskinea899a722019-06-24 14:06:43 +020084 psa_crypto.o psa_crypto_se.o \
Gilles Peskine961849f2018-11-30 18:54:54 +010085 psa_crypto_slot_management.o \
Darryl Greendb2b8db2018-06-15 13:06:04 +010086 psa_crypto_storage.o \
Gilles Peskine6194dc22018-11-16 22:24:15 +010087 psa_its_file.o \
Daniel Kingadc32c02016-05-16 18:25:45 -030088 ripemd160.o rsa_internal.o rsa.o \
89 sha1.o sha256.o sha512.o \
Jaeden Amero92da0bd2019-04-26 11:59:31 +010090 threading.o timing.o \
Gilles Peskine55d53532020-03-09 17:48:13 +010091 version.o version_features.o \
Jaeden Amero92da0bd2019-04-26 11:59:31 +010092 xtea.o
Jaeden Amero30b340a2018-10-25 17:37:00 +010093
Christoph M. Wintersteiger62dddd02018-12-14 13:07:50 +000094include ../3rdparty/Makefile.inc
95LOCAL_CFLAGS+=$(THIRDPARTY_INCLUDES)
Christoph M. Wintersteiger2d4725f2019-02-15 13:35:04 +000096OBJS_CRYPTO+=$(THIRDPARTY_CRYPTO_OBJECTS)
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020097
98OBJS_X509= certs.o pkcs11.o x509.o \
99 x509_create.o x509_crl.o x509_crt.o \
100 x509_csr.o x509write_crt.o x509write_csr.o
101
Andres AG788aa4a2016-09-14 14:32:09 +0100102OBJS_TLS= debug.o net_sockets.o \
103 ssl_cache.o ssl_ciphersuites.o \
104 ssl_cli.o ssl_cookie.o \
Hanno Becker6e7051a2020-02-05 11:33:54 +0000105 ssl_msg.o \
Andres AG788aa4a2016-09-14 14:32:09 +0100106 ssl_srv.o ssl_ticket.o \
Hanno Becker471c0c92020-02-05 11:32:03 +0000107 ssl_tls.o
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200108
Paul Bakkerad7eca22010-03-24 06:46:47 +0000109.SILENT:
Paul Bakker5121ce52009-01-03 21:22:43 +0000110
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200111.PHONY: all static shared clean
112
Paul Bakker9a736322012-11-14 12:39:52 +0000113ifndef SHARED
Paul Bakker3783d6d2011-07-13 11:25:36 +0000114all: static
Paul Bakker9a736322012-11-14 12:39:52 +0000115else
Manuel Pégourié-Gonnard04a81d52015-01-27 11:24:05 +0100116all: shared static
Paul Bakker9a736322012-11-14 12:39:52 +0000117endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000118
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200119static: libmbedcrypto.a libmbedx509.a libmbedtls.a
Paul Bakker5121ce52009-01-03 21:22:43 +0000120
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200121shared: libmbedcrypto.$(DLEXT) libmbedx509.$(DLEXT) libmbedtls.$(DLEXT)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000122
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200123# tls
124libmbedtls.a: $(OBJS_TLS)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000125 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100126 $(AR) $(ARFLAGS) $@ $(OBJS_TLS)
127ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100128ifneq ($(APPLE_BUILD),0)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000129 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100130 $(RL) $(RLFLAGS) $@
131endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100132endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000133
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200134libmbedtls.$(SOEXT_TLS): $(OBJS_TLS) libmbedx509.so
Paul Bakkerad7eca22010-03-24 06:46:47 +0000135 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200136 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000137
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200138libmbedtls.so: libmbedtls.$(SOEXT_TLS)
139 echo " LN $@ -> $<"
140 ln -sf $< $@
Paul Bakkerb0763142013-11-05 11:27:12 +0100141
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900142libmbedtls.dylib: $(OBJS_TLS) libmbedx509.dylib
Paul Bakkerad7eca22010-03-24 06:46:47 +0000143 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900144 $(CC) -dynamiclib -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000145
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200146libmbedtls.dll: $(OBJS_TLS) libmbedx509.dll
Paul Bakkerb0763142013-11-05 11:27:12 +0100147 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200148 $(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 +0200149
150# x509
151libmbedx509.a: $(OBJS_X509)
152 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100153 $(AR) $(ARFLAGS) $@ $(OBJS_X509)
154ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100155ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200156 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100157 $(RL) $(RLFLAGS) $@
158endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100159endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200160
Gilles Peskine722a7e62020-02-26 19:05:19 +0100161libmbedx509.$(SOEXT_X509): $(OBJS_X509) libmbedcrypto.so
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200162 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200163 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200164
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200165libmbedx509.so: libmbedx509.$(SOEXT_X509)
166 echo " LN $@ -> $<"
167 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200168
Gilles Peskine722a7e62020-02-26 19:05:19 +0100169libmbedx509.dylib: $(OBJS_X509) libmbedcrypto.dylib
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200170 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900171 $(CC) -dynamiclib -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200172
Gilles Peskine722a7e62020-02-26 19:05:19 +0100173libmbedx509.dll: $(OBJS_X509) libmbedcrypto.dll
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200174 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200175 $(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 +0200176
177# crypto
178libmbedcrypto.a: $(OBJS_CRYPTO)
179 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100180 $(AR) $(ARFLAGS) $@ $(OBJS_CRYPTO)
181ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100182ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200183 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100184 $(RL) $(RLFLAGS) $@
185endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100186endif
Paul Bakkera585beb2011-06-21 08:59:44 +0000187
Paul Bakker5121ce52009-01-03 21:22:43 +0000188libmbedcrypto.$(SOEXT_CRYPTO): $(OBJS_CRYPTO)
Paul Bakker62f88dc2012-05-10 21:26:28 +0000189 echo " LD $@"
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000190 $(CC) -shared -Wl,-soname,$@ $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
Andrzej Kurek8af39232019-10-07 09:19:18 -0400191
Paul Bakker62f88dc2012-05-10 21:26:28 +0000192libmbedcrypto.so: libmbedcrypto.$(SOEXT_CRYPTO)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000193 echo " LN $@ -> $<"
Paul Bakker62f88dc2012-05-10 21:26:28 +0000194 ln -sf $< $@
Paul Bakker5121ce52009-01-03 21:22:43 +0000195
196libmbedcrypto.dylib: $(OBJS_CRYPTO)
197 echo " LD $@"
198 $(CC) -dynamiclib $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
199
200libmbedcrypto.dll: $(OBJS_CRYPTO)
201 echo " LD $@"
202 $(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_CRYPTO) -lws2_32 -lwinmm -lgdi32 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
203
Alon Bar-Levf7a9f302015-02-18 17:55:05 +0200204.c.o:
Paul Bakker5121ce52009-01-03 21:22:43 +0000205 echo " CC $<"
Christoph M. Wintersteiger977d89a2018-10-25 12:47:03 +0100206 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
Paul Bakker5121ce52009-01-03 21:22:43 +0000207
208clean:
209ifndef WINDOWS
Gilles Peskine55d53532020-03-09 17:48:13 +0100210 rm -f *.o libmbed*
Gilles Peskinea647f122020-03-10 10:36:19 +0100211 rm -f $(THIRDPARTY_CRYPTO_OBJECTS)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200212else
Darryl Green9b9a7902019-08-30 14:51:55 +0100213 if exist *.o del /Q /F *.o
214 if exist libmbed* del /Q /F libmbed*
Gilles Peskinea647f122020-03-10 10:36:19 +0100215 del /Q /F del_errors_out_if_the_file_list_is_empty_but_not_if_a_file_does_not_exist $(subst /,\,$(THIRDPARTY_CRYPTO_OBJECTS))
Paul Bakker5121ce52009-01-03 21:22:43 +0000216endif