llvm-project/llvm/test/CodeGen/LoongArch/get-reg-error-la64.ll
gonglingqin eca62f9204 [LoongArch] Diagnose the behavior of reading and writing registers that do not conform to the hardware register size
When reading or writing a register that does not conform to the size of a
hardware register, an error message is generated instead of a compiler crash.

Differential Revision: https://reviews.llvm.org/D138008
2022-11-24 10:38:44 +08:00

22 lines
621 B
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: not llc < %s --mtriple=loongarch64 2>&1 | FileCheck %s
define i32 @read_sp() nounwind {
entry:
; CHECK: On LA64, only 64-bit registers can be read.
%a1 = call i32 @llvm.read_register.i32(metadata !0)
ret i32 %a1
}
define void @write_sp(i32 %val) nounwind {
entry:
; CHECK: On LA64, only 64-bit registers can be written.
call void @llvm.write_register.i32(metadata !0, i32 %val)
ret void
}
declare i32 @llvm.read_register.i32(metadata) nounwind
declare void @llvm.write_register.i32(metadata, i32) nounwind
!0 = !{!"$sp\00"}