blob: 1ea243b0f5178ffc2c669ce9a021ce5dccd1f4bf [file] [log] [blame]
Gilles Peskine570e5482024-01-02 18:11:10 +01001MBEDTLS_TEST_PATH = .
Gilles Peskinef3d1ae12023-12-22 11:40:58 +01002include ../scripts/common.make
Paul Bakker0049c2f2009-07-11 19:15:43 +00003
Gilles Peskine396853a2021-09-20 18:57:55 +02004# Set this to -v to see the details of failing test cases
5TEST_FLAGS ?= $(if $(filter-out 0 OFF Off off NO No no FALSE False false N n,$(CTEST_OUTPUT_ON_FAILURE)),-v,)
6
Gilles Peskinef5c5ce72023-12-22 11:36:53 +01007# Also include library headers, for the sake of invasive tests.
8LOCAL_CFLAGS += -I../library
Paul Bakker0049c2f2009-07-11 19:15:43 +00009
Nicholas Wilson61fa4362018-06-25 12:10:00 +010010# Enable definition of various functions used throughout the testsuite
11# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
12# on non-POSIX platforms.
13LOCAL_CFLAGS += -D_POSIX_C_SOURCE=200809L
14
Gilles Peskine51681552019-05-20 19:35:37 +020015ifdef RECORD_PSA_STATUS_COVERAGE_LOG
16LOCAL_CFLAGS += -Werror -DRECORD_PSA_STATUS_COVERAGE_LOG
17endif
18
Werner Lewis8b2df742022-07-08 13:54:57 +010019GENERATED_BIGNUM_DATA_FILES := $(patsubst tests/%,%,$(shell \
David Horstmannea091522024-05-29 17:57:08 +010020 $(PYTHON) ../framework/scripts/generate_bignum_tests.py --list || \
Werner Lewis8b2df742022-07-08 13:54:57 +010021 echo FAILED \
22))
23ifeq ($(GENERATED_BIGNUM_DATA_FILES),FAILED)
David Horstmannea091522024-05-29 17:57:08 +010024$(error "$(PYTHON) ../framework/scripts/generate_bignum_tests.py --list" failed)
Werner Lewis8b2df742022-07-08 13:54:57 +010025endif
Gilles Peskine26d279e2024-05-23 16:38:07 +020026GENERATED_DATA_FILES += $(GENERATED_BIGNUM_DATA_FILES)
27
Gilles Peskine06fb1802024-05-23 16:31:22 +020028GENERATED_CONFIG_DATA_FILES := $(patsubst tests/%,%,$(shell \
29 $(PYTHON) ../framework/scripts/generate_config_tests.py --list || \
30 echo FAILED \
31))
32ifeq ($(GENERATED_CONFIG_DATA_FILES),FAILED)
33$(error "$(PYTHON) ../framework/scripts/generate_config_tests.py --list" failed)
34endif
35GENERATED_DATA_FILES += $(GENERATED_CONFIG_DATA_FILES)
36
Gabor Mezei95ecaaf2023-01-16 16:53:29 +010037GENERATED_ECP_DATA_FILES := $(patsubst tests/%,%,$(shell \
David Horstmannea091522024-05-29 17:57:08 +010038 $(PYTHON) ../framework/scripts/generate_ecp_tests.py --list || \
Gabor Mezei95ecaaf2023-01-16 16:53:29 +010039 echo FAILED \
40))
41ifeq ($(GENERATED_ECP_DATA_FILES),FAILED)
David Horstmannea091522024-05-29 17:57:08 +010042$(error "$(PYTHON) ../framework/scripts/generate_ecp_tests.py --list" failed)
Gabor Mezei95ecaaf2023-01-16 16:53:29 +010043endif
Gilles Peskine26d279e2024-05-23 16:38:07 +020044GENERATED_DATA_FILES += $(GENERATED_ECP_DATA_FILES)
45
Werner Lewis8b2df742022-07-08 13:54:57 +010046GENERATED_PSA_DATA_FILES := $(patsubst tests/%,%,$(shell \
David Horstmannea091522024-05-29 17:57:08 +010047 $(PYTHON) ../framework/scripts/generate_psa_tests.py --list || \
Gilles Peskinee9ad95a2021-07-13 18:36:05 +020048 echo FAILED \
49))
Werner Lewis8b2df742022-07-08 13:54:57 +010050ifeq ($(GENERATED_PSA_DATA_FILES),FAILED)
David Horstmannea091522024-05-29 17:57:08 +010051$(error "$(PYTHON) ../framework/scripts/generate_psa_tests.py --list" failed)
Gilles Peskinee9ad95a2021-07-13 18:36:05 +020052endif
Gilles Peskine26d279e2024-05-23 16:38:07 +020053GENERATED_DATA_FILES += $(GENERATED_PSA_DATA_FILES)
54
55GENERATED_FILES = $(GENERATED_DATA_FILES)
56GENERATED_FILES += src/test_keys.h src/test_certs.h
57
Gilles Peskineae7e1c72024-09-25 10:27:47 +020058# Generated files needed to (fully) run ssl-opt.sh
59.PHONY: ssl-opt
60
Elena Uziunaite1d8a2252024-10-08 13:02:48 +010061opt-testcases/tls13-compat.sh: ../framework/scripts/generate_tls13_compat_tests.py
Gilles Peskine8ca70ac2024-09-19 19:09:33 +020062 echo " Gen $@"
Elena Uziunaite1d8a2252024-10-08 13:02:48 +010063 $(PYTHON) ../framework/scripts/generate_tls13_compat_tests.py -o $@
Gilles Peskine0e9ba082024-09-13 15:57:44 +020064GENERATED_FILES += opt-testcases/tls13-compat.sh
Gilles Peskineae7e1c72024-09-25 10:27:47 +020065ssl-opt: opt-testcases/tls13-compat.sh
Gilles Peskine0e9ba082024-09-13 15:57:44 +020066
Gilles Peskine26d279e2024-05-23 16:38:07 +020067.PHONY: generated_files
68generated_files: $(GENERATED_FILES)
Gilles Peskine687d1ab2021-04-22 01:01:56 +020069
Werner Lewis8b2df742022-07-08 13:54:57 +010070# generate_bignum_tests.py and generate_psa_tests.py spend more time analyzing
71# inputs than generating outputs. Its inputs are the same no matter which files
72# are being generated.
Gilles Peskine5df77c62021-07-13 17:22:58 +020073# It's rare not to want all the outputs. So always generate all of its outputs.
74# Use an intermediate phony dependency so that parallel builds don't run
75# a separate instance of the recipe for each output file.
Gilles Peskine0b62b7a2023-09-08 16:19:13 +020076$(GENERATED_BIGNUM_DATA_FILES): $(gen_file_dep) generated_bignum_test_data
David Horstmannea091522024-05-29 17:57:08 +010077generated_bignum_test_data: ../framework/scripts/generate_bignum_tests.py
David Horstmann9638ca32024-05-03 14:36:12 +010078generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_common.py
79generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_core.py
80generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_mod_raw.py
81generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_mod.py
82generated_bignum_test_data: ../framework/scripts/mbedtls_framework/test_case.py
83generated_bignum_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py
Werner Lewis8b2df742022-07-08 13:54:57 +010084generated_bignum_test_data:
85 echo " Gen $(GENERATED_BIGNUM_DATA_FILES)"
David Horstmannea091522024-05-29 17:57:08 +010086 $(PYTHON) ../framework/scripts/generate_bignum_tests.py
Gilles Peskine26d279e2024-05-23 16:38:07 +020087.SECONDARY: generated_bignum_test_data
Werner Lewis8b2df742022-07-08 13:54:57 +010088
Gilles Peskine06fb1802024-05-23 16:31:22 +020089# We deliberately omit the configuration files (mbedtls_config.h,
90# crypto_config.h) from the depenency list because during development
91# and on the CI, we often edit those in a way that doesn't change the
92# output, to comment out certain options, or even to remove certain
93# lines which do affect the output negatively (it will miss the
94# corresponding test cases).
95$(GENERATED_CONFIG_DATA_FILES): $(gen_file_dep) generated_config_test_data
96generated_config_test_data: ../framework/scripts/generate_config_tests.py
97generated_config_test_data: ../scripts/config.py
98generated_config_test_data: ../framework/scripts/mbedtls_framework/test_case.py
99generated_config_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py
100generated_config_test_data:
101 echo " Gen $(GENERATED_CONFIG_DATA_FILES)"
102 $(PYTHON) ../framework/scripts/generate_config_tests.py
103.SECONDARY: generated_config_test_data
104
Gilles Peskine0b62b7a2023-09-08 16:19:13 +0200105$(GENERATED_ECP_DATA_FILES): $(gen_file_dep) generated_ecp_test_data
David Horstmannea091522024-05-29 17:57:08 +0100106generated_ecp_test_data: ../framework/scripts/generate_ecp_tests.py
David Horstmann9638ca32024-05-03 14:36:12 +0100107generated_ecp_test_data: ../framework/scripts/mbedtls_framework/bignum_common.py
108generated_ecp_test_data: ../framework/scripts/mbedtls_framework/ecp.py
109generated_ecp_test_data: ../framework/scripts/mbedtls_framework/test_case.py
110generated_ecp_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py
Gabor Mezei95ecaaf2023-01-16 16:53:29 +0100111generated_ecp_test_data:
112 echo " Gen $(GENERATED_ECP_DATA_FILES)"
David Horstmannea091522024-05-29 17:57:08 +0100113 $(PYTHON) ../framework/scripts/generate_ecp_tests.py
Gilles Peskine26d279e2024-05-23 16:38:07 +0200114.SECONDARY: generated_ecp_test_data
Gabor Mezei95ecaaf2023-01-16 16:53:29 +0100115
Gilles Peskine0b62b7a2023-09-08 16:19:13 +0200116$(GENERATED_PSA_DATA_FILES): $(gen_file_dep) generated_psa_test_data
David Horstmannea091522024-05-29 17:57:08 +0100117generated_psa_test_data: ../framework/scripts/generate_psa_tests.py
David Horstmann9638ca32024-05-03 14:36:12 +0100118generated_psa_test_data: ../framework/scripts/mbedtls_framework/crypto_data_tests.py
119generated_psa_test_data: ../framework/scripts/mbedtls_framework/crypto_knowledge.py
120generated_psa_test_data: ../framework/scripts/mbedtls_framework/macro_collector.py
121generated_psa_test_data: ../framework/scripts/mbedtls_framework/psa_information.py
122generated_psa_test_data: ../framework/scripts/mbedtls_framework/psa_storage.py
123generated_psa_test_data: ../framework/scripts/mbedtls_framework/test_case.py
124generated_psa_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py
Gilles Peskine1411c7c2021-04-22 14:50:16 +0200125## The generated file only depends on the options that are present in
126## crypto_config.h, not on which options are set. To avoid regenerating this
127## file all the time when switching between configurations, don't declare
128## crypto_config.h as a dependency. Remove this file from your working tree
129## if you've just added or removed an option in crypto_config.h.
Gilles Peskine5df77c62021-07-13 17:22:58 +0200130#generated_psa_test_data: ../include/psa/crypto_config.h
131generated_psa_test_data: ../include/psa/crypto_values.h
132generated_psa_test_data: ../include/psa/crypto_extra.h
133generated_psa_test_data: suites/test_suite_psa_crypto_metadata.data
134generated_psa_test_data:
Werner Lewis8b2df742022-07-08 13:54:57 +0100135 echo " Gen $(GENERATED_PSA_DATA_FILES) ..."
David Horstmannea091522024-05-29 17:57:08 +0100136 $(PYTHON) ../framework/scripts/generate_psa_tests.py
Gilles Peskine26d279e2024-05-23 16:38:07 +0200137.SECONDARY: generated_psa_test_data
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200138
Azim Khan27a35e72018-06-29 12:39:19 +0100139# A test application is built for each suites/test_suite_*.data file.
140# Application name is same as .data file's base name and can be
141# constructed by stripping path 'suites/' and extension .data.
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200142DATA_FILES := $(wildcard suites/test_suite_*.data)
143# Make sure that generated data files are included even if they don't
144# exist yet when the makefile is parsed.
Gilles Peskine26d279e2024-05-23 16:38:07 +0200145DATA_FILES += $(filter-out $(DATA_FILES),$(GENERATED_DATA_FILES))
Gilles Peskine687d1ab2021-04-22 01:01:56 +0200146APPS = $(basename $(subst suites/,,$(DATA_FILES)))
Mohammad Azim Khan94aefaf2017-03-23 12:32:54 +0000147
Azim Khan27a35e72018-06-29 12:39:19 +0100148# Construct executable name by adding OS specific suffix $(EXEXT).
Mohammad Azim Khan94aefaf2017-03-23 12:32:54 +0000149BINARIES := $(addsuffix $(EXEXT),$(APPS))
150
Paul Bakker0049c2f2009-07-11 19:15:43 +0000151.SILENT:
152
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200153.PHONY: all check test clean
154
Azim Khan1de892b2017-06-09 15:02:36 +0100155all: $(BINARIES)
156
Ronald Cronddaf99c2020-06-19 11:27:26 +0200157mbedtls_test: $(MBEDTLS_TEST_OBJS)
158
David Horstmannea091522024-05-29 17:57:08 +0100159src/test_certs.h: ../framework/scripts/generate_test_cert_macros.py \
160 $($(PYTHON) ../framework/scripts/generate_test_cert_macros.py --list-dependencies)
Gilles Peskine8ca70ac2024-09-19 19:09:33 +0200161 echo " Gen $@"
David Horstmannea091522024-05-29 17:57:08 +0100162 $(PYTHON) ../framework/scripts/generate_test_cert_macros.py --output $@
Valerio Settia607a1b2024-04-08 17:52:12 +0200163
David Horstmannea091522024-05-29 17:57:08 +0100164src/test_keys.h: ../framework/scripts/generate_test_keys.py
Gilles Peskine8ca70ac2024-09-19 19:09:33 +0200165 echo " Gen $@"
David Horstmannea091522024-05-29 17:57:08 +0100166 $(PYTHON) ../framework/scripts/generate_test_keys.py --output $@
Valerio Settia607a1b2024-04-08 17:52:12 +0200167
Gilles Peskinee1d51bd2021-01-20 19:47:23 +0100168TEST_OBJS_DEPS = $(wildcard include/test/*.h include/test/*/*.h)
Gilles Peskined71539f2020-11-25 18:17:17 +0100169ifdef RECORD_PSA_STATUS_COVERAGE_LOG
Gilles Peskine75829a42021-01-25 13:46:14 +0100170# Explicitly depend on this header because on a clean copy of the source tree,
171# it doesn't exist yet and must be generated as part of the build, and
172# therefore the wildcard enumeration above doesn't include it.
Gilles Peskined71539f2020-11-25 18:17:17 +0100173TEST_OBJS_DEPS += include/test/instrument_record_status.h
174endif
Valerio Settia607a1b2024-04-08 17:52:12 +0200175TEST_OBJS_DEPS += src/test_certs.h src/test_keys.h
Gilles Peskined71539f2020-11-25 18:17:17 +0100176
David Horstmann45c83ca2024-11-05 14:45:50 +0000177# Rule to compile common test C files in framework
178../framework/tests/src/%.o : ../framework/tests/src/%.c $(TEST_OBJS_DEPS)
Ronald Cronb6d6d4c2020-06-03 10:11:18 +0200179 echo " CC $<"
180 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
181
David Horstmann45c83ca2024-11-05 14:45:50 +0000182../framework/tests/src/drivers/%.o : ../framework/tests/src/drivers/%.c
183 echo " CC $<"
184 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
185
186# Rule to compile common test C files in src folder
187src/%.o : src/%.c $(TEST_OBJS_DEPS)
Steven Cooremana70d5882020-07-16 20:26:18 +0200188 echo " CC $<"
189 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
190
Yanray Wangb458b8c2022-10-28 11:49:33 +0800191src/test_helpers/%.o : src/test_helpers/%.c
192 echo " CC $<"
193 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $<
194
Mohammad Azim Khan94aefaf2017-03-23 12:32:54 +0000195C_FILES := $(addsuffix .c,$(APPS))
Gilles Peskine1d7cc082022-11-10 19:50:34 +0100196c: $(C_FILES)
Mohammad Azim Khan94aefaf2017-03-23 12:32:54 +0000197
Azim Khan27a35e72018-06-29 12:39:19 +0100198# Wildcard target for test code generation:
199# A .c file is generated for each .data file in the suites/ directory. Each .c
200# file depends on a .data and .function file from suites/ directory. Following
201# nameing convention is followed:
202#
203# C file | Depends on
204#-----------------------------------------------------------------------------
205# foo.c | suites/foo.function suites/foo.data
206# foo.bar.c | suites/foo.function suites/foo.bar.data
207#
208# Note above that .c and .data files have same base name.
209# However, corresponding .function file's base name is the word before first
210# dot in .c file's base name.
211#
Mohammad Azim Khan94aefaf2017-03-23 12:32:54 +0000212.SECONDEXPANSION:
David Horstmannea091522024-05-29 17:57:08 +0100213%.c: suites/$$(firstword $$(subst ., ,$$*)).function suites/%.data ../framework/scripts/generate_test_code.py suites/helpers.function suites/main_test.function suites/host_test.function
Manuel Pégourié-Gonnard78ec2b02015-07-08 22:12:06 +0100214 echo " Gen $@"
David Horstmannea091522024-05-29 17:57:08 +0100215 $(PYTHON) ../framework/scripts/generate_test_code.py -f suites/$(firstword $(subst ., ,$*)).function \
Mohammad Azim Khanfff49042017-03-28 01:48:31 +0100216 -d suites/$*.data \
Azim Khan1de892b2017-06-09 15:02:36 +0100217 -t suites/main_test.function \
Mohammad Azim Khan95402612017-07-19 10:15:54 +0100218 -p suites/host_test.function \
Mohammad Azim Khanfff49042017-03-28 01:48:31 +0100219 -s suites \
Azim Khane3b26af2018-06-29 02:36:57 +0100220 --helpers-file suites/helpers.function \
Mohammad Azim Khanfff49042017-03-28 01:48:31 +0100221 -o .
Paul Bakker286bf3c2013-04-08 18:09:51 +0200222
Paul Bakker286bf3c2013-04-08 18:09:51 +0200223
Gilles Peskined71539f2020-11-25 18:17:17 +0100224$(BINARIES): %$(EXEXT): %.c $(MBEDLIBS) $(TEST_OBJS_DEPS) $(MBEDTLS_TEST_OBJS)
Manuel Pégourié-Gonnard78ec2b02015-07-08 22:12:06 +0100225 echo " CC $<"
Gilles Peskine4ad57332023-12-22 11:30:30 +0100226 $(CC) $(LOCAL_CFLAGS) $(CFLAGS) $< $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@
Paul Bakker286bf3c2013-04-08 18:09:51 +0200227
Paul Bakker0049c2f2009-07-11 19:15:43 +0000228clean:
Paul Bakker62f88dc2012-05-10 21:26:28 +0000229ifndef WINDOWS
Gilles Peskined0254222021-09-14 11:28:22 +0200230 rm -rf $(BINARIES) *.c *.datax
David Horstmann636367f2024-08-28 16:30:33 +0100231 rm -f src/*.o src/drivers/*.o src/test_helpers/*.o src/libmbed*
Gilles Peskined71539f2020-11-25 18:17:17 +0100232 rm -f include/test/instrument_record_status.h
Gilles Peskinedf6e84a2023-02-22 22:09:51 +0100233 rm -f include/alt-extra/*/*_alt.h
Ronald Cron72b25da2021-04-28 18:29:24 +0200234 rm -rf libtestdriver1
Manuel Pégourié-Gonnard85101052022-12-29 16:04:35 +0100235 rm -f ../library/libtestdriver1.a
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200236else
Darryl Green6c0f94c2018-10-17 16:12:33 +0100237 if exist *.c del /Q /F *.c
238 if exist *.exe del /Q /F *.exe
239 if exist *.datax del /Q /F *.datax
Ronald Cronb6d6d4c2020-06-03 10:11:18 +0200240 if exist src/*.o del /Q /F src/*.o
Steven Cooremana70d5882020-07-16 20:26:18 +0200241 if exist src/drivers/*.o del /Q /F src/drivers/*.o
Yanray Wangb458b8c2022-10-28 11:49:33 +0800242 if exist src/test_helpers/*.o del /Q /F src/test_helpers/*.o
David Horstmann204c4b42024-08-28 16:28:46 +0100243 if exist src/libmbed* del /Q /F src/libmbed*
Gilles Peskined71539f2020-11-25 18:17:17 +0100244 if exist include/test/instrument_record_status.h del /Q /F include/test/instrument_record_status.h
Azim Khan27a35e72018-06-29 12:39:19 +0100245endif
Paul Bakker0049c2f2009-07-11 19:15:43 +0000246
Gilles Peskineac372cc2018-11-29 10:15:06 +0000247# Test suites caught by SKIP_TEST_SUITES are built but not executed.
Mohammad Azim Khan94aefaf2017-03-23 12:32:54 +0000248check: $(BINARIES)
Gilles Peskine396853a2021-09-20 18:57:55 +0200249 perl scripts/run-test-suites.pl $(TEST_FLAGS) --skip=$(SKIP_TEST_SUITES)
Manuel Pégourié-Gonnard5c59a4f2015-06-24 13:06:24 +0200250
251test: check
Mohammad Azim Khan1f29be72017-03-20 22:21:22 +0000252
Gilles Peskinedf6e84a2023-02-22 22:09:51 +0100253# Generate variants of some headers for testing
254include/alt-extra/%_alt.h: ../include/%.h
255 perl -p -e 's/^(# *(define|ifndef) +\w+_)H\b/$${1}ALT_H/' $< >$@
256
Ronald Cron72b25da2021-04-28 18:29:24 +0200257# Generate test library
258
259# Perl code that is executed to transform each original line from a library
260# source file into the corresponding line in the test driver copy of the
261# library. Add a LIBTESTDRIVER1_/libtestdriver1_ to mbedtls_xxx and psa_xxx
262# symbols.
263define libtestdriver1_rewrite :=
264 s!^(\s*#\s*include\s*[\"<])(mbedtls|psa)/!$${1}libtestdriver1/include/$${2}/!; \
265 next if /^\s*#\s*include/; \
266 s/\b(?=MBEDTLS_|PSA_)/LIBTESTDRIVER1_/g; \
267 s/\b(?=mbedtls_|psa_)/libtestdriver1_/g;
268endef
269
Gilles Peskine1c13aa72024-03-04 11:06:56 +0100270libtestdriver1.a: export MBEDTLS_PATH := $(patsubst ../..//%,/%,../../$(MBEDTLS_PATH))
Ronald Cron72b25da2021-04-28 18:29:24 +0200271libtestdriver1.a:
272 # Copy the library and fake a 3rdparty Makefile include.
273 rm -Rf ./libtestdriver1
274 mkdir ./libtestdriver1
275 cp -Rf ../library ./libtestdriver1
276 cp -Rf ../include ./libtestdriver1
277 cp -Rf ../scripts ./libtestdriver1
278 mkdir ./libtestdriver1/3rdparty
279 touch ./libtestdriver1/3rdparty/Makefile.inc
280
281 # Set the test driver base (minimal) configuration.
David Horstmann685c1942024-11-06 11:11:59 +0000282 cp ../framework/tests/include/test/drivers/config_test_driver.h ./libtestdriver1/include/mbedtls/mbedtls_config.h
Ronald Cron72b25da2021-04-28 18:29:24 +0200283
284 # Set the PSA cryptography configuration for the test library.
285 # It is set from the copied include/psa/crypto_config.h of the Mbed TLS
286 # library the test library is intended to be linked with extended by
David Horstmann685c1942024-11-06 11:11:59 +0000287 # ../framework/tests/include/test/drivers/crypto_config_test_driver_extension.h to
Ronald Cron72b25da2021-04-28 18:29:24 +0200288 # mirror the PSA_ACCEL_* macros.
289 mv ./libtestdriver1/include/psa/crypto_config.h ./libtestdriver1/include/psa/crypto_config.h.bak
290 head -n -1 ./libtestdriver1/include/psa/crypto_config.h.bak > ./libtestdriver1/include/psa/crypto_config.h
David Horstmann685c1942024-11-06 11:11:59 +0000291 cat ../framework/tests/include/test/drivers/crypto_config_test_driver_extension.h >> ./libtestdriver1/include/psa/crypto_config.h
Ronald Cron72b25da2021-04-28 18:29:24 +0200292 echo "#endif /* PSA_CRYPTO_CONFIG_H */" >> ./libtestdriver1/include/psa/crypto_config.h
293
294 # Prefix MBEDTLS_* PSA_* symbols with LIBTESTDRIVER1_ as well as
295 # mbedtls_* psa_* symbols with libtestdriver1_ to avoid symbol clash
296 # when this test driver library is linked with the Mbed TLS library.
297 perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/library/*.[ch]
298 perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/include/*/*.h
299
300 $(MAKE) -C ./libtestdriver1/library CFLAGS="-I../../ $(CFLAGS)" LDFLAGS="$(LDFLAGS)" libmbedcrypto.a
301 cp ./libtestdriver1/library/libmbedcrypto.a ../library/libtestdriver1.a
302
Gilles Peskine51681552019-05-20 19:35:37 +0200303ifdef RECORD_PSA_STATUS_COVERAGE_LOG
Ronald Cron02c78b72020-05-27 09:22:32 +0200304include/test/instrument_record_status.h: ../include/psa/crypto.h Makefile
Gilles Peskined71539f2020-11-25 18:17:17 +0100305 echo " Gen $@"
Gilles Peskine51681552019-05-20 19:35:37 +0200306 sed <../include/psa/crypto.h >$@ -n 's/^psa_status_t \([A-Za-z0-9_]*\)(.*/#define \1(...) RECORD_STATUS("\1", \1(__VA_ARGS__))/p'
307endif