The current lookup prefers a strong definition to a STB_WEAK definition (similar
to glibc pre-2.2 behavior) which idoes non-t conforming to the ELF specification.
The non-compliant behavior provoked https://reviews.llvm.org/D4418 which was intended to fix
intended to fix -shared-libasan but introduced new problems (and caused some sanitizer tests (e.g. `test/asan/TestCases/interception_failure_test.cpp`) to fail):
sanitizer interceptors are STB_GLOBAL instead of STB_WEAK,tests (e.g. so defining`test/asan/TestCases/interception_failure_test.cpp`) to
a second STB_GLOBALfail): sanitizer interceptor can lead to a multiple definition linker error.s are STB_GLOBAL instead of STB_WEAK, so defining a
For example, in asecond STB_GLOBAL interceptor can lead to a multiple definition linker error.
For example, in a `-fsanitize={address,memory,...}` build, libc functions like
malloc/free/strtol/... cannot be provided by user object files.
See See
https://docs.freebsd.org/cgi/getmsg.cgi?fetch=16483939+0+archive/2014/freebsd-current/20140716.freebsd-current for discussions
for discussions.
This patch makes the behavior ELF compliant by default and allows users
to specify `LD_DYNAMIC_WEAK` to restore the old behavior.
As advised by kib, STB_WEAK wrestling in symbol lookups in `Search the dynamic
linker itself` are untouched.