[PATCH] D89701: [SVE][CodeGen][DAGCombiner] Fix TypeSize warning in redundant store elimination
Peter Waller via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Oct 26 09:38:44 PDT 2020
This revision was automatically updated to reflect the committed changes.
Closed by commit rG5b742a0c106f: [SVE][CodeGen][DAGCombiner] Fix TypeSize warning in redundant store elimination (authored by peterwaller-arm).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D89701/new/
https://reviews.llvm.org/D89701
Files:
llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
llvm/test/CodeGen/AArch64/sve-redundant-store.ll
Index: llvm/test/CodeGen/AArch64/sve-redundant-store.ll
===================================================================
--- /dev/null
+++ llvm/test/CodeGen/AArch64/sve-redundant-store.ll
@@ -0,0 +1,30 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
+; RUN: llc -O2 -mtriple=aarch64-linux-gnu -mattr=+sve < %s 2>%t | FileCheck %s
+; RUN: FileCheck --check-prefix=WARN --allow-empty %s <%t
+
+; If this check fails please read test/CodeGen/AArch64/README for instructions on how to resolve it.
+; WARN-NOT: warning: {{.*}}TypeSize is not scalable
+
+; #include <arm_sve.h>
+; #include <stdint.h>
+;
+; void redundant_store(uint32_t *p, svint32_t v) {
+; *p = 1;
+; *(svint32_t *)p = v;
+; }
+
+; Update me: Until dead store elimination is improved in DAGCombine, this will contain a redundant store.
+;
+define void @redundant_store(i32* nocapture %p, <vscale x 4 x i32> %v) {
+; CHECK-LABEL: redundant_store:
+; CHECK: // %bb.0:
+; CHECK-NEXT: mov w8, #1
+; CHECK-NEXT: ptrue p0.s
+; CHECK-NEXT: str w8, [x0]
+; CHECK-NEXT: st1w { z0.s }, p0, [x0]
+; CHECK-NEXT: ret
+ store i32 1, i32* %p, align 4
+ %1 = bitcast i32* %p to <vscale x 4 x i32>*
+ store <vscale x 4 x i32> %v, <vscale x 4 x i32>* %1, align 16
+ ret void
+}
Index: llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
===================================================================
--- llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+++ llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
@@ -17326,11 +17326,12 @@
!ST1->getBasePtr().isUndef() &&
// BaseIndexOffset and the code below requires knowing the size
// of a vector, so bail out if MemoryVT is scalable.
+ !ST->getMemoryVT().isScalableVector() &&
!ST1->getMemoryVT().isScalableVector()) {
const BaseIndexOffset STBase = BaseIndexOffset::match(ST, DAG);
const BaseIndexOffset ChainBase = BaseIndexOffset::match(ST1, DAG);
- unsigned STBitSize = ST->getMemoryVT().getSizeInBits();
- unsigned ChainBitSize = ST1->getMemoryVT().getSizeInBits();
+ unsigned STBitSize = ST->getMemoryVT().getFixedSizeInBits();
+ unsigned ChainBitSize = ST1->getMemoryVT().getFixedSizeInBits();
// If this is a store who's preceding store to a subset of the current
// location and no one other node is chained to that store we can
// effectively drop the store. Do not remove stores to undef as they may
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D89701.300705.patch
Type: text/x-patch
Size: 2492 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201026/8cd1616d/attachment.bin>
More information about the llvm-commits
mailing list