diff --git a/bl2u/bl2u_main.c b/bl2u/bl2u_main.c index a7e3fb9..b29d57e 100644 --- a/bl2u/bl2u_main.c +++ b/bl2u/bl2u_main.c @@ -17,6 +17,7 @@ #include #include + /******************************************************************************* * This function is responsible to: * Load SCP_BL2U if platform has defined SCP_BL2U_BASE diff --git a/drivers/auth/mbedtls/mbedtls_common.c b/drivers/auth/mbedtls/mbedtls_common.c index c048d00..64dc196 100644 --- a/drivers/auth/mbedtls/mbedtls_common.c +++ b/drivers/auth/mbedtls/mbedtls_common.c @@ -5,6 +5,7 @@ */ #include +#include /* mbed TLS headers */ #include @@ -23,6 +24,12 @@ #endif static unsigned char heap[MBEDTLS_HEAP_SIZE]; +static void cleanup(void) +{ + ERROR("EXIT from BL2\n"); + panic(); +} + /* * mbed TLS initialization function */ @@ -31,6 +38,9 @@ static int ready; if (!ready) { + if (atexit(cleanup)) + panic(); + /* Initialize the mbed TLS heap */ mbedtls_memory_buffer_alloc_init(heap, MBEDTLS_HEAP_SIZE); diff --git a/lib/libc/exit.c b/lib/libc/exit.c index afc3f93..b2fde9c 100644 --- a/lib/libc/exit.c +++ b/lib/libc/exit.c @@ -4,11 +4,23 @@ * SPDX-License-Identifier: BSD-3-Clause */ -#include #include -void exit(int v) +static void (*exitfun)(void); + +void exit(int status) { - ERROR("EXIT\n"); - panic(); + if (exitfun) + (*exitfun)(); + for (;;) + ; +} + +int atexit(void (*fun)(void)) +{ + if (exitfun) + return -1; + exitfun = fun; + + return 0; }