annotate test/Verifier/amdgpu-cc.ll @ 146:3fc4d5c3e21e

set tail call flag for code segment in CGCAll
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 23 Dec 2018 19:23:36 +0900
parents 803732b1fca8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
121
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
1 ; RUN: not llvm-as < %s 2>&1 | FileCheck %s
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
2
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
3 ; CHECK: Calling convention requires void return type
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
4 ; CHECK-NEXT: i32 ()* @nonvoid_cc_amdgpu_kernel
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
5 define amdgpu_kernel i32 @nonvoid_cc_amdgpu_kernel() {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
6 ret i32 0
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
7 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
8
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
9 ; CHECK: Calling convention does not support varargs or perfect forwarding!
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
10 ; CHECK-NEXT: void (...)* @varargs_amdgpu_kernel
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
11 define amdgpu_kernel void @varargs_amdgpu_kernel(...) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
12 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
13 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
14
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
15 ; CHECK: Calling convention does not allow sret
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
16 ; CHECK-NEXT: void (i32*)* @sret_cc_amdgpu_kernel
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
17 define amdgpu_kernel void @sret_cc_amdgpu_kernel(i32* sret %ptr) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
18 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
19 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
20
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
21 ; CHECK: Calling convention does not support varargs or perfect forwarding!
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
22 ; CHECK-NEXT: void (...)* @varargs_amdgpu_vs
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
23 define amdgpu_vs void @varargs_amdgpu_vs(...) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
24 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
25 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
26
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
27 ; CHECK: Calling convention does not support varargs or perfect forwarding!
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
28 ; CHECK-NEXT: void (...)* @varargs_amdgpu_gs
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
29 define amdgpu_gs void @varargs_amdgpu_gs(...) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
30 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
31 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
32
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
33 ; CHECK: Calling convention does not support varargs or perfect forwarding!
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
34 ; CHECK-NEXT: void (...)* @varargs_amdgpu_ps
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
35 define amdgpu_ps void @varargs_amdgpu_ps(...) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
36 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
37 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
38
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
39 ; CHECK: Calling convention does not support varargs or perfect forwarding!
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
40 ; CHECK-NEXT: void (...)* @varargs_amdgpu_cs
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
41 define amdgpu_cs void @varargs_amdgpu_cs(...) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
42 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
43 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
44
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
45 ; CHECK: Calling convention requires void return type
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
46 ; CHECK-NEXT: i32 ()* @nonvoid_cc_spir_kernel
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
47 define spir_kernel i32 @nonvoid_cc_spir_kernel() {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
48 ret i32 0
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
49 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
50
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
51 ; CHECK: Calling convention does not support varargs or perfect forwarding!
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
52 ; CHECK-NEXT: void (...)* @varargs_spir_kernel
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
53 define spir_kernel void @varargs_spir_kernel(...) {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
54 ret void
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
55 }