aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/AMDGPU/invalid-inline-asm-constraint-crash.ll
blob: 542e8d2db07ae56d9a7a1e31ddfc6bbd898aaae4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
; 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
}