Tom Stellard | 49f8bfd | 2015-01-06 18:00:21 +0000 | [diff] [blame] | 1 | ; RUN: llc -march=amdgcn -mcpu=SI -verify-machineinstrs < %s | FileCheck %s |
Marek Olsak | 7517077 | 2015-01-27 17:27:15 +0000 | [diff] [blame] | 2 | ; RUN: llc -march=amdgcn -mcpu=tonga -verify-machineinstrs < %s | FileCheck %s |
Tom Stellard | 5cbb53c | 2014-11-03 19:49:05 +0000 | [diff] [blame] | 3 | ; RUN: llc -march=r600 -mcpu=redwood -verify-machineinstrs < %s | FileCheck %s |
| 4 | |
| 5 | ; CHECK-NOT: {{^}}func: |
| 6 | define internal fastcc i32 @func(i32 %a) { |
| 7 | entry: |
| 8 | %tmp0 = add i32 %a, 1 |
| 9 | ret i32 %tmp0 |
| 10 | } |
| 11 | |
| 12 | ; CHECK: {{^}}kernel: |
Nikolay Haustov | eba8089 | 2016-08-31 11:18:33 +0000 | [diff] [blame] | 13 | ; CHECK-NOT: call |
Matt Arsenault | 3dbeefa | 2017-03-21 21:39:51 +0000 | [diff] [blame] | 14 | define amdgpu_kernel void @kernel(i32 addrspace(1)* %out) { |
Tom Stellard | 5cbb53c | 2014-11-03 19:49:05 +0000 | [diff] [blame] | 15 | entry: |
| 16 | %tmp0 = call i32 @func(i32 1) |
| 17 | store i32 %tmp0, i32 addrspace(1)* %out |
| 18 | ret void |
| 19 | } |
| 20 | |
| 21 | ; CHECK: {{^}}kernel2: |
Nikolay Haustov | eba8089 | 2016-08-31 11:18:33 +0000 | [diff] [blame] | 22 | ; CHECK-NOT: call |
Matt Arsenault | 3dbeefa | 2017-03-21 21:39:51 +0000 | [diff] [blame] | 23 | define amdgpu_kernel void @kernel2(i32 addrspace(1)* %out) { |
Tom Stellard | 5cbb53c | 2014-11-03 19:49:05 +0000 | [diff] [blame] | 24 | entry: |
| 25 | call void @kernel(i32 addrspace(1)* %out) |
| 26 | ret void |
| 27 | } |
Nikolay Haustov | eba8089 | 2016-08-31 11:18:33 +0000 | [diff] [blame] | 28 | |
| 29 | ; CHECK-NOT: func_alias |
| 30 | @func_alias = alias i32 (i32), i32 (i32)* @func |
| 31 | |
| 32 | ; CHECK: {{^}}kernel3: |
| 33 | ; CHECK-NOT: call |
Matt Arsenault | 3dbeefa | 2017-03-21 21:39:51 +0000 | [diff] [blame] | 34 | define amdgpu_kernel void @kernel3(i32 addrspace(1)* %out) { |
Nikolay Haustov | eba8089 | 2016-08-31 11:18:33 +0000 | [diff] [blame] | 35 | entry: |
| 36 | %tmp0 = call i32 @func_alias(i32 1) |
| 37 | store i32 %tmp0, i32 addrspace(1)* %out |
| 38 | ret void |
| 39 | } |
| 40 | |
| 41 | ; CHECK-NOT: kernel_alias |
| 42 | @kernel_alias = alias void (i32 addrspace(1)*), void (i32 addrspace(1)*)* @kernel |
| 43 | |
| 44 | ; CHECK: {{^}}kernel4: |
| 45 | ; CHECK-NOT: call |
Matt Arsenault | 3dbeefa | 2017-03-21 21:39:51 +0000 | [diff] [blame] | 46 | define amdgpu_kernel void @kernel4(i32 addrspace(1)* %out) { |
Nikolay Haustov | eba8089 | 2016-08-31 11:18:33 +0000 | [diff] [blame] | 47 | entry: |
| 48 | call void @kernel_alias(i32 addrspace(1)* %out) |
| 49 | ret void |
| 50 | } |