platform_bionic/libdl
Mitch Phillips a493fe4153 Add the recoverable GWP-ASan feature.
GWP-ASan's recoverable mode was landed upstream in
https://reviews.llvm.org/D140173.

This mode allows for a use-after-free or a buffer-overflow bug to be
detected by GWP-ASan, a crash report dumped, but then GWP-ASan (through
the preCrashReport() and postCrashReportRecoverableOnly() hooks) will
patch up the memory so that the process can continue, in spite of the
memory safety bug.

This is desirable, as it allows us to consider migrating non-system apps
from opt-in GWP-ASan to opt-out GWP-ASan. The major concern was "if we
make it opt-out, then bad apps will start crashing". If we don't crash,
problem solved :). Obviously, we'll need to do this with an amount of
process sampling to mitigate against the 70KiB memory overhead.

The biggest problem is that the debuggerd signal handler isn't the first
signal handler for apps, it's the sigchain handler inside of libart.
Clearly, the sigchain handler needs to ask us whether the crash is
GWP-ASan's fault, and if so, please patch up the allocator. Because of
linker namespace restrictions, libart can't directly ask the linker
(which is where debuggerd lies), so we provide a proxy function in libc.

Test: Build the platform, run sanitizer-status and various test apps
with recoverable gwp-asan. Assert that it doesn't crash, and we get a
debuggerd report.
Bug: 247012630

Change-Id: I86d5e27a9ca5531c8942e62647fd377c3cd36dfd
2023-02-02 15:35:25 -08:00
..
Android.bp Build libdl for risc-v. 2022-10-11 19:01:30 +00:00
libdl.cpp Add the recoverable GWP-ASan feature. 2023-02-02 15:35:25 -08:00
libdl.map.txt Add the recoverable GWP-ASan feature. 2023-02-02 15:35:25 -08:00
libdl_android.cpp Delete definitions of __aeabi_unwind_cpp_pr0. 2020-01-10 10:40:43 -08:00
libdl_android.map.txt Move platform-private symbols out of libdl.so 2019-04-01 13:16:33 +02:00
libdl_cfi.cpp Fix a few bionic test failures caused by hwasan global instrumentation. 2019-08-15 09:21:34 -07:00
libdl_static.cpp Move dl_unwind_find_exidx from libdl.a to libc.a 2019-10-14 16:34:12 -07:00
MODULE_LICENSE_APACHE2 Move libdl and linker to static NOTICE files. 2019-04-19 14:18:07 -07:00
NOTICE Fix/update notices. 2021-02-16 15:06:50 -08:00