diff options
| author | Xinliang David Li <davidxl@google.com> | 2016-02-17 00:14:52 +0000 | 
|---|---|---|
| committer | Xinliang David Li <davidxl@google.com> | 2016-02-17 00:14:52 +0000 | 
| commit | b83bedd8c28a8b0c45da05cf9709cdebdd98a2fc (patch) | |
| tree | 6c1c6afeea98ca3517d62191dee6ddb9000317d8 /llvm/test/Instrumentation/InstrProfiling | |
| parent | 1d547bf566223a389aebe97027dc235d85b80c9d (diff) | |
| download | bcm5719-llvm-b83bedd8c28a8b0c45da05cf9709cdebdd98a2fc.tar.gz bcm5719-llvm-b83bedd8c28a8b0c45da05cf9709cdebdd98a2fc.zip | |
New test case: make sure alloc bit is not set for covmap section on Linux
llvm-svn: 261038
Diffstat (limited to 'llvm/test/Instrumentation/InstrProfiling')
| -rw-r--r-- | llvm/test/Instrumentation/InstrProfiling/alloc.ll | 25 | 
1 files changed, 25 insertions, 0 deletions
| diff --git a/llvm/test/Instrumentation/InstrProfiling/alloc.ll b/llvm/test/Instrumentation/InstrProfiling/alloc.ll new file mode 100644 index 00000000000..ad1b370eb8a --- /dev/null +++ b/llvm/test/Instrumentation/InstrProfiling/alloc.ll @@ -0,0 +1,25 @@ +;; Ensure that SHF_ALLOC section flag is not set for the __llvm_covmap section on Linux. +; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu | FileCheck %s + +@__profn_foo = private constant [3 x i8] c"foo" +@__llvm_coverage_mapping = internal constant { { i32, i32, i32, i32 }, [1 x <{ i64, i32, i64 }>], [24 x i8] } { { i32, i32, i32, i32 } { i32 1, i32 10, i32 14, i32 1 }, [1 x <{ i64, i32, i64 }>] [<{ i64, i32, i64 }> <{ i64 6699318081062747564, i32 9, i64 0 }>], [24 x i8] c"\01\08/tmp/t.c\01\00\00\01\01\01\0C\01\02\00\00\00\00\00" }, section "__llvm_covmap", align 8 +@__profc_foo = private global [1 x i64] zeroinitializer, section "__llvm_prf_cnts", align 8 +@__profd_foo = private global { i64, i64, i64*, i8*, i8*, i32, [1 x i16] } { i64 6699318081062747564, i64 0, i64* getelementptr inbounds ([1 x i64], [1 x i64]* @__profc_foo, i32 0, i32 0), i8* bitcast (void ()* @foo to i8*), i8* null, i32 1, [1 x i16] zeroinitializer }, section "__llvm_prf_data", align 8 +@__llvm_prf_nm = private constant [13 x i8] c"\03\0Bx\DAK\CB\CF\07\00\02\82\01E", section "__llvm_prf_names" +@llvm.used = appending global [3 x i8*] [i8* bitcast ({ { i32, i32, i32, i32 }, [1 x <{ i64, i32, i64 }>], [24 x i8] }* @__llvm_coverage_mapping to i8*), i8* bitcast ({ i64, i64, i64*, i8*, i8*, i32, [1 x i16] }* @__profd_foo to i8*), i8* getelementptr inbounds ([13 x i8], [13 x i8]* @__llvm_prf_nm, i32 0, i32 0)], section "llvm.metadata" + +; Function Attrs: nounwind uwtable +define void @foo() #0 { +  %pgocount = load i64, i64* getelementptr inbounds ([1 x i64], [1 x i64]* @__profc_foo, i64 0, i64 0) +  %1 = add i64 %pgocount, 1 +  store i64 %1, i64* getelementptr inbounds ([1 x i64], [1 x i64]* @__profc_foo, i64 0, i64 0) +  ret void +} + +; Function Attrs: nounwind +declare void @llvm.instrprof.increment(i8*, i64, i32, i32) #1 + +; CHECK-DAG: .section	__llvm_covmap,"" +; CHECK-DAG: .section	__llvm_prf_cnts,"aw",@progbits +; CHECK-DAG: .section	__llvm_prf_data,"aw",@progbits + | 

