Skip to content

Commit

Permalink
[TypePromotion] Promote undef by converting to 0.
Browse files Browse the repository at this point in the history
If we're promoting an undef I think that means that we expect the
upper bits are zero. undef doesn't guarantee that.

This patch replaces undef with 0 to ensure this. This matches how
a zext or sext of undef would be folded by InstCombine/InstSimplify.

I haven't found a failure from this was just thinking through the code.

Differential Revision: https://reviews.llvm.org/D123174
  • Loading branch information
topperc committed May 12, 2022
1 parent 40e9654 commit cec249c
Show file tree
Hide file tree
Showing 4 changed files with 9 additions and 9 deletions.
2 changes: 1 addition & 1 deletion llvm/lib/CodeGen/TypePromotion.cpp
Expand Up @@ -489,7 +489,7 @@ void IRPromoter::PromoteTree() {
: ConstantExpr::getZExt(Const, ExtTy);
I->setOperand(i, NewConst);
} else if (isa<UndefValue>(Op))
I->setOperand(i, UndefValue::get(ExtTy));
I->setOperand(i, ConstantInt::get(ExtTy, 0));
}

// Mutate the result type, unless this is an icmp or switch.
Expand Down
12 changes: 6 additions & 6 deletions llvm/test/CodeGen/AArch64/typepromotion-phisret.ll
Expand Up @@ -180,14 +180,14 @@ exit: ; preds = %if.end
define i16 @phi_multiple_undefs(i16 zeroext %arg) {
; CHECK-LABEL: phi_multiple_undefs:
; CHECK: // %bb.0: // %entry
; CHECK-NEXT: mov w8, #1
; CHECK-NEXT: // implicit-def: $w9
; CHECK-NEXT: mov w8, wzr
; CHECK-NEXT: mov w9, #1
; CHECK-NEXT: .LBB4_1: // %loop
; CHECK-NEXT: // =>This Inner Loop Header: Depth=1
; CHECK-NEXT: cmp w9, #128
; CHECK-NEXT: cinc w10, w8, lo
; CHECK-NEXT: add w9, w9, w10
; CHECK-NEXT: cmp w9, #253
; CHECK-NEXT: cmp w8, #128
; CHECK-NEXT: cinc w10, w9, lo
; CHECK-NEXT: add w8, w8, w10
; CHECK-NEXT: cmp w8, #253
; CHECK-NEXT: b.lo .LBB4_1
; CHECK-NEXT: // %bb.2: // %exit
; CHECK-NEXT: ret
Expand Down
Expand Up @@ -140,7 +140,7 @@ define i32 @with_undef() {
; CHECK: bb3:
; CHECK-NEXT: [[VAR4:%.*]] = phi i64 [ [[VAR33:%.*]], [[BB31:%.*]] ], [ undef, [[BB:%.*]] ]
; CHECK-NEXT: [[VAR5:%.*]] = phi %struct.wobble* [ [[VAR38:%.*]], [[BB31]] ], [ [[VAR]], [[BB]] ]
; CHECK-NEXT: [[VAR6:%.*]] = phi i32 [ [[VAR32:%.*]], [[BB31]] ], [ undef, [[BB]] ]
; CHECK-NEXT: [[VAR6:%.*]] = phi i32 [ [[VAR32:%.*]], [[BB31]] ], [ 0, [[BB]] ]
; CHECK-NEXT: [[VAR7:%.*]] = icmp eq %struct.wobble* [[VAR5]], null
; CHECK-NEXT: br i1 [[VAR7]], label [[BB8:%.*]], label [[BB9:%.*]]
; CHECK: bb8:
Expand Down
2 changes: 1 addition & 1 deletion llvm/test/Transforms/TypePromotion/ARM/phis-ret.ll
Expand Up @@ -227,7 +227,7 @@ define i16 @phi_multiple_undefs(i16 zeroext %arg) {
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
; CHECK-NEXT: [[VAL:%.*]] = phi i32 [ undef, [[ENTRY:%.*]] ], [ [[INC2:%.*]], [[IF_END:%.*]] ]
; CHECK-NEXT: [[VAL:%.*]] = phi i32 [ 0, [[ENTRY:%.*]] ], [ [[INC2:%.*]], [[IF_END:%.*]] ]
; CHECK-NEXT: [[CMP:%.*]] = icmp ult i32 [[VAL]], 128
; CHECK-NEXT: br i1 [[CMP]], label [[IF_THEN:%.*]], label [[IF_ELSE:%.*]]
; CHECK: if.then:
Expand Down

0 comments on commit cec249c

Please sign in to comment.