1//===-- tsan_new_delete.cc ----------------------------------------------===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9// 10// This file is a part of ThreadSanitizer (TSan), a race detector. 11// 12// Interceptors for operators new and delete. 13//===----------------------------------------------------------------------===// 14#include "interception/interception.h" 15#include "sanitizer_common/sanitizer_internal_defs.h" 16#include "tsan_interceptors.h" 17 18using namespace __tsan; // NOLINT 19 20namespace std { 21struct nothrow_t {}; 22} // namespace std 23 24DECLARE_REAL(void *, malloc, uptr size) 25DECLARE_REAL(void, free, void *ptr) 26#if SANITIZER_MAC || SANITIZER_ANDROID 27#define __libc_malloc REAL(malloc) 28#define __libc_free REAL(free) 29#endif 30 31#define OPERATOR_NEW_BODY(mangled_name) \ 32 if (cur_thread()->in_symbolizer) \ 33 return __libc_malloc(size); \ 34 void *p = 0; \ 35 { \ 36 SCOPED_INTERCEPTOR_RAW(mangled_name, size); \ 37 p = user_alloc(thr, pc, size); \ 38 } \ 39 invoke_malloc_hook(p, size); \ 40 return p; 41 42SANITIZER_INTERFACE_ATTRIBUTE 43void *operator new(__sanitizer::uptr size); 44void *operator new(__sanitizer::uptr size) { 45 OPERATOR_NEW_BODY(_Znwm); 46} 47 48SANITIZER_INTERFACE_ATTRIBUTE 49void *operator new[](__sanitizer::uptr size); 50void *operator new[](__sanitizer::uptr size) { 51 OPERATOR_NEW_BODY(_Znam); 52} 53 54SANITIZER_INTERFACE_ATTRIBUTE 55void *operator new(__sanitizer::uptr size, std::nothrow_t const&); 56void *operator new(__sanitizer::uptr size, std::nothrow_t const&) { 57 OPERATOR_NEW_BODY(_ZnwmRKSt9nothrow_t); 58} 59 60SANITIZER_INTERFACE_ATTRIBUTE 61void *operator new[](__sanitizer::uptr size, std::nothrow_t const&); 62void *operator new[](__sanitizer::uptr size, std::nothrow_t const&) { 63 OPERATOR_NEW_BODY(_ZnamRKSt9nothrow_t); 64} 65 66#define OPERATOR_DELETE_BODY(mangled_name) \ 67 if (ptr == 0) return; \ 68 if (cur_thread()->in_symbolizer) \ 69 return __libc_free(ptr); \ 70 invoke_free_hook(ptr); \ 71 SCOPED_INTERCEPTOR_RAW(mangled_name, ptr); \ 72 user_free(thr, pc, ptr); 73 74SANITIZER_INTERFACE_ATTRIBUTE 75void operator delete(void *ptr) NOEXCEPT; 76void operator delete(void *ptr) NOEXCEPT { 77 OPERATOR_DELETE_BODY(_ZdlPv); 78} 79 80SANITIZER_INTERFACE_ATTRIBUTE 81void operator delete[](void *ptr) NOEXCEPT; 82void operator delete[](void *ptr) NOEXCEPT { 83 OPERATOR_DELETE_BODY(_ZdaPv); 84} 85 86SANITIZER_INTERFACE_ATTRIBUTE 87void operator delete(void *ptr, std::nothrow_t const&); 88void operator delete(void *ptr, std::nothrow_t const&) { 89 OPERATOR_DELETE_BODY(_ZdlPvRKSt9nothrow_t); 90} 91 92SANITIZER_INTERFACE_ATTRIBUTE 93void operator delete[](void *ptr, std::nothrow_t const&); 94void operator delete[](void *ptr, std::nothrow_t const&) { 95 OPERATOR_DELETE_BODY(_ZdaPvRKSt9nothrow_t); 96} 97