mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-23 16:51:08 +00:00
Merge pull request #304 from gilles-peskine-arm/asan-test-fail-crypto
Make sure Asan failures are detected in 'make test'
This commit is contained in:
commit
0eaf49c9be
|
@ -128,6 +128,9 @@ pre_initialize_variables () {
|
||||||
# Include more verbose output for failing tests run by CMake
|
# Include more verbose output for failing tests run by CMake
|
||||||
export CTEST_OUTPUT_ON_FAILURE=1
|
export CTEST_OUTPUT_ON_FAILURE=1
|
||||||
|
|
||||||
|
# CFLAGS and LDFLAGS for Asan builds that don't use CMake
|
||||||
|
ASAN_CFLAGS='-Werror -Wall -Wextra -fsanitize=address,undefined -fno-sanitize-recover=all'
|
||||||
|
|
||||||
# Gather the list of available components. These are the functions
|
# Gather the list of available components. These are the functions
|
||||||
# defined in this script whose name starts with "component_".
|
# defined in this script whose name starts with "component_".
|
||||||
# Parse the script with sed, because in sh there is no way to list
|
# Parse the script with sed, because in sh there is no way to list
|
||||||
|
@ -826,7 +829,7 @@ component_test_malloc_0_null () {
|
||||||
msg "build: malloc(0) returns NULL (ASan+UBSan build)"
|
msg "build: malloc(0) returns NULL (ASan+UBSan build)"
|
||||||
scripts/config.pl full
|
scripts/config.pl full
|
||||||
scripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_C
|
scripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_C
|
||||||
make CC=gcc CFLAGS="'-DMBEDTLS_CONFIG_FILE=\"$PWD/tests/configs/config-wrapper-malloc-0-null.h\"' -O -Werror -Wall -Wextra -fsanitize=address,undefined" LDFLAGS='-fsanitize=address,undefined'
|
make CC=gcc CFLAGS="'-DMBEDTLS_CONFIG_FILE=\"$PWD/tests/configs/config-wrapper-malloc-0-null.h\"' $ASAN_CFLAGS -O" LDFLAGS="$ASAN_CFLAGS"
|
||||||
|
|
||||||
msg "test: malloc(0) returns NULL (ASan+UBSan build)"
|
msg "test: malloc(0) returns NULL (ASan+UBSan build)"
|
||||||
make test
|
make test
|
||||||
|
@ -868,7 +871,7 @@ component_test_aes_fewer_tables_and_rom_tables () {
|
||||||
component_test_se_default () {
|
component_test_se_default () {
|
||||||
msg "build: default config + MBEDTLS_PSA_CRYPTO_SE_C"
|
msg "build: default config + MBEDTLS_PSA_CRYPTO_SE_C"
|
||||||
scripts/config.pl set MBEDTLS_PSA_CRYPTO_SE_C
|
scripts/config.pl set MBEDTLS_PSA_CRYPTO_SE_C
|
||||||
make CC=clang CFLAGS='-Werror -Wall -Wextra -Wno-unused-function -Os -fsanitize=address' LDFLAGS='-fsanitize=address'
|
make CC=clang CFLAGS="$ASAN_CFLAGS -Os" LDFLAGS="$ASAN_CFLAGS"
|
||||||
|
|
||||||
msg "test: default config + MBEDTLS_PSA_CRYPTO_SE_C"
|
msg "test: default config + MBEDTLS_PSA_CRYPTO_SE_C"
|
||||||
make test
|
make test
|
||||||
|
@ -877,7 +880,7 @@ component_test_se_default () {
|
||||||
component_test_se_full () {
|
component_test_se_full () {
|
||||||
msg "build: full config + MBEDTLS_PSA_CRYPTO_SE_C"
|
msg "build: full config + MBEDTLS_PSA_CRYPTO_SE_C"
|
||||||
scripts/config.pl set MBEDTLS_PSA_CRYPTO_SE_C
|
scripts/config.pl set MBEDTLS_PSA_CRYPTO_SE_C
|
||||||
make CC=gcc CFLAGS='-Werror -Wall -Wextra -O2 -fsanitize=address' LDFLAGS='-fsanitize=address'
|
make CC=gcc CFLAGS="$ASAN_CFLAGS -O2" LDFLAGS="$ASAN_CFLAGS"
|
||||||
|
|
||||||
msg "test: full config + MBEDTLS_PSA_CRYPTO_SE_C"
|
msg "test: full config + MBEDTLS_PSA_CRYPTO_SE_C"
|
||||||
make test
|
make test
|
||||||
|
@ -912,7 +915,7 @@ component_test_m32_o0 () {
|
||||||
# Build once with -O0, to compile out the i386 specific inline assembly
|
# Build once with -O0, to compile out the i386 specific inline assembly
|
||||||
msg "build: i386, make, gcc -O0 (ASan build)" # ~ 30s
|
msg "build: i386, make, gcc -O0 (ASan build)" # ~ 30s
|
||||||
scripts/config.pl full
|
scripts/config.pl full
|
||||||
make CC=gcc CFLAGS='-O0 -Werror -Wall -Wextra -m32 -fsanitize=address' LDFLAGS='-m32 -fsanitize=address'
|
make CC=gcc CFLAGS="$ASAN_CFLAGS -m32 -O0" LDFLAGS="-m32 $ASAN_CFLAGS"
|
||||||
|
|
||||||
msg "test: i386, make, gcc -O0 (ASan build)"
|
msg "test: i386, make, gcc -O0 (ASan build)"
|
||||||
make test
|
make test
|
||||||
|
@ -931,7 +934,7 @@ component_test_m32_o1 () {
|
||||||
scripts/config.pl unset MBEDTLS_MEMORY_BACKTRACE
|
scripts/config.pl unset MBEDTLS_MEMORY_BACKTRACE
|
||||||
scripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_C
|
scripts/config.pl unset MBEDTLS_MEMORY_BUFFER_ALLOC_C
|
||||||
scripts/config.pl unset MBEDTLS_MEMORY_DEBUG
|
scripts/config.pl unset MBEDTLS_MEMORY_DEBUG
|
||||||
make CC=gcc CFLAGS='-O1 -Werror -Wall -Wextra -m32 -fsanitize=address' LDFLAGS='-m32 -fsanitize=address'
|
make CC=gcc CFLAGS="$ASAN_CFLAGS -m32 -O1" LDFLAGS="-m32 $ASAN_CFLAGS"
|
||||||
|
|
||||||
msg "test: i386, make, gcc -O1 (ASan build)"
|
msg "test: i386, make, gcc -O1 (ASan build)"
|
||||||
make test
|
make test
|
||||||
|
@ -944,7 +947,7 @@ component_test_m32_everest () {
|
||||||
msg "build: i386, Everest ECDH context (ASan build)" # ~ 6 min
|
msg "build: i386, Everest ECDH context (ASan build)" # ~ 6 min
|
||||||
scripts/config.pl unset MBEDTLS_ECDH_LEGACY_CONTEXT
|
scripts/config.pl unset MBEDTLS_ECDH_LEGACY_CONTEXT
|
||||||
scripts/config.pl set MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED
|
scripts/config.pl set MBEDTLS_ECDH_VARIANT_EVEREST_ENABLED
|
||||||
make CC=gcc CFLAGS='-O2 -Werror -Wall -Wextra -m32 -fsanitize=address'
|
make CC=gcc CFLAGS="$ASAN_CFLAGS -m32 -O2" LDFLAGS="-m32 $ASAN_CFLAGS"
|
||||||
|
|
||||||
msg "test: i386, Everest ECDH context - main suites (inc. selftests) (ASan build)" # ~ 50s
|
msg "test: i386, Everest ECDH context - main suites (inc. selftests) (ASan build)" # ~ 50s
|
||||||
make test
|
make test
|
||||||
|
|
|
@ -93,7 +93,7 @@ for my $suite (@suites)
|
||||||
$suite_cases_failed = () = $result =~ /.. FAILED/g;
|
$suite_cases_failed = () = $result =~ /.. FAILED/g;
|
||||||
$suite_cases_skipped = () = $result =~ /.. ----/g;
|
$suite_cases_skipped = () = $result =~ /.. ----/g;
|
||||||
|
|
||||||
if( $result =~ /PASSED/ ) {
|
if( $? == 0 ) {
|
||||||
print "PASS\n";
|
print "PASS\n";
|
||||||
if( $verbose > 2 ) {
|
if( $verbose > 2 ) {
|
||||||
pad_print_center( 72, '-', "Begin $suite" );
|
pad_print_center( 72, '-', "Begin $suite" );
|
||||||
|
|
|
@ -565,16 +565,17 @@ static int check_persistent_data( psa_key_lifetime_t lifetime,
|
||||||
psa_storage_uid_t uid = file_uid_for_lifetime( lifetime );
|
psa_storage_uid_t uid = file_uid_for_lifetime( lifetime );
|
||||||
struct psa_storage_info_t info;
|
struct psa_storage_info_t info;
|
||||||
uint8_t *loaded = NULL;
|
uint8_t *loaded = NULL;
|
||||||
|
int ok = 0;
|
||||||
|
|
||||||
PSA_ASSERT( psa_its_get_info( uid, &info ) );
|
PSA_ASSERT( psa_its_get_info( uid, &info ) );
|
||||||
ASSERT_ALLOC( loaded, info.size );
|
ASSERT_ALLOC( loaded, info.size );
|
||||||
PSA_ASSERT( psa_its_get( uid, 0, info.size, loaded, NULL ) );
|
PSA_ASSERT( psa_its_get( uid, 0, info.size, loaded, NULL ) );
|
||||||
ASSERT_COMPARE( expected_data, size, loaded, info.size );
|
ASSERT_COMPARE( expected_data, size, loaded, info.size );
|
||||||
return( 1 );
|
ok = 1;
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
mbedtls_free( loaded );
|
mbedtls_free( loaded );
|
||||||
return( 0 );
|
return( ok );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check that a function's return status is "smoke-free", i.e. that
|
/* Check that a function's return status is "smoke-free", i.e. that
|
||||||
|
|
Loading…
Reference in a new issue