| ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck --check-prefix=GCN %s |
| ; RUN: llc -global-isel -amdgpu-fixed-function-abi -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck --check-prefix=GCN %s |
| |
| ; Test with zero frame |
| ; GCN-LABEL: {{^}}func1 |
| ; GCN: v_mov_b32_e32 v0, s30 |
| ; GCN: v_mov_b32_e32 v1, s31 |
| ; GCN: s_setpc_b64 s[30:31] |
| define i8* @func1() nounwind { |
| entry: |
| %0 = tail call i8* @llvm.returnaddress(i32 0) |
| ret i8* %0 |
| } |
| |
| ; Test with non-zero frame |
| ; GCN-LABEL: {{^}}func2 |
| ; GCN: v_mov_b32_e32 v0, 0 |
| ; GCN: v_mov_b32_e32 v1, 0 |
| ; GCN: s_setpc_b64 s[30:31] |
| define i8* @func2() nounwind { |
| entry: |
| %0 = tail call i8* @llvm.returnaddress(i32 1) |
| ret i8* %0 |
| } |
| |
| ; Test with amdgpu_kernel |
| ; GCN-LABEL: {{^}}func3 |
| ; GCN: v_mov_b32_e32 v0, 0 |
| ; GCN: v_mov_b32_e32 v1, {{v0|0}} |
| define amdgpu_kernel void @func3(i8** %out) nounwind { |
| entry: |
| %tmp = tail call i8* @llvm.returnaddress(i32 0) |
| store i8* %tmp, i8** %out, align 4 |
| ret void |
| } |
| |
| ; Test with use outside the entry-block |
| ; GCN-LABEL: {{^}}func4 |
| ; GCN: v_mov_b32_e32 v0, 0 |
| ; GCN: v_mov_b32_e32 v1, {{v0|0}} |
| define amdgpu_kernel void @func4(i8** %out, i32 %val) nounwind { |
| entry: |
| %cmp = icmp ne i32 %val, 0 |
| br i1 %cmp, label %store, label %exit |
| |
| store: |
| %tmp = tail call i8* @llvm.returnaddress(i32 1) |
| store i8* %tmp, i8** %out, align 4 |
| ret void |
| |
| exit: |
| ret void |
| } |
| |
| ; Test ending in unreachable |
| ; GCN-LABEL: {{^}}func5 |
| ; GCN: v_mov_b32_e32 v0, 0 |
| define void @func5() nounwind { |
| entry: |
| %tmp = tail call i8* @llvm.returnaddress(i32 2) |
| store volatile i32 0, i32 addrspace(3)* undef, align 4 |
| unreachable |
| } |
| |
| declare void @callee() |
| |
| ; GCN-LABEL: {{^}}multi_use: |
| ; GCN-DAG: v_mov_b32_e32 v[[LO:4[0-9]+]], s30 |
| ; GCN-DAG: v_mov_b32_e32 v[[HI:4[0-9]+]], s31 |
| ; GCN: global_store_dwordx2 v{{\[[0-9]+:[0-9]+\]}}, v{{\[}}[[LO]]:[[HI]]{{\]}} |
| ; GCN: s_swappc_b64 |
| ; GCN: global_store_dwordx2 v{{\[[0-9]+:[0-9]+\]}}, v{{\[}}[[LO]]:[[HI]]{{\]}} |
| define void @multi_use() nounwind { |
| entry: |
| %ret0 = tail call i8* @llvm.returnaddress(i32 0) |
| store volatile i8* %ret0, i8* addrspace(1)* undef |
| call void @callee() |
| %ret1 = tail call i8* @llvm.returnaddress(i32 0) |
| store volatile i8* %ret1, i8* addrspace(1)* undef |
| ret void |
| } |
| |
| declare i8* @llvm.returnaddress(i32) nounwind readnone |