[PATCH] D139550: [DAGCombine] Fix always true condition in combineShiftToMULH
Juan Manuel Martinez CaamaƱo via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Dec 15 04:05:15 PST 2022
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rG4d852374b1d6: [DAGCombine] Fix always true condition in combineShiftToMULH (authored by jmmartinez).
Changed prior to commit:
https://reviews.llvm.org/D139550?vs=482760&id=483120#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D139550/new/
https://reviews.llvm.org/D139550
Files:
llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
llvm/test/CodeGen/AMDGPU/dagcomb-mullohi.ll
Index: llvm/test/CodeGen/AMDGPU/dagcomb-mullohi.ll
===================================================================
--- llvm/test/CodeGen/AMDGPU/dagcomb-mullohi.ll
+++ llvm/test/CodeGen/AMDGPU/dagcomb-mullohi.ll
@@ -125,8 +125,8 @@
ret i32 %i8
}
-define i32 @mul_one_bit_hi_hi_u32(i32 %arg, i32 %arg1, i32* %arg2) {
-; CHECK-LABEL: mul_one_bit_hi_hi_u32:
+define i32 @mul_one_bit_hi_hi_u32_lshr_lshr(i32 %arg, i32 %arg1, i32* %arg2) {
+; CHECK-LABEL: mul_one_bit_hi_hi_u32_lshr_lshr:
; CHECK: ; %bb.0: ; %bb
; CHECK-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
; CHECK-NEXT: v_mul_hi_u32 v0, v1, v0
@@ -145,3 +145,24 @@
%i8 = trunc i64 %i7 to i32
ret i32 %i8
}
+
+define i32 @mul_one_bit_hi_hi_u32_lshr_ashr(i32 %arg, i32 %arg1, i32* %arg2) {
+; CHECK-LABEL: mul_one_bit_hi_hi_u32_lshr_ashr:
+; CHECK: ; %bb.0: ; %bb
+; CHECK-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
+; CHECK-NEXT: v_mul_hi_u32 v4, v1, v0
+; CHECK-NEXT: v_ashrrev_i64 v[0:1], 33, v[3:4]
+; CHECK-NEXT: flat_store_dword v[2:3], v4
+; CHECK-NEXT: s_waitcnt vmcnt(0) lgkmcnt(0)
+; CHECK-NEXT: s_setpc_b64 s[30:31]
+bb:
+ %i = zext i32 %arg to i64
+ %i3 = zext i32 %arg1 to i64
+ %i4 = mul nsw i64 %i3, %i
+ %i5 = lshr i64 %i4, 32
+ %i6 = trunc i64 %i5 to i32
+ store i32 %i6, i32* %arg2, align 4
+ %i7 = ashr i64 %i4, 33
+ %i8 = trunc i64 %i7 to i32
+ ret i32 %i8
+}
Index: llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
===================================================================
--- llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+++ llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
@@ -9390,7 +9390,7 @@
// return true if U may use the lower bits of its operands
auto UserOfLowerBits = [NarrowVTSize](SDNode *U) {
- if (U->getOpcode() != ISD::SRL || U->getOpcode() != ISD::SRA) {
+ if (U->getOpcode() != ISD::SRL && U->getOpcode() != ISD::SRA) {
return true;
}
ConstantSDNode *UShiftAmtSrc = isConstOrConstSplat(U->getOperand(1));
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D139550.483120.patch
Type: text/x-patch
Size: 2002 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221215/c56c9bba/attachment.bin>
More information about the llvm-commits
mailing list