[PATCH] D122068: [AMDGPU] divergence patterns for the BUILD_VECTOR i16, undef expansion.
Alexander via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sat Mar 19 08:15:22 PDT 2022
alex-t created this revision.
alex-t added reviewers: rampitec, foad.
Herald added subscribers: kerbowa, hiraditya, t-tye, tpr, dstuttard, yaxunl, jvesely, kzhuravl, arsenm.
Herald added a project: All.
alex-t requested review of this revision.
Herald added a subscriber: wdng.
Herald added a project: LLVM.
BUILD_VECTOR of i16 and undef gets expanded to the COPY_TO_REGCLASS.
The latter is further lowererd to the copy instructions.
We need to provide the correct register class for the uniform and divergent BUILD_VECTOR nodes
to avoid VGPR to SGPR copies.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D122068
Files:
llvm/lib/Target/AMDGPU/SIInstructions.td
llvm/test/CodeGen/AMDGPU/divergence-driven-buildvector.ll
Index: llvm/test/CodeGen/AMDGPU/divergence-driven-buildvector.ll
===================================================================
--- llvm/test/CodeGen/AMDGPU/divergence-driven-buildvector.ll
+++ llvm/test/CodeGen/AMDGPU/divergence-driven-buildvector.ll
@@ -1,5 +1,6 @@
; RUN: llc -march=amdgcn -stop-after=amdgpu-isel < %s | FileCheck -check-prefix=GCN %s
; RUN: llc -march=amdgcn -mcpu=gfx900 -stop-after=amdgpu-isel < %s | FileCheck -check-prefix=GFX9 %s
+; RUN: llc -march=amdgcn -mcpu=gfx906 -stop-after=amdgpu-isel < %s | FileCheck -check-prefix=GFX906 %s
; GCN-LABEL: name: uniform_vec_0_i16
; GCN: S_LSHL_B32
@@ -213,3 +214,25 @@
%val = bitcast <2 x half> %vec to float
ret float %val
}
+
+; GFX906-LABEL: name: build_vec_v2i16_undeflo_divergent
+; GFX906: %[[LOAD:[0-9]+]]:vgpr_32 = DS_READ_U16
+; GFX906: %{{[0-9]+}}:vgpr_32 = COPY %[[LOAD]]
+define <2 x i16> @build_vec_v2i16_undeflo_divergent(i16 addrspace(3)* %in) #0 {
+entry:
+ %load = load i16, i16 addrspace(3)* %in
+ %build = insertelement <2 x i16> undef, i16 %load, i32 0
+ ret <2 x i16> %build
+}
+
+; GFX906-LABEL: name: build_vec_v2i16_undeflo_uniform
+; GFX906: %[[LOAD:[0-9]+]]:vgpr_32 = DS_READ_U16
+; GFX906: %{{[0-9]+}}:sreg_32 = COPY %[[LOAD]]
+define amdgpu_kernel void @build_vec_v2i16_undeflo_uniform(i16 addrspace(3)* %in, i32 addrspace(1)* %out) #0 {
+entry:
+ %load = load i16, i16 addrspace(3)* %in
+ %build = insertelement <2 x i16> undef, i16 %load, i32 0
+ %result = bitcast <2 x i16> %build to i32
+ store i32 %result, i32 addrspace(1)* %out
+ ret void
+}
Index: llvm/lib/Target/AMDGPU/SIInstructions.td
===================================================================
--- llvm/lib/Target/AMDGPU/SIInstructions.td
+++ llvm/lib/Target/AMDGPU/SIInstructions.td
@@ -2594,12 +2594,12 @@
>;
def : GCNPat <
- (v2i16 (build_vector (i16 SReg_32:$src0), (i16 undef))),
+ (v2i16 (UniformBinFrag<build_vector> (i16 SReg_32:$src0), (i16 undef))),
(COPY_TO_REGCLASS SReg_32:$src0, SReg_32)
>;
def : GCNPat <
- (v2i16 (build_vector (i16 VGPR_32:$src0), (i16 undef))),
+ (v2i16 (DivergentBinFrag<build_vector> (i16 VGPR_32:$src0), (i16 undef))),
(COPY_TO_REGCLASS VGPR_32:$src0, VGPR_32)
>;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D122068.416699.patch
Type: text/x-patch
Size: 2247 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220319/6d0c5d9d/attachment.bin>
More information about the llvm-commits
mailing list