[Xtensa] Implement Windowed Register Option. (#124656)
[llvm-project.git] / llvm / test / CodeGen / AArch64 / arm64-prefetch-addrmode.ll
blob44202ffba6374b24cd582cf2f64ab4add53833cf
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
2 ; RUN: llc -mtriple=aarch64 < %s | FileCheck %s
4 define void @imm9(ptr %object) {
5 ; CHECK-LABEL: imm9:
6 ; CHECK:       // %bb.0:
7 ; CHECK-NEXT:    prfum pldl1keep, [x0, #7]
8 ; CHECK-NEXT:    ret
9   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 7
10   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
11   ret void
14 define void @imm9_max(ptr %object) {
15 ; CHECK-LABEL: imm9_max:
16 ; CHECK:       // %bb.0:
17 ; CHECK-NEXT:    prfum pldl1keep, [x0, #255]
18 ; CHECK-NEXT:    ret
19   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 255
20   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
21   ret void
24 define void @imm9_above_max(ptr %object) {
25 ; CHECK-LABEL: imm9_above_max:
26 ; CHECK:       // %bb.0:
27 ; CHECK-NEXT:    add x8, x0, #257
28 ; CHECK-NEXT:    prfm pldl1keep, [x8]
29 ; CHECK-NEXT:    ret
30   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 257  ; 256 would use the imm12 mode
31   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
32   ret void
35 define void @imm9_min(ptr %object) {
36 ; CHECK-LABEL: imm9_min:
37 ; CHECK:       // %bb.0:
38 ; CHECK-NEXT:    prfum pldl1keep, [x0, #-256]
39 ; CHECK-NEXT:    ret
40   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 -256
41   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
42   ret void
45 define void @imm9_below_min(ptr %object) {
46 ; CHECK-LABEL: imm9_below_min:
47 ; CHECK:       // %bb.0:
48 ; CHECK-NEXT:    sub x8, x0, #257
49 ; CHECK-NEXT:    prfm pldl1keep, [x8]
50 ; CHECK-NEXT:    ret
51   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 -257
52   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
53   ret void
56 define void @imm12(ptr %object) {
57 ; CHECK-LABEL: imm12:
58 ; CHECK:       // %bb.0:
59 ; CHECK-NEXT:    prfm pldl1keep, [x0, #8]
60 ; CHECK-NEXT:    ret
61   %incdec.ptr = getelementptr inbounds i64, ptr %object, i64 1
62   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
63   ret void
66 define void @imm12_max(ptr %object) {
67 ; CHECK-LABEL: imm12_max:
68 ; CHECK:       // %bb.0:
69 ; CHECK-NEXT:    prfm pldl1keep, [x0, #32760]
70 ; CHECK-NEXT:    ret
71   %incdec.ptr = getelementptr inbounds i64, ptr %object, i64 4095
72   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
73   ret void
76 define void @imm12_above_max(ptr %object) {
77 ; CHECK-LABEL: imm12_above_max:
78 ; CHECK:       // %bb.0:
79 ; CHECK-NEXT:    mov w8, #32768 // =0x8000
80 ; CHECK-NEXT:    prfm pldl1keep, [x0, x8]
81 ; CHECK-NEXT:    ret
82   %incdec.ptr = getelementptr inbounds i64, ptr %object, i64 4096
83   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
84   ret void
87 define void @reg(ptr %object, i64 %a) {
88 ; CHECK-LABEL: reg:
89 ; CHECK:       // %bb.0:
90 ; CHECK-NEXT:    prfm pldl1keep, [x0, x1]
91 ; CHECK-NEXT:    ret
92   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 %a
93   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
94   ret void
97 define void @reg_shift(ptr %object, i64 %a) {
98 ; CHECK-LABEL: reg_shift:
99 ; CHECK:       // %bb.0:
100 ; CHECK-NEXT:    prfm pldl1keep, [x0, x1, lsl #3]
101 ; CHECK-NEXT:    ret
102   %incdec.ptr = getelementptr inbounds i64, ptr %object, i64 %a
103   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
104   ret void
107 define void @reg_sext(ptr %object, i32 %a) {
108 ; CHECK-LABEL: reg_sext:
109 ; CHECK:       // %bb.0:
110 ; CHECK-NEXT:    prfm pldl1keep, [x0, w1, sxtw]
111 ; CHECK-NEXT:    ret
112   %incdec.ptr = getelementptr inbounds i8, ptr %object, i32 %a
113   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
114   ret void
117 define void @reg_sext_shift(ptr %object, i32 %a) {
118 ; CHECK-LABEL: reg_sext_shift:
119 ; CHECK:       // %bb.0:
120 ; CHECK-NEXT:    prfm pldl1keep, [x0, w1, sxtw #3]
121 ; CHECK-NEXT:    ret
122   %incdec.ptr = getelementptr inbounds i64, ptr %object, i32 %a
123   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
124   ret void
127 define void @reg_zext(ptr %object, i32 %a) {
128 ; CHECK-LABEL: reg_zext:
129 ; CHECK:       // %bb.0:
130 ; CHECK-NEXT:    prfm pldl1keep, [x0, w1, uxtw]
131 ; CHECK-NEXT:    ret
132   %a.zext = zext i32 %a to i64
133   %incdec.ptr = getelementptr inbounds i8, ptr %object, i64 %a.zext
134   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
135   ret void
138 define void @reg_zext_shift(ptr %object, i32 %a) {
139 ; CHECK-LABEL: reg_zext_shift:
140 ; CHECK:       // %bb.0:
141 ; CHECK-NEXT:    prfm pldl1keep, [x0, w1, uxtw #3]
142 ; CHECK-NEXT:    ret
143   %a.zext = zext i32 %a to i64
144   %incdec.ptr = getelementptr inbounds i64, ptr %object, i64 %a.zext
145   call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
146   ret void