forked from OSchip/llvm-project
[AMDGPU] Add FP_CLASS to the add/setcc combine
This is one of the nodes which also compile as v_cmp_*. Differential Revision: https://reviews.llvm.org/D34485 llvm-svn: 305970
This commit is contained in:
parent
72208a8226
commit
3ed38c601a
|
@ -4872,7 +4872,9 @@ SDValue SITargetLowering::performAddCombine(SDNode *N,
|
|||
case ISD::SIGN_EXTEND:
|
||||
case ISD::ANY_EXTEND: {
|
||||
auto Cond = RHS.getOperand(0);
|
||||
if (Cond.getOpcode() != ISD::SETCC) break;
|
||||
if (Cond.getOpcode() != ISD::SETCC &&
|
||||
Cond.getOpcode() != AMDGPUISD::FP_CLASS)
|
||||
break;
|
||||
SDVTList VTList = DAG.getVTList(MVT::i32, MVT::i1);
|
||||
SDValue Args[] = { LHS, DAG.getConstant(0, SL, MVT::i32), Cond };
|
||||
Opc = (Opc == ISD::SIGN_EXTEND) ? ISD::SUBCARRY : ISD::ADDCARRY;
|
||||
|
|
|
@ -116,6 +116,42 @@ bb:
|
|||
ret void
|
||||
}
|
||||
|
||||
; GCN-LABEL: {{^}}zext_flclass:
|
||||
; GCN: v_cmp_class_f32_e{{32|64}} [[CC:[^,]+]],
|
||||
; GCN: v_addc_u32_e{{32|64}} v{{[0-9]+}}, {{[^,]+}}, 0, v{{[0-9]+}}, [[CC]]
|
||||
; GCN-NOT: v_cndmask
|
||||
|
||||
define amdgpu_kernel void @zext_flclass(i32 addrspace(1)* nocapture %arg, float %x) {
|
||||
bb:
|
||||
%id = tail call i32 @llvm.amdgcn.workitem.id.x()
|
||||
%gep = getelementptr inbounds i32, i32 addrspace(1)* %arg, i32 %id
|
||||
%v = load i32, i32 addrspace(1)* %gep, align 4
|
||||
%cmp = tail call zeroext i1 @llvm.amdgcn.class.f32(float %x, i32 608)
|
||||
%ext = zext i1 %cmp to i32
|
||||
%add = add i32 %v, %ext
|
||||
store i32 %add, i32 addrspace(1)* %gep, align 4
|
||||
ret void
|
||||
}
|
||||
|
||||
; GCN-LABEL: {{^}}sext_flclass:
|
||||
; GCN: v_cmp_class_f32_e{{32|64}} [[CC:[^,]+]],
|
||||
; GCN: v_subb_u32_e{{32|64}} v{{[0-9]+}}, {{[^,]+}}, v{{[0-9]+}}, 0, [[CC]]
|
||||
; GCN-NOT: v_cndmask
|
||||
|
||||
define amdgpu_kernel void @sext_flclass(i32 addrspace(1)* nocapture %arg, float %x) {
|
||||
bb:
|
||||
%id = tail call i32 @llvm.amdgcn.workitem.id.x()
|
||||
%gep = getelementptr inbounds i32, i32 addrspace(1)* %arg, i32 %id
|
||||
%v = load i32, i32 addrspace(1)* %gep, align 4
|
||||
%cmp = tail call zeroext i1 @llvm.amdgcn.class.f32(float %x, i32 608)
|
||||
%ext = sext i1 %cmp to i32
|
||||
%add = add i32 %v, %ext
|
||||
store i32 %add, i32 addrspace(1)* %gep, align 4
|
||||
ret void
|
||||
}
|
||||
|
||||
declare i1 @llvm.amdgcn.class.f32(float, i32) #0
|
||||
|
||||
declare i32 @llvm.amdgcn.workitem.id.x() #0
|
||||
|
||||
declare i32 @llvm.amdgcn.workitem.id.y() #0
|
||||
|
|
Loading…
Reference in New Issue