2018-11-15 10:32:43 +08:00
|
|
|
; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=kaveri -mattr=-code-object-v3 -enable-ipra=0 -verify-machineinstrs < %s | FileCheck -allow-deprecated-dag-overlap -enable-var-scope -check-prefixes=GCN,CIVI %s
|
|
|
|
; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 -mattr=-code-object-v3 -enable-ipra=0 -verify-machineinstrs < %s | FileCheck -allow-deprecated-dag-overlap -enable-var-scope -check-prefixes=GCN,GFX9 %s
|
2017-08-04 07:00:29 +08:00
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_dispatch_ptr:
|
2018-03-05 23:12:21 +08:00
|
|
|
; GCN: v_mov_b32_e32 v[[LO:[0-9]+]], s6
|
|
|
|
; GCN: v_mov_b32_e32 v[[HI:[0-9]+]], s7
|
|
|
|
; GCN: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]{{\]}}
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_dispatch_ptr() #1 {
|
2018-02-14 02:00:25 +08:00
|
|
|
%dispatch_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.dispatch.ptr() #0
|
|
|
|
%header_ptr = bitcast i8 addrspace(4)* %dispatch_ptr to i32 addrspace(4)*
|
|
|
|
%value = load volatile i32, i32 addrspace(4)* %header_ptr
|
2017-08-04 07:00:29 +08:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_dispatch_ptr:
|
|
|
|
; GCN: enable_sgpr_dispatch_ptr = 1
|
|
|
|
; GCN: s_mov_b64 s[6:7], s[4:5]
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_dispatch_ptr(i32) #1 {
|
|
|
|
call void @use_dispatch_ptr()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_queue_ptr:
|
2018-03-05 23:12:21 +08:00
|
|
|
; GCN: v_mov_b32_e32 v[[LO:[0-9]+]], s6
|
|
|
|
; GCN: v_mov_b32_e32 v[[HI:[0-9]+]], s7
|
|
|
|
; GCN: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]{{\]}}
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_queue_ptr() #1 {
|
2018-02-14 02:00:25 +08:00
|
|
|
%queue_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.queue.ptr() #0
|
|
|
|
%header_ptr = bitcast i8 addrspace(4)* %queue_ptr to i32 addrspace(4)*
|
|
|
|
%value = load volatile i32, i32 addrspace(4)* %header_ptr
|
2017-08-04 07:00:29 +08:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_queue_ptr:
|
|
|
|
; GCN: enable_sgpr_queue_ptr = 1
|
|
|
|
; GCN: s_mov_b64 s[6:7], s[4:5]
|
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_queue_ptr(i32) #1 {
|
|
|
|
call void @use_queue_ptr()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_queue_ptr_addrspacecast:
|
2018-03-05 23:12:21 +08:00
|
|
|
; CIVI: flat_load_dword v[[HI:[0-9]+]], v[0:1]
|
2017-08-04 07:00:29 +08:00
|
|
|
; GFX9: s_getreg_b32 [[APERTURE_LOAD:s[0-9]+]]
|
2018-03-05 23:12:21 +08:00
|
|
|
; CIVI: v_mov_b32_e32 v[[LO:[0-9]+]], 16
|
|
|
|
; GFX9: v_mov_b32_e32 v[[HI:[0-9]+]], [[APERTURE_LOAD]]
|
|
|
|
; GFX9: {{flat|global}}_store_dword v{{\[[0-9]+}}:[[HI]]{{\]}}
|
|
|
|
; CIVI: {{flat|global}}_store_dword v{{\[}}[[LO]]:[[HI]]{{\]}}
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_queue_ptr_addrspacecast() #1 {
|
2018-02-03 00:07:16 +08:00
|
|
|
%asc = addrspacecast i32 addrspace(3)* inttoptr (i32 16 to i32 addrspace(3)*) to i32*
|
|
|
|
store volatile i32 0, i32* %asc
|
2017-08-04 07:00:29 +08:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_queue_ptr_addrspacecast:
|
|
|
|
; CIVI: enable_sgpr_queue_ptr = 1
|
|
|
|
|
|
|
|
; CIVI: s_mov_b64 s[6:7], s[4:5]
|
|
|
|
; GFX9-NOT: s_mov_b64
|
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_queue_ptr_addrspacecast(i32) #1 {
|
|
|
|
call void @use_queue_ptr_addrspacecast()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_kernarg_segment_ptr:
|
2018-03-05 23:12:21 +08:00
|
|
|
; GCN: v_mov_b32_e32 v[[LO:[0-9]+]], s6
|
|
|
|
; GCN: v_mov_b32_e32 v[[HI:[0-9]+]], s7
|
|
|
|
; GCN: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]{{\]}}
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_kernarg_segment_ptr() #1 {
|
2018-02-14 02:00:25 +08:00
|
|
|
%kernarg_segment_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.kernarg.segment.ptr() #0
|
|
|
|
%header_ptr = bitcast i8 addrspace(4)* %kernarg_segment_ptr to i32 addrspace(4)*
|
|
|
|
%value = load volatile i32, i32 addrspace(4)* %header_ptr
|
2017-08-04 07:00:29 +08:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_kernarg_segment_ptr:
|
|
|
|
; GCN: enable_sgpr_kernarg_segment_ptr = 1
|
|
|
|
; GCN: s_mov_b64 s[6:7], s[4:5]
|
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_kernarg_segment_ptr(i32) #1 {
|
|
|
|
call void @use_kernarg_segment_ptr()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_dispatch_id:
|
|
|
|
; GCN: ; use s[6:7]
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_dispatch_id() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%id = call i64 @llvm.amdgcn.dispatch.id()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i64 %id)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; No kernarg segment so that there is a mov to check. With kernarg
|
|
|
|
; pointer enabled, it happens to end up in the right place anyway.
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_dispatch_id:
|
|
|
|
; GCN: enable_sgpr_dispatch_id = 1
|
|
|
|
|
|
|
|
; GCN: s_mov_b64 s[6:7], s[4:5]
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_dispatch_id() #1 {
|
|
|
|
call void @use_dispatch_id()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_x:
|
|
|
|
; GCN: s_waitcnt
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_x() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_stack_workgroup_id_x:
|
|
|
|
; GCN: s_waitcnt
|
2019-06-06 06:20:47 +08:00
|
|
|
; GCN-NOT: s32
|
2019-06-06 06:37:50 +08:00
|
|
|
; GCN: buffer_store_dword v0, off, s[0:3], s32{{$}}
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_setpc_b64
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_stack_workgroup_id_x() #1 {
|
2018-02-03 00:07:16 +08:00
|
|
|
%alloca = alloca i32, addrspace(5)
|
|
|
|
store volatile i32 0, i32 addrspace(5)* %alloca
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_y:
|
|
|
|
; GCN: s_waitcnt
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_y() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_z:
|
|
|
|
; GCN: s_waitcnt
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_z() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_xy:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use s6
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_xy() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val0 = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
%val1 = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val0)
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val1)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_xyz:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use s6
|
|
|
|
; GCN: ; use s7
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_xyz() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val0 = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
%val1 = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
%val2 = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val0)
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val1)
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val2)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_xz:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use s6
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_xz() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val0 = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
%val1 = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val0)
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val1)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_workgroup_id_yz:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use s6
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_workgroup_id_yz() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val0 = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
%val1 = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val0)
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val1)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_x:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 0
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 0
|
|
|
|
|
|
|
|
; GCN-NOT: s6
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b32 s4, s6
|
|
|
|
; GCN-NEXT: s_getpc_b64 s[6:7]
|
|
|
|
; GCN-NEXT: s_add_u32 s6, s6, use_workgroup_id_x@rel32@lo+4
|
|
|
|
; GCN-NEXT: s_addc_u32 s7, s7, use_workgroup_id_x@rel32@hi+4
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-NEXT: s_endpgm
|
2017-08-04 07:00:29 +08:00
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_x() #1 {
|
|
|
|
call void @use_workgroup_id_x()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_y:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 0
|
|
|
|
|
|
|
|
; GCN: s_mov_b32 s33, s8
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s4, s7
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_y() #1 {
|
|
|
|
call void @use_workgroup_id_y()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_z:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 0
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 1
|
|
|
|
; GCN: s_mov_b32 s33, s8
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b32 s4, s7
|
|
|
|
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_z() #1 {
|
|
|
|
call void @use_workgroup_id_z()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_xy:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 0
|
|
|
|
|
|
|
|
; GCN: s_mov_b32 s33, s8
|
2019-06-21 05:58:24 +08:00
|
|
|
|
|
|
|
; GCN: s_mov_b32 s4, s6
|
|
|
|
; GCN: s_mov_b32 s6, s7
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_xy() #1 {
|
|
|
|
call void @use_workgroup_id_xy()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_xyz:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 1
|
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s33, s9
|
|
|
|
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b32 s4, s6
|
|
|
|
; GCN: s_mov_b32 s6, s7
|
|
|
|
; GCN: s_mov_b32 s7, s8
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_xyz() #1 {
|
|
|
|
call void @use_workgroup_id_xyz()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_xz:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 0
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 1
|
|
|
|
|
|
|
|
; GCN: s_mov_b32 s33, s8
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b32 s4, s6
|
|
|
|
; GCN: s_mov_b32 s6, s7
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
|
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_xz() #1 {
|
|
|
|
call void @use_workgroup_id_xz()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_workgroup_id_yz:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 1
|
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s33, s9
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b32 s6, s8
|
|
|
|
; GCN: s_mov_b32 s4, s7
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_workgroup_id_yz() #1 {
|
|
|
|
call void @use_workgroup_id_yz()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; Argument is in right place already
|
|
|
|
; GCN-LABEL: {{^}}func_indirect_use_workgroup_id_x:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-NOT: s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @func_indirect_use_workgroup_id_x() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
call void @use_workgroup_id_x()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}func_indirect_use_workgroup_id_y:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-NOT: s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @func_indirect_use_workgroup_id_y() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
call void @use_workgroup_id_y()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}func_indirect_use_workgroup_id_z:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-NOT: s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @func_indirect_use_workgroup_id_z() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
call void @use_workgroup_id_z()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}other_arg_use_workgroup_id_x:
|
|
|
|
; GCN: {{flat|global}}_store_dword v{{\[[0-9]+:[0-9]+\]}}, v0
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @other_arg_use_workgroup_id_x(i32 %arg0) #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
store volatile i32 %arg0, i32 addrspace(1)* undef
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}other_arg_use_workgroup_id_y:
|
|
|
|
; GCN: {{flat|global}}_store_dword v{{\[[0-9]+:[0-9]+\]}}, v0
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @other_arg_use_workgroup_id_y(i32 %arg0) #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
store volatile i32 %arg0, i32 addrspace(1)* undef
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}other_arg_use_workgroup_id_z:
|
|
|
|
; GCN: {{flat|global}}_store_dword v{{\[[0-9]+:[0-9]+\]}}, v0
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @other_arg_use_workgroup_id_z(i32 %arg0) #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
%val = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
store volatile i32 %arg0, i32 addrspace(1)* undef
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_other_arg_use_workgroup_id_x:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 0
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 0
|
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s33, s7
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN-DAG: v_mov_b32_e32 v0, 0x22b
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s4, s6
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s32, s33
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-NOT: s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_other_arg_use_workgroup_id_x() #1 {
|
|
|
|
call void @other_arg_use_workgroup_id_x(i32 555)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_other_arg_use_workgroup_id_y:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 0
|
|
|
|
|
|
|
|
; GCN-DAG: s_mov_b32 s33, s8
|
|
|
|
; GCN-DAG: v_mov_b32_e32 v0, 0x22b
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s4, s7
|
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_other_arg_use_workgroup_id_y() #1 {
|
|
|
|
call void @other_arg_use_workgroup_id_y(i32 555)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_other_arg_use_workgroup_id_z:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 0
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 1
|
|
|
|
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s33, s8
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN-DAG: v_mov_b32_e32 v0, 0x22b
|
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_other_arg_use_workgroup_id_z() #1 {
|
|
|
|
call void @other_arg_use_workgroup_id_z(i32 555)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}use_every_sgpr_input:
|
2019-06-06 06:37:50 +08:00
|
|
|
; GCN: buffer_store_dword v{{[0-9]+}}, off, s[0:3], s32{{$}}
|
2018-03-05 23:12:21 +08:00
|
|
|
; GCN: v_mov_b32_e32 v[[LO:[0-9]+]], s6
|
|
|
|
; GCN: v_mov_b32_e32 v[[HI:[0-9]+]], s7
|
|
|
|
; GCN: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]{{\]}}
|
|
|
|
; GCN: v_mov_b32_e32 v[[LO:[0-9]+]], s8
|
|
|
|
; GCN: v_mov_b32_e32 v[[HI:[0-9]+]], s9
|
|
|
|
; GCN: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]{{\]}}
|
|
|
|
; GCN: v_mov_b32_e32 v[[LO:[0-9]+]], s10
|
|
|
|
; GCN: v_mov_b32_e32 v[[HI:[0-9]+]], s11
|
|
|
|
; GCN: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO]]:[[HI]]{{\]}}
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use s[12:13]
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: ; use s4
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use s14
|
|
|
|
; GCN: ; use s15
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @use_every_sgpr_input() #1 {
|
2018-02-03 00:07:16 +08:00
|
|
|
%alloca = alloca i32, align 4, addrspace(5)
|
|
|
|
store volatile i32 0, i32 addrspace(5)* %alloca
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%dispatch_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.dispatch.ptr() #0
|
|
|
|
%dispatch_ptr.bc = bitcast i8 addrspace(4)* %dispatch_ptr to i32 addrspace(4)*
|
|
|
|
%val0 = load volatile i32, i32 addrspace(4)* %dispatch_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%queue_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.queue.ptr() #0
|
|
|
|
%queue_ptr.bc = bitcast i8 addrspace(4)* %queue_ptr to i32 addrspace(4)*
|
|
|
|
%val1 = load volatile i32, i32 addrspace(4)* %queue_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%kernarg_segment_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.kernarg.segment.ptr() #0
|
|
|
|
%kernarg_segment_ptr.bc = bitcast i8 addrspace(4)* %kernarg_segment_ptr to i32 addrspace(4)*
|
|
|
|
%val2 = load volatile i32, i32 addrspace(4)* %kernarg_segment_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
|
|
|
%val3 = call i64 @llvm.amdgcn.dispatch.id()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i64 %val3)
|
|
|
|
|
|
|
|
%val4 = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val4)
|
|
|
|
|
|
|
|
%val5 = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val5)
|
|
|
|
|
|
|
|
%val6 = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val6)
|
|
|
|
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}kern_indirect_use_every_sgpr_input:
|
|
|
|
; GCN: enable_sgpr_workgroup_id_x = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_y = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_id_z = 1
|
|
|
|
; GCN: enable_sgpr_workgroup_info = 0
|
|
|
|
|
|
|
|
; GCN: enable_sgpr_private_segment_buffer = 1
|
|
|
|
; GCN: enable_sgpr_dispatch_ptr = 1
|
|
|
|
; GCN: enable_sgpr_queue_ptr = 1
|
|
|
|
; GCN: enable_sgpr_kernarg_segment_ptr = 1
|
|
|
|
; GCN: enable_sgpr_dispatch_id = 1
|
|
|
|
; GCN: enable_sgpr_flat_scratch_init = 1
|
|
|
|
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s33, s17
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_mov_b64 s[12:13], s[10:11]
|
|
|
|
; GCN: s_mov_b64 s[10:11], s[8:9]
|
|
|
|
; GCN: s_mov_b64 s[8:9], s[6:7]
|
|
|
|
; GCN: s_mov_b64 s[6:7], s[4:5]
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b32 s4, s14
|
|
|
|
; GCN: s_mov_b32 s14, s15
|
|
|
|
; GCN: s_mov_b32 s15, s16
|
2017-08-17 12:04:11 +08:00
|
|
|
; GCN: s_mov_b32 s32, s33
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
define amdgpu_kernel void @kern_indirect_use_every_sgpr_input() #1 {
|
|
|
|
call void @use_every_sgpr_input()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}func_indirect_use_every_sgpr_input:
|
|
|
|
; GCN-NOT: s6
|
|
|
|
; GCN-NOT: s7
|
|
|
|
; GCN-NOT: s8
|
|
|
|
; GCN-NOT: s9
|
|
|
|
; GCN-NOT: s10
|
|
|
|
; GCN-NOT: s11
|
|
|
|
; GCN-NOT: s12
|
|
|
|
; GCN-NOT: s13
|
|
|
|
; GCN-NOT: s[6:7]
|
|
|
|
; GCN-NOT: s[8:9]
|
|
|
|
; GCN-NOT: s[10:11]
|
|
|
|
; GCN-NOT: s[12:13]
|
2019-06-27 04:35:18 +08:00
|
|
|
; GCN: s_or_saveexec_b64 s[6:7], -1
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @func_indirect_use_every_sgpr_input() #1 {
|
2017-08-04 07:00:29 +08:00
|
|
|
call void @use_every_sgpr_input()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}func_use_every_sgpr_input_call_use_workgroup_id_xyz:
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN-NOT: s_mov_b32 s4
|
|
|
|
; GCN: s_mov_b32 s6, s14
|
|
|
|
; GCN-NEXT: s_mov_b32 s7, s15
|
|
|
|
; GCN-NOT: s_mov_b32 s4
|
|
|
|
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @func_use_every_sgpr_input_call_use_workgroup_id_xyz() #1 {
|
2018-02-03 00:07:16 +08:00
|
|
|
%alloca = alloca i32, align 4, addrspace(5)
|
|
|
|
store volatile i32 0, i32 addrspace(5)* %alloca
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%dispatch_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.dispatch.ptr() #0
|
|
|
|
%dispatch_ptr.bc = bitcast i8 addrspace(4)* %dispatch_ptr to i32 addrspace(4)*
|
|
|
|
%val0 = load volatile i32, i32 addrspace(4)* %dispatch_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%queue_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.queue.ptr() #0
|
|
|
|
%queue_ptr.bc = bitcast i8 addrspace(4)* %queue_ptr to i32 addrspace(4)*
|
|
|
|
%val1 = load volatile i32, i32 addrspace(4)* %queue_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%kernarg_segment_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.kernarg.segment.ptr() #0
|
|
|
|
%kernarg_segment_ptr.bc = bitcast i8 addrspace(4)* %kernarg_segment_ptr to i32 addrspace(4)*
|
|
|
|
%val2 = load volatile i32, i32 addrspace(4)* %kernarg_segment_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
|
|
|
%val3 = call i64 @llvm.amdgcn.dispatch.id()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i64 %val3)
|
|
|
|
|
|
|
|
%val4 = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val4)
|
|
|
|
|
|
|
|
%val5 = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val5)
|
|
|
|
|
|
|
|
%val6 = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val6)
|
|
|
|
|
|
|
|
call void @use_workgroup_id_xyz()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
; GCN-LABEL: {{^}}func_use_every_sgpr_input_call_use_workgroup_id_xyz_spill:
|
|
|
|
; GCN: s_mov_b32 s5, s32
|
2018-10-30 23:04:40 +08:00
|
|
|
|
|
|
|
; GCN-DAG: s_add_u32 s32, s32, 0x400
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b64 s{{\[}}[[LO_X:[0-9]+]]{{\:}}[[HI_X:[0-9]+]]{{\]}}, s[6:7]
|
|
|
|
; GCN-NOT: s_mov_b32 s4,
|
2018-02-28 00:59:10 +08:00
|
|
|
; GCN-DAG: s_mov_b32 s6, s14
|
|
|
|
; GCN-DAG: s_mov_b32 s7, s15
|
2018-03-05 23:12:21 +08:00
|
|
|
|
2019-06-21 05:58:24 +08:00
|
|
|
; GCN: s_mov_b64 s{{\[}}[[LO_Y:[0-9]+]]{{\:}}[[HI_Y:[0-9]+]]{{\]}}, s[8:9]
|
|
|
|
|
|
|
|
; GCN-DAG: s_mov_b32 [[SAVE_X:s[0-57-9][0-9]*]], s4
|
|
|
|
; GCN-DAG: s_mov_b32 [[SAVE_Y:s[0-57-9][0-9]*]], s14
|
|
|
|
; GCN-DAG: s_mov_b32 [[SAVE_Z:s[0-68-9][0-9]*]], s15
|
|
|
|
|
|
|
|
; GCN: s_mov_b64 s{{\[}}[[LO_Z:[0-9]+]]{{\:}}[[HI_Z:[0-9]+]]{{\]}}, s[10:11]
|
2018-03-05 23:12:21 +08:00
|
|
|
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: s_swappc_b64
|
|
|
|
|
2019-06-06 06:37:50 +08:00
|
|
|
; GCN-DAG: buffer_store_dword v{{[0-9]+}}, off, s[0:3], s5{{$}}
|
Bias physical register immediate assignments
The machine scheduler currently biases register copies to/from
physical registers to be closer to their point of use / def to
minimize their live ranges. This change extends this to also physical
register assignments from immediate values.
This causes a reduction in reduction in overall register pressure and
minor reduction in spills and indirectly fixes an out-of-registers
assertion (PR39391).
Most test changes are from minor instruction reorderings and register
name selection changes and direct consequences of that.
Reviewers: MatzeB, qcolombet, myatsina, pcc
Subscribers: nemanjai, jvesely, nhaehnle, eraman, hiraditya,
javed.absar, arphaman, jfb, jsji, llvm-commits
Differential Revision: https://reviews.llvm.org/D54218
llvm-svn: 346894
2018-11-15 05:11:53 +08:00
|
|
|
; GCN-DAG: v_mov_b32_e32 v[[LO1:[0-9]+]], s[[LO_X]]
|
|
|
|
; GCN-DAG: v_mov_b32_e32 v[[HI1:[0-9]+]], s[[HI_X]]
|
|
|
|
; GCN-DAG: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO1]]:[[HI1]]{{\]}}
|
|
|
|
; GCN-DAG: v_mov_b32_e32 v[[LO2:[0-9]+]], s[[LO_Y]]
|
|
|
|
; GCN-DAG: v_mov_b32_e32 v[[HI2:[0-9]+]], s[[HI_Y]]
|
|
|
|
; GCN-DAG: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO2]]:[[HI2]]{{\]}}
|
|
|
|
; GCN-DAG: v_mov_b32_e32 v[[LO3:[0-9]+]], s[[LO_Z]]
|
|
|
|
; GCN-DAG: v_mov_b32_e32 v[[HI3:[0-9]+]], s[[HI_Z]]
|
|
|
|
; GCN-DAG: {{flat|global}}_load_dword v{{[0-9]+}}, v{{\[}}[[LO3]]:[[HI3]]{{\]}}
|
2017-08-04 07:00:29 +08:00
|
|
|
; GCN: ; use
|
|
|
|
; GCN: ; use [[SAVE_X]]
|
|
|
|
; GCN: ; use [[SAVE_Y]]
|
|
|
|
; GCN: ; use [[SAVE_Z]]
|
2019-06-20 23:38:30 +08:00
|
|
|
define hidden void @func_use_every_sgpr_input_call_use_workgroup_id_xyz_spill() #1 {
|
2018-02-03 00:07:16 +08:00
|
|
|
%alloca = alloca i32, align 4, addrspace(5)
|
2017-08-04 07:00:29 +08:00
|
|
|
call void @use_workgroup_id_xyz()
|
|
|
|
|
2018-02-03 00:07:16 +08:00
|
|
|
store volatile i32 0, i32 addrspace(5)* %alloca
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%dispatch_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.dispatch.ptr() #0
|
|
|
|
%dispatch_ptr.bc = bitcast i8 addrspace(4)* %dispatch_ptr to i32 addrspace(4)*
|
|
|
|
%val0 = load volatile i32, i32 addrspace(4)* %dispatch_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%queue_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.queue.ptr() #0
|
|
|
|
%queue_ptr.bc = bitcast i8 addrspace(4)* %queue_ptr to i32 addrspace(4)*
|
|
|
|
%val1 = load volatile i32, i32 addrspace(4)* %queue_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
2018-02-14 02:00:25 +08:00
|
|
|
%kernarg_segment_ptr = call noalias i8 addrspace(4)* @llvm.amdgcn.kernarg.segment.ptr() #0
|
|
|
|
%kernarg_segment_ptr.bc = bitcast i8 addrspace(4)* %kernarg_segment_ptr to i32 addrspace(4)*
|
|
|
|
%val2 = load volatile i32, i32 addrspace(4)* %kernarg_segment_ptr.bc
|
2017-08-04 07:00:29 +08:00
|
|
|
|
|
|
|
%val3 = call i64 @llvm.amdgcn.dispatch.id()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i64 %val3)
|
|
|
|
|
|
|
|
%val4 = call i32 @llvm.amdgcn.workgroup.id.x()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val4)
|
|
|
|
|
|
|
|
%val5 = call i32 @llvm.amdgcn.workgroup.id.y()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val5)
|
|
|
|
|
|
|
|
%val6 = call i32 @llvm.amdgcn.workgroup.id.z()
|
|
|
|
call void asm sideeffect "; use $0", "s"(i32 %val6)
|
|
|
|
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
declare i32 @llvm.amdgcn.workgroup.id.x() #0
|
|
|
|
declare i32 @llvm.amdgcn.workgroup.id.y() #0
|
|
|
|
declare i32 @llvm.amdgcn.workgroup.id.z() #0
|
2018-02-14 02:00:25 +08:00
|
|
|
declare noalias i8 addrspace(4)* @llvm.amdgcn.queue.ptr() #0
|
|
|
|
declare noalias i8 addrspace(4)* @llvm.amdgcn.kernarg.segment.ptr() #0
|
2017-08-04 07:00:29 +08:00
|
|
|
declare i64 @llvm.amdgcn.dispatch.id() #0
|
2018-02-14 02:00:25 +08:00
|
|
|
declare noalias i8 addrspace(4)* @llvm.amdgcn.dispatch.ptr() #0
|
2017-08-04 07:00:29 +08:00
|
|
|
|
|
|
|
attributes #0 = { nounwind readnone speculatable }
|
|
|
|
attributes #1 = { nounwind noinline }
|