| Gilles Peskine | 570e548 | 2024-01-02 18:11:10 +0100 | [diff] [blame] | 1 | MBEDTLS_TEST_PATH = . | 
| Gilles Peskine | f3d1ae1 | 2023-12-22 11:40:58 +0100 | [diff] [blame] | 2 | include ../scripts/common.make | 
| Paul Bakker | 0049c2f | 2009-07-11 19:15:43 +0000 | [diff] [blame] | 3 |  | 
| Gilles Peskine | 396853a | 2021-09-20 18:57:55 +0200 | [diff] [blame] | 4 | # Set this to -v to see the details of failing test cases | 
|  | 5 | TEST_FLAGS ?= $(if $(filter-out 0 OFF Off off NO No no FALSE False false N n,$(CTEST_OUTPUT_ON_FAILURE)),-v,) | 
|  | 6 |  | 
| Ronald Cron | c29afb6 | 2024-07-01 14:50:54 +0200 | [diff] [blame] | 7 | # Also include private headers, for the sake of invasive tests. | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 8 | LOCAL_CFLAGS += -I$(MBEDTLS_PATH)/library -I$(MBEDTLS_PATH)/tf-psa-crypto/core -I$(MBEDTLS_PATH)/tf-psa-crypto/drivers/builtin/src | 
| Ronald Cron | 1451a76 | 2024-06-10 16:02:04 +0200 | [diff] [blame] | 9 |  | 
| Nicholas Wilson | 61fa436 | 2018-06-25 12:10:00 +0100 | [diff] [blame] | 10 | # 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. | 
|  | 13 | LOCAL_CFLAGS += -D_POSIX_C_SOURCE=200809L | 
|  | 14 |  | 
| Gilles Peskine | 5168155 | 2019-05-20 19:35:37 +0200 | [diff] [blame] | 15 | ifdef RECORD_PSA_STATUS_COVERAGE_LOG | 
|  | 16 | LOCAL_CFLAGS += -Werror -DRECORD_PSA_STATUS_COVERAGE_LOG | 
|  | 17 | endif | 
|  | 18 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 19 | GENERATED_BIGNUM_DATA_FILES := $(addprefix ../tf-psa-crypto/,$(shell \ | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 20 | $(PYTHON) ../framework/scripts/generate_bignum_tests.py --list || \ | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 21 | echo FAILED \ | 
|  | 22 | )) | 
|  | 23 | ifeq ($(GENERATED_BIGNUM_DATA_FILES),FAILED) | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 24 | $(error "$(PYTHON) ../framework/scripts/generate_bignum_tests.py --list" failed) | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 25 | endif | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 26 | GENERATED_CRYPTO_DATA_FILES += $(GENERATED_BIGNUM_DATA_FILES) | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 27 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 28 | GENERATED_CONFIG_DATA_FILES_RAW := $(patsubst tests/%,%,$(shell \ | 
| Gilles Peskine | e154e6f | 2024-05-23 16:31:22 +0200 | [diff] [blame] | 29 | $(PYTHON) ../framework/scripts/generate_config_tests.py --list || \ | 
|  | 30 | echo FAILED \ | 
|  | 31 | )) | 
|  | 32 | ifeq ($(GENERATED_CONFIG_DATA_FILES),FAILED) | 
|  | 33 | $(error "$(PYTHON) ../framework/scripts/generate_config_tests.py --list" failed) | 
|  | 34 | endif | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 35 | GENERATED_MBEDTLS_CONFIG_DATA_FILES := $(foreach file,$(GENERATED_CONFIG_DATA_FILES_RAW),$(if $(findstring mbedtls,$(file)),$(file),)) | 
|  | 36 | GENERATED_PSA_CONFIG_DATA_FILES := $(foreach file,$(GENERATED_CONFIG_DATA_FILES_RAW),$(if $(findstring psa,$(file)),$(addprefix ../tf-psa-crypto/tests/,$(file)),)) | 
|  | 37 | GENERATED_CONFIG_DATA_FILES := $(GENERATED_MBEDTLS_CONFIG_DATA_FILES)$(GENERATED_PSA_CONFIG_DATA_FILES) | 
|  | 38 | GENERATED_DATA_FILES += $(GENERATED_MBEDTLS_CONFIG_DATA_FILES) | 
|  | 39 | GENERATED_CRYPTO_DATA_FILES += $(GENERATED_PSA_CONFIG_DATA_FILES) | 
| Gilles Peskine | e154e6f | 2024-05-23 16:31:22 +0200 | [diff] [blame] | 40 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 41 | GENERATED_ECP_DATA_FILES := $(addprefix ../tf-psa-crypto/,$(shell \ | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 42 | $(PYTHON) ../framework/scripts/generate_ecp_tests.py --list || \ | 
| Gabor Mezei | 95ecaaf | 2023-01-16 16:53:29 +0100 | [diff] [blame] | 43 | echo FAILED \ | 
|  | 44 | )) | 
|  | 45 | ifeq ($(GENERATED_ECP_DATA_FILES),FAILED) | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 46 | $(error "$(PYTHON) ../framework/scripts/generate_ecp_tests.py --list" failed) | 
| Gabor Mezei | 95ecaaf | 2023-01-16 16:53:29 +0100 | [diff] [blame] | 47 | endif | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 48 | GENERATED_CRYPTO_DATA_FILES += $(GENERATED_ECP_DATA_FILES) | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 49 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 50 | GENERATED_PSA_DATA_FILES := $(addprefix ../tf-psa-crypto/,$(shell \ | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 51 | $(PYTHON) ../framework/scripts/generate_psa_tests.py --list || \ | 
| Gilles Peskine | e9ad95a | 2021-07-13 18:36:05 +0200 | [diff] [blame] | 52 | echo FAILED \ | 
|  | 53 | )) | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 54 | ifeq ($(GENERATED_PSA_DATA_FILES),FAILED) | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 55 | $(error "$(PYTHON) ../framework/scripts/generate_psa_tests.py --list" failed) | 
| Gilles Peskine | e9ad95a | 2021-07-13 18:36:05 +0200 | [diff] [blame] | 56 | endif | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 57 | GENERATED_CRYPTO_DATA_FILES += $(GENERATED_PSA_DATA_FILES) | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 58 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 59 | GENERATED_FILES = $(GENERATED_DATA_FILES) $(GENERATED_CRYPTO_DATA_FILES) | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 60 | GENERATED_FILES += src/test_keys.h src/test_certs.h | 
|  | 61 |  | 
|  | 62 | .PHONY: generated_files | 
|  | 63 | generated_files: $(GENERATED_FILES) | 
| Gilles Peskine | 687d1ab | 2021-04-22 01:01:56 +0200 | [diff] [blame] | 64 |  | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 65 | # generate_bignum_tests.py and generate_psa_tests.py spend more time analyzing | 
|  | 66 | # inputs than generating outputs. Its inputs are the same no matter which files | 
|  | 67 | # are being generated. | 
| Gilles Peskine | 5df77c6 | 2021-07-13 17:22:58 +0200 | [diff] [blame] | 68 | # It's rare not to want all the outputs. So always generate all of its outputs. | 
|  | 69 | # Use an intermediate phony dependency so that parallel builds don't run | 
|  | 70 | # a separate instance of the recipe for each output file. | 
| Gilles Peskine | 0b62b7a | 2023-09-08 16:19:13 +0200 | [diff] [blame] | 71 | $(GENERATED_BIGNUM_DATA_FILES): $(gen_file_dep) generated_bignum_test_data | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 72 | generated_bignum_test_data: ../framework/scripts/generate_bignum_tests.py | 
| David Horstmann | cd84bb2 | 2024-05-03 14:36:12 +0100 | [diff] [blame] | 73 | generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_common.py | 
|  | 74 | generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_core.py | 
|  | 75 | generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_mod_raw.py | 
|  | 76 | generated_bignum_test_data: ../framework/scripts/mbedtls_framework/bignum_mod.py | 
|  | 77 | generated_bignum_test_data: ../framework/scripts/mbedtls_framework/test_case.py | 
|  | 78 | generated_bignum_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 79 | generated_bignum_test_data: | 
|  | 80 | echo "  Gen   $(GENERATED_BIGNUM_DATA_FILES)" | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 81 | $(PYTHON) ../framework/scripts/generate_bignum_tests.py --directory ../tf-psa-crypto/tests/suites | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 82 | .SECONDARY: generated_bignum_test_data | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 83 |  | 
| Gilles Peskine | e154e6f | 2024-05-23 16:31:22 +0200 | [diff] [blame] | 84 | # We deliberately omit the configuration files (mbedtls_config.h, | 
|  | 85 | # crypto_config.h) from the depenency list because during development | 
|  | 86 | # and on the CI, we often edit those in a way that doesn't change the | 
|  | 87 | # output, to comment out certain options, or even to remove certain | 
|  | 88 | # lines which do affect the output negatively (it will miss the | 
|  | 89 | # corresponding test cases). | 
|  | 90 | $(GENERATED_CONFIG_DATA_FILES): $(gen_file_dep) generated_config_test_data | 
|  | 91 | generated_config_test_data: ../framework/scripts/generate_config_tests.py | 
|  | 92 | generated_config_test_data: ../scripts/config.py | 
|  | 93 | generated_config_test_data: ../framework/scripts/mbedtls_framework/test_case.py | 
|  | 94 | generated_config_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py | 
|  | 95 | generated_config_test_data: | 
|  | 96 | echo "  Gen   $(GENERATED_CONFIG_DATA_FILES)" | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 97 | $(PYTHON) ../framework/scripts/generate_config_tests.py $(GENERATED_MBEDTLS_CONFIG_DATA_FILES) | 
|  | 98 | $(PYTHON) ../framework/scripts/generate_config_tests.py --directory ../tf-psa-crypto/tests/suites $(GENERATED_PSA_CONFIG_DATA_FILES) | 
| Gilles Peskine | e154e6f | 2024-05-23 16:31:22 +0200 | [diff] [blame] | 99 | .SECONDARY: generated_config_test_data | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 100 |  | 
| Gilles Peskine | 0b62b7a | 2023-09-08 16:19:13 +0200 | [diff] [blame] | 101 | $(GENERATED_ECP_DATA_FILES): $(gen_file_dep) generated_ecp_test_data | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 102 | generated_ecp_test_data: ../framework/scripts/generate_ecp_tests.py | 
| David Horstmann | cd84bb2 | 2024-05-03 14:36:12 +0100 | [diff] [blame] | 103 | generated_ecp_test_data: ../framework/scripts/mbedtls_framework/bignum_common.py | 
|  | 104 | generated_ecp_test_data: ../framework/scripts/mbedtls_framework/ecp.py | 
|  | 105 | generated_ecp_test_data: ../framework/scripts/mbedtls_framework/test_case.py | 
|  | 106 | generated_ecp_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py | 
| Gabor Mezei | 95ecaaf | 2023-01-16 16:53:29 +0100 | [diff] [blame] | 107 | generated_ecp_test_data: | 
|  | 108 | echo "  Gen   $(GENERATED_ECP_DATA_FILES)" | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 109 | $(PYTHON) ../framework/scripts/generate_ecp_tests.py --directory ../tf-psa-crypto/tests/suites | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 110 | .SECONDARY: generated_ecp_test_data | 
| Gabor Mezei | 95ecaaf | 2023-01-16 16:53:29 +0100 | [diff] [blame] | 111 |  | 
| Gilles Peskine | 0b62b7a | 2023-09-08 16:19:13 +0200 | [diff] [blame] | 112 | $(GENERATED_PSA_DATA_FILES): $(gen_file_dep) generated_psa_test_data | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 113 | generated_psa_test_data: ../framework/scripts/generate_psa_tests.py | 
| David Horstmann | cd84bb2 | 2024-05-03 14:36:12 +0100 | [diff] [blame] | 114 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/crypto_data_tests.py | 
|  | 115 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/crypto_knowledge.py | 
|  | 116 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/macro_collector.py | 
|  | 117 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/psa_information.py | 
|  | 118 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/psa_storage.py | 
|  | 119 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/test_case.py | 
|  | 120 | generated_psa_test_data: ../framework/scripts/mbedtls_framework/test_data_generation.py | 
| Gilles Peskine | 1411c7c | 2021-04-22 14:50:16 +0200 | [diff] [blame] | 121 | ## The generated file only depends on the options that are present in | 
|  | 122 | ## crypto_config.h, not on which options are set. To avoid regenerating this | 
|  | 123 | ## file all the time when switching between configurations, don't declare | 
|  | 124 | ## crypto_config.h as a dependency. Remove this file from your working tree | 
|  | 125 | ## if you've just added or removed an option in crypto_config.h. | 
| Ronald Cron | c7e9e36 | 2024-06-10 09:41:49 +0200 | [diff] [blame] | 126 | #generated_psa_test_data: ../tf-psa-crypto/include/psa/crypto_config.h | 
|  | 127 | generated_psa_test_data: ../tf-psa-crypto/include/psa/crypto_values.h | 
|  | 128 | generated_psa_test_data: ../tf-psa-crypto/include/psa/crypto_extra.h | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 129 | generated_psa_test_data: ../tf-psa-crypto/tests/suites/test_suite_psa_crypto_metadata.data | 
| Gilles Peskine | 5df77c6 | 2021-07-13 17:22:58 +0200 | [diff] [blame] | 130 | generated_psa_test_data: | 
| Werner Lewis | 8b2df74 | 2022-07-08 13:54:57 +0100 | [diff] [blame] | 131 | echo "  Gen   $(GENERATED_PSA_DATA_FILES) ..." | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 132 | $(PYTHON) ../framework/scripts/generate_psa_tests.py --directory ../tf-psa-crypto/tests/suites | 
| Gilles Peskine | b0aa75e | 2024-05-23 16:38:07 +0200 | [diff] [blame] | 133 | .SECONDARY: generated_psa_test_data | 
| Gilles Peskine | 687d1ab | 2021-04-22 01:01:56 +0200 | [diff] [blame] | 134 |  | 
| Azim Khan | 27a35e7 | 2018-06-29 12:39:19 +0100 | [diff] [blame] | 135 | # A test application is built for each suites/test_suite_*.data file. | 
|  | 136 | # Application name is same as .data file's base name and can be | 
|  | 137 | # constructed by stripping path 'suites/' and extension .data. | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 138 | DATA_FILES = $(filter-out $(GENERATED_DATA_FILES), $(wildcard suites/test_suite_*.data)) | 
|  | 139 | CRYPTO_DATA_FILES = $(filter-out $(GENERATED_CRYPTO_DATA_FILES), $(wildcard ../tf-psa-crypto/tests/suites/test_suite_*.data)) | 
|  | 140 |  | 
| Gilles Peskine | 687d1ab | 2021-04-22 01:01:56 +0200 | [diff] [blame] | 141 | # Make sure that generated data files are included even if they don't | 
|  | 142 | # exist yet when the makefile is parsed. | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 143 | DATA_FILES += $(GENERATED_DATA_FILES) | 
|  | 144 | CRYPTO_DATA_FILES += $(GENERATED_CRYPTO_DATA_FILES) | 
|  | 145 |  | 
| Gilles Peskine | 687d1ab | 2021-04-22 01:01:56 +0200 | [diff] [blame] | 146 | APPS = $(basename $(subst suites/,,$(DATA_FILES))) | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 147 | CRYPTO_APPS = $(basename $(subst suites/,,$(CRYPTO_DATA_FILES))) | 
| Mohammad Azim Khan | 94aefaf | 2017-03-23 12:32:54 +0000 | [diff] [blame] | 148 |  | 
| Azim Khan | 27a35e7 | 2018-06-29 12:39:19 +0100 | [diff] [blame] | 149 | # Construct executable name by adding OS specific suffix $(EXEXT). | 
| Mohammad Azim Khan | 94aefaf | 2017-03-23 12:32:54 +0000 | [diff] [blame] | 150 | BINARIES := $(addsuffix $(EXEXT),$(APPS)) | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 151 | CRYPTO_BINARIES := $(addsuffix $(EXEXT),$(CRYPTO_APPS)) | 
| Mohammad Azim Khan | 94aefaf | 2017-03-23 12:32:54 +0000 | [diff] [blame] | 152 |  | 
| Paul Bakker | 0049c2f | 2009-07-11 19:15:43 +0000 | [diff] [blame] | 153 | .SILENT: | 
|  | 154 |  | 
| Manuel Pégourié-Gonnard | 5c59a4f | 2015-06-24 13:06:24 +0200 | [diff] [blame] | 155 | .PHONY: all check test clean | 
|  | 156 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 157 | all: $(BINARIES) $(CRYPTO_BINARIES) | 
| Azim Khan | 1de892b | 2017-06-09 15:02:36 +0100 | [diff] [blame] | 158 |  | 
| Ronald Cron | ddaf99c | 2020-06-19 11:27:26 +0200 | [diff] [blame] | 159 | mbedtls_test: $(MBEDTLS_TEST_OBJS) | 
|  | 160 |  | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 161 | src/test_certs.h: ../framework/scripts/generate_test_cert_macros.py \ | 
|  | 162 | $($(PYTHON) ../framework/scripts/generate_test_cert_macros.py --list-dependencies) | 
|  | 163 | $(PYTHON) ../framework/scripts/generate_test_cert_macros.py --output $@ | 
| Valerio Setti | 8284f3d | 2024-04-08 17:52:12 +0200 | [diff] [blame] | 164 |  | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 165 | src/test_keys.h: ../framework/scripts/generate_test_keys.py | 
|  | 166 | $(PYTHON) ../framework/scripts/generate_test_keys.py --output $@ | 
| Valerio Setti | 8284f3d | 2024-04-08 17:52:12 +0200 | [diff] [blame] | 167 |  | 
| Gilles Peskine | e1d51bd | 2021-01-20 19:47:23 +0100 | [diff] [blame] | 168 | TEST_OBJS_DEPS = $(wildcard include/test/*.h include/test/*/*.h) | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 169 | ifdef RECORD_PSA_STATUS_COVERAGE_LOG | 
| Gilles Peskine | 75829a4 | 2021-01-25 13:46:14 +0100 | [diff] [blame] | 170 | # 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 Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 173 | TEST_OBJS_DEPS += include/test/instrument_record_status.h | 
|  | 174 | endif | 
| Valerio Setti | 8284f3d | 2024-04-08 17:52:12 +0200 | [diff] [blame] | 175 | TEST_OBJS_DEPS += src/test_certs.h src/test_keys.h | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 176 |  | 
| Ronald Cron | b6d6d4c | 2020-06-03 10:11:18 +0200 | [diff] [blame] | 177 | # Rule to compile common test C files in src folder | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 178 | src/%.o : src/%.c $(TEST_OBJS_DEPS) | 
| Ronald Cron | b6d6d4c | 2020-06-03 10:11:18 +0200 | [diff] [blame] | 179 | echo "  CC    $<" | 
|  | 180 | $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $< | 
|  | 181 |  | 
| Steven Cooreman | a70d588 | 2020-07-16 20:26:18 +0200 | [diff] [blame] | 182 | src/drivers/%.o : src/drivers/%.c | 
|  | 183 | echo "  CC    $<" | 
|  | 184 | $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $< | 
|  | 185 |  | 
| Yanray Wang | b458b8c | 2022-10-28 11:49:33 +0800 | [diff] [blame] | 186 | src/test_helpers/%.o : src/test_helpers/%.c | 
|  | 187 | echo "  CC    $<" | 
|  | 188 | $(CC) $(LOCAL_CFLAGS) $(CFLAGS) -o $@ -c $< | 
|  | 189 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 190 | C_FILES := $(addsuffix .c,$(APPS)) $(addsuffix .c,$(CRYPTO_APPS)) | 
| Gilles Peskine | 1d7cc08 | 2022-11-10 19:50:34 +0100 | [diff] [blame] | 191 | c: $(C_FILES) | 
| Mohammad Azim Khan | 94aefaf | 2017-03-23 12:32:54 +0000 | [diff] [blame] | 192 |  | 
| Azim Khan | 27a35e7 | 2018-06-29 12:39:19 +0100 | [diff] [blame] | 193 | # Wildcard target for test code generation: | 
|  | 194 | # A .c file is generated for each .data file in the suites/ directory. Each .c | 
|  | 195 | # file depends on a .data and .function file from suites/ directory. Following | 
|  | 196 | # nameing convention is followed: | 
|  | 197 | # | 
|  | 198 | #     C file        |        Depends on | 
|  | 199 | #----------------------------------------------------------------------------- | 
|  | 200 | #  foo.c            | suites/foo.function suites/foo.data | 
|  | 201 | #  foo.bar.c        | suites/foo.function suites/foo.bar.data | 
|  | 202 | # | 
|  | 203 | # Note above that .c and .data files have same base name. | 
|  | 204 | # However, corresponding .function file's base name is the word before first | 
|  | 205 | # dot in .c file's base name. | 
|  | 206 | # | 
| Mohammad Azim Khan | 94aefaf | 2017-03-23 12:32:54 +0000 | [diff] [blame] | 207 | .SECONDEXPANSION: | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 208 | %.c: suites/$$(firstword $$(subst ., ,$$*)).function suites/%.data ../framework/scripts/generate_test_code.py ../tf-psa-crypto/tests/suites/helpers.function ../tf-psa-crypto/tests/suites/main_test.function ../tf-psa-crypto/tests/suites/host_test.function | 
| Manuel Pégourié-Gonnard | 78ec2b0 | 2015-07-08 22:12:06 +0100 | [diff] [blame] | 209 | echo "  Gen   $@" | 
| David Horstmann | f6f3bca | 2024-05-29 17:57:08 +0100 | [diff] [blame] | 210 | $(PYTHON) ../framework/scripts/generate_test_code.py -f suites/$(firstword $(subst ., ,$*)).function \ | 
| Mohammad Azim Khan | fff4904 | 2017-03-28 01:48:31 +0100 | [diff] [blame] | 211 | -d suites/$*.data \ | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 212 | -t ../tf-psa-crypto/tests/suites/main_test.function \ | 
|  | 213 | -p ../tf-psa-crypto/tests/suites/host_test.function \ | 
|  | 214 | -s suites  \ | 
|  | 215 | --helpers-file ../tf-psa-crypto/tests/suites/helpers.function \ | 
|  | 216 | -o . | 
|  | 217 |  | 
|  | 218 | ../tf-psa-crypto/tests/%.c: ../tf-psa-crypto/tests/suites/$$(firstword $$(subst ., ,$$*)).function ../tf-psa-crypto/tests/suites/%.data ../framework/scripts/generate_test_code.py ../tf-psa-crypto/tests/suites/helpers.function ../tf-psa-crypto/tests/suites/main_test.function ../tf-psa-crypto/tests/suites/host_test.function | 
|  | 219 | echo "  Gen   $@" | 
|  | 220 | cd ../tf-psa-crypto/tests && $(PYTHON) ../../framework/scripts/generate_test_code.py -f suites/$(firstword $(subst ., ,$*)).function \ | 
|  | 221 | -d suites/$*.data \ | 
| Azim Khan | 1de892b | 2017-06-09 15:02:36 +0100 | [diff] [blame] | 222 | -t suites/main_test.function \ | 
| Mohammad Azim Khan | 9540261 | 2017-07-19 10:15:54 +0100 | [diff] [blame] | 223 | -p suites/host_test.function \ | 
| Mohammad Azim Khan | fff4904 | 2017-03-28 01:48:31 +0100 | [diff] [blame] | 224 | -s suites  \ | 
| Azim Khan | e3b26af | 2018-06-29 02:36:57 +0100 | [diff] [blame] | 225 | --helpers-file suites/helpers.function \ | 
| Mohammad Azim Khan | fff4904 | 2017-03-28 01:48:31 +0100 | [diff] [blame] | 226 | -o . | 
| Paul Bakker | 286bf3c | 2013-04-08 18:09:51 +0200 | [diff] [blame] | 227 |  | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 228 | $(BINARIES): %$(EXEXT): %.c $(MBEDLIBS) $(TEST_OBJS_DEPS) $(MBEDTLS_TEST_OBJS) | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 229 | echo "  CC   $<" | 
| Gilles Peskine | 4ad5733 | 2023-12-22 11:30:30 +0100 | [diff] [blame] | 230 | $(CC) $(LOCAL_CFLAGS) $(CFLAGS) $< $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@ | 
| Paul Bakker | 286bf3c | 2013-04-08 18:09:51 +0200 | [diff] [blame] | 231 |  | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 232 | LOCAL_CRYPTO_CFLAGS = $(patsubst -I./include, -I../../tests/include, $(patsubst -I../%,-I../../%, $(LOCAL_CFLAGS))) | 
|  | 233 | LOCAL_CRYPTO_LDFLAGS = $(patsubst -L../library, -L../../library, \ | 
|  | 234 | $(patsubst -L../tests/%, -L../../tests/%, \ | 
|  | 235 | $(patsubst ./src/%,../../tests/src/%, $(LOCAL_LDFLAGS)))) | 
|  | 236 | $(CRYPTO_BINARIES): %$(EXEXT): %.c $(MBEDLIBS) $(TEST_OBJS_DEPS) $(MBEDTLS_TEST_OBJS) | 
|  | 237 | echo "  CC   $<" | 
|  | 238 | cd ../tf-psa-crypto/tests && $(CC) $(LOCAL_CRYPTO_CFLAGS) $(CFLAGS) $(subst $(EXEXT),,$(@F)).c $(LOCAL_CRYPTO_LDFLAGS) $(LDFLAGS) -o $(@F) | 
|  | 239 |  | 
| Paul Bakker | 0049c2f | 2009-07-11 19:15:43 +0000 | [diff] [blame] | 240 | clean: | 
| Paul Bakker | 62f88dc | 2012-05-10 21:26:28 +0000 | [diff] [blame] | 241 | ifndef WINDOWS | 
| Valerio Setti | 0917265 | 2024-06-27 08:00:54 +0200 | [diff] [blame] | 242 | $(MAKE) -C psa-client-server/psasim clean | 
| Gilles Peskine | d025422 | 2021-09-14 11:28:22 +0200 | [diff] [blame] | 243 | rm -rf $(BINARIES) *.c *.datax | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 244 | rm -rf $(CRYPTO_BINARIES) ../tf-psa-crypto/tests/*.c ../tf-psa-crypto/tests/*.datax | 
| Valerio Setti | 96daf67 | 2024-04-11 11:50:46 +0200 | [diff] [blame] | 245 | rm -f src/*.o src/drivers/*.o src/test_helpers/*.o src/libmbed* src/test_keys.h src/test_certs.h | 
|  | 246 | rm -f src/test_keys.h src/test_certs.h | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 247 | rm -f include/test/instrument_record_status.h | 
| Gilles Peskine | df6e84a | 2023-02-22 22:09:51 +0100 | [diff] [blame] | 248 | rm -f include/alt-extra/*/*_alt.h | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 249 | rm -rf libtestdriver1 | 
| Valerio Setti | d1b6ef1 | 2024-05-07 16:00:21 +0200 | [diff] [blame] | 250 | rm -rf libpsaclient libpsaserver | 
| Manuel Pégourié-Gonnard | 8510105 | 2022-12-29 16:04:35 +0100 | [diff] [blame] | 251 | rm -f ../library/libtestdriver1.a | 
| Manuel Pégourié-Gonnard | 5c59a4f | 2015-06-24 13:06:24 +0200 | [diff] [blame] | 252 | else | 
| Darryl Green | 6c0f94c | 2018-10-17 16:12:33 +0100 | [diff] [blame] | 253 | if exist *.c del /Q /F *.c | 
|  | 254 | if exist *.exe del /Q /F *.exe | 
|  | 255 | if exist *.datax del /Q /F *.datax | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 256 | if exist ../tf-psa-crypto/tests/*.c del /Q /F ../tf-psa-crypto/tests/*.c | 
|  | 257 | if exist ../tf-psa-crypto/tests/*.exe del /Q /F ../tf-psa-crypto/tests/*.exe | 
|  | 258 | if exist ../tf-psa-crypto/tests/*.datax del /Q /F ../tf-psa-crypto/tests/*.datax | 
| Ronald Cron | b6d6d4c | 2020-06-03 10:11:18 +0200 | [diff] [blame] | 259 | if exist src/*.o del /Q /F src/*.o | 
| Steven Cooreman | a70d588 | 2020-07-16 20:26:18 +0200 | [diff] [blame] | 260 | if exist src/drivers/*.o del /Q /F src/drivers/*.o | 
| Valerio Setti | 96daf67 | 2024-04-11 11:50:46 +0200 | [diff] [blame] | 261 | if exist src/test_keys.h del /Q /F src/test_keys.h | 
|  | 262 | if exist src/test_certs.h del /Q /F src/test_cers.h | 
| Yanray Wang | b458b8c | 2022-10-28 11:49:33 +0800 | [diff] [blame] | 263 | if exist src/test_helpers/*.o del /Q /F src/test_helpers/*.o | 
| Ronald Cron | b6d6d4c | 2020-06-03 10:11:18 +0200 | [diff] [blame] | 264 | if exist src/libmbed* del /Q /F src/libmed* | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 265 | if exist include/test/instrument_record_status.h del /Q /F include/test/instrument_record_status.h | 
| Azim Khan | 27a35e7 | 2018-06-29 12:39:19 +0100 | [diff] [blame] | 266 | endif | 
| Paul Bakker | 0049c2f | 2009-07-11 19:15:43 +0000 | [diff] [blame] | 267 |  | 
| Gilles Peskine | ac372cc | 2018-11-29 10:15:06 +0000 | [diff] [blame] | 268 | # Test suites caught by SKIP_TEST_SUITES are built but not executed. | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 269 | check: $(BINARIES) $(CRYPTO_BINARIES) | 
| Gilles Peskine | 396853a | 2021-09-20 18:57:55 +0200 | [diff] [blame] | 270 | perl scripts/run-test-suites.pl $(TEST_FLAGS) --skip=$(SKIP_TEST_SUITES) | 
| Ronald Cron | 901a675 | 2024-07-09 14:24:16 +0200 | [diff] [blame] | 271 | cd ../tf-psa-crypto/tests && perl ../../tests/scripts/run-test-suites.pl $(TEST_FLAGS) --skip=$(SKIP_TEST_SUITES) | 
| Manuel Pégourié-Gonnard | 5c59a4f | 2015-06-24 13:06:24 +0200 | [diff] [blame] | 272 |  | 
|  | 273 | test: check | 
| Mohammad Azim Khan | 1f29be7 | 2017-03-20 22:21:22 +0000 | [diff] [blame] | 274 |  | 
| Gilles Peskine | df6e84a | 2023-02-22 22:09:51 +0100 | [diff] [blame] | 275 | # Generate variants of some headers for testing | 
|  | 276 | include/alt-extra/%_alt.h: ../include/%.h | 
|  | 277 | perl -p -e 's/^(# *(define|ifndef) +\w+_)H\b/$${1}ALT_H/' $< >$@ | 
| Ronald Cron | c7e9e36 | 2024-06-10 09:41:49 +0200 | [diff] [blame] | 278 | include/alt-extra/%_alt.h: ../tf-psa-crypto/include/%.h | 
|  | 279 | perl -p -e 's/^(# *(define|ifndef) +\w+_)H\b/$${1}ALT_H/' $< >$@ | 
| Ronald Cron | 3d817ad | 2024-06-14 08:43:28 +0200 | [diff] [blame] | 280 | include/alt-extra/%_alt.h: ../tf-psa-crypto/drivers/builtin/include/%.h | 
|  | 281 | perl -p -e 's/^(# *(define|ifndef) +\w+_)H\b/$${1}ALT_H/' $< >$@ | 
| Gilles Peskine | df6e84a | 2023-02-22 22:09:51 +0100 | [diff] [blame] | 282 |  | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 283 | # Generate test library | 
|  | 284 |  | 
|  | 285 | # Perl code that is executed to transform each original line from a library | 
|  | 286 | # source file into the corresponding line in the test driver copy of the | 
|  | 287 | # library. Add a LIBTESTDRIVER1_/libtestdriver1_ to mbedtls_xxx and psa_xxx | 
|  | 288 | # symbols. | 
|  | 289 | define libtestdriver1_rewrite := | 
| Ronald Cron | 52cc858 | 2024-06-17 17:26:39 +0200 | [diff] [blame] | 290 | s!^(\s*#\s*include\s*[\"<])mbedtls/build_info.h!$${1}libtestdriver1/include/mbedtls/build_info.h!; \ | 
|  | 291 | s!^(\s*#\s*include\s*[\"<])mbedtls/mbedtls_config.h!$${1}libtestdriver1/include/mbedtls/mbedtls_config.h!; \ | 
|  | 292 | s!^(\s*#\s*include\s*[\"<])mbedtls/config_adjust_legacy_crypto.h!$${1}libtestdriver1/include/mbedtls/config_adjust_legacy_crypto.h!; \ | 
|  | 293 | s!^(\s*#\s*include\s*[\"<])mbedtls/config_adjust_x509.h!$${1}libtestdriver1/include/mbedtls/config_adjust_x509.h!; \ | 
|  | 294 | s!^(\s*#\s*include\s*[\"<])mbedtls/config_adjust_ssl.h!$${1}libtestdriver1/include/mbedtls/config_adjust_ssl.h!; \ | 
|  | 295 | s!^(\s*#\s*include\s*[\"<])mbedtls/check_config.h!$${1}libtestdriver1/include/mbedtls/check_config.h!; \ | 
|  | 296 | s!^(\s*#\s*include\s*[\"<])mbedtls/!$${1}libtestdriver1/tf-psa-crypto/drivers/builtin/include/mbedtls/!; \ | 
| Ronald Cron | 1451a76 | 2024-06-10 16:02:04 +0200 | [diff] [blame] | 297 | s!^(\s*#\s*include\s*[\"<])psa/!$${1}libtestdriver1/tf-psa-crypto/include/psa/!; \ | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 298 | next if /^\s*#\s*include/; \ | 
|  | 299 | s/\b(?=MBEDTLS_|PSA_)/LIBTESTDRIVER1_/g; \ | 
|  | 300 | s/\b(?=mbedtls_|psa_)/libtestdriver1_/g; | 
|  | 301 | endef | 
|  | 302 |  | 
|  | 303 | libtestdriver1.a: | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 304 | rm -Rf ./libtestdriver1 | 
|  | 305 | mkdir ./libtestdriver1 | 
| Ronald Cron | 4cc77a1 | 2024-07-02 08:52:26 +0200 | [diff] [blame] | 306 | mkdir ./libtestdriver1/tf-psa-crypto | 
|  | 307 | mkdir ./libtestdriver1/tf-psa-crypto/drivers | 
|  | 308 | mkdir ./libtestdriver1/tf-psa-crypto/drivers/everest | 
|  | 309 | mkdir ./libtestdriver1/tf-psa-crypto/drivers/p256-m | 
|  | 310 | touch ./libtestdriver1/tf-psa-crypto/drivers/everest/Makefile.inc | 
|  | 311 | touch ./libtestdriver1/tf-psa-crypto/drivers/p256-m/Makefile.inc | 
| Ronald Cron | b2bdb78 | 2024-07-02 07:59:11 +0200 | [diff] [blame] | 312 | cp -Rf ../framework ./libtestdriver1 | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 313 | cp -Rf ../library ./libtestdriver1 | 
|  | 314 | cp -Rf ../include ./libtestdriver1 | 
| Ronald Cron | 4cc77a1 | 2024-07-02 08:52:26 +0200 | [diff] [blame] | 315 | cp -Rf ../tf-psa-crypto/core ./libtestdriver1/tf-psa-crypto | 
|  | 316 | cp -Rf ../tf-psa-crypto/include ./libtestdriver1/tf-psa-crypto | 
|  | 317 | cp -Rf ../tf-psa-crypto/drivers/builtin ./libtestdriver1/tf-psa-crypto/drivers | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 318 | cp -Rf ../scripts ./libtestdriver1 | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 319 |  | 
|  | 320 | # Set the test driver base (minimal) configuration. | 
|  | 321 | cp ./include/test/drivers/config_test_driver.h ./libtestdriver1/include/mbedtls/mbedtls_config.h | 
|  | 322 |  | 
|  | 323 | # Set the PSA cryptography configuration for the test library. | 
|  | 324 | # It is set from the copied include/psa/crypto_config.h of the Mbed TLS | 
|  | 325 | # library the test library is intended to be linked with extended by | 
|  | 326 | # ./include/test/drivers/crypto_config_test_driver_extension.h to | 
|  | 327 | # mirror the PSA_ACCEL_* macros. | 
| Ronald Cron | 1451a76 | 2024-06-10 16:02:04 +0200 | [diff] [blame] | 328 | mv ./libtestdriver1/tf-psa-crypto/include/psa/crypto_config.h ./libtestdriver1/tf-psa-crypto/include/psa/crypto_config.h.bak | 
|  | 329 | head -n -1 ./libtestdriver1/tf-psa-crypto/include/psa/crypto_config.h.bak > ./libtestdriver1/tf-psa-crypto/include/psa/crypto_config.h | 
|  | 330 | cat ./include/test/drivers/crypto_config_test_driver_extension.h >> ./libtestdriver1/tf-psa-crypto/include/psa/crypto_config.h | 
|  | 331 | echo "#endif /* PSA_CRYPTO_CONFIG_H */" >> ./libtestdriver1/tf-psa-crypto/include/psa/crypto_config.h | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 332 |  | 
|  | 333 | # Prefix MBEDTLS_* PSA_* symbols with LIBTESTDRIVER1_ as well as | 
|  | 334 | # mbedtls_* psa_* symbols with libtestdriver1_ to avoid symbol clash | 
|  | 335 | # when this test driver library is linked with the Mbed TLS library. | 
|  | 336 | perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/library/*.[ch] | 
|  | 337 | perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/include/*/*.h | 
| Ronald Cron | b2bdb78 | 2024-07-02 07:59:11 +0200 | [diff] [blame] | 338 | perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/tf-psa-crypto/core/*.[ch] | 
| Ronald Cron | 1451a76 | 2024-06-10 16:02:04 +0200 | [diff] [blame] | 339 | perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/tf-psa-crypto/include/*/*.h | 
| Ronald Cron | 52cc858 | 2024-06-17 17:26:39 +0200 | [diff] [blame] | 340 | perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/tf-psa-crypto/drivers/builtin/include/*/*.h | 
| Ronald Cron | b2bdb78 | 2024-07-02 07:59:11 +0200 | [diff] [blame] | 341 | perl -pi -e '$(libtestdriver1_rewrite)' ./libtestdriver1/tf-psa-crypto/drivers/builtin/src/*.[ch] | 
| Ronald Cron | 72b25da | 2021-04-28 18:29:24 +0200 | [diff] [blame] | 342 |  | 
|  | 343 | $(MAKE) -C ./libtestdriver1/library CFLAGS="-I../../ $(CFLAGS)" LDFLAGS="$(LDFLAGS)" libmbedcrypto.a | 
|  | 344 | cp ./libtestdriver1/library/libmbedcrypto.a ../library/libtestdriver1.a | 
|  | 345 |  | 
| Gilles Peskine | 5168155 | 2019-05-20 19:35:37 +0200 | [diff] [blame] | 346 | ifdef RECORD_PSA_STATUS_COVERAGE_LOG | 
| Ronald Cron | c7e9e36 | 2024-06-10 09:41:49 +0200 | [diff] [blame] | 347 | include/test/instrument_record_status.h: ../tf-psa-crypto/include/psa/crypto.h Makefile | 
| Gilles Peskine | d71539f | 2020-11-25 18:17:17 +0100 | [diff] [blame] | 348 | echo "  Gen  $@" | 
| Ronald Cron | c7e9e36 | 2024-06-10 09:41:49 +0200 | [diff] [blame] | 349 | sed <../tf-psa-crypto/include/psa/crypto.h >$@ -n 's/^psa_status_t \([A-Za-z0-9_]*\)(.*/#define \1(...) RECORD_STATUS("\1", \1(__VA_ARGS__))/p' | 
| Gilles Peskine | 5168155 | 2019-05-20 19:35:37 +0200 | [diff] [blame] | 350 | endif |