llvm-project/llvm/test/CodeGen/LoongArch/intrinsic.ll

49 lines
1.1 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc --mtriple=loongarch32 < %s | FileCheck %s
; RUN: llc --mtriple=loongarch64 < %s | FileCheck %s
declare void @llvm.loongarch.dbar(i32)
declare void @llvm.loongarch.ibar(i32)
declare void @llvm.loongarch.break(i32)
declare void @llvm.loongarch.syscall(i32)
define void @foo() nounwind {
; CHECK-LABEL: foo:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: dbar 0
; CHECK-NEXT: ret
entry:
call void @llvm.loongarch.dbar(i32 0)
ret void
}
define void @ibar() nounwind {
; CHECK-LABEL: ibar:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: ibar 0
; CHECK-NEXT: ret
entry:
call void @llvm.loongarch.ibar(i32 0)
ret void
}
define void @break() nounwind {
; CHECK-LABEL: break:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: break 1
; CHECK-NEXT: ret
entry:
call void @llvm.loongarch.break(i32 1)
ret void
}
define void @syscall() nounwind {
; CHECK-LABEL: syscall:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: syscall 1
; CHECK-NEXT: ret
entry:
call void @llvm.loongarch.syscall(i32 1)
ret void
}