xref: /llvm-project/llvm/test/Transforms/PGOProfile/icp_vtable_tail_call.ll (revision 1518b260ce2cbd9286365709642dc749e542d683)
1*1518b260SMingming Liu; RUN: opt < %s -passes='pgo-icall-prom' -pass-remarks=pgo-icall-prom -enable-vtable-profile-use -S 2>&1 | FileCheck %s --check-prefixes=VTABLE,REMARK
2*1518b260SMingming Liu
3*1518b260SMingming Liutarget datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128"
4*1518b260SMingming Liutarget triple = "x86_64-unknown-linux-gnu"
5*1518b260SMingming Liu
6*1518b260SMingming Liu; REMARK: remark: <unknown>:0:0: Promote indirect call to _ZN7Derived5func1Eii with count 900 out of 1600, sink 1 instruction(s) and compare 1 vtable(s): {_ZTV7Derived}
7*1518b260SMingming Liu; REMARK: remark: <unknown>:0:0: Promote indirect call to _ZN4Base5func1Eii with count 700 out of 700, sink 1 instruction(s) and compare 1 vtable(s): {_ZTV4Base}
8*1518b260SMingming Liu
9*1518b260SMingming Liu@_ZTV7Derived = constant { [3 x ptr] } { [3 x ptr] [ptr null, ptr null, ptr @_ZN7Derived5func1Eii] }, !type !0, !type !1, !type !2, !type !3
10*1518b260SMingming Liu@_ZTV4Base = constant { [3 x ptr] } { [3 x ptr] [ptr null, ptr null, ptr @_ZN4Base5func1Eii] }, !type !0, !type !1
11*1518b260SMingming Liu
12*1518b260SMingming Liudefine i32 @test_tail_call(ptr %ptr, i32 %a, i32 %b) {
13*1518b260SMingming Liu; VTABLE-LABEL: define i32 @test_tail_call(
14*1518b260SMingming Liu; VTABLE-SAME: ptr [[PTR:%.*]], i32 [[A:%.*]], i32 [[B:%.*]]) {
15*1518b260SMingming Liu; VTABLE-NEXT:  entry:
16*1518b260SMingming Liu; VTABLE-NEXT:    [[VTABLE:%.*]] = load ptr, ptr [[PTR]], align 8
17*1518b260SMingming Liu; VTABLE-NEXT:    [[TMP0:%.*]] = tail call i1 @llvm.type.test(ptr [[VTABLE]], metadata !"_ZTS4Base")
18*1518b260SMingming Liu; VTABLE-NEXT:    tail call void @llvm.assume(i1 [[TMP0]])
19*1518b260SMingming Liu; VTABLE-NEXT:    [[TMP2:%.*]] = icmp eq ptr [[VTABLE]], getelementptr inbounds (i8, ptr @_ZTV7Derived, i32 16)
20*1518b260SMingming Liu; VTABLE-NEXT:    br i1 [[TMP2]], label [[IF_TRUE_DIRECT_TARG:%.*]], label [[TMP4:%.*]], !prof [[PROF4:![0-9]+]]
21*1518b260SMingming Liu; VTABLE:       if.true.direct_targ:
22*1518b260SMingming Liu; VTABLE-NEXT:    [[TMP3:%.*]] = musttail call i32 @_ZN7Derived5func1Eii(ptr [[PTR]], i32 [[A]], i32 [[B]])
23*1518b260SMingming Liu; VTABLE-NEXT:    ret i32 [[TMP3]]
24*1518b260SMingming Liu; VTABLE:       3:
25*1518b260SMingming Liu; VTABLE-NEXT:    [[TMP4:%.*]] = icmp eq ptr [[VTABLE]], getelementptr inbounds (i8, ptr @_ZTV4Base, i32 16)
26*1518b260SMingming Liu; VTABLE-NEXT:    br i1 [[TMP4]], label [[IF_TRUE_DIRECT_TARG1:%.*]], label [[TMP7:%.*]], !prof [[PROF5:![0-9]+]]
27*1518b260SMingming Liu; VTABLE:       if.true.direct_targ1:
28*1518b260SMingming Liu; VTABLE-NEXT:    [[TMP6:%.*]] = musttail call i32 @_ZN4Base5func1Eii(ptr [[PTR]], i32 [[A]], i32 [[B]])
29*1518b260SMingming Liu; VTABLE-NEXT:    ret i32 [[TMP6]]
30*1518b260SMingming Liu; VTABLE:       6:
31*1518b260SMingming Liu; VTABLE-NEXT:    [[TMP1:%.*]] = load ptr, ptr [[VTABLE]], align 8
32*1518b260SMingming Liu; VTABLE-NEXT:    [[CALL:%.*]] = musttail call i32 [[TMP1]](ptr [[PTR]], i32 [[A]], i32 [[B]])
33*1518b260SMingming Liu; VTABLE-NEXT:    ret i32 [[CALL]]
34*1518b260SMingming Liu;
35*1518b260SMingming Liuentry:
36*1518b260SMingming Liu  %vtable = load ptr, ptr %ptr, !prof !4
37*1518b260SMingming Liu  %0 = tail call i1 @llvm.type.test(ptr %vtable, metadata !"_ZTS4Base")
38*1518b260SMingming Liu  tail call void @llvm.assume(i1 %0)
39*1518b260SMingming Liu  %1 = load ptr, ptr %vtable
40*1518b260SMingming Liu  %call = musttail call i32 %1(ptr %ptr, i32 %a, i32 %b), !prof !5
41*1518b260SMingming Liu  ret i32 %call
42*1518b260SMingming Liu}
43*1518b260SMingming Liu
44*1518b260SMingming Liudeclare i1 @llvm.type.test(ptr, metadata)
45*1518b260SMingming Liudeclare void @llvm.assume(i1)
46*1518b260SMingming Liu
47*1518b260SMingming Liudefine i32 @_ZN7Derived5func1Eii(ptr %this, i32 %a, i32 %b) {
48*1518b260SMingming Liuentry:
49*1518b260SMingming Liu  %sub = sub nsw i32 %a, %b
50*1518b260SMingming Liu  ret i32 %sub
51*1518b260SMingming Liu}
52*1518b260SMingming Liu
53*1518b260SMingming Liudefine i32 @_ZN4Base5func1Eii(ptr %this, i32 %a, i32 %b) {
54*1518b260SMingming Liuentry:
55*1518b260SMingming Liu  %add = add nsw i32 %b, %a
56*1518b260SMingming Liu  ret i32 %add
57*1518b260SMingming Liu}
58*1518b260SMingming Liu
59*1518b260SMingming Liu
60*1518b260SMingming Liu!0 = !{i64 16, !"_ZTS4Base"}
61*1518b260SMingming Liu!1 = !{i64 16, !"_ZTSM4BaseFiiiE.virtual"}
62*1518b260SMingming Liu!2 = !{i64 16, !"_ZTS7Derived"}
63*1518b260SMingming Liu!3 = !{i64 16, !"_ZTSM7DerivedFiiiE.virtual"}
64*1518b260SMingming Liu!4 = !{!"VP", i32 2, i64 1600, i64 13870436605473471591, i64 900, i64 1960855528937986108, i64 700}
65*1518b260SMingming Liu!5 = !{!"VP", i32 0, i64 1600, i64 7889036118036845314, i64 900, i64 10495086226207060333, i64 700}
66*1518b260SMingming Liu
67*1518b260SMingming Liu; VTABLE: [[PROF4]] = !{!"branch_weights", i32 900, i32 700}
68*1518b260SMingming Liu; VTABLE: [[PROF5]] = !{!"branch_weights", i32 700, i32 0}
69