llvm-project/llvm/test/CodeGen/AMDGPU/invalid-inline-asm-constraint-crash.ll
Fangrui Song 9afaf9c6c8 [AMDGPU,test] Change llc -march= to -mtriple=
Follow-up to 806761a7629df268c8aed49657aeccffa6bca449
2024-12-15 10:54:21 -08:00

53 lines
1.4 KiB
LLVM

; RUN: not llc -mtriple=amdgcn < %s 2>&1 | FileCheck -check-prefix=ERR %s
; ERR: error: couldn't allocate output register for constraint 'q'
define void @crash_use_invalid_output_constraint_block(ptr addrspace(1) %arg) {
bb:
%v = call i32 asm sideeffect "", "=q"()
br label %use
use:
store i32 %v, ptr addrspace(1) %arg
ret void
}
; ERR: error: unknown asm constraint 'q'
define void @invalid_input_constraint() {
call void asm sideeffect "", "q"(i32 1)
ret void
}
; ERR: error: unknown asm constraint 'q'
define void @invalid_input_constraint_multi() {
call void asm sideeffect "", "q,q"(i32 1, i16 2)
ret void
}
; ERR: error: unknown asm constraint 'q'
define void @invalid_input_constraint_multi_valid() {
call void asm sideeffect "", "q,v"(i32 1, i64 2)
ret void
}
; ERR: error: couldn't allocate output register for constraint 'q'
define void @crash_use_invalid_output_constraint_block_multi(ptr addrspace(1) %arg) {
bb:
%v = call { i32, i32 } asm sideeffect "", "=q,=q"()
br label %use
use:
store { i32, i32 } %v, ptr addrspace(1) %arg
ret void
}
; ERR: error: couldn't allocate output register for constraint 'q'
define void @crash_use_invalid_output_constraint_block_multi_valid(ptr addrspace(1) %arg) {
bb:
%v = call { i32, i32 } asm sideeffect "", "=q,=v"()
br label %use
use:
store { i32, i32 } %v, ptr addrspace(1) %arg
ret void
}