[asan][test] Cleanup asan-stack-safety.ll test
authorVitaly Buka <vitalybuka@google.com>
Wed, 27 Jul 2022 00:06:18 +0000 (17:06 -0700)
committerVitaly Buka <vitalybuka@google.com>
Wed, 27 Jul 2022 00:18:00 +0000 (17:18 -0700)
llvm/test/Instrumentation/AddressSanitizer/asan-stack-safety.ll

index f4bc203..290154f 100644 (file)
@@ -1,43 +1,41 @@
 ; REQUIRES: x86-registered-target
 
-; RUN: opt < %s -S -asan-instrumentation-with-call-threshold=0 \
-; RUN:     -passes='asan-pipeline' -asan-use-stack-safety=0 -o - | FileCheck %s --check-prefixes=NOSAFETY
-; RUN: opt < %s -S -asan-instrumentation-with-call-threshold=0 \
-; RUN:     -passes='asan-pipeline' -asan-use-stack-safety=1 -o - | FileCheck %s --check-prefixes=SAFETY
-; NOSAFETY: call void @__asan_load1
-; NOSAFETY: call void @__asan_store1
-; NOSAFETY: call void @__asan_store1
-; NOSAFETY: call void @__asan_store1
-; SAFETY-NOT: call void @__asan_load1
-; SAFETY-NOT: call void @__asan_store1
-; SAFETY-NOT: call void @__asan_store1
-; SAFETY-NOT: call void @__asan_store1
+; RUN: opt < %s -S -asan-instrumentation-with-call-threshold=0 -passes='asan-pipeline' -asan-use-stack-safety=0 -o - | FileCheck %s --implicit-check-not="call void @__asan_{{load|store}}" --check-prefixes=CHECK,NOSAFETY
+; RUN: opt < %s -S -asan-instrumentation-with-call-threshold=0 -passes='asan-pipeline' -asan-use-stack-safety=1 -o - | FileCheck %s --implicit-check-not="call void @__asan_{{load|store}}"
 
+; CHECK-LABEL: define i32 @load
 define i32 @load() sanitize_address {
   %buf = alloca [10 x i8], align 1
   %arrayidx = getelementptr inbounds [10 x i8], [10 x i8]* %buf, i64 0, i64 0
   %1 = load i8, i8* %arrayidx, align 1
+  ; NOSAFETY: call void @__asan_load1
   ret i32 0
 }
 
+; CHECK-LABEL: define i32 @store
 define i32 @store() sanitize_address {
   %buf = alloca [10 x i8], align 1
   %arrayidx = getelementptr inbounds [10 x i8], [10 x i8]* %buf, i64 0, i64 0
   store i8 0, i8* %arrayidx
+  ; NOSAFETY: call void @__asan_store1
   ret i32 0
 }
 
 
+; CHECK-LABEL: define void @atomicrmw
 define void @atomicrmw() sanitize_address {
   %buf = alloca [10 x i8], align 1
   %arrayidx = getelementptr inbounds [10 x i8], [10 x i8]* %buf, i64 0, i64 0
   %1 = atomicrmw add i8* %arrayidx, i8 1 seq_cst
+  ; NOSAFETY: call void @__asan_store1
   ret void
 }
 
+; CHECK-LABEL: define void @cmpxchg
 define void @cmpxchg(i8 %compare_to, i8 %new_value) sanitize_address {
   %buf = alloca [10 x i8], align 1
   %arrayidx = getelementptr inbounds [10 x i8], [10 x i8]* %buf, i64 0, i64 0
   %1 = cmpxchg i8* %arrayidx, i8 %compare_to, i8 %new_value seq_cst seq_cst
+  ; NOSAFETY: call void @__asan_store1
   ret void
 }