Index: lib/asan/asan_interceptors.cc =================================================================== --- lib/asan/asan_interceptors.cc +++ lib/asan/asan_interceptors.cc @@ -81,6 +81,51 @@ } \ } while (0) +// memcpy is called during __asan_init() from the internals of printf(...). +// We do not treat memcpy with to==from as a bug. +// See http://llvm.org/bugs/show_bug.cgi?id=11763. +#define ASAN_MEMCPY_IMPL(ctx, to, from, size) \ + do { \ + if (UNLIKELY(!asan_inited)) return internal_memcpy(to, from, size); \ + if (asan_init_is_running) { \ + return REAL(memcpy)(to, from, size); \ + } \ + ENSURE_ASAN_INITED(); \ + if (flags()->replace_intrin) { \ + if (to != from) { \ + CHECK_RANGES_OVERLAP("memcpy", to, size, from, size); \ + } \ + ASAN_READ_RANGE(ctx, from, size); \ + ASAN_WRITE_RANGE(ctx, to, size); \ + } \ + return REAL(memcpy)(to, from, size); \ + } while (0) + +// memset is called inside Printf. +#define ASAN_MEMSET_IMPL(ctx, block, c, size) \ + do { \ + if (UNLIKELY(!asan_inited)) return internal_memset(block, c, size); \ + if (asan_init_is_running) { \ + return REAL(memset)(block, c, size); \ + } \ + ENSURE_ASAN_INITED(); \ + if (flags()->replace_intrin) { \ + ASAN_WRITE_RANGE(ctx, block, size); \ + } \ + return REAL(memset)(block, c, size); \ + } while (0) + +#define ASAN_MEMMOVE_IMPL(ctx, to, from, size) \ + do { \ + if (UNLIKELY(!asan_inited)) return internal_memmove(to, from, size); \ + ENSURE_ASAN_INITED(); \ + if (flags()->replace_intrin) { \ + ASAN_READ_RANGE(ctx, from, size); \ + ASAN_WRITE_RANGE(ctx, to, size); \ + } \ + return internal_memmove(to, from, size); \ + } while (0) + #define ASAN_READ_RANGE(ctx, offset, size) \ ACCESS_MEMORY_RANGE(ctx, offset, size, false) #define ASAN_WRITE_RANGE(ctx, offset, size) \ @@ -198,6 +243,11 @@ } else { \ *begin = *end = 0; \ } + +#define COMMON_INTERCEPTOR_MEMSET ASAN_MEMSET_IMPL(ctx, block, c, size) +#define COMMON_INTERCEPTOR_MEMMOVE ASAN_MEMCPY_IMPL(ctx, to, from, size) +#define COMMON_INTERCEPTOR_MEMCPY ASAN_MEMMOVE_IMPL(ctx, to, from, size) + // Asan needs custom handling of these: #undef SANITIZER_INTERCEPT_MEMSET #undef SANITIZER_INTERCEPT_MEMMOVE @@ -389,58 +439,14 @@ } #endif -// memcpy is called during __asan_init() from the internals of printf(...). -// We do not treat memcpy with to==from as a bug. -// See http://llvm.org/bugs/show_bug.cgi?id=11763. -#define ASAN_MEMCPY_IMPL(ctx, to, from, size) do { \ - if (UNLIKELY(!asan_inited)) return internal_memcpy(to, from, size); \ - if (asan_init_is_running) { \ - return REAL(memcpy)(to, from, size); \ - } \ - ENSURE_ASAN_INITED(); \ - if (flags()->replace_intrin) { \ - if (to != from) { \ - CHECK_RANGES_OVERLAP("memcpy", to, size, from, size); \ - } \ - ASAN_READ_RANGE(ctx, from, size); \ - ASAN_WRITE_RANGE(ctx, to, size); \ - } \ - return REAL(memcpy)(to, from, size); \ - } while (0) - - void *__asan_memcpy(void *to, const void *from, uptr size) { ASAN_MEMCPY_IMPL(nullptr, to, from, size); } -// memset is called inside Printf. -#define ASAN_MEMSET_IMPL(ctx, block, c, size) do { \ - if (UNLIKELY(!asan_inited)) return internal_memset(block, c, size); \ - if (asan_init_is_running) { \ - return REAL(memset)(block, c, size); \ - } \ - ENSURE_ASAN_INITED(); \ - if (flags()->replace_intrin) { \ - ASAN_WRITE_RANGE(ctx, block, size); \ - } \ - return REAL(memset)(block, c, size); \ - } while (0) - void *__asan_memset(void *block, int c, uptr size) { ASAN_MEMSET_IMPL(nullptr, block, c, size); } -#define ASAN_MEMMOVE_IMPL(ctx, to, from, size) do { \ - if (UNLIKELY(!asan_inited)) \ - return internal_memmove(to, from, size); \ - ENSURE_ASAN_INITED(); \ - if (flags()->replace_intrin) { \ - ASAN_READ_RANGE(ctx, from, size); \ - ASAN_WRITE_RANGE(ctx, to, size); \ - } \ - return internal_memmove(to, from, size); \ - } while (0) - void *__asan_memmove(void *to, const void *from, uptr size) { ASAN_MEMMOVE_IMPL(nullptr, to, from, size); } Index: lib/msan/msan_interceptors.cc =================================================================== --- lib/msan/msan_interceptors.cc +++ lib/msan/msan_interceptors.cc @@ -1354,6 +1354,13 @@ *begin = *end = 0; \ } +#define COMMON_INTERCEPTOR_MEMSET(block, c, size) \ + { return __msan_memset(block, c, size); } +#define COMMON_INTERCEPTOR_MEMMOVE(to, from, size) \ + { return __msan_memmove(to, from, size); } +#define COMMON_INTERCEPTOR_MEMCPY(to, from, size) \ + { return __msan_memcpy(to, from, size); } + #include "sanitizer_common/sanitizer_platform_interceptors.h" // Msan needs custom handling of these: #undef SANITIZER_INTERCEPT_MEMSET Index: lib/sanitizer_common/sanitizer_common_interceptors.inc =================================================================== --- lib/sanitizer_common/sanitizer_common_interceptors.inc +++ lib/sanitizer_common/sanitizer_common_interceptors.inc @@ -163,6 +163,55 @@ COMMON_INTERCEPT_FUNCTION(fn) #endif +#ifndef COMMON_INTERCEPTOR_MEMSET +#define COMMON_INTERCEPTOR_MEMSET(dst, v, size) \ + { \ + if (COMMON_INTERCEPTOR_NOTHING_IS_INITIALIZED) \ + return internal_memset(dst, v, size); \ + void *ctx; \ + COMMON_INTERCEPTOR_ENTER(ctx, memset, dst, v, size); \ + if (common_flags()->intercept_intrin) \ + COMMON_INTERCEPTOR_WRITE_RANGE(ctx, dst, size); \ + return REAL(memset)(dst, v, size); \ + } +#endif + +#ifndef COMMON_INTERCEPTOR_MEMMOVE +#define COMMON_INTERCEPTOR_MEMMOVE(dst, src, size) \ + { \ + if (COMMON_INTERCEPTOR_NOTHING_IS_INITIALIZED) \ + return internal_memmove(dst, src, size); \ + void *ctx; \ + COMMON_INTERCEPTOR_ENTER(ctx, memmove, dst, src, size); \ + if (common_flags()->intercept_intrin) { \ + COMMON_INTERCEPTOR_WRITE_RANGE(ctx, dst, size); \ + COMMON_INTERCEPTOR_READ_RANGE(ctx, src, size); \ + } \ + return REAL(memmove)(dst, src, size); \ + } +#endif + +// On OS X, calling internal_memcpy here will cause memory corruptions, +// because memcpy and memmove are actually aliases of the same +// implementation. We need to use internal_memmove here. +// N.B.: If we switch this to internal_ we'll have to use internal_memmove +// due to memcpy being an alias of memmove on OS X. +#ifndef COMMON_INTERCEPTOR_MEMCPY +#define COMMON_INTERCEPTOR_MEMCPY(dst, src, size) \ + { \ + if (COMMON_INTERCEPTOR_NOTHING_IS_INITIALIZED) { \ + return internal_memmove(dst, src, size); \ + } \ + void *ctx; \ + COMMON_INTERCEPTOR_ENTER(ctx, memcpy, dst, src, size); \ + if (common_flags()->intercept_intrin) { \ + COMMON_INTERCEPTOR_WRITE_RANGE(ctx, dst, size); \ + COMMON_INTERCEPTOR_READ_RANGE(ctx, src, size); \ + } \ + return REAL(memcpy)(dst, src, size); \ + } +#endif + struct FileMetadata { // For open_memstream(). char **addr; @@ -565,15 +614,8 @@ #endif #if SANITIZER_INTERCEPT_MEMSET -INTERCEPTOR(void*, memset, void *dst, int v, uptr size) { - if (COMMON_INTERCEPTOR_NOTHING_IS_INITIALIZED) - return internal_memset(dst, v, size); - void *ctx; - COMMON_INTERCEPTOR_ENTER(ctx, memset, dst, v, size); - if (common_flags()->intercept_intrin) - COMMON_INTERCEPTOR_WRITE_RANGE(ctx, dst, size); - return REAL(memset)(dst, v, size); -} +INTERCEPTOR(void *, memset, void *dst, int v, uptr size) +COMMON_INTERCEPTOR_MEMSET(dst, v, size) #define INIT_MEMSET COMMON_INTERCEPT_FUNCTION(memset) #else @@ -581,17 +623,8 @@ #endif #if SANITIZER_INTERCEPT_MEMMOVE -INTERCEPTOR(void*, memmove, void *dst, const void *src, uptr size) { - if (COMMON_INTERCEPTOR_NOTHING_IS_INITIALIZED) - return internal_memmove(dst, src, size); - void *ctx; - COMMON_INTERCEPTOR_ENTER(ctx, memmove, dst, src, size); - if (common_flags()->intercept_intrin) { - COMMON_INTERCEPTOR_WRITE_RANGE(ctx, dst, size); - COMMON_INTERCEPTOR_READ_RANGE(ctx, src, size); - } - return REAL(memmove)(dst, src, size); -} +INTERCEPTOR(void *, memmove, void *dst, const void *src, uptr size) +COMMON_INTERCEPTOR_MEMMOVE(dst, src, size) #define INIT_MEMMOVE COMMON_INTERCEPT_FUNCTION(memmove) #else @@ -599,23 +632,8 @@ #endif #if SANITIZER_INTERCEPT_MEMCPY -INTERCEPTOR(void*, memcpy, void *dst, const void *src, uptr size) { - if (COMMON_INTERCEPTOR_NOTHING_IS_INITIALIZED) { - // On OS X, calling internal_memcpy here will cause memory corruptions, - // because memcpy and memmove are actually aliases of the same - // implementation. We need to use internal_memmove here. - return internal_memmove(dst, src, size); - } - void *ctx; - COMMON_INTERCEPTOR_ENTER(ctx, memcpy, dst, src, size); - if (common_flags()->intercept_intrin) { - COMMON_INTERCEPTOR_WRITE_RANGE(ctx, dst, size); - COMMON_INTERCEPTOR_READ_RANGE(ctx, src, size); - } - // N.B.: If we switch this to internal_ we'll have to use internal_memmove - // due to memcpy being an alias of memmove on OS X. - return REAL(memcpy)(dst, src, size); -} +INTERCEPTOR(void *, memcpy, void *dst, const void *src, uptr size) +COMMON_INTERCEPTOR_MEMCPY(dst, src, size) #define INIT_MEMCPY COMMON_INTERCEPT_FUNCTION(memcpy) #else @@ -4837,47 +4855,43 @@ #endif #if SANITIZER_INTERCEPT_AEABI_MEM -DECLARE_REAL_AND_INTERCEPTOR(void *, memmove, void *, const void *, uptr) -DECLARE_REAL_AND_INTERCEPTOR(void *, memcpy, void *, const void *, uptr) -DECLARE_REAL_AND_INTERCEPTOR(void *, memset, void *, int, uptr) +INTERCEPTOR(void *, __aeabi_memmove, void *to, const void *from, uptr size) +COMMON_INTERCEPTOR_MEMMOVE(to, from, size) + +INTERCEPTOR(void *, __aeabi_memmove4, void *to, const void *from, uptr size) +COMMON_INTERCEPTOR_MEMMOVE(to, from, size) + +INTERCEPTOR(void *, __aeabi_memmove8, void *to, const void *from, uptr size) +COMMON_INTERCEPTOR_MEMMOVE(to, from, size) + +INTERCEPTOR(void *, __aeabi_memcpy, void *to, const void *from, uptr size) +COMMON_INTERCEPTOR_MEMCPY(to, from, size) + +INTERCEPTOR(void *, __aeabi_memcpy4, void *to, const void *from, uptr size) +COMMON_INTERCEPTOR_MEMCPY(to, from, size) + +INTERCEPTOR(void *, __aeabi_memcpy8, void *to, const void *from, uptr size) +COMMON_INTERCEPTOR_MEMCPY(to, from, size) -INTERCEPTOR(void *, __aeabi_memmove, void *to, const void *from, uptr size) { - return WRAP(memmove)(to, from, size); -} -INTERCEPTOR(void *, __aeabi_memmove4, void *to, const void *from, uptr size) { - return WRAP(memmove)(to, from, size); -} -INTERCEPTOR(void *, __aeabi_memmove8, void *to, const void *from, uptr size) { - return WRAP(memmove)(to, from, size); -} -INTERCEPTOR(void *, __aeabi_memcpy, void *to, const void *from, uptr size) { - return WRAP(memcpy)(to, from, size); -} -INTERCEPTOR(void *, __aeabi_memcpy4, void *to, const void *from, uptr size) { - return WRAP(memcpy)(to, from, size); -} -INTERCEPTOR(void *, __aeabi_memcpy8, void *to, const void *from, uptr size) { - return WRAP(memcpy)(to, from, size); -} // Note the argument order. -INTERCEPTOR(void *, __aeabi_memset, void *block, uptr size, int c) { - return WRAP(memset)(block, c, size); -} -INTERCEPTOR(void *, __aeabi_memset4, void *block, uptr size, int c) { - return WRAP(memset)(block, c, size); -} -INTERCEPTOR(void *, __aeabi_memset8, void *block, uptr size, int c) { - return WRAP(memset)(block, c, size); -} -INTERCEPTOR(void *, __aeabi_memclr, void *block, uptr size) { - return WRAP(memset)(block, 0, size); -} -INTERCEPTOR(void *, __aeabi_memclr4, void *block, uptr size) { - return WRAP(memset)(block, 0, size); -} -INTERCEPTOR(void *, __aeabi_memclr8, void *block, uptr size) { - return WRAP(memset)(block, 0, size); -} +INTERCEPTOR(void *, __aeabi_memset, void *block, uptr size, int c) +COMMON_INTERCEPTOR_MEMSET(block, c, size) + +INTERCEPTOR(void *, __aeabi_memset4, void *block, uptr size, int c) +COMMON_INTERCEPTOR_MEMSET(block, c, size) + +INTERCEPTOR(void *, __aeabi_memset8, void *block, uptr size, int c) +COMMON_INTERCEPTOR_MEMSET(block, c, size) + +INTERCEPTOR(void *, __aeabi_memclr, void *block, uptr size) +COMMON_INTERCEPTOR_MEMSET(block, 0, size) + +INTERCEPTOR(void *, __aeabi_memclr4, void *block, uptr size) +COMMON_INTERCEPTOR_MEMSET(block, 0, size) + +INTERCEPTOR(void *, __aeabi_memclr8, void *block, uptr size) +COMMON_INTERCEPTOR_MEMSET(block, 0, size) + #define INIT_AEABI_MEM \ COMMON_INTERCEPT_FUNCTION(__aeabi_memmove); \ COMMON_INTERCEPT_FUNCTION(__aeabi_memmove4); \ @@ -4896,11 +4910,9 @@ #endif // SANITIZER_INTERCEPT_AEABI_MEM #if SANITIZER_INTERCEPT___BZERO -DECLARE_REAL_AND_INTERCEPTOR(void *, memset, void *, int, uptr); +INTERCEPTOR(void *, __bzero, void *block, uptr size) +COMMON_INTERCEPTOR_MEMSET(block, 0, size) -INTERCEPTOR(void *, __bzero, void *block, uptr size) { - return WRAP(memset)(block, 0, size); -} #define INIT___BZERO COMMON_INTERCEPT_FUNCTION(__bzero); #else #define INIT___BZERO