diff options
author | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2013-06-04 13:49:10 +0000 |
---|---|---|
committer | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2013-06-04 13:49:10 +0000 |
commit | 2e9ffcbc2184f308881fc04ce0799c557b7e5b0f (patch) | |
tree | 420fcdba71820f529682fc5fdebe91ba78342624 /lib/msan | |
parent | f43f6026dc9374e657fb6300840b18ead6347b74 (diff) |
[sanitizer] Fix __sanitizer_unaligned_* to work with unaligned data types.
git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@183224 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/msan')
-rw-r--r-- | lib/msan/msan.cc | 36 | ||||
-rw-r--r-- | lib/msan/msan_interface_internal.h | 12 |
2 files changed, 24 insertions, 24 deletions
diff --git a/lib/msan/msan.cc b/lib/msan/msan.cc index 95b9110b7..cf7b01c3d 100644 --- a/lib/msan/msan.cc +++ b/lib/msan/msan.cc @@ -459,29 +459,29 @@ u32 __msan_get_umr_origin() { return __msan_origin_tls; } -u16 __sanitizer_unaligned_load16(const void *p) { - __msan_retval_tls[0] = *(u16 *)MEM_TO_SHADOW((uptr)p); - return *(u16 *)p; +u16 __sanitizer_unaligned_load16(const uu16 *p) { + __msan_retval_tls[0] = *(uu16 *)MEM_TO_SHADOW((uptr)p); + return *p; } -u32 __sanitizer_unaligned_load32(const void *p) { - __msan_retval_tls[0] = *(u32 *)MEM_TO_SHADOW((uptr)p); - return *(u32 *)p; +u32 __sanitizer_unaligned_load32(const uu32 *p) { + __msan_retval_tls[0] = *(uu32 *)MEM_TO_SHADOW((uptr)p); + return *p; } -u64 __sanitizer_unaligned_load64(const void *p) { - __msan_retval_tls[0] = *(u64 *)MEM_TO_SHADOW((uptr)p); - return *(u64 *)p; +u64 __sanitizer_unaligned_load64(const uu64 *p) { + __msan_retval_tls[0] = *(uu64 *)MEM_TO_SHADOW((uptr)p); + return *p; } -void __sanitizer_unaligned_store16(void *p, u16 x) { - *(u16 *)MEM_TO_SHADOW((uptr)p) = __msan_param_tls[1]; - *(u16 *)p = x; +void __sanitizer_unaligned_store16(uu16 *p, u16 x) { + *(uu16 *)MEM_TO_SHADOW((uptr)p) = __msan_param_tls[1]; + *p = x; } -void __sanitizer_unaligned_store32(void *p, u32 x) { - *(u32 *)MEM_TO_SHADOW((uptr)p) = __msan_param_tls[1]; - *(u32 *)p = x; +void __sanitizer_unaligned_store32(uu32 *p, u32 x) { + *(uu32 *)MEM_TO_SHADOW((uptr)p) = __msan_param_tls[1]; + *p = x; } -void __sanitizer_unaligned_store64(void *p, u64 x) { - *(u64 *)MEM_TO_SHADOW((uptr)p) = __msan_param_tls[1]; - *(u64 *)p = x; +void __sanitizer_unaligned_store64(uu64 *p, u64 x) { + *(uu64 *)MEM_TO_SHADOW((uptr)p) = __msan_param_tls[1]; + *p = x; } #if !SANITIZER_SUPPORTS_WEAK_HOOKS diff --git a/lib/msan/msan_interface_internal.h b/lib/msan/msan_interface_internal.h index 0dcb926cb..f3d8ee3ef 100644 --- a/lib/msan/msan_interface_internal.h +++ b/lib/msan/msan_interface_internal.h @@ -125,22 +125,22 @@ void __msan_allocated_memory(const void* data, uptr size); void __msan_unpoison_param(uptr n); SANITIZER_INTERFACE_ATTRIBUTE -u16 __sanitizer_unaligned_load16(const void *p); +u16 __sanitizer_unaligned_load16(const uu16 *p); SANITIZER_INTERFACE_ATTRIBUTE -u32 __sanitizer_unaligned_load32(const void *p); +u32 __sanitizer_unaligned_load32(const uu32 *p); SANITIZER_INTERFACE_ATTRIBUTE -u64 __sanitizer_unaligned_load64(const void *p); +u64 __sanitizer_unaligned_load64(const uu64 *p); SANITIZER_INTERFACE_ATTRIBUTE -void __sanitizer_unaligned_store16(void *p, u16 x); +void __sanitizer_unaligned_store16(uu16 *p, u16 x); SANITIZER_INTERFACE_ATTRIBUTE -void __sanitizer_unaligned_store32(void *p, u32 x); +void __sanitizer_unaligned_store32(uu32 *p, u32 x); SANITIZER_INTERFACE_ATTRIBUTE -void __sanitizer_unaligned_store64(void *p, u64 x); +void __sanitizer_unaligned_store64(uu64 *p, u64 x); } // extern "C" #endif // MSAN_INTERFACE_INTERNAL_H |