1 //===-- asan_interceptors.cc ----------------------------------------------===//
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
6 //===----------------------------------------------------------------------===//
8 // This file is a part of AddressSanitizer, an address sanity checker.
10 // Interceptors for operators new and delete.
11 //===----------------------------------------------------------------------===//
13 #include "asan_allocator.h"
14 #include "asan_internal.h"
15 #include "asan_stack.h"
20 // This function is a no-op. We need it to make sure that object file
21 // with our replacements will actually be loaded from static ASan
22 // run-time library at link-time.
23 void ReplaceOperatorsNewAndDelete() { }
26 using namespace __asan
; // NOLINT
28 // On Android new() goes through malloc interceptors.
29 // See also https://code.google.com/p/address-sanitizer/issues/detail?id=131.
32 // Fake std::nothrow_t to avoid including <new>.
37 #define OPERATOR_NEW_BODY(type) \
38 GET_STACK_TRACE_MALLOC;\
39 return asan_memalign(0, size, &stack, type);
42 void *operator new(size_t size
) { OPERATOR_NEW_BODY(FROM_NEW
); }
44 void *operator new[](size_t size
) { OPERATOR_NEW_BODY(FROM_NEW_BR
); }
46 void *operator new(size_t size
, std::nothrow_t
const&)
47 { OPERATOR_NEW_BODY(FROM_NEW
); }
49 void *operator new[](size_t size
, std::nothrow_t
const&)
50 { OPERATOR_NEW_BODY(FROM_NEW_BR
); }
52 #define OPERATOR_DELETE_BODY(type) \
53 GET_STACK_TRACE_FREE;\
54 asan_free(ptr, &stack, type);
57 void operator delete(void *ptr
) { OPERATOR_DELETE_BODY(FROM_NEW
); }
59 void operator delete[](void *ptr
) { OPERATOR_DELETE_BODY(FROM_NEW_BR
); }
61 void operator delete(void *ptr
, std::nothrow_t
const&)
62 { OPERATOR_DELETE_BODY(FROM_NEW
); }
64 void operator delete[](void *ptr
, std::nothrow_t
const&)
65 { OPERATOR_DELETE_BODY(FROM_NEW_BR
); }