leecheechen dfb5b6e27c
[LoongArch] Don't crash on instruction prefetch intrinsics (#135760)
Instead of failing to select during isel, drop the intrinsic in
lowering.

Similar as the X86's PR. Seeing: https://reviews.llvm.org/D151050.

Fixes #134624
2025-04-16 14:12:00 +08:00

34 lines
1000 B
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc --mtriple=loongarch32 < %s | FileCheck %s --check-prefix=LA32
; RUN: llc --mtriple=loongarch64 < %s | FileCheck %s --check-prefix=LA64
declare void @llvm.prefetch(ptr, i32, i32, i32) nounwind
define dso_local void @prefetch_no_offset(ptr %ptr) nounwind {
; LA32-LABEL: prefetch_no_offset:
; LA32: # %bb.0: # %entry
; LA32-NEXT: ret
;
; LA64-LABEL: prefetch_no_offset:
; LA64: # %bb.0: # %entry
; LA64-NEXT: ret
entry:
tail call void @llvm.prefetch(ptr %ptr, i32 0, i32 3, i32 0)
ret void
}
define dso_local void @prefetch_with_offset(ptr %ptr) nounwind {
; LA32-LABEL: prefetch_with_offset:
; LA32: # %bb.0: # %entry
; LA32-NEXT: ret
;
; LA64-LABEL: prefetch_with_offset:
; LA64: # %bb.0: # %entry
; LA64-NEXT: ret
entry:
%addr = getelementptr i8, ptr %ptr, i64 200
tail call void @llvm.prefetch(ptr %addr, i32 0, i32 3, i32 0)
ret void
}