From 908fa90b512761ac05a7898fe48b14b9426d2e54 Mon Sep 17 00:00:00 2001 From: Konstantin Zhuravlyov Date: Tue, 3 Oct 2017 21:31:24 +0000 Subject: [PATCH] AMDGPU: Expand setcc for v2i32 and v4i32 llvm-svn: 314852 --- llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp | 1 + llvm/test/CodeGen/AMDGPU/setcc.ll | 52 +++++++++++++++++++ 2 files changed, 53 insertions(+) diff --git a/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp b/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp index 7dcb9f5317ec..df1a83631ec2 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp @@ -476,6 +476,7 @@ AMDGPUTargetLowering::AMDGPUTargetLowering(const TargetMachine &TM, setOperationAction(ISD::CTTZ, VT, Expand); setOperationAction(ISD::CTLZ, VT, Expand); setOperationAction(ISD::VECTOR_SHUFFLE, VT, Expand); + setOperationAction(ISD::SETCC, VT, Expand); } static const MVT::SimpleValueType FloatVectorTypes[] = { diff --git a/llvm/test/CodeGen/AMDGPU/setcc.ll b/llvm/test/CodeGen/AMDGPU/setcc.ll index a3bf167e756a..122f2432eac7 100644 --- a/llvm/test/CodeGen/AMDGPU/setcc.ll +++ b/llvm/test/CodeGen/AMDGPU/setcc.ll @@ -416,4 +416,56 @@ bb2: ret void } +; FUNC-LABEL: setcc_v2i32_expand +; GCN: v_cmp_gt_i32 +; GCN: v_cmp_gt_i32 +define amdgpu_kernel void @setcc_v2i32_expand( + <2 x i32> addrspace(1)* %a, + <2 x i32> addrspace(1)* %b, + <2 x i32> addrspace(1)* %c, + <2 x float> addrspace(1)* %r) { +entry: + %a.val = load <2 x i32>, <2 x i32> addrspace(1)* %a + %b.val = load <2 x i32>, <2 x i32> addrspace(1)* %b + %c.val = load <2 x i32>, <2 x i32> addrspace(1)* %c + + %icmp.val.1 = icmp sgt <2 x i32> %a.val, + %zext.val.1 = zext <2 x i1> %icmp.val.1 to <2 x i32> + %shl.val.1 = shl nuw <2 x i32> %zext.val.1, + %xor.val.1 = xor <2 x i32> %shl.val.1, %b.val + %bitcast.val.1 = bitcast <2 x i32> %xor.val.1 to <2 x float> + %icmp.val.2 = icmp sgt <2 x i32> %c.val, + %select.val.1 = select <2 x i1> %icmp.val.2, <2 x float> , <2 x float> %bitcast.val.1 + + store <2 x float> %select.val.1, <2 x float> addrspace(1)* %r + ret void +} + +; FUNC-LABEL: setcc_v4i32_expand +; GCN: v_cmp_gt_i32 +; GCN: v_cmp_gt_i32 +; GCN: v_cmp_gt_i32 +; GCN: v_cmp_gt_i32 +define amdgpu_kernel void @setcc_v4i32_expand( + <4 x i32> addrspace(1)* %a, + <4 x i32> addrspace(1)* %b, + <4 x i32> addrspace(1)* %c, + <4 x float> addrspace(1)* %r) { +entry: + %a.val = load <4 x i32>, <4 x i32> addrspace(1)* %a + %b.val = load <4 x i32>, <4 x i32> addrspace(1)* %b + %c.val = load <4 x i32>, <4 x i32> addrspace(1)* %c + + %icmp.val.1 = icmp sgt <4 x i32> %a.val, + %zext.val.1 = zext <4 x i1> %icmp.val.1 to <4 x i32> + %shl.val.1 = shl nuw <4 x i32> %zext.val.1, + %xor.val.1 = xor <4 x i32> %shl.val.1, %b.val + %bitcast.val.1 = bitcast <4 x i32> %xor.val.1 to <4 x float> + %icmp.val.2 = icmp sgt <4 x i32> %c.val, + %select.val.1 = select <4 x i1> %icmp.val.2, <4 x float> , <4 x float> %bitcast.val.1 + + store <4 x float> %select.val.1, <4 x float> addrspace(1)* %r + ret void +} + attributes #0 = { nounwind }