diff --git a/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp b/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp index 966f21346e4fe..be0a2b1aec516 100644 --- a/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp +++ b/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp @@ -3,7 +3,7 @@ // RUN: not %run %t 2>&1 | FileCheck --check-prefix=CHECK-CRASH %s // Check that suppressing a function name works within a no-fork sandbox -// RUN: echo "interceptor_via_fun:CFStringCreateWithBytes" > %t.supp +// RUN: echo "interceptor_via_fun:createCFString" > %t.supp // RUN: %env_asan_opts=suppressions='"%t.supp"' \ // RUN: sandbox-exec -p '(version 1)(allow default)(deny process-fork)' \ // RUN: %run %t 2>&1 | FileCheck --check-prefix=CHECK-IGNORE %s @@ -13,12 +13,18 @@ #include +// Disable optimizations to ensure that this function appears on the stack trace so our +// configured suppressions `interceptor_via_fun:createCFString` can take effect. +__attribute__((noinline, disable_tail_calls)) CFStringRef +createCFString(const unsigned char *bytes, CFIndex length) { + return CFStringCreateWithBytes(kCFAllocatorDefault, bytes, length, + kCFStringEncodingUTF8, FALSE); +} + int main() { char *a = (char *)malloc(6); strcpy(a, "hello"); - CFStringRef str = - CFStringCreateWithBytes(kCFAllocatorDefault, (unsigned char *)a, 10, - kCFStringEncodingUTF8, FALSE); // BOOM + CFStringRef str = createCFString((unsigned char *)a, 10); // BOOM fprintf(stderr, "Ignored.\n"); free(a); CFRelease(str);