diff options
| -rw-r--r-- | compiler-rt/lib/asan/asan_new_delete.cc | 39 | ||||
| -rw-r--r-- | compiler-rt/lib/asan/lit_tests/large_func_test.cc | 5 | 
2 files changed, 42 insertions, 2 deletions
diff --git a/compiler-rt/lib/asan/asan_new_delete.cc b/compiler-rt/lib/asan/asan_new_delete.cc index 8c45b81a8b7..40aa31c26a6 100644 --- a/compiler-rt/lib/asan/asan_new_delete.cc +++ b/compiler-rt/lib/asan/asan_new_delete.cc @@ -40,6 +40,14 @@ struct nothrow_t {};    GET_STACK_TRACE_MALLOC;\    return asan_memalign(0, size, &stack, type); +// On OS X it's not enough to just provide our own 'operator new' and +// 'operator delete' implementations, because they're going to be in the +// runtime dylib, and the main executable will depend on both the runtime +// dylib and libstdc++, each of those'll have its implementation of new and +// delete. +// To make sure that C++ allocation/deallocation operators are overridden on +// OS X we need to intercept them using their mangled names. +#if !defined(__APPLE__)  INTERCEPTOR_ATTRIBUTE  void *operator new(size_t size) { OPERATOR_NEW_BODY(FROM_NEW); }  INTERCEPTOR_ATTRIBUTE @@ -51,10 +59,26 @@ INTERCEPTOR_ATTRIBUTE  void *operator new[](size_t size, std::nothrow_t const&)  { OPERATOR_NEW_BODY(FROM_NEW_BR); } +#else  // __APPLE__ +INTERCEPTOR(void *, _Znwm, size_t size) { +  OPERATOR_NEW_BODY(FROM_NEW); +} +INTERCEPTOR(void *, _Znam, size_t size) { +  OPERATOR_NEW_BODY(FROM_NEW_BR); +} +INTERCEPTOR(void *, _ZnwmRKSt9nothrow_t, size_t size, std::nothrow_t const&) { +  OPERATOR_NEW_BODY(FROM_NEW); +} +INTERCEPTOR(void *, _ZnamRKSt9nothrow_t, size_t size, std::nothrow_t const&) { +  OPERATOR_NEW_BODY(FROM_NEW_BR); +} +#endif +  #define OPERATOR_DELETE_BODY(type) \    GET_STACK_TRACE_FREE;\    asan_free(ptr, &stack, type); +#if !defined(__APPLE__)  INTERCEPTOR_ATTRIBUTE  void operator delete(void *ptr) { OPERATOR_DELETE_BODY(FROM_NEW); }  INTERCEPTOR_ATTRIBUTE @@ -66,4 +90,19 @@ INTERCEPTOR_ATTRIBUTE  void operator delete[](void *ptr, std::nothrow_t const&)  { OPERATOR_DELETE_BODY(FROM_NEW_BR); } +#else  // __APPLE__ +INTERCEPTOR(void, _ZdlPv, void *ptr) { +  OPERATOR_DELETE_BODY(FROM_NEW); +} +INTERCEPTOR(void, _ZdaPv, void *ptr) { +  OPERATOR_DELETE_BODY(FROM_NEW_BR); +} +INTERCEPTOR(void, _ZdlPvRKSt9nothrow_t, void *ptr, std::nothrow_t const&) { +  OPERATOR_DELETE_BODY(FROM_NEW); +} +INTERCEPTOR(void, _ZdaPvRKSt9nothrow_t, void *ptr, std::nothrow_t const&) { +  OPERATOR_DELETE_BODY(FROM_NEW_BR); +} +#endif +  #endif diff --git a/compiler-rt/lib/asan/lit_tests/large_func_test.cc b/compiler-rt/lib/asan/lit_tests/large_func_test.cc index ad228251891..ceecc29b7b0 100644 --- a/compiler-rt/lib/asan/lit_tests/large_func_test.cc +++ b/compiler-rt/lib/asan/lit_tests/large_func_test.cc @@ -56,7 +56,8 @@ int main(int argc, char **argv) {    // CHECK: {{    #1 0x.* in _?main .*large_func_test.cc:}}[[@LINE-1]]    // CHECK: {{0x.* is located 12 bytes to the right of 400-byte region}}    // CHECK: {{allocated by thread T0 here:}} -  // CHECK: {{    #0 0x.* in operator new.*}} -  // CHECK: {{    #1 0x.* in _?main .*large_func_test.cc:}}[[@LINE-6]] +  // CHECK-Linux: {{    #0 0x.* in operator new.*}} +  // CHECK-Darwin: {{    #0 0x.* in .*_Zna.*}} +  // CHECK: {{    #1 0x.* in _?main .*large_func_test.cc:}}[[@LINE-7]]    delete x;  }  | 

