[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / PGOProfile / PR41279_2.ll
blobfc3e54fcb4c17a36ff389d291bcf3913a66be900
1 ; Test that instrumentaiton works fine for the case of catchswitch stmts.
2 ; RUN: opt < %s -passes=pgo-instr-gen -S | FileCheck %s --check-prefix=GEN
3 ; RUN: llvm-profdata merge %S/Inputs/PR41279_2.proftext -o %t.profdata
4 ; RUN: opt < %s -passes=pgo-instr-use -pgo-test-profile-file=%t.profdata -S | FileCheck %s --check-prefix=USE
7 define dso_local void @f() personality ptr @__C_specific_handler {
8 ; USE-LABEL: @f
9 ; USE-SAME: !prof ![[FUNC_ENTRY_COUNT:[0-9]+]]
10 ; USE-DAG: {{![0-9]+}} = !{i32 1, !"ProfileSummary", {{![0-9]+}}}
11 ; USE-DAG: {{![0-9]+}} = !{!"DetailedSummary", {{![0-9]+}}}
12 ; USE-DAG: ![[FUNC_ENTRY_COUNT]] = !{!"function_entry_count", i64 5}
13 entry:
14   %__exception_code = alloca i32, align 4
15   %__exception_code2 = alloca i32, align 4
16   invoke void @f() #2
17           to label %invoke.cont unwind label %catch.dispatch
19 catch.dispatch:
20   %0 = catchswitch within none [label %__except] unwind to caller
22 __except:
23   %1 = catchpad within %0 [ptr null]
24   catchret from %1 to label %__except1
26 __except1:
27   %2 = call i32 @llvm.eh.exceptioncode(token %1)
28   store i32 %2, ptr %__exception_code, align 4
29   br label %__try.cont7
30 ;GEN:  _except1:
31 ;GEN:    call void @llvm.instrprof.increment(ptr @__profn_f, i64 {{[0-9]+}}, i32 2, i32 1)
33 invoke.cont:
34   br label %__try.cont
36 __try.cont:
37   invoke void @f()
38           to label %invoke.cont3 unwind label %catch.dispatch4
40 catch.dispatch4:
41   %3 = catchswitch within none [label %__except5] unwind to caller
42 ; GEN: catch.dispatch4:
43 ; GEN-NOT: call void @llvm.instrprof.increment
45 __except5:
46   %4 = catchpad within %3 [ptr null]
47   catchret from %4 to label %__except6
49 __except6:
50   %5 = call i32 @llvm.eh.exceptioncode(token %4)
51   store i32 %5, ptr %__exception_code2, align 4
52   br label %__try.cont7
54 __try.cont7:
55   ret void
57 invoke.cont3:
58   br label %__try.cont7
59 ;GEN: invoke.cont3:
60 ;GEN:  call void @llvm.instrprof.increment(ptr @__profn_f, i64 {{[0-9]+}}, i32 2, i32 0)
64 declare dso_local i32 @__C_specific_handler(...)
66 declare i32 @llvm.eh.exceptioncode(token)