Do not try to create a MVT type of width 0.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@72557 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Evan Cheng 2009-05-28 23:52:18 +00:00
parent 2265ba0717
commit d3c76bb6fc
2 changed files with 40 additions and 0 deletions

View File

@ -4937,6 +4937,8 @@ SDValue DAGCombiner::ReduceLoadOpStoreWidth(SDNode *N) {
APInt Imm = cast<ConstantSDNode>(N1)->getAPIntValue(); APInt Imm = cast<ConstantSDNode>(N1)->getAPIntValue();
if (Opc == ISD::AND) if (Opc == ISD::AND)
Imm ^= APInt::getAllOnesValue(BitWidth); Imm ^= APInt::getAllOnesValue(BitWidth);
if (Imm == 0 || Imm.isAllOnesValue())
return SDValue();
unsigned ShAmt = Imm.countTrailingZeros(); unsigned ShAmt = Imm.countTrailingZeros();
unsigned MSB = BitWidth - Imm.countLeadingZeros() - 1; unsigned MSB = BitWidth - Imm.countLeadingZeros() - 1;
unsigned NewBW = NextPowerOf2(MSB - ShAmt); unsigned NewBW = NextPowerOf2(MSB - ShAmt);

View File

@ -0,0 +1,38 @@
; RUN: llvm-as < %s | llc -march=x86-64
%struct.tempsym_t = type { i8*, i8*, i8*, i8*, i32, i32, i32, i32, i32 }
define fastcc signext i8 @S_next_symbol(%struct.tempsym_t* %symptr) nounwind ssp {
entry:
br label %bb116
bb: ; preds = %bb116
switch i8 undef, label %bb14 [
i8 9, label %bb116
i8 32, label %bb116
i8 10, label %bb116
i8 13, label %bb116
i8 12, label %bb116
]
bb14: ; preds = %bb
br i1 undef, label %bb75, label %bb115
bb75: ; preds = %bb14
%srcval16 = load i448* null, align 8 ; <i448> [#uses=1]
%tmp = zext i32 undef to i448 ; <i448> [#uses=1]
%tmp15 = shl i448 %tmp, 288 ; <i448> [#uses=1]
%mask = and i448 %srcval16, -2135987035423586845985235064014169866455883682256196619149693890381755748887481053010428711403521 ; <i448> [#uses=1]
%ins = or i448 %tmp15, %mask ; <i448> [#uses=1]
store i448 %ins, i448* null, align 8
ret i8 1
bb115: ; preds = %bb14
ret i8 1
bb116: ; preds = %bb, %bb, %bb, %bb, %bb, %entry
br i1 undef, label %bb, label %bb117
bb117: ; preds = %bb116
ret i8 0
}