Skip to content

Commit 3e8534f

Browse files
committed
[InstSimplify] allow partial undef constants for vector min/max folds
1 parent 3c20ede commit 3e8534f

File tree

2 files changed

+6
-11
lines changed

2 files changed

+6
-11
lines changed

llvm/lib/Analysis/InstructionSimplify.cpp

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -5266,16 +5266,15 @@ static Value *simplifyBinaryIntrinsic(Function *F, Value *Op0, Value *Op1,
52665266
if (isa<Constant>(Op0))
52675267
std::swap(Op0, Op1);
52685268

5269-
// TODO: Allow partial undef vector constants.
52705269
const APInt *C;
5271-
if (!match(Op1, m_APInt(C)))
5270+
if (!match(Op1, m_APIntAllowUndef(C)))
52725271
break;
52735272

52745273
if ((IID == Intrinsic::smax && C->isMaxSignedValue()) ||
52755274
(IID == Intrinsic::smin && C->isMinSignedValue()) ||
52765275
(IID == Intrinsic::umax && C->isMaxValue()) ||
52775276
(IID == Intrinsic::umin && C->isMinValue()))
5278-
return Op1;
5277+
return ConstantInt::get(ReturnType, *C);
52795278

52805279
break;
52815280
}

llvm/test/Transforms/InstSimplify/maxmin_intrinsics.ll

Lines changed: 4 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -218,35 +218,31 @@ define <2 x i8> @umin_maxval_commute(<2 x i8> %x) {
218218

219219
define <2 x i8> @smax_maxval_partial_undef(<2 x i8> %x) {
220220
; CHECK-LABEL: @smax_maxval_partial_undef(
221-
; CHECK-NEXT: [[R:%.*]] = call <2 x i8> @llvm.smax.v2i8(<2 x i8> <i8 undef, i8 127>, <2 x i8> [[X:%.*]])
222-
; CHECK-NEXT: ret <2 x i8> [[R]]
221+
; CHECK-NEXT: ret <2 x i8> <i8 127, i8 127>
223222
;
224223
%r = call <2 x i8> @llvm.smax.v2i8(<2 x i8> <i8 undef, i8 127>, <2 x i8> %x)
225224
ret <2 x i8> %r
226225
}
227226

228227
define <2 x i8> @smin_minval_partial_undef(<2 x i8> %x) {
229228
; CHECK-LABEL: @smin_minval_partial_undef(
230-
; CHECK-NEXT: [[R:%.*]] = call <2 x i8> @llvm.smin.v2i8(<2 x i8> [[X:%.*]], <2 x i8> <i8 -128, i8 undef>)
231-
; CHECK-NEXT: ret <2 x i8> [[R]]
229+
; CHECK-NEXT: ret <2 x i8> <i8 -128, i8 -128>
232230
;
233231
%r = call <2 x i8> @llvm.smin.v2i8(<2 x i8> %x, <2 x i8> <i8 -128, i8 undef>)
234232
ret <2 x i8> %r
235233
}
236234

237235
define <2 x i8> @umax_maxval_partial_undef(<2 x i8> %x) {
238236
; CHECK-LABEL: @umax_maxval_partial_undef(
239-
; CHECK-NEXT: [[R:%.*]] = call <2 x i8> @llvm.umax.v2i8(<2 x i8> <i8 -1, i8 undef>, <2 x i8> [[X:%.*]])
240-
; CHECK-NEXT: ret <2 x i8> [[R]]
237+
; CHECK-NEXT: ret <2 x i8> <i8 -1, i8 -1>
241238
;
242239
%r = call <2 x i8> @llvm.umax.v2i8(<2 x i8> <i8 255, i8 undef>, <2 x i8> %x)
243240
ret <2 x i8> %r
244241
}
245242

246243
define <2 x i8> @umin_minval_partial_undef(<2 x i8> %x) {
247244
; CHECK-LABEL: @umin_minval_partial_undef(
248-
; CHECK-NEXT: [[R:%.*]] = call <2 x i8> @llvm.umin.v2i8(<2 x i8> [[X:%.*]], <2 x i8> <i8 undef, i8 0>)
249-
; CHECK-NEXT: ret <2 x i8> [[R]]
245+
; CHECK-NEXT: ret <2 x i8> zeroinitializer
250246
;
251247
%r = call <2 x i8> @llvm.umin.v2i8(<2 x i8> %x, <2 x i8> <i8 undef, i8 0>)
252248
ret <2 x i8> %r

0 commit comments

Comments
 (0)