|  | /* | 
|  | * Copyright (c) 2019 Jan Van Winkel <jan.van_winkel@dxplore.eu> | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  |  | 
|  | #if defined(CONFIG_64BIT) && defined(__GNUC__) && !defined(__clang__) | 
|  | const char *__asan_default_options(void) | 
|  | { | 
|  | /* Running leak detection at exit could lead to a deadlock on | 
|  | * 64-bit boards if GCC is used. | 
|  | * https://github.com/zephyrproject-rtos/zephyr/issues/20122 | 
|  | */ | 
|  | return "leak_check_at_exit=0:"; | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #ifdef CONFIG_HAS_SDL | 
|  | const char *__lsan_default_suppressions(void) | 
|  | { | 
|  | /* The SDL2 library does not clean-up all it resources on exit, | 
|  | * as such suppress all memory leaks coming from libSDL2 and the | 
|  | * underlying X11 library | 
|  | */ | 
|  | return "leak:libX11\nleak:libSDL2\n"; | 
|  | } | 
|  | #endif /* CONFIG_HAS_SDL */ | 
|  |  | 
|  | #ifdef CONFIG_ASAN_NOP_DLCLOSE | 
|  | /* LSAN has a known limitation that if dlcose is called before performing the | 
|  | * leak check; "<unknown module>" is reported in the stack traces during the | 
|  | * leak check and these can not be suppressed, see | 
|  | * https://github.com/google/sanitizers/issues/89 for more info. | 
|  | * | 
|  | * A workaround for this is to implement a NOP version of dlclose. | 
|  | */ | 
|  | int dlclose(void *handler) | 
|  | { | 
|  | return 0; | 
|  | } | 
|  | #endif /* CONFIG_ASAN_NOP_DLCLOSE */ |