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) {
7 ; CHECK-NEXT: prfum pldl1keep, [x0, #7]
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)
14 define void @imm9_max(ptr %object) {
15 ; CHECK-LABEL: imm9_max:
17 ; CHECK-NEXT: prfum pldl1keep, [x0, #255]
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)
24 define void @imm9_above_max(ptr %object) {
25 ; CHECK-LABEL: imm9_above_max:
27 ; CHECK-NEXT: add x8, x0, #257
28 ; CHECK-NEXT: prfm pldl1keep, [x8]
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)
35 define void @imm9_min(ptr %object) {
36 ; CHECK-LABEL: imm9_min:
38 ; CHECK-NEXT: prfum pldl1keep, [x0, #-256]
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)
45 define void @imm9_below_min(ptr %object) {
46 ; CHECK-LABEL: imm9_below_min:
48 ; CHECK-NEXT: sub x8, x0, #257
49 ; CHECK-NEXT: prfm pldl1keep, [x8]
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)
56 define void @imm12(ptr %object) {
59 ; CHECK-NEXT: prfm pldl1keep, [x0, #8]
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)
66 define void @imm12_max(ptr %object) {
67 ; CHECK-LABEL: imm12_max:
69 ; CHECK-NEXT: prfm pldl1keep, [x0, #32760]
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)
76 define void @imm12_above_max(ptr %object) {
77 ; CHECK-LABEL: imm12_above_max:
79 ; CHECK-NEXT: mov w8, #32768 // =0x8000
80 ; CHECK-NEXT: prfm pldl1keep, [x0, x8]
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)
87 define void @reg(ptr %object, i64 %a) {
90 ; CHECK-NEXT: prfm pldl1keep, [x0, x1]
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)
97 define void @reg_shift(ptr %object, i64 %a) {
98 ; CHECK-LABEL: reg_shift:
100 ; CHECK-NEXT: prfm pldl1keep, [x0, x1, lsl #3]
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)
107 define void @reg_sext(ptr %object, i32 %a) {
108 ; CHECK-LABEL: reg_sext:
110 ; CHECK-NEXT: prfm pldl1keep, [x0, w1, sxtw]
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)
117 define void @reg_sext_shift(ptr %object, i32 %a) {
118 ; CHECK-LABEL: reg_sext_shift:
120 ; CHECK-NEXT: prfm pldl1keep, [x0, w1, sxtw #3]
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)
127 define void @reg_zext(ptr %object, i32 %a) {
128 ; CHECK-LABEL: reg_zext:
130 ; CHECK-NEXT: prfm pldl1keep, [x0, w1, uxtw]
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)
138 define void @reg_zext_shift(ptr %object, i32 %a) {
139 ; CHECK-LABEL: reg_zext_shift:
141 ; CHECK-NEXT: prfm pldl1keep, [x0, w1, uxtw #3]
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)