annotate llvm/test/CodeGen/AMDGPU/byval-frame-setup.ll @ 173:0572611fdcc8 llvm10 llvm12

reorgnization done
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 11:55:54 +0900
parents 1d019706d866
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=fiji -enable-ipra=0 -verify-machineinstrs < %s | FileCheck -enable-var-scope -check-prefixes=GCN,VI %s
anatofuz
parents:
diff changeset
2 ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=hawaii -enable-ipra=0 -verify-machineinstrs < %s | FileCheck -enable-var-scope -check-prefixes=GCN,CI %s
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 %struct.ByValStruct = type { [4 x i32] }
anatofuz
parents:
diff changeset
5 ; Make sure the offset is folded and function's frame register is used
anatofuz
parents:
diff changeset
6 ; rather than the global scratch wave offset.
anatofuz
parents:
diff changeset
7 ; GCN-LABEL: {{^}}void_func_byval_struct_use_outside_entry_block:
anatofuz
parents:
diff changeset
8 ; GCN-NOT: v_lshrrev_b32
anatofuz
parents:
diff changeset
9 ; GCN-NOT: s_sub_u32
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 ; GCN: s_and_saveexec_b64
anatofuz
parents:
diff changeset
12 ; GCN: s_cbranch_execz [[BB1:BB[0-9]+_[0-9]+]]
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 ; GCN: buffer_load_dword [[LOAD0:v[0-9]+]], off, s[0:3], s32{{$}}
anatofuz
parents:
diff changeset
15 ; GCN-NOT: s32
anatofuz
parents:
diff changeset
16 ; GCN: buffer_store_dword [[LOAD0]], off, s[0:3], s32{{$}}
anatofuz
parents:
diff changeset
17 ; GCN-NOT: s32
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 ; GCN: buffer_load_dword [[LOAD1:v[0-9]+]], off, s[0:3], s32 offset:16{{$}}
anatofuz
parents:
diff changeset
20 ; GCN-NOT: s32
anatofuz
parents:
diff changeset
21 ; GCN: buffer_store_dword [[LOAD1]], off, s[0:3], s32 offset:16{{$}}
anatofuz
parents:
diff changeset
22 ; GCN-NOT: s32
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 ; GCN: [[BB1]]
anatofuz
parents:
diff changeset
25 ; GCN: s_or_b64 exec, exec
anatofuz
parents:
diff changeset
26 define hidden void @void_func_byval_struct_use_outside_entry_block(%struct.ByValStruct addrspace(5)* byval noalias nocapture align 4 %arg0, %struct.ByValStruct addrspace(5)* byval noalias nocapture align 4 %arg1, i1 %cond) #1 {
anatofuz
parents:
diff changeset
27 entry:
anatofuz
parents:
diff changeset
28 br i1 %cond, label %bb0, label %bb1
anatofuz
parents:
diff changeset
29
anatofuz
parents:
diff changeset
30 bb0:
anatofuz
parents:
diff changeset
31 %arrayidx = getelementptr inbounds %struct.ByValStruct, %struct.ByValStruct addrspace(5)* %arg0, i32 0, i32 0, i32 0
anatofuz
parents:
diff changeset
32 %tmp = load volatile i32, i32 addrspace(5)* %arrayidx, align 4
anatofuz
parents:
diff changeset
33 %add = add nsw i32 %tmp, 1
anatofuz
parents:
diff changeset
34 store volatile i32 %add, i32 addrspace(5)* %arrayidx, align 4
anatofuz
parents:
diff changeset
35 %arrayidx2 = getelementptr inbounds %struct.ByValStruct, %struct.ByValStruct addrspace(5)* %arg1, i32 0, i32 0, i32 0
anatofuz
parents:
diff changeset
36 %tmp1 = load volatile i32, i32 addrspace(5)* %arrayidx2, align 4
anatofuz
parents:
diff changeset
37 %add3 = add nsw i32 %tmp1, 2
anatofuz
parents:
diff changeset
38 store volatile i32 %add3, i32 addrspace(5)* %arrayidx2, align 4
anatofuz
parents:
diff changeset
39 store volatile i32 9, i32 addrspace(1)* null, align 4
anatofuz
parents:
diff changeset
40 br label %bb1
anatofuz
parents:
diff changeset
41
anatofuz
parents:
diff changeset
42 bb1:
anatofuz
parents:
diff changeset
43 ret void
anatofuz
parents:
diff changeset
44 }
anatofuz
parents:
diff changeset
45 declare hidden void @external_void_func_void() #0
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47 declare void @llvm.lifetime.start.p5i8(i64, i8 addrspace(5)* nocapture) #3
anatofuz
parents:
diff changeset
48 declare void @llvm.lifetime.end.p5i8(i64, i8 addrspace(5)* nocapture) #3
anatofuz
parents:
diff changeset
49
anatofuz
parents:
diff changeset
50 attributes #0 = { nounwind }
anatofuz
parents:
diff changeset
51 attributes #1 = { noinline norecurse nounwind }
anatofuz
parents:
diff changeset
52 attributes #2 = { nounwind norecurse "frame-pointer"="all" }