[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / Transforms / PGOProfile / indirect_call_annotation.ll
blob6f72a998784b5ba52524ce7534c5c416257764a2
1 ; RUN: llvm-profdata merge %S/Inputs/indirect_call.proftext -o %t.profdata
2 ; RUN: opt < %s -pgo-instr-use -pgo-test-profile-file=%t.profdata -S | FileCheck %s --check-prefix=VP-ANNOTATION
3 ; RUN: opt < %s -passes=pgo-instr-use -pgo-test-profile-file=%t.profdata -S | FileCheck %s --check-prefix=VP-ANNOTATION
4 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
5 target triple = "x86_64-unknown-linux-gnu"
7 @foo = common global i32 (i32)* null, align 8
9 define i32 @func1(i32 %x) {
10 entry:
11   ret i32 %x
14 define i32 @func2(i32 %x) {
15 entry:
16   %add = add nsw i32 %x, 1
17   ret i32 %add
20 define i32 @func3(i32 %x) {
21 entry:
22   %add = add nsw i32 %x, 3
23   ret i32 %add
26 define i32 @bar(i32 %i) {
27 entry:
28   %tmp = load i32 (i32)*, i32 (i32)** @foo, align 8
29   %call = call i32 %tmp(i32 %i)
30 ; VP-ANNOTATION: %call = call i32 %tmp(i32 %i)
31 ; VP-ANNOTATION-SAME: !prof ![[VP:[0-9]+]]
32 ; VP-ANNOTATION: ![[VP]] = !{!"VP", i32 0, i64 140, i64 -4377547752858689819, i64 80, i64 -2545542355363006406, i64 40, i64 -6929281286627296573, i64 20}
33   ret i32 %call