forked from OSchip/llvm-project
AMDGPU/GlobalISel: Set type on vgpr live in special arguments
Fixes assertion with workitem ID intrinsics used in non-kernel functions. llvm-svn: 371951
This commit is contained in:
parent
9f52c1ea58
commit
60169ed613
|
@ -1671,7 +1671,8 @@ static ArgDescriptor allocateVGPR32Input(CCState &CCInfo, unsigned Mask = ~0u,
|
|||
assert(Reg != AMDGPU::NoRegister);
|
||||
|
||||
MachineFunction &MF = CCInfo.getMachineFunction();
|
||||
MF.addLiveIn(Reg, &AMDGPU::VGPR_32RegClass);
|
||||
Register LiveInVReg = MF.addLiveIn(Reg, &AMDGPU::VGPR_32RegClass);
|
||||
MF.getRegInfo().setType(LiveInVReg, LLT::scalar(32));
|
||||
return ArgDescriptor::createRegister(Reg, Mask);
|
||||
}
|
||||
|
||||
|
|
|
@ -88,5 +88,32 @@ bb2:
|
|||
ret void
|
||||
}
|
||||
|
||||
; ALL-LABEL: {{^}}test_workitem_id_x_func:
|
||||
; ALL: v_lshrrev_b32_e32 v2, 0, v2
|
||||
; ALL-NEXT: v_and_b32_e32 v2, 0x3ff, v2
|
||||
define void @test_workitem_id_x_func(i32 addrspace(1)* %out) #1 {
|
||||
%id = call i32 @llvm.amdgcn.workitem.id.x()
|
||||
store i32 %id, i32 addrspace(1)* %out
|
||||
ret void
|
||||
}
|
||||
|
||||
; ALL-LABEL: {{^}}test_workitem_id_y_func:
|
||||
; ALL: v_lshrrev_b32_e32 v2, 10, v2
|
||||
; ALL-NEXT: v_and_b32_e32 v2, 0x3ff, v2
|
||||
define void @test_workitem_id_y_func(i32 addrspace(1)* %out) #1 {
|
||||
%id = call i32 @llvm.amdgcn.workitem.id.y()
|
||||
store i32 %id, i32 addrspace(1)* %out
|
||||
ret void
|
||||
}
|
||||
|
||||
; ALL-LABEL: {{^}}test_workitem_id_z_func:
|
||||
; ALL: v_lshrrev_b32_e32 v2, 20, v2
|
||||
; ALL-NEXT: v_and_b32_e32 v2, 0x3ff, v2
|
||||
define void @test_workitem_id_z_func(i32 addrspace(1)* %out) #1 {
|
||||
%id = call i32 @llvm.amdgcn.workitem.id.z()
|
||||
store i32 %id, i32 addrspace(1)* %out
|
||||
ret void
|
||||
}
|
||||
|
||||
attributes #0 = { nounwind readnone }
|
||||
attributes #1 = { nounwind }
|
||||
|
|
Loading…
Reference in New Issue