mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
rdar://12329730 (2nd part, revised)
The type of shirt-right (logical or arithemetic) should remain unchanged when transforming "X << C1 >> C2" into "X << (C1-C2)" git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169209 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b715b205a4
commit
bba3eb054a
@ -876,7 +876,8 @@ Value *InstCombiner::SimplifyShrShlDemandedBits(Instruction *Shr,
|
||||
New->setHasNoUnsignedWrap(Orig->hasNoUnsignedWrap());
|
||||
} else {
|
||||
Constant *Amt = ConstantInt::get(VarX->getType(), ShrAmt - ShlAmt);
|
||||
New = BinaryOperator::CreateLShr(VarX, Amt);
|
||||
New = isLshr ? BinaryOperator::CreateLShr(VarX, Amt) :
|
||||
BinaryOperator::CreateAShr(VarX, Amt);
|
||||
}
|
||||
|
||||
return InsertNewInstWith(New, *Shl);
|
||||
|
@ -723,7 +723,7 @@ define i32 @test60(i32 %x) {
|
||||
%or = or i32 %shl, 1
|
||||
ret i32 %or
|
||||
; CHECK: @test60
|
||||
; CHECK: lshr i32 %x, 3
|
||||
; CHECK: ashr i32 %x, 3
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user