
Previously instruction selection failed to generate PRFM instructions with register offsets because `AArch64ISD::PREFETCH` is not a `MemSDNode`.
148 lines
4.5 KiB
LLVM
148 lines
4.5 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
|
|
; RUN: llc -mtriple=aarch64 < %s | FileCheck %s
|
|
|
|
define void @imm9(ptr %object) {
|
|
; CHECK-LABEL: imm9:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfum pldl1keep, [x0, #7]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 7
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm9_max(ptr %object) {
|
|
; CHECK-LABEL: imm9_max:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfum pldl1keep, [x0, #255]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 255
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm9_above_max(ptr %object) {
|
|
; CHECK-LABEL: imm9_above_max:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: add x8, x0, #257
|
|
; CHECK-NEXT: prfm pldl1keep, [x8]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 257 ; 256 would use the imm12 mode
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm9_min(ptr %object) {
|
|
; CHECK-LABEL: imm9_min:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfum pldl1keep, [x0, #-256]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 -256
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm9_below_min(ptr %object) {
|
|
; CHECK-LABEL: imm9_below_min:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: sub x8, x0, #257
|
|
; CHECK-NEXT: prfm pldl1keep, [x8]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 -257
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm12(ptr %object) {
|
|
; CHECK-LABEL: imm12:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, #8]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i64, ptr %object, i64 1
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm12_max(ptr %object) {
|
|
; CHECK-LABEL: imm12_max:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, #32760]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i64, ptr %object, i64 4095
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @imm12_above_max(ptr %object) {
|
|
; CHECK-LABEL: imm12_above_max:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: mov w8, #32768 // =0x8000
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, x8]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i64, ptr %object, i64 4096
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @reg(ptr %object, i64 %a) {
|
|
; CHECK-LABEL: reg:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, x1]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 %a
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @reg_shift(ptr %object, i64 %a) {
|
|
; CHECK-LABEL: reg_shift:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, x1, lsl #3]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i64, ptr %object, i64 %a
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @reg_sext(ptr %object, i32 %a) {
|
|
; CHECK-LABEL: reg_sext:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, w1, sxtw]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i32 %a
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @reg_sext_shift(ptr %object, i32 %a) {
|
|
; CHECK-LABEL: reg_sext_shift:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, w1, sxtw #3]
|
|
; CHECK-NEXT: ret
|
|
%incdec.ptr = getelementptr inbounds i64, ptr %object, i32 %a
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @reg_zext(ptr %object, i32 %a) {
|
|
; CHECK-LABEL: reg_zext:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, w1, uxtw]
|
|
; CHECK-NEXT: ret
|
|
%a.zext = zext i32 %a to i64
|
|
%incdec.ptr = getelementptr inbounds i8, ptr %object, i64 %a.zext
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|
|
|
|
define void @reg_zext_shift(ptr %object, i32 %a) {
|
|
; CHECK-LABEL: reg_zext_shift:
|
|
; CHECK: // %bb.0:
|
|
; CHECK-NEXT: prfm pldl1keep, [x0, w1, uxtw #3]
|
|
; CHECK-NEXT: ret
|
|
%a.zext = zext i32 %a to i64
|
|
%incdec.ptr = getelementptr inbounds i64, ptr %object, i64 %a.zext
|
|
call void @llvm.prefetch.p0(ptr %incdec.ptr, i32 0, i32 3, i32 1)
|
|
ret void
|
|
}
|