[PATCH] D68059: hwasan: Compatibility fixes for short granules.
Peter Collingbourne via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Sep 25 15:50:55 PDT 2019
pcc created this revision.
pcc added reviewers: eugenis, hctim.
Herald added subscribers: Sanitizers, hiraditya, kristof.beyls, srhines.
Herald added projects: Sanitizers, LLVM.
We can't use short granules with stack instrumentation when targeting older
API levels because the rest of the system won't understand the short granule
tags stored in shadow memory.
Moreover, we need to be able to let old binaries (which won't understand
short granule tags) run on a new system that supports short granule
tags. Such binaries will call the __hwasan_tag_mismatch function when their
outlined checks fail. We can compensate for the binary's lack of support
for short granules by implementing the short granule part of the check in
the __hwasan_tag_mismatch function. Unfortunately we can't do anything about
inline checks, but I don't believe that we can generate these by default on
aarch64, nor did we do so when the ABI was fixed.
A new function, __hwasan_tag_mismatch_v2, is introduced that lets code
targeting the new runtime avoid redoing the short granule check. Because tag
mismatches are rare this isn't important from a performance perspective; the
main benefit is that it introduces a symbol dependency that prevents binaries
targeting the new runtime from running on older (i.e. incompatible) runtimes.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D68059
Files:
compiler-rt/lib/hwasan/hwasan_tag_mismatch_aarch64.S
compiler-rt/test/hwasan/TestCases/stack-oob.c
compiler-rt/test/hwasan/lit.cfg.py
llvm/lib/Target/AArch64/AArch64AsmPrinter.cpp
llvm/lib/Transforms/Instrumentation/HWAddressSanitizer.cpp
llvm/test/CodeGen/AArch64/hwasan-check-memaccess.ll
llvm/test/Instrumentation/HWAddressSanitizer/alloca-compat.ll
llvm/test/Instrumentation/HWAddressSanitizer/alloca.ll
llvm/test/Instrumentation/HWAddressSanitizer/basic-compat.ll
llvm/test/Instrumentation/HWAddressSanitizer/basic.ll
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D68059.221852.patch
Type: text/x-patch
Size: 32414 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190925/869d4ede/attachment.bin>
More information about the llvm-commits
mailing list