diff options
author | Filipe Cabecinhas <me@filcab.net> | 2016-09-21 19:21:01 +0000 |
---|---|---|
committer | Filipe Cabecinhas <me@filcab.net> | 2016-09-21 19:21:01 +0000 |
commit | 287bcde99afe838798828826afeb65dac307488f (patch) | |
tree | ade097cf4fdf28079391cb0319298a00d34aa138 /lib/asan/asan_errors.h | |
parent | 89222768bd438ab122953779da0a20f5e0d73c1b (diff) | |
download | compiler-rt-287bcde99afe838798828826afeb65dac307488f.tar.gz |
[asan] Store full AddressDescription objects in ErrorInvalidPointerPair
Reviewers: kcc, vitalybuka, eugenis
Subscribers: kubabrecka, llvm-commits
Differential Revision: https://reviews.llvm.org/D24777
git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@282102 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/asan/asan_errors.h')
-rw-r--r-- | lib/asan/asan_errors.h | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/lib/asan/asan_errors.h b/lib/asan/asan_errors.h index 57062dd0a..3d917aec9 100644 --- a/lib/asan/asan_errors.h +++ b/lib/asan/asan_errors.h @@ -279,13 +279,20 @@ struct ErrorODRViolation : ErrorBase { }; struct ErrorInvalidPointerPair : ErrorBase { - uptr pc, bp, sp, p1, p2; + uptr pc, bp, sp; + AddressDescription addr1_description; + AddressDescription addr2_description; // VS2013 doesn't implement unrestricted unions, so we need a trivial default // constructor ErrorInvalidPointerPair() = default; - ErrorInvalidPointerPair(u32 tid, uptr pc_, uptr bp_, uptr sp_, uptr p1_, - uptr p2_) - : ErrorBase(tid), pc(pc_), bp(bp_), sp(sp_), p1(p1_), p2(p2_) {} + ErrorInvalidPointerPair(u32 tid, uptr pc_, uptr bp_, uptr sp_, uptr p1, + uptr p2) + : ErrorBase(tid), + pc(pc_), + bp(bp_), + sp(sp_), + addr1_description(p1, 1, /*shouldLockThreadRegistry=*/false), + addr2_description(p2, 1, /*shouldLockThreadRegistry=*/false) {} void Print(); }; |