[sanitizer] Improve FreeBSD ASLR detection
[llvm-project.git] / llvm / test / Instrumentation / InstrProfiling / icall-comdat.ll
blobac5b689d7ba88b7c512f06169a3f1c5ac8816041
1 ;; Check that static counters are allocated for value profiler
3 ; RUN: opt < %s -mtriple=x86_64-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC
4 ; RUN: opt < %s -mtriple=powerpc-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC
5 ; RUN: opt < %s -mtriple=sparc-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC
6 ; RUN: opt < %s -mtriple=s390x-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC-EXT
7 ; RUN: opt < %s -mtriple=powerpc64-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC-EXT
8 ; RUN: opt < %s -mtriple=sparc64-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC-EXT
9 ; RUN: opt < %s -mtriple=mips-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC-SEXT
10 ; RUN: opt < %s -mtriple=mips64-unknown-linux -instrprof -vp-static-alloc=true -S | FileCheck %s --check-prefix=STATIC-SEXT
11 ; RUN: opt < %s -mtriple=x86_64-unknown-linux -instrprof -vp-static-alloc=false -S | FileCheck %s --check-prefix=DYN
15 @__profn_foo = private constant [3 x i8] c"foo"
16 @__profn_bar = private constant [3 x i8] c"bar"
18 define i32 @foo(i32 ()* ) {
19   call void @llvm.instrprof.increment(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @__profn_foo, i32 0, i32 0), i64 12884901887, i32 1, i32 0)
20   %2 = ptrtoint i32 ()* %0 to i64
21   call void @llvm.instrprof.value.profile(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @__profn_foo, i32 0, i32 0), i64 12884901887, i64 %2, i32 0, i32 0)
22   %3 = tail call i32 %0()
23   ret i32 %3
26 $bar = comdat any
28 define i32 @bar(i32 ()* ) comdat {
29 entry:
30   call void @llvm.instrprof.increment(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @__profn_bar, i32 0, i32 0), i64 12884901887, i32 1, i32 0)
31   %1 = ptrtoint i32 ()* %0 to i64
32   call void @llvm.instrprof.value.profile(i8* getelementptr inbounds ([3 x i8], [3 x i8]* @__profn_bar, i32 0, i32 0), i64 12884901887, i64 %1, i32 0, i32 0)
33   %2 = tail call i32 %0()
34   ret i32 %2
37 ; Function Attrs: nounwind
38 declare void @llvm.instrprof.increment(i8*, i64, i32, i32) #0
40 ; Function Attrs: nounwind
41 declare void @llvm.instrprof.value.profile(i8*, i64, i64, i32, i32) #0
43 attributes #0 = { nounwind }
45 ; STATIC: @__profvp_foo = private global [1 x i64] zeroinitializer, section "{{[^"]+}}", comdat($__profc_foo)
46 ; STATIC: @__profvp_bar = private global [1 x i64] zeroinitializer, section "{{[^"]+}}", comdat($__profc_bar)
47 ; STATIC: @__llvm_prf_vnodes
49 ; DYN-NOT: @__profvp_foo
50 ; DYN-NOT: @__llvm_prf_vnodes
52 ;; __llvm_prf_vnodes and __llvm_prf_nm are not referenced by other metadata sections.
53 ;; We have to conservatively place them in llvm.used.
54 ; STATIC:      @llvm.used = appending global
55 ; STATIC-SAME:   @__llvm_prf_vnodes
56 ; STATIC-SAME:   @__llvm_prf_nm
58 ; STATIC: call void @__llvm_profile_instrument_target(i64 %3, i8* bitcast ({ i64, i64, i64, i8*, i8*, i32, [2 x i16] }* @__profd_foo to i8*), i32 0)
59 ; STATIC-EXT: call void @__llvm_profile_instrument_target(i64 %3, i8* bitcast ({ i64, i64, i64, i8*, i8*, i32, [2 x i16] }* @__profd_foo to i8*), i32 zeroext 0)
60 ; STATIC-SEXT: call void @__llvm_profile_instrument_target(i64 %3, i8* bitcast ({ i64, i64, i64, i8*, i8*, i32, [2 x i16] }* @__profd_foo to i8*), i32 signext 0)
62 ; STATIC: declare void @__llvm_profile_instrument_target(i64, i8*, i32)
63 ; STATIC-EXT: declare void @__llvm_profile_instrument_target(i64, i8*, i32 zeroext)
64 ; STATIC-SEXT: declare void @__llvm_profile_instrument_target(i64, i8*, i32 signext)