[PATCH] D39393: [asan] Use dynamic shadow on 32-bit Android.

Peter Collingbourne via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Nov 6 16:26:16 PST 2017


pcc added inline comments.


================
Comment at: compiler-rt/lib/sanitizer_common/sanitizer_linux.cc:970
 
-uptr GetMaxVirtualAddress() {
+uptr GetMaxVirtualAddress(bool ifunc_safe) {
 #if SANITIZER_NETBSD && defined(__x86_64__)
----------------
eugenis wrote:
> pcc wrote:
> > Is the `ifunc_safe` change necessary? If `common_flags()` is inlined, I would expect the access to go through `common_flags_dont_use`, which you have marked as hidden. You might want to make `common_flags()` hidden as well, in case it doesn't get inlined.
> unfortunately it does into GetKernelAreaSize(), because common_flags()->full_address_space is statically initialized to false. And that is not ifunc-safe.
Oh, right.

I have a mild preference for there to be a separate function that is ifunc-safe (maybe rename this function to `GetMaxUserVirtualAddress` and then have the ifunc-safe one be `GetMaxVirtualAddress`), but up to you.


https://reviews.llvm.org/D39393





More information about the llvm-commits mailing list