blob: 06bd09a980f21a9ba04cb258cc965954212170d0 [file] [log] [blame]
Paul Bakker5121ce52009-01-03 21:22:43 +00001
Bence Szépkútibb0cfeb2021-05-28 09:42:25 +02002# Also see "include/mbedtls/mbedtls_config.h"
Paul Bakker5121ce52009-01-03 21:22:43 +00003
Alon Bar-Levf7a9f302015-02-18 17:55:05 +02004CFLAGS ?= -O2
Paul Elliott9e3256a2020-12-17 18:17:32 +00005WARNING_CFLAGS ?= -Wall -Wextra -Wformat=2 -Wno-format-nonliteral
Alon Bar-Levada41052015-02-18 17:47:52 +02006LDFLAGS ?=
Alon Bar-Levf7a9f302015-02-18 17:55:05 +02007
Gilles Peskine76dd3aa2020-07-02 15:58:37 +02008# Include ../include for public headers and . for private headers.
9# Note that . needs to be included explicitly for the sake of library
10# files that are not in the /library directory (which currently means
11# under /3rdparty).
Gilles Peskine66c3dc42020-06-03 02:25:17 +020012LOCAL_CFLAGS = $(WARNING_CFLAGS) -I. -I../include -D_FILE_OFFSET_BITS=64
Alon Bar-Levada41052015-02-18 17:47:52 +020013LOCAL_LDFLAGS =
Paul Bakker5121ce52009-01-03 21:22:43 +000014
Paul Bakkerc7ffd362012-04-05 12:08:29 +000015ifdef DEBUG
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020016LOCAL_CFLAGS += -g3
Paul Bakkerc7ffd362012-04-05 12:08:29 +000017endif
18
Paul Bakkerad7eca22010-03-24 06:46:47 +000019# MicroBlaze specific options:
20# CFLAGS += -mno-xl-soft-mul -mxl-barrel-shift
Paul Bakker5121ce52009-01-03 21:22:43 +000021
Paul Bakkerad7eca22010-03-24 06:46:47 +000022# To compile on Plan9:
23# CFLAGS += -D_BSD_EXTENSION
Paul Bakker5121ce52009-01-03 21:22:43 +000024
Gilles Peskine687d1ab2021-04-22 01:01:56 +020025PERL ?= perl
26
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000027# if were running on Windows build for Windows
28ifdef WINDOWS
29WINDOWS_BUILD=1
Andres Amaya Garciac471cd72018-06-13 09:28:04 +010030else ifeq ($(shell uname -s),Darwin)
Andres Amaya Garciae3402ce2018-06-20 10:43:21 +010031ifeq ($(AR),ar)
Andres Amaya Garcia1d937592018-06-13 10:04:58 +010032APPLE_BUILD ?= 1
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000033endif
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000034endif
35
Paul Bakkerad7eca22010-03-24 06:46:47 +000036# To compile as a shared library:
Paul Bakker9a736322012-11-14 12:39:52 +000037ifdef SHARED
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000038# all code is position-indep with mingw, avoid warning about useless flag
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000039ifndef WINDOWS_BUILD
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020040LOCAL_CFLAGS += -fPIC -fpic
Paul Bakker9a736322012-11-14 12:39:52 +000041endif
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000042endif
Paul Bakker5121ce52009-01-03 21:22:43 +000043
Dave Rodgman76016572021-06-30 23:08:08 +010044SOEXT_TLS=so.14
45SOEXT_X509=so.2
46SOEXT_CRYPTO=so.7
Paul Bakker33aac372011-08-13 11:47:41 +000047
Antonin Décimo36e89b52019-01-23 15:24:37 +010048# Set AR_DASH= (empty string) to use an ar implementation that does not accept
Andres Amaya Garciaceed91b2018-03-25 23:48:39 +010049# the - prefix for command line options (e.g. llvm-ar)
50AR_DASH ?= -
Paul Bakker5121ce52009-01-03 21:22:43 +000051
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010052ARFLAGS = $(AR_DASH)src
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010053ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010054ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010055ARFLAGS = $(AR_DASH)Src
56RLFLAGS = -no_warning_for_no_symbols -c
57RL ?= ranlib
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010058endif
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010059endif
60
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010061DLEXT ?= so
Alon Bar-Lev18ba0cc2015-02-14 01:04:58 +020062ifdef WINDOWS_BUILD
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010063# Windows shared library extension:
64DLEXT = dll
65else ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010066ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010067# Mac OS X shared library extension:
68DLEXT = dylib
Paul Bakkercd5b5292012-05-10 20:49:10 +000069endif
Paul Bakker6083fd22011-12-03 21:45:14 +000070endif
Paul Bakkerbdb912d2012-02-13 23:11:30 +000071
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +020072OBJS_CRYPTO= \
73 aes.o \
74 aesni.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +020075 aria.o \
76 asn1parse.o \
77 asn1write.o \
78 base64.o \
79 bignum.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +020080 camellia.o \
81 ccm.o \
82 chacha20.o \
83 chachapoly.o \
84 cipher.o \
85 cipher_wrap.o \
86 cmac.o \
87 ctr_drbg.o \
88 des.o \
89 dhm.o \
90 ecdh.o \
91 ecdsa.o \
92 ecjpake.o \
93 ecp.o \
94 ecp_curves.o \
95 entropy.o \
96 entropy_poll.o \
97 error.o \
98 gcm.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +020099 hkdf.o \
100 hmac_drbg.o \
101 md.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200102 md5.o \
103 memory_buffer_alloc.o \
Hanno Becker53314aa2021-02-22 15:03:37 +0000104 mps_reader.o \
105 mps_trace.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200106 nist_kw.o \
107 oid.o \
108 padlock.o \
109 pem.o \
110 pk.o \
111 pk_wrap.o \
112 pkcs12.o \
113 pkcs5.o \
114 pkparse.o \
115 pkwrite.o \
116 platform.o \
117 platform_util.o \
118 poly1305.o \
119 psa_crypto.o \
Ronald Cron7ceee8d2021-03-17 16:55:43 +0100120 psa_crypto_aead.o \
Ronald Cron0ff57952021-03-08 16:46:35 +0100121 psa_crypto_cipher.o \
Ronald Crond7906322021-01-28 16:07:56 +0100122 psa_crypto_client.o \
Steven Cooremancd84cb42020-07-16 20:28:36 +0200123 psa_crypto_driver_wrappers.o \
Ronald Cron00b7bfc2020-11-25 15:25:26 +0100124 psa_crypto_ecp.o \
Steven Cooreman0e307642021-02-18 16:18:32 +0100125 psa_crypto_hash.o \
Steven Cooremand13a70f2021-03-19 15:24:23 +0100126 psa_crypto_mac.o \
Ronald Cron00b7bfc2020-11-25 15:25:26 +0100127 psa_crypto_rsa.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200128 psa_crypto_se.o \
129 psa_crypto_slot_management.o \
130 psa_crypto_storage.o \
131 psa_its_file.o \
132 ripemd160.o \
133 rsa.o \
Chris Jones66a4cd42021-03-09 16:04:12 +0000134 rsa_alt_helpers.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200135 sha1.o \
136 sha256.o \
137 sha512.o \
138 threading.o \
139 timing.o \
140 version.o \
141 version_features.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200142 # This line is intentionally left blank
Jaeden Amero30b340a2018-10-25 17:37:00 +0100143
Christoph M. Wintersteiger62dddd02018-12-14 13:07:50 +0000144include ../3rdparty/Makefile.inc
145LOCAL_CFLAGS+=$(THIRDPARTY_INCLUDES)
Christoph M. Wintersteiger2d4725f2019-02-15 13:35:04 +0000146OBJS_CRYPTO+=$(THIRDPARTY_CRYPTO_OBJECTS)
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200147
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200148OBJS_X509= \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200149 x509.o \
150 x509_create.o \
151 x509_crl.o \
152 x509_crt.o \
153 x509_csr.o \
154 x509write_crt.o \
155 x509write_csr.o \
156 # This line is intentionally left blank
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200157
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200158OBJS_TLS= \
159 debug.o \
160 net_sockets.o \
161 ssl_cache.o \
162 ssl_ciphersuites.o \
163 ssl_cli.o \
164 ssl_cookie.o \
165 ssl_msg.o \
166 ssl_srv.o \
167 ssl_ticket.o \
168 ssl_tls.o \
Hanno Beckerbe9d6642020-08-21 13:20:06 +0100169 ssl_tls13_keys.o \
Manuel Pégourié-Gonnard10a5b532020-04-03 11:50:59 +0200170 # This line is intentionally left blank
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200171
Paul Bakkerad7eca22010-03-24 06:46:47 +0000172.SILENT:
Paul Bakker5121ce52009-01-03 21:22:43 +0000173
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200174.PHONY: all static shared clean
175
Paul Bakker9a736322012-11-14 12:39:52 +0000176ifndef SHARED
Paul Bakker3783d6d2011-07-13 11:25:36 +0000177all: static
Paul Bakker9a736322012-11-14 12:39:52 +0000178else
Manuel Pégourié-Gonnard04a81d52015-01-27 11:24:05 +0100179all: shared static
Paul Bakker9a736322012-11-14 12:39:52 +0000180endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000181
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200182static: libmbedcrypto.a libmbedx509.a libmbedtls.a
Paul Bakker5121ce52009-01-03 21:22:43 +0000183
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200184shared: libmbedcrypto.$(DLEXT) libmbedx509.$(DLEXT) libmbedtls.$(DLEXT)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000185
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200186# tls
187libmbedtls.a: $(OBJS_TLS)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000188 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100189 $(AR) $(ARFLAGS) $@ $(OBJS_TLS)
190ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100191ifneq ($(APPLE_BUILD),0)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000192 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100193 $(RL) $(RLFLAGS) $@
194endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100195endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000196
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200197libmbedtls.$(SOEXT_TLS): $(OBJS_TLS) libmbedx509.so
Paul Bakkerad7eca22010-03-24 06:46:47 +0000198 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200199 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000200
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200201libmbedtls.so: libmbedtls.$(SOEXT_TLS)
202 echo " LN $@ -> $<"
203 ln -sf $< $@
Paul Bakkerb0763142013-11-05 11:27:12 +0100204
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900205libmbedtls.dylib: $(OBJS_TLS) libmbedx509.dylib
Paul Bakkerad7eca22010-03-24 06:46:47 +0000206 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900207 $(CC) -dynamiclib -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000208
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200209libmbedtls.dll: $(OBJS_TLS) libmbedx509.dll
Paul Bakkerb0763142013-11-05 11:27:12 +0100210 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200211 $(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 +0200212
213# x509
214libmbedx509.a: $(OBJS_X509)
215 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100216 $(AR) $(ARFLAGS) $@ $(OBJS_X509)
217ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100218ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200219 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100220 $(RL) $(RLFLAGS) $@
221endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100222endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200223
Gilles Peskine722a7e62020-02-26 19:05:19 +0100224libmbedx509.$(SOEXT_X509): $(OBJS_X509) libmbedcrypto.so
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200225 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200226 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200227
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200228libmbedx509.so: libmbedx509.$(SOEXT_X509)
229 echo " LN $@ -> $<"
230 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200231
Gilles Peskine722a7e62020-02-26 19:05:19 +0100232libmbedx509.dylib: $(OBJS_X509) libmbedcrypto.dylib
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200233 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900234 $(CC) -dynamiclib -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200235
Gilles Peskine722a7e62020-02-26 19:05:19 +0100236libmbedx509.dll: $(OBJS_X509) libmbedcrypto.dll
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200237 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200238 $(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 +0200239
240# crypto
241libmbedcrypto.a: $(OBJS_CRYPTO)
242 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100243 $(AR) $(ARFLAGS) $@ $(OBJS_CRYPTO)
244ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100245ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200246 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100247 $(RL) $(RLFLAGS) $@
248endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100249endif
Paul Bakkera585beb2011-06-21 08:59:44 +0000250
Paul Bakker5121ce52009-01-03 21:22:43 +0000251libmbedcrypto.$(SOEXT_CRYPTO): $(OBJS_CRYPTO)
Paul Bakker62f88dc2012-05-10 21:26:28 +0000252 echo " LD $@"
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000253 $(CC) -shared -Wl,-soname,$@ $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
Andrzej Kurek8af39232019-10-07 09:19:18 -0400254
Paul Bakker62f88dc2012-05-10 21:26:28 +0000255libmbedcrypto.so: libmbedcrypto.$(SOEXT_CRYPTO)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000256 echo " LN $@ -> $<"
Paul Bakker62f88dc2012-05-10 21:26:28 +0000257 ln -sf $< $@
Paul Bakker5121ce52009-01-03 21:22:43 +0000258
259libmbedcrypto.dylib: $(OBJS_CRYPTO)
260 echo " LD $@"
261 $(CC) -dynamiclib $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
262
263libmbedcrypto.dll: $(OBJS_CRYPTO)
264 echo " LD $@"
265 $(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_CRYPTO) -lws2_32 -lwinmm -lgdi32 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
266
Alon Bar-Levf7a9f302015-02-18 17:55:05 +0200267.c.o:
Paul Bakker5121ce52009-01-03 21:22:43 +0000268 echo " CC $<"
Christoph M. Wintersteiger977d89a2018-10-25 12:47:03 +0100269 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
Paul Bakker5121ce52009-01-03 21:22:43 +0000270
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200271.PHONY: generated_files
272GENERATED_FILES = error.c version_features.c
273generated_files: $(GENERATED_FILES)
274
275error.c: ../scripts/generate_errors.pl
276error.c: ../scripts/data_files/error.fmt
Gilles Peskine1411c7c2021-04-22 14:50:16 +0200277error.c: $(filter-out %config%,$(wildcard ../include/mbedtls/*.h))
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200278error.c:
279 echo " Gen $@"
280 $(PERL) ../scripts/generate_errors.pl
281
282version_features.c: ../scripts/generate_features.pl
283version_features.c: ../scripts/data_files/version_features.fmt
Bence Szépkútibb0cfeb2021-05-28 09:42:25 +0200284## The generated file only depends on the options that are present in mbedtls_config.h,
Gilles Peskine1411c7c2021-04-22 14:50:16 +0200285## not on which options are set. To avoid regenerating this file all the time
Bence Szépkútibb0cfeb2021-05-28 09:42:25 +0200286## when switching between configurations, don't declare mbedtls_config.h as a
Gilles Peskine1411c7c2021-04-22 14:50:16 +0200287## dependency. Remove this file from your working tree if you've just added or
Bence Szépkútibb0cfeb2021-05-28 09:42:25 +0200288## removed an option in mbedtls_config.h.
289#version_features.c: ../include/mbedtls/mbedtls_config.h
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200290version_features.c:
291 echo " Gen $@"
292 $(PERL) ../scripts/generate_features.pl
293
Paul Bakker5121ce52009-01-03 21:22:43 +0000294clean:
295ifndef WINDOWS
Gilles Peskine55d53532020-03-09 17:48:13 +0100296 rm -f *.o libmbed*
Gilles Peskinea647f122020-03-10 10:36:19 +0100297 rm -f $(THIRDPARTY_CRYPTO_OBJECTS)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200298else
Darryl Green9b9a7902019-08-30 14:51:55 +0100299 if exist *.o del /Q /F *.o
300 if exist libmbed* del /Q /F libmbed*
Gilles Peskinea647f122020-03-10 10:36:19 +0100301 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 +0000302endif
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200303
304neat: clean
305ifndef WINDOWS
306 rm -f $(GENERATED_FILES)
307else
308 for %f in ($(subst /,\,$(GENERATED_FILES))) if exist %f del /Q /F %f
309endif