xref: /aosp_15_r20/external/llvm/test/CodeGen/AArch64/arm64-prefetch.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc %s -march arm64 -o - | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker@a = common global i32* null, align 8
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine void @test(i32 %i, i32 %j) nounwind ssp {
6*9880d681SAndroid Build Coastguard Workerentry:
7*9880d681SAndroid Build Coastguard Worker  ; CHECK: @test
8*9880d681SAndroid Build Coastguard Worker  %j.addr = alloca i32, align 4
9*9880d681SAndroid Build Coastguard Worker  store i32 %j, i32* %j.addr, align 4, !tbaa !0
10*9880d681SAndroid Build Coastguard Worker  %tmp = bitcast i32* %j.addr to i8*
11*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pldl1strm
12*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 0, i32 1)
13*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pldl3keep
14*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 1, i32 1)
15*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pldl2keep
16*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 2, i32 1)
17*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pldl1keep
18*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 3, i32 1)
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum plil1strm
21*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 0, i32 0)
22*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum plil3keep
23*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 1, i32 0)
24*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum plil2keep
25*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 2, i32 0)
26*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum plil1keep
27*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 0, i32 3, i32 0)
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pstl1strm
30*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 1, i32 0, i32 1)
31*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pstl3keep
32*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 1, i32 1, i32 1)
33*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pstl2keep
34*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 1, i32 2, i32 1)
35*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfum pstl1keep
36*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp, i32 1, i32 3, i32 1)
37*9880d681SAndroid Build Coastguard Worker
38*9880d681SAndroid Build Coastguard Worker  %tmp1 = load i32, i32* %j.addr, align 4, !tbaa !0
39*9880d681SAndroid Build Coastguard Worker  %add = add nsw i32 %tmp1, %i
40*9880d681SAndroid Build Coastguard Worker  %idxprom = sext i32 %add to i64
41*9880d681SAndroid Build Coastguard Worker  %tmp2 = load i32*, i32** @a, align 8, !tbaa !3
42*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds i32, i32* %tmp2, i64 %idxprom
43*9880d681SAndroid Build Coastguard Worker  %tmp3 = bitcast i32* %arrayidx to i8*
44*9880d681SAndroid Build Coastguard Worker
45*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pldl1strm
46*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp3, i32 0, i32 0, i32 1)
47*9880d681SAndroid Build Coastguard Worker  %tmp4 = load i32*, i32** @a, align 8, !tbaa !3
48*9880d681SAndroid Build Coastguard Worker  %arrayidx3 = getelementptr inbounds i32, i32* %tmp4, i64 %idxprom
49*9880d681SAndroid Build Coastguard Worker  %tmp5 = bitcast i32* %arrayidx3 to i8*
50*9880d681SAndroid Build Coastguard Worker
51*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pldl3keep
52*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp5, i32 0, i32 1, i32 1)
53*9880d681SAndroid Build Coastguard Worker  %tmp6 = load i32*, i32** @a, align 8, !tbaa !3
54*9880d681SAndroid Build Coastguard Worker  %arrayidx6 = getelementptr inbounds i32, i32* %tmp6, i64 %idxprom
55*9880d681SAndroid Build Coastguard Worker  %tmp7 = bitcast i32* %arrayidx6 to i8*
56*9880d681SAndroid Build Coastguard Worker
57*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pldl2keep
58*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp7, i32 0, i32 2, i32 1)
59*9880d681SAndroid Build Coastguard Worker  %tmp8 = load i32*, i32** @a, align 8, !tbaa !3
60*9880d681SAndroid Build Coastguard Worker  %arrayidx9 = getelementptr inbounds i32, i32* %tmp8, i64 %idxprom
61*9880d681SAndroid Build Coastguard Worker  %tmp9 = bitcast i32* %arrayidx9 to i8*
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pldl1keep
64*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp9, i32 0, i32 3, i32 1)
65*9880d681SAndroid Build Coastguard Worker  %tmp10 = load i32*, i32** @a, align 8, !tbaa !3
66*9880d681SAndroid Build Coastguard Worker  %arrayidx12 = getelementptr inbounds i32, i32* %tmp10, i64 %idxprom
67*9880d681SAndroid Build Coastguard Worker  %tmp11 = bitcast i32* %arrayidx12 to i8*
68*9880d681SAndroid Build Coastguard Worker
69*9880d681SAndroid Build Coastguard Worker
70*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm plil1strm
71*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp11, i32 0, i32 0, i32 0)
72*9880d681SAndroid Build Coastguard Worker  %tmp12 = load i32*, i32** @a, align 8, !tbaa !3
73*9880d681SAndroid Build Coastguard Worker  %arrayidx15 = getelementptr inbounds i32, i32* %tmp12, i64 %idxprom
74*9880d681SAndroid Build Coastguard Worker  %tmp13 = bitcast i32* %arrayidx3 to i8*
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm plil3keep
77*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp13, i32 0, i32 1, i32 0)
78*9880d681SAndroid Build Coastguard Worker  %tmp14 = load i32*, i32** @a, align 8, !tbaa !3
79*9880d681SAndroid Build Coastguard Worker  %arrayidx18 = getelementptr inbounds i32, i32* %tmp14, i64 %idxprom
80*9880d681SAndroid Build Coastguard Worker  %tmp15 = bitcast i32* %arrayidx6 to i8*
81*9880d681SAndroid Build Coastguard Worker
82*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm plil2keep
83*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp15, i32 0, i32 2, i32 0)
84*9880d681SAndroid Build Coastguard Worker  %tmp16 = load i32*, i32** @a, align 8, !tbaa !3
85*9880d681SAndroid Build Coastguard Worker  %arrayidx21 = getelementptr inbounds i32, i32* %tmp16, i64 %idxprom
86*9880d681SAndroid Build Coastguard Worker  %tmp17 = bitcast i32* %arrayidx9 to i8*
87*9880d681SAndroid Build Coastguard Worker
88*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm plil1keep
89*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp17, i32 0, i32 3, i32 0)
90*9880d681SAndroid Build Coastguard Worker  %tmp18 = load i32*, i32** @a, align 8, !tbaa !3
91*9880d681SAndroid Build Coastguard Worker  %arrayidx24 = getelementptr inbounds i32, i32* %tmp18, i64 %idxprom
92*9880d681SAndroid Build Coastguard Worker  %tmp19 = bitcast i32* %arrayidx12 to i8*
93*9880d681SAndroid Build Coastguard Worker
94*9880d681SAndroid Build Coastguard Worker
95*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pstl1strm
96*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp19, i32 1, i32 0, i32 1)
97*9880d681SAndroid Build Coastguard Worker  %tmp20 = load i32*, i32** @a, align 8, !tbaa !3
98*9880d681SAndroid Build Coastguard Worker  %arrayidx27 = getelementptr inbounds i32, i32* %tmp20, i64 %idxprom
99*9880d681SAndroid Build Coastguard Worker  %tmp21 = bitcast i32* %arrayidx15 to i8*
100*9880d681SAndroid Build Coastguard Worker
101*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pstl3keep
102*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp21, i32 1, i32 1, i32 1)
103*9880d681SAndroid Build Coastguard Worker  %tmp22 = load i32*, i32** @a, align 8, !tbaa !3
104*9880d681SAndroid Build Coastguard Worker  %arrayidx30 = getelementptr inbounds i32, i32* %tmp22, i64 %idxprom
105*9880d681SAndroid Build Coastguard Worker  %tmp23 = bitcast i32* %arrayidx18 to i8*
106*9880d681SAndroid Build Coastguard Worker
107*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pstl2keep
108*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp23, i32 1, i32 2, i32 1)
109*9880d681SAndroid Build Coastguard Worker  %tmp24 = load i32*, i32** @a, align 8, !tbaa !3
110*9880d681SAndroid Build Coastguard Worker  %arrayidx33 = getelementptr inbounds i32, i32* %tmp24, i64 %idxprom
111*9880d681SAndroid Build Coastguard Worker  %tmp25 = bitcast i32* %arrayidx21 to i8*
112*9880d681SAndroid Build Coastguard Worker
113*9880d681SAndroid Build Coastguard Worker  ; CHECK: prfm pstl1keep
114*9880d681SAndroid Build Coastguard Worker  call void @llvm.prefetch(i8* %tmp25, i32 1, i32 3, i32 1)
115*9880d681SAndroid Build Coastguard Worker  ret void
116*9880d681SAndroid Build Coastguard Worker}
117*9880d681SAndroid Build Coastguard Worker
118*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.prefetch(i8* nocapture, i32, i32, i32) nounwind
119*9880d681SAndroid Build Coastguard Worker
120*9880d681SAndroid Build Coastguard Worker!0 = !{!"int", !1}
121*9880d681SAndroid Build Coastguard Worker!1 = !{!"omnipotent char", !2}
122*9880d681SAndroid Build Coastguard Worker!2 = !{!"Simple C/C++ TBAA"}
123*9880d681SAndroid Build Coastguard Worker!3 = !{!"any pointer", !1}
124