blob: 38bb59a2b17dc23e52869aa61199fd3622d8821c [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
Manuel Pégourié-Gonnardd8167e82019-02-01 11:12:52 +01004# build crypto form submodule unless explicitly disabled
5USE_CRYPTO_SUBMODULE ?= 1
6
Alon Bar-Levf7a9f302015-02-18 17:55:05 +02007CFLAGS ?= -O2
8WARNING_CFLAGS ?= -Wall -W -Wdeclaration-after-statement
Alon Bar-Levada41052015-02-18 17:47:52 +02009LDFLAGS ?=
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020010
11LOCAL_CFLAGS = $(WARNING_CFLAGS) -I../include -D_FILE_OFFSET_BITS=64
Alon Bar-Levada41052015-02-18 17:47:52 +020012LOCAL_LDFLAGS =
Paul Bakker5121ce52009-01-03 21:22:43 +000013
Paul Bakkerc7ffd362012-04-05 12:08:29 +000014ifdef DEBUG
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020015LOCAL_CFLAGS += -g3
Paul Bakkerc7ffd362012-04-05 12:08:29 +000016endif
17
Paul Bakkerad7eca22010-03-24 06:46:47 +000018# MicroBlaze specific options:
19# CFLAGS += -mno-xl-soft-mul -mxl-barrel-shift
Paul Bakker5121ce52009-01-03 21:22:43 +000020
Paul Bakkerad7eca22010-03-24 06:46:47 +000021# To compile on Plan9:
22# CFLAGS += -D_BSD_EXTENSION
Paul Bakker5121ce52009-01-03 21:22:43 +000023
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000024# if were running on Windows build for Windows
25ifdef WINDOWS
26WINDOWS_BUILD=1
Andres Amaya Garciac471cd72018-06-13 09:28:04 +010027else ifeq ($(shell uname -s),Darwin)
Andres Amaya Garciae3402ce2018-06-20 10:43:21 +010028ifeq ($(AR),ar)
Andres Amaya Garcia1d937592018-06-13 10:04:58 +010029APPLE_BUILD ?= 1
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000030endif
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000031endif
32
Paul Bakkerad7eca22010-03-24 06:46:47 +000033# To compile as a shared library:
Paul Bakker9a736322012-11-14 12:39:52 +000034ifdef SHARED
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000035# all code is position-indep with mingw, avoid warning about useless flag
Manuel Pégourié-Gonnard02ba5782015-02-18 13:42:26 +000036ifndef WINDOWS_BUILD
Alon Bar-Levf7a9f302015-02-18 17:55:05 +020037LOCAL_CFLAGS += -fPIC -fpic
Paul Bakker9a736322012-11-14 12:39:52 +000038endif
Manuel Pégourié-Gonnard3cfb3452015-02-13 13:34:08 +000039endif
Paul Bakker5121ce52009-01-03 21:22:43 +000040
Simon Butcher4d075cd2018-08-31 15:59:10 +010041SOEXT_TLS=so.12
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +020042SOEXT_X509=so.0
Simon Butcher2fcd3e42018-06-18 14:39:06 +010043SOEXT_CRYPTO=so.3
Paul Bakker33aac372011-08-13 11:47:41 +000044
Antonin Décimo36e89b52019-01-23 15:24:37 +010045# Set AR_DASH= (empty string) to use an ar implementation that does not accept
Andres Amaya Garciaceed91b2018-03-25 23:48:39 +010046# the - prefix for command line options (e.g. llvm-ar)
47AR_DASH ?= -
Paul Bakker5121ce52009-01-03 21:22:43 +000048
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010049ARFLAGS = $(AR_DASH)src
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010050ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010051ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010052ARFLAGS = $(AR_DASH)Src
53RLFLAGS = -no_warning_for_no_symbols -c
54RL ?= ranlib
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010055endif
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010056endif
57
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010058DLEXT ?= so
Alon Bar-Lev18ba0cc2015-02-14 01:04:58 +020059ifdef WINDOWS_BUILD
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010060# Windows shared library extension:
61DLEXT = dll
62else ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +010063ifneq ($(APPLE_BUILD),0)
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +010064# Mac OS X shared library extension:
65DLEXT = dylib
Paul Bakkercd5b5292012-05-10 20:49:10 +000066endif
Paul Bakker6083fd22011-12-03 21:45:14 +000067endif
Paul Bakkerbdb912d2012-02-13 23:11:30 +000068
Jaeden Amero30b340a2018-10-25 17:37:00 +010069
Manuel Pégourié-Gonnardd8167e82019-02-01 11:12:52 +010070ifneq ($(USE_CRYPTO_SUBMODULE), 0)
Jaeden Amero30b340a2018-10-25 17:37:00 +010071# Look in crypto for libmbedcrypto.
72LOCAL_LDFLAGS += -L../crypto/library
73LOCAL_CFLAGS += -I../crypto/include
74CRYPTO := ../crypto/library/
75else
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020076OBJS_CRYPTO= aes.o aesni.o arc4.o \
Manuel Pégourié-Gonnard39b19042018-06-07 12:01:33 +020077 aria.o asn1parse.o asn1write.o \
78 base64.o bignum.o blowfish.o \
79 camellia.o ccm.o chacha20.o \
80 chachapoly.o cipher.o cipher_wrap.o \
Brian Murray8262ac32016-05-17 10:17:31 -070081 cmac.o ctr_drbg.o des.o \
82 dhm.o ecdh.o ecdsa.o \
83 ecjpake.o ecp.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020084 ecp_curves.o entropy.o entropy_poll.o \
85 error.o gcm.o havege.o \
Thomas Fossati656864b2016-07-17 08:51:22 +010086 hkdf.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020087 hmac_drbg.o md.o md2.o \
88 md4.o md5.o md_wrap.o \
Ron Eldorcb349ac2018-07-15 09:29:47 +030089 memory_buffer_alloc.o nist_kw.o \
90 oid.o padlock.o pem.o \
91 pk.o pk_wrap.o pkcs12.o \
92 pkcs5.o pkparse.o pkwrite.o \
93 platform.o platform_util.o poly1305.o \
Daniel Kingadc32c02016-05-16 18:25:45 -030094 ripemd160.o rsa_internal.o rsa.o \
95 sha1.o sha256.o sha512.o \
96 threading.o timing.o version.o \
97 version_features.o xtea.o
Jaeden Amero30b340a2018-10-25 17:37:00 +010098CRYPTO :=
99endif
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200100
101OBJS_X509= certs.o pkcs11.o x509.o \
102 x509_create.o x509_crl.o x509_crt.o \
103 x509_csr.o x509write_crt.o x509write_csr.o
104
Andres AG788aa4a2016-09-14 14:32:09 +0100105OBJS_TLS= debug.o net_sockets.o \
106 ssl_cache.o ssl_ciphersuites.o \
107 ssl_cli.o ssl_cookie.o \
108 ssl_srv.o ssl_ticket.o \
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200109 ssl_tls.o
110
Paul Bakkerad7eca22010-03-24 06:46:47 +0000111.SILENT:
Paul Bakker5121ce52009-01-03 21:22:43 +0000112
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200113.PHONY: all static shared clean
114
Paul Bakker9a736322012-11-14 12:39:52 +0000115ifndef SHARED
Paul Bakker3783d6d2011-07-13 11:25:36 +0000116all: static
Paul Bakker9a736322012-11-14 12:39:52 +0000117else
Manuel Pégourié-Gonnard04a81d52015-01-27 11:24:05 +0100118all: shared static
Paul Bakker9a736322012-11-14 12:39:52 +0000119endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000120
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200121static: libmbedcrypto.a libmbedx509.a libmbedtls.a
Paul Bakker5121ce52009-01-03 21:22:43 +0000122
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200123shared: libmbedcrypto.$(DLEXT) libmbedx509.$(DLEXT) libmbedtls.$(DLEXT)
Manuel Pégourié-Gonnardc26a0922015-01-23 12:51:33 +0000124
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200125# tls
126libmbedtls.a: $(OBJS_TLS)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000127 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100128 $(AR) $(ARFLAGS) $@ $(OBJS_TLS)
129ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100130ifneq ($(APPLE_BUILD),0)
Paul Bakkerad7eca22010-03-24 06:46:47 +0000131 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100132 $(RL) $(RLFLAGS) $@
133endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100134endif
Paul Bakker5121ce52009-01-03 21:22:43 +0000135
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200136libmbedtls.$(SOEXT_TLS): $(OBJS_TLS) libmbedx509.so
Paul Bakkerad7eca22010-03-24 06:46:47 +0000137 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200138 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000139
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200140libmbedtls.so: libmbedtls.$(SOEXT_TLS)
141 echo " LN $@ -> $<"
142 ln -sf $< $@
Paul Bakkerb0763142013-11-05 11:27:12 +0100143
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900144libmbedtls.dylib: $(OBJS_TLS) libmbedx509.dylib
Paul Bakkerad7eca22010-03-24 06:46:47 +0000145 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900146 $(CC) -dynamiclib -L. -lmbedcrypto -lmbedx509 $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_TLS)
Paul Bakker5121ce52009-01-03 21:22:43 +0000147
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200148libmbedtls.dll: $(OBJS_TLS) libmbedx509.dll
Paul Bakkerb0763142013-11-05 11:27:12 +0100149 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200150 $(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 +0200151
152# x509
153libmbedx509.a: $(OBJS_X509)
154 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100155 $(AR) $(ARFLAGS) $@ $(OBJS_X509)
156ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100157ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200158 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100159 $(RL) $(RLFLAGS) $@
160endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100161endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200162
Jaeden Amero30b340a2018-10-25 17:37:00 +0100163libmbedx509.$(SOEXT_X509): $(OBJS_X509) $(CRYPTO)libmbedcrypto.so
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200164 echo " LD $@"
Manuel Pégourié-Gonnarded46c432015-08-10 10:17:32 +0200165 $(CC) -shared -Wl,-soname,$@ -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200166
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200167libmbedx509.so: libmbedx509.$(SOEXT_X509)
168 echo " LN $@ -> $<"
169 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200170
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900171libmbedx509.dylib: $(OBJS_X509) libmbedcrypto.dylib
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200172 echo " LD $@"
Mitsuhiro Nakamura5ff2ee52018-02-20 11:58:19 +0900173 $(CC) -dynamiclib -L. -lmbedcrypto $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_X509)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200174
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200175libmbedx509.dll: $(OBJS_X509) libmbedcrypto.dll
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200176 echo " LD $@"
Manuel Pégourié-Gonnard111ce9f2015-08-07 12:07:16 +0200177 $(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 +0200178
179# crypto
Manuel Pégourié-Gonnardd8167e82019-02-01 11:12:52 +0100180ifneq ($(USE_CRYPTO_SUBMODULE), 0)
Jaeden Amero30b340a2018-10-25 17:37:00 +0100181libmbedcrypto.%:
182 $(MAKE) CRYPTO_INCLUDES:="-I../../include -I../include" -C ../crypto/library $@
183else
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200184libmbedcrypto.a: $(OBJS_CRYPTO)
185 echo " AR $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100186 $(AR) $(ARFLAGS) $@ $(OBJS_CRYPTO)
187ifdef APPLE_BUILD
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100188ifneq ($(APPLE_BUILD),0)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200189 echo " RL $@"
Andres Amaya Garcia0e98e882018-05-23 09:19:54 +0100190 $(RL) $(RLFLAGS) $@
191endif
Andres Amaya Garciac51d6132018-06-19 17:25:34 +0100192endif
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200193
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200194libmbedcrypto.$(SOEXT_CRYPTO): $(OBJS_CRYPTO)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200195 echo " LD $@"
Manuel Pégourié-Gonnard574ae182015-06-25 14:30:22 +0200196 $(CC) -shared -Wl,-soname,$@ $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200197
Manuel Pégourié-Gonnard752c5012015-06-25 11:54:52 +0200198libmbedcrypto.so: libmbedcrypto.$(SOEXT_CRYPTO)
199 echo " LN $@ -> $<"
200 ln -sf $< $@
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200201
202libmbedcrypto.dylib: $(OBJS_CRYPTO)
203 echo " LD $@"
204 $(CC) -dynamiclib $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ $(OBJS_CRYPTO)
205
206libmbedcrypto.dll: $(OBJS_CRYPTO)
207 echo " LD $@"
Manuel Pégourié-Gonnard8018c282015-08-07 11:55:56 +0200208 $(CC) -shared -Wl,-soname,$@ -Wl,--out-implib,$@.a -o $@ $(OBJS_CRYPTO) -lws2_32 -lwinmm -lgdi32 -static-libgcc $(LOCAL_LDFLAGS) $(LDFLAGS)
Jaeden Amero30b340a2018-10-25 17:37:00 +0100209endif
Paul Bakkera585beb2011-06-21 08:59:44 +0000210
Paul Bakkerad7eca22010-03-24 06:46:47 +0000211.c.o:
Paul Bakker96d42da2012-04-05 13:22:07 +0000212 echo " CC $<"
Alon Bar-Levf7a9f302015-02-18 17:55:05 +0200213 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -c $<
Paul Bakker5121ce52009-01-03 21:22:43 +0000214
215clean:
Paul Bakker62f88dc2012-05-10 21:26:28 +0000216ifndef WINDOWS
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200217 rm -f *.o libmbed*
218else
219 del /Q /F *.o libmbed*
Paul Bakker62f88dc2012-05-10 21:26:28 +0000220endif