1; RUN: llc -mtriple=amdgcn-amd-amdhsa -verify-machineinstrs -enable-ipra -amdgpu-sroa=0 < %s | FileCheck -check-prefix=GCN %s 2; RUN: llc -mtriple=amdgcn-amd-amdhsa -verify-machineinstrs -amdgpu-sroa=0 < %s | FileCheck -check-prefix=GCN %s 3 4; Kernels are not called, so there is no call preserved mask. 5; GCN-LABEL: {{^}}kernel: 6; GCN: flat_store_dword 7define amdgpu_kernel void @kernel(i32 addrspace(1)* %out) #0 { 8entry: 9 store i32 0, i32 addrspace(1)* %out 10 ret void 11} 12 13; GCN-LABEL: {{^}}func: 14; GCN: ; NumVgprs: 8 15define void @func() #1 { 16 call void asm sideeffect "", "~{v0},~{v1},~{v2},~{v3},~{v4},~{v5},~{v6},~{v7}"() #0 17 ret void 18} 19 20; GCN-LABEL: {{^}}kernel_call: 21; GCN-NOT: buffer_store 22; GCN-NOT: buffer_load 23; GCN-NOT: readlane 24; GCN-NOT: writelane 25; GCN: flat_load_dword v8 26; GCN: s_swappc_b64 27; GCN-NOT: buffer_store 28; GCN-NOT: buffer_load 29; GCN-NOT: readlane 30; GCN-NOT: writelane 31; GCN: flat_store_dword v{{\[[0-9]+:[0-9]+\]}}, v8 32 33; GCN: ; NumSgprs: 37 34; GCN: ; NumVgprs: 9 35define amdgpu_kernel void @kernel_call() #0 { 36 %vgpr = load volatile i32, i32 addrspace(1)* undef 37 tail call void @func() 38 store volatile i32 %vgpr, i32 addrspace(1)* undef 39 ret void 40} 41 42; GCN-LABEL: {{^}}func_regular_call: 43; GCN-NOT: buffer_store 44; GCN-NOT: buffer_load 45; GCN-NOT: readlane 46; GCN-NOT: writelane 47; GCN: flat_load_dword v8 48; GCN: s_swappc_b64 49; GCN-NOT: buffer_store 50; GCN-NOT: buffer_load 51; GCN-NOT: readlane 52; GCN-NOT: writelane 53; GCN: flat_store_dword v{{\[[0-9]+:[0-9]+\]}}, v8 54 55; GCN: ; NumSgprs: 32 56; GCN: ; NumVgprs: 9 57define void @func_regular_call() #1 { 58 %vgpr = load volatile i32, i32 addrspace(1)* undef 59 tail call void @func() 60 store volatile i32 %vgpr, i32 addrspace(1)* undef 61 ret void 62} 63 64; GCN-LABEL: {{^}}func_tail_call: 65; GCN: s_waitcnt 66; GCN-NEXT: s_getpc_b64 s[6:7] 67; GCN-NEXT: s_add_u32 s6, 68; GCN-NEXT: s_addc_u32 s7, 69; GCN-NEXT: s_setpc_b64 s[6:7] 70 71; GCN: ; NumSgprs: 32 72; GCN: ; NumVgprs: 8 73define void @func_tail_call() #1 { 74 tail call void @func() 75 ret void 76} 77 78; GCN-LABEL: {{^}}func_call_tail_call: 79; GCN: flat_load_dword v8 80; GCN: s_swappc_b64 81; GCN: flat_store_dword v{{\[[0-9]+:[0-9]+\]}}, v8 82; GCN: s_setpc_b64 83 84; GCN: ; NumSgprs: 32 85; GCN: ; NumVgprs: 9 86define void @func_call_tail_call() #1 { 87 %vgpr = load volatile i32, i32 addrspace(1)* undef 88 tail call void @func() 89 store volatile i32 %vgpr, i32 addrspace(1)* undef 90 tail call void @func() 91 ret void 92} 93 94define void @void_func_void() noinline { 95 ret void 96} 97 98; Make sure we don't get save/restore of FP between calls. 99; GCN-LABEL: {{^}}test_funcx2: 100; GCN-NOT: s5 101; GCN-NOT: s32 102define void @test_funcx2() #0 { 103 call void @void_func_void() 104 call void @void_func_void() 105 ret void 106} 107 108attributes #0 = { nounwind } 109attributes #1 = { nounwind noinline } 110