Skip to content

Commit 231d113

Browse files
authored
[InstCombine] Handle commuted patterns in foldSelectWithSRem (#121896)
Closes #121771.
1 parent d82d53b commit 231d113

File tree

2 files changed

+17
-2
lines changed

2 files changed

+17
-2
lines changed

llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2823,9 +2823,9 @@ static Instruction *foldSelectWithSRem(SelectInst &SI, InstCombinerImpl &IC,
28232823
// %cnd = icmp slt i32 %rem, 0
28242824
// %add = add i32 %rem, %n
28252825
// %sel = select i1 %cnd, i32 %add, i32 %rem
2826-
if (match(TrueVal, m_Add(m_Specific(RemRes), m_Value(Remainder))) &&
2826+
if (match(TrueVal, m_c_Add(m_Specific(RemRes), m_Value(Remainder))) &&
28272827
match(RemRes, m_SRem(m_Value(Op), m_Specific(Remainder))) &&
2828-
IC.isKnownToBeAPowerOfTwo(Remainder, /*OrZero*/ true) &&
2828+
IC.isKnownToBeAPowerOfTwo(Remainder, /*OrZero=*/true) &&
28292829
FalseVal == RemRes)
28302830
return FoldToBitwiseAnd(Remainder);
28312831

llvm/test/Transforms/InstCombine/select-divrem.ll

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -322,6 +322,21 @@ define i8 @rem_euclid_non_const_pow2(i8 %0, i8 %1) {
322322
ret i8 %sel
323323
}
324324

325+
define i8 @rem_euclid_non_const_pow2_commuted(i8 %0, i8 %1) {
326+
; CHECK-LABEL: @rem_euclid_non_const_pow2_commuted(
327+
; CHECK-NEXT: [[NOTMASK:%.*]] = shl nsw i8 -1, [[TMP0:%.*]]
328+
; CHECK-NEXT: [[TMP3:%.*]] = xor i8 [[NOTMASK]], -1
329+
; CHECK-NEXT: [[SEL:%.*]] = and i8 [[TMP1:%.*]], [[TMP3]]
330+
; CHECK-NEXT: ret i8 [[SEL]]
331+
;
332+
%pow2 = shl i8 1, %0
333+
%rem = srem i8 %1, %pow2
334+
%cond = icmp slt i8 %rem, 0
335+
%add = add i8 %pow2, %rem
336+
%sel = select i1 %cond, i8 %add, i8 %rem
337+
ret i8 %sel
338+
}
339+
325340
define i32 @rem_euclid_pow2_true_arm_folded(i32 %n) {
326341
; CHECK-LABEL: @rem_euclid_pow2_true_arm_folded(
327342
; CHECK-NEXT: [[RES:%.*]] = and i32 [[N:%.*]], 1

0 commit comments

Comments
 (0)