[llvm] r261038 - New test case: make sure alloc bit is not set for covmap section on Linux

Xinliang David Li via llvm-commits llvm-commits at lists.llvm.org
Tue Feb 16 16:14:52 PST 2016


Author: davidxl
Date: Tue Feb 16 18:14:52 2016
New Revision: 261038

URL: http://llvm.org/viewvc/llvm-project?rev=261038&view=rev
Log:
New test case: make sure alloc bit is not set for covmap section on Linux

Added:
    llvm/trunk/test/Instrumentation/InstrProfiling/alloc.ll

Added: llvm/trunk/test/Instrumentation/InstrProfiling/alloc.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Instrumentation/InstrProfiling/alloc.ll?rev=261038&view=auto
==============================================================================
--- llvm/trunk/test/Instrumentation/InstrProfiling/alloc.ll (added)
+++ llvm/trunk/test/Instrumentation/InstrProfiling/alloc.ll Tue Feb 16 18:14:52 2016
@@ -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
+
+ at __profn_foo = private constant [3 x i8] c"foo"
+ at __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
+ at __profc_foo = private global [1 x i64] zeroinitializer, section "__llvm_prf_cnts", align 8
+ at __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
+ at __llvm_prf_nm = private constant [13 x i8] c"\03\0Bx\DAK\CB\CF\07\00\02\82\01E", section "__llvm_prf_names"
+ at 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", at progbits
+; CHECK-DAG: .section	__llvm_prf_data,"aw", at progbits
+




More information about the llvm-commits mailing list