[compiler-rt] [Darwin][ASan][Test] Create a noinlined wrapper function for reliable suppression in test. (PR #131194)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 13 12:20:30 PDT 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-compiler-rt-sanitizer
Author: None (thetruestblue)
<details>
<summary>Changes</summary>
CFStringCreateWithBytes may not always appear on stack due to optimizations. Create a wrapper function for the purposes of testing suppression files that will always appear on stack for test stability.
Also necessary to disable leaks.
rdar://144800068
Patch by: padriff
---
Full diff: https://github.com/llvm/llvm-project/pull/131194.diff
1 Files Affected:
- (modified) compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp (+10-5)
``````````diff
diff --git a/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp b/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp
index 966f21346e4fe..aa005de493057 100644
--- a/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp
+++ b/compiler-rt/test/asan/TestCases/Darwin/suppressions-sandbox.cpp
@@ -3,8 +3,8 @@
// 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: %env_asan_opts=suppressions='"%t.supp"' \
+// RUN: echo "interceptor_via_fun:createCFString" > %t.supp
+// RUN: %env_asan_opts=suppressions='"%t.supp"':verbostiy=1:detect_leaks=0 \
// 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,17 @@
#include <CoreFoundation/CoreFoundation.h>
+// Use a noinline wrapper function to suppress to stabilize test.
+__attribute__((noinline)) 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);
``````````
</details>
https://github.com/llvm/llvm-project/pull/131194
More information about the llvm-commits
mailing list