From 64b4090290af5c6ab17327c6ee42a001fa6c0d12 Mon Sep 17 00:00:00 2001 From: Kuba Brecka Date: Mon, 7 Sep 2015 12:25:51 +0000 Subject: Revert r246961 "[asan] Intercept and wrap XPC callback blocks". There is a build failure for the simulator. git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@246967 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/asan/asan_mac.cc | 54 +++++--------------------- test/asan/TestCases/Darwin/xpc_interceptors.mm | 37 ------------------ 2 files changed, 9 insertions(+), 82 deletions(-) delete mode 100644 test/asan/TestCases/Darwin/xpc_interceptors.mm diff --git a/lib/asan/asan_mac.cc b/lib/asan/asan_mac.cc index 3224db8be..0f0f9bb08 100644 --- a/lib/asan/asan_mac.cc +++ b/lib/asan/asan_mac.cc @@ -33,18 +33,17 @@ extern "C" { #endif #include // for dladdr() -#include -#include #include #include -#include -#include // for free() #include #include #include #include +#include +#include +#include // for free() #include -#include +#include namespace __asan { @@ -273,6 +272,11 @@ void ReadContextStack(void *context, uptr *stack, uptr *ssize) { // The implementation details are at // http://libdispatch.macosforge.org/trac/browser/trunk/src/queue.c +typedef void* dispatch_group_t; +typedef void* dispatch_queue_t; +typedef void* dispatch_source_t; +typedef u64 dispatch_time_t; +typedef void (*dispatch_function_t)(void *block); typedef void* (*worker_t)(void *block); // A wrapper for the ObjC blocks used to support libdispatch. @@ -395,15 +399,6 @@ void dispatch_source_set_event_handler(dispatch_source_t ds, void(^work)(void)); work(); \ } -#define GET_ASAN_BLOCK_XPC(work) \ - void (^asan_block)(xpc_object_t object); \ - int parent_tid = GetCurrentTidOrInvalid(); \ - asan_block = ^(xpc_object_t object) { \ - GET_STACK_TRACE_THREAD; \ - asan_register_worker_thread(parent_tid, &stack); \ - work(object); \ - } - INTERCEPTOR(void, dispatch_async, dispatch_queue_t dq, void(^work)(void)) { ENABLE_FRAME_POINTER; @@ -442,37 +437,6 @@ INTERCEPTOR(void, dispatch_source_set_event_handler, GET_ASAN_BLOCK(work); REAL(dispatch_source_set_event_handler)(ds, asan_block); } - -INTERCEPTOR(void, xpc_connection_send_message_with_reply, - xpc_connection_t connection, xpc_object_t message, - dispatch_queue_t replyq, xpc_handler_t handler) { - ENABLE_FRAME_POINTER; - GET_ASAN_BLOCK_XPC(handler); - REAL(xpc_connection_send_message_with_reply)(connection, message, replyq, - asan_block); -} - -INTERCEPTOR(void, xpc_connection_set_event_handler, xpc_connection_t connection, - xpc_handler_t handler) { - ENABLE_FRAME_POINTER; - GET_ASAN_BLOCK_XPC(handler); - REAL(xpc_connection_set_event_handler)(connection, asan_block); -} - -INTERCEPTOR(void, xpc_set_event_stream_handler, const char *stream, - dispatch_queue_t targetq, xpc_handler_t handler) { - ENABLE_FRAME_POINTER; - GET_ASAN_BLOCK_XPC(handler); - REAL(xpc_set_event_stream_handler)(stream, targetq, asan_block); -} - -INTERCEPTOR(void, xpc_connection_send_barrier, xpc_connection_t connection, - dispatch_block_t barrier) { - ENABLE_FRAME_POINTER; - GET_ASAN_BLOCK(barrier); - REAL(xpc_connection_send_barrier)(connection, asan_block); -} - #endif #endif // SANITIZER_MAC diff --git a/test/asan/TestCases/Darwin/xpc_interceptors.mm b/test/asan/TestCases/Darwin/xpc_interceptors.mm deleted file mode 100644 index 9872419b1..000000000 --- a/test/asan/TestCases/Darwin/xpc_interceptors.mm +++ /dev/null @@ -1,37 +0,0 @@ -// Check that blocks executed on the XPC callback queue are handled correctly by -// ASan. - -// RUN: %clangxx_asan -O0 %s -o %t -framework Foundation && not %run %t 2>&1 | FileCheck %s - -#import -#include -#include - -int main() { - // Set up a 5-second timeout. - dispatch_after(dispatch_time(DISPATCH_TIME_NOW, 5 * NSEC_PER_SEC), - dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), - ^{ - exit(0); - }); - - xpc_connection_t _connection = xpc_connection_create_mach_service( - "com.example.non.existing.xpc", NULL, 0); - - xpc_connection_set_event_handler(_connection, ^(xpc_object_t event) { - char *mem = (char *)malloc(10); - NSLog(@"mem = %p", mem); - - // Without the XPC API interceptors, this would cause an assertion failure - // when describing the current thread (XPC callback thread). - fprintf(stderr, "%s\n", mem + 10); // BOOM. - // CHECK: ERROR: AddressSanitizer: heap-buffer-overflow - // CHECK: READ of size 1 at - // CHECK: allocated by thread - // CHECK: {{ #0 0x.* in .*malloc}} - }); - - xpc_connection_resume(_connection); - dispatch_main(); - return 0; -} -- cgit v1.2.3