diff options
author | NAKAMURA Takumi <geek4civic@gmail.com> | 2024-07-07 22:48:20 +0900 |
---|---|---|
committer | NAKAMURA Takumi <geek4civic@gmail.com> | 2024-07-09 22:21:20 +0900 |
commit | 302937859fce0bb506ef6edf9c3e77c86ab44b86 (patch) | |
tree | a3d40641baf2e1d1917108f23d8faf93185c7f8e /clang/test | |
parent | 221d5c570c2ad0201d808b889280ef71b80c1845 (diff) | |
download | llvm-302937859fce0bb506ef6edf9c3e77c86ab44b86.zip llvm-302937859fce0bb506ef6edf9c3e77c86ab44b86.tar.gz llvm-302937859fce0bb506ef6edf9c3e77c86ab44b86.tar.bz2 |
Update clang/test/system_macro.cpp for both -system-headers-coverage=true/false
Part of #97952
Diffstat (limited to 'clang/test')
-rw-r--r-- | clang/test/CoverageMapping/system_macro.cpp | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/clang/test/CoverageMapping/system_macro.cpp b/clang/test/CoverageMapping/system_macro.cpp index 7257525..3909c17 100644 --- a/clang/test/CoverageMapping/system_macro.cpp +++ b/clang/test/CoverageMapping/system_macro.cpp @@ -1,4 +1,15 @@ -// RUN: %clang_cc1 -mllvm -emptyline-comment-coverage=false -mllvm -system-headers-coverage -std=c++11 -fprofile-instrument=clang -fcoverage-mapping -dump-coverage-mapping -emit-llvm-only -main-file-name system_macro.cpp -o - %s | FileCheck %s +// RUN: %clang_cc1 -mllvm -emptyline-comment-coverage=false -mllvm -system-headers-coverage=true -std=c++11 -fprofile-instrument=clang -fcoverage-mapping -dump-coverage-mapping -emit-llvm -main-file-name system_macro.cpp -o %t.w_sys.ll %s | FileCheck %s --check-prefixes=CHECK,W_SYS +// RUN: %clang_cc1 -mllvm -emptyline-comment-coverage=false -mllvm -system-headers-coverage=false -std=c++11 -fprofile-instrument=clang -fcoverage-mapping -dump-coverage-mapping -emit-llvm -main-file-name system_macro.cpp -o %t.wosys.ll %s | FileCheck %s --check-prefixes=CHECK,WOSYS +// RUN: FileCheck %s --check-prefixes=LL_CHECK,LL_W_SYS < %t.w_sys.ll +// RUN: FileCheck %s --check-prefixes=LL_CHECK,LL_WOSYS < %t.wosys.ll + +// LL_CHECK: @__covrec_ +// LL_W_SYS: [[PROFC:@.*__profc_.*SysTmpl.*]] = +// LL_WOSYS: [[PROFC:@.*__profc_.*SysTmpl.*]] = +// LL_W_SYS: @{{.*}}__profd_{{.*}}SysTmpl{{.*}} = +// LL_WOSYS: @{{.*}}__profd_{{.*}}SysTmpl{{.*}} = + +// LL_CHECK: @llvm.used = #ifdef IS_SYSHEADER @@ -6,6 +17,12 @@ #define Func(x) if (x) {} #define SomeType int +// LL_CHECK: define {{.*}} i1 @{{.*}}SysTmpl +template <bool f> bool SysTmpl() { return f; } +// Check SysTmpl() is instrumented or not. +// LL_W_SYS: load i64, ptr [[PROFC]], +// LL_WOSYS: load i64, ptr [[PROFC]], + #else #define IS_SYSHEADER @@ -13,15 +30,22 @@ // CHECK-LABEL: doSomething void doSomething(int x) { // CHECK: File 0, [[@LINE]]:25 -> {{[0-9:]+}} = #0 - Func(x); // CHECK: Expansion,File 0, [[@LINE]]:3 -> [[@LINE]]:7 + // WOSYS-NOT: Expansion, + // W_SYS: Expansion,File 0, [[@LINE+1]]:3 -> [[@LINE+1]]:7 + Func(x); + // CHECK: Gap,File 0, [[@LINE+1]]:10 return; - // CHECK: Expansion,File 0, [[@LINE+1]]:3 -> [[@LINE+1]]:11 + // WOSYS-NOT: Expansion, + // W_SYS: Expansion,File 0, [[@LINE+1]]:3 -> [[@LINE+1]]:11 SomeType *f; // CHECK: File 0, [[@LINE]]:11 -> {{[0-9:]+}} = 0 } // CHECK-LABEL: main int main() { // CHECK: File 0, [[@LINE]]:12 -> [[@LINE+2]]:2 = #0 - Func([] { return true; }()); + Func([] { return SysTmpl<true>(); }()); } +// W_SYS: SysTmpl +// WOSYS-NOT: SysTmpl + #endif |