mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-08-05 19:35:48 +03:00
Test the PSA alternative header configuration macros
Test that MBEDTLS_PSA_CRYPTO_PLATFORM_FILE and MBEDTLS_PSA_CRYPTO_STRUCT_FILE can be set to files in a directory that comes after the standard directory in the include file search path. Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
1
programs/.gitignore
vendored
1
programs/.gitignore
vendored
@@ -64,6 +64,7 @@ test/cpp_dummy_build.cpp
|
|||||||
test/dlopen
|
test/dlopen
|
||||||
test/ecp-bench
|
test/ecp-bench
|
||||||
test/query_compile_time_config
|
test/query_compile_time_config
|
||||||
|
test/query_included_headers
|
||||||
test/selftest
|
test/selftest
|
||||||
test/ssl_cert_test
|
test/ssl_cert_test
|
||||||
test/udp_proxy
|
test/udp_proxy
|
||||||
|
@@ -123,6 +123,7 @@ APPS = \
|
|||||||
ssl/ssl_server2 \
|
ssl/ssl_server2 \
|
||||||
test/benchmark \
|
test/benchmark \
|
||||||
test/query_compile_time_config \
|
test/query_compile_time_config \
|
||||||
|
test/query_included_headers \
|
||||||
test/selftest \
|
test/selftest \
|
||||||
test/udp_proxy \
|
test/udp_proxy \
|
||||||
test/zeroize \
|
test/zeroize \
|
||||||
@@ -403,6 +404,10 @@ test/query_config.o: test/query_config.c test/query_config.h $(DEP)
|
|||||||
echo " CC test/query_config.c"
|
echo " CC test/query_config.c"
|
||||||
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) -c test/query_config.c -o $@
|
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) -c test/query_config.c -o $@
|
||||||
|
|
||||||
|
test/query_included_headers$(EXEXT): test/query_included_headers.c $(DEP)
|
||||||
|
echo " CC test/query_included_headers.c"
|
||||||
|
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) test/query_included_headers.c $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@
|
||||||
|
|
||||||
test/selftest$(EXEXT): test/selftest.c $(DEP)
|
test/selftest$(EXEXT): test/selftest.c $(DEP)
|
||||||
echo " CC test/selftest.c"
|
echo " CC test/selftest.c"
|
||||||
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) test/selftest.c $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@
|
$(CC) $(LOCAL_CFLAGS) $(CFLAGS) test/selftest.c $(LOCAL_LDFLAGS) $(LDFLAGS) -o $@
|
||||||
|
@@ -3,6 +3,7 @@ set(libs
|
|||||||
)
|
)
|
||||||
|
|
||||||
set(executables_libs
|
set(executables_libs
|
||||||
|
query_included_headers
|
||||||
selftest
|
selftest
|
||||||
udp_proxy
|
udp_proxy
|
||||||
)
|
)
|
||||||
|
41
programs/test/query_included_headers.c
Normal file
41
programs/test/query_included_headers.c
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
/* Ad hoc report on included headers. */
|
||||||
|
/*
|
||||||
|
* Copyright The Mbed TLS Contributors
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <psa/crypto.h>
|
||||||
|
#include <mbedtls/platform.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
|
||||||
|
/* Which PSA platform header? */
|
||||||
|
#if defined(PSA_CRYPTO_PLATFORM_H)
|
||||||
|
mbedtls_printf("PSA_CRYPTO_PLATFORM_H\n");
|
||||||
|
#endif
|
||||||
|
#if defined(PSA_CRYPTO_PLATFORM_ALT_H)
|
||||||
|
mbedtls_printf("PSA_CRYPTO_PLATFORM_ALT_H\n");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Which PSA struct header? */
|
||||||
|
#if defined(PSA_CRYPTO_STRUCT_H)
|
||||||
|
mbedtls_printf("PSA_CRYPTO_STRUCT_H\n");
|
||||||
|
#endif
|
||||||
|
#if defined(PSA_CRYPTO_STRUCT_ALT_H)
|
||||||
|
mbedtls_printf("PSA_CRYPTO_STRUCT_ALT_H\n");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
2
tests/.gitignore
vendored
2
tests/.gitignore
vendored
@@ -13,6 +13,8 @@ data_files/hmac_drbg_seed
|
|||||||
data_files/ctr_drbg_seed
|
data_files/ctr_drbg_seed
|
||||||
data_files/entropy_seed
|
data_files/entropy_seed
|
||||||
|
|
||||||
|
include/alt-extra/psa/crypto_platform_alt.h
|
||||||
|
include/alt-extra/psa/crypto_struct_alt.h
|
||||||
include/test/instrument_record_status.h
|
include/test/instrument_record_status.h
|
||||||
|
|
||||||
src/*.o
|
src/*.o
|
||||||
|
@@ -219,6 +219,7 @@ ifndef WINDOWS
|
|||||||
rm -rf $(BINARIES) *.c *.datax
|
rm -rf $(BINARIES) *.c *.datax
|
||||||
rm -f src/*.o src/drivers/*.o src/libmbed*
|
rm -f src/*.o src/drivers/*.o src/libmbed*
|
||||||
rm -f include/test/instrument_record_status.h
|
rm -f include/test/instrument_record_status.h
|
||||||
|
rm -f include/alt-extra/*/*_alt.h
|
||||||
rm -rf libtestdriver1
|
rm -rf libtestdriver1
|
||||||
rm -f ../library/libtestdriver1.a
|
rm -f ../library/libtestdriver1.a
|
||||||
else
|
else
|
||||||
@@ -244,6 +245,10 @@ check: $(BINARIES)
|
|||||||
|
|
||||||
test: check
|
test: check
|
||||||
|
|
||||||
|
# Generate variants of some headers for testing
|
||||||
|
include/alt-extra/%_alt.h: ../include/%.h
|
||||||
|
perl -p -e 's/^(# *(define|ifndef) +\w+_)H\b/$${1}ALT_H/' $< >$@
|
||||||
|
|
||||||
# Generate test library
|
# Generate test library
|
||||||
|
|
||||||
# Perl code that is executed to transform each original line from a library
|
# Perl code that is executed to transform each original line from a library
|
||||||
|
7
tests/include/alt-extra/psa/crypto.h
Normal file
7
tests/include/alt-extra/psa/crypto.h
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
/* The goal of the include/alt-extra directory is to test what happens
|
||||||
|
* if certain files come _after_ the normal include directory.
|
||||||
|
* Make sure that if the alt-extra directory comes before the normal
|
||||||
|
* directory (so we wouldn't be achieving our test objective), the build
|
||||||
|
* will fail.
|
||||||
|
*/
|
||||||
|
#error "The normal include directory must come first in the include path"
|
@@ -3258,6 +3258,27 @@ component_build_psa_config_file () {
|
|||||||
rm -f psa_test_config.h psa_user_config.h
|
rm -f psa_test_config.h psa_user_config.h
|
||||||
}
|
}
|
||||||
|
|
||||||
|
component_build_psa_alt_headers () {
|
||||||
|
msg "build: make with PSA alt headers" # ~20s
|
||||||
|
|
||||||
|
# Generate alternative versions of the substitutable headers with the
|
||||||
|
# same content except different include guards.
|
||||||
|
make -C tests include/alt-extra/psa/crypto_platform_alt.h include/alt-extra/psa/crypto_struct_alt.h
|
||||||
|
|
||||||
|
# Build the library and some programs.
|
||||||
|
# Don't build the fuzzers to avoid having to go through hoops to set
|
||||||
|
# a correct include path for programs/fuzz/Makefile.
|
||||||
|
make CFLAGS="-I ../tests/include/alt-extra -DMBEDTLS_PSA_CRYPTO_PLATFORM_FILE='\"psa/crypto_platform_alt.h\"' -DMBEDTLS_PSA_CRYPTO_STRUCT_FILE='\"psa/crypto_struct_alt.h\"'" lib
|
||||||
|
make -C programs -o fuzz CFLAGS="-I ../tests/include/alt-extra -DMBEDTLS_PSA_CRYPTO_PLATFORM_FILE='\"psa/crypto_platform_alt.h\"' -DMBEDTLS_PSA_CRYPTO_STRUCT_FILE='\"psa/crypto_struct_alt.h\"'"
|
||||||
|
|
||||||
|
# Check that we're getting the alternative include guards and not the
|
||||||
|
# original include guards.
|
||||||
|
programs/test/query_included_headers | grep -x PSA_CRYPTO_PLATFORM_ALT_H
|
||||||
|
programs/test/query_included_headers | grep -x PSA_CRYPTO_STRUCT_ALT_H
|
||||||
|
programs/test/query_included_headers | not grep -x PSA_CRYPTO_PLATFORM_H
|
||||||
|
programs/test/query_included_headers | not grep -x PSA_CRYPTO_STRUCT_H
|
||||||
|
}
|
||||||
|
|
||||||
component_test_m32_o0 () {
|
component_test_m32_o0 () {
|
||||||
# Build without optimization, so as to use portable C code (in a 32-bit
|
# Build without optimization, so as to use portable C code (in a 32-bit
|
||||||
# build) and not the i386-specific inline assembly.
|
# build) and not the i386-specific inline assembly.
|
||||||
|
Reference in New Issue
Block a user