On Thu, May 5, 2022 at 2:02 PM H.J. Lu <hjl.to...@gmail.com> wrote: > > cherry-pick: > > b226894d475b [sanitizer] [sanitizer] Correct GetTls for x32 > --- > libsanitizer/sanitizer_common/sanitizer_linux_libcdep.cpp | 4 ++++ > 1 file changed, 4 insertions(+) > > diff --git a/libsanitizer/sanitizer_common/sanitizer_linux_libcdep.cpp > b/libsanitizer/sanitizer_common/sanitizer_linux_libcdep.cpp > index d966d857a76..620267cdd02 100644 > --- a/libsanitizer/sanitizer_common/sanitizer_linux_libcdep.cpp > +++ b/libsanitizer/sanitizer_common/sanitizer_linux_libcdep.cpp > @@ -462,7 +462,11 @@ static void GetTls(uptr *addr, uptr *size) { > #elif SANITIZER_GLIBC && defined(__x86_64__) > // For aarch64 and x86-64, use an O(1) approach which requires relatively > // precise ThreadDescriptorSize. g_tls_size was initialized in InitTlsSize. > +# if SANITIZER_X32 > + asm("mov %%fs:8,%0" : "=r"(*addr)); > +# else > asm("mov %%fs:16,%0" : "=r"(*addr)); > +# endif > *size = g_tls_size; > *addr -= *size; > *addr += ThreadDescriptorSize(); > -- > 2.35.1 >
I am backporting this to GCC 12. -- H.J.