mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
InstSimplify: shl nsw/nuw undef, %V -> undef
We can always choose an value for undef which might cause %V to shift out an important bit except for one case, when %V is zero. However, shl behaves like an identity function when the right hand side is zero. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@224405 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9451a382ed
commit
891ec6d69f
@ -1338,6 +1338,11 @@ static Value *SimplifyRightShift(unsigned Opcode, Value *Op0, Value *Op1,
|
|||||||
if (Op0 == Op1)
|
if (Op0 == Op1)
|
||||||
return Constant::getNullValue(Op0->getType());
|
return Constant::getNullValue(Op0->getType());
|
||||||
|
|
||||||
|
// undef >> X -> 0
|
||||||
|
// undef >> X -> undef (if it's exact)
|
||||||
|
if (match(Op0, m_Undef()))
|
||||||
|
return isExact ? Op0 : Constant::getNullValue(Op0->getType());
|
||||||
|
|
||||||
// The low bit cannot be shifted out of an exact shift if it is set.
|
// The low bit cannot be shifted out of an exact shift if it is set.
|
||||||
if (isExact) {
|
if (isExact) {
|
||||||
unsigned BitWidth = Op0->getType()->getScalarSizeInBits();
|
unsigned BitWidth = Op0->getType()->getScalarSizeInBits();
|
||||||
@ -1360,8 +1365,9 @@ static Value *SimplifyShlInst(Value *Op0, Value *Op1, bool isNSW, bool isNUW,
|
|||||||
return V;
|
return V;
|
||||||
|
|
||||||
// undef << X -> 0
|
// undef << X -> 0
|
||||||
|
// undef << X -> undef if (if it's NSW/NUW)
|
||||||
if (match(Op0, m_Undef()))
|
if (match(Op0, m_Undef()))
|
||||||
return Constant::getNullValue(Op0->getType());
|
return isNSW || isNUW ? Op0 : Constant::getNullValue(Op0->getType());
|
||||||
|
|
||||||
// (X >> A) << A -> X
|
// (X >> A) << A -> X
|
||||||
Value *X;
|
Value *X;
|
||||||
@ -1386,12 +1392,6 @@ static Value *SimplifyLShrInst(Value *Op0, Value *Op1, bool isExact,
|
|||||||
MaxRecurse))
|
MaxRecurse))
|
||||||
return V;
|
return V;
|
||||||
|
|
||||||
// undef >>l X -> 0
|
|
||||||
// undef >>l X -> undef (if it's exact)
|
|
||||||
if (match(Op0, m_Undef()))
|
|
||||||
return isExact ? UndefValue::get(Op0->getType())
|
|
||||||
: Constant::getNullValue(Op0->getType());
|
|
||||||
|
|
||||||
// (X << A) >> A -> X
|
// (X << A) >> A -> X
|
||||||
Value *X;
|
Value *X;
|
||||||
if (match(Op0, m_NUWShl(m_Value(X), m_Specific(Op1))))
|
if (match(Op0, m_NUWShl(m_Value(X), m_Specific(Op1))))
|
||||||
@ -1422,12 +1422,6 @@ static Value *SimplifyAShrInst(Value *Op0, Value *Op1, bool isExact,
|
|||||||
if (match(Op0, m_AllOnes()))
|
if (match(Op0, m_AllOnes()))
|
||||||
return Op0;
|
return Op0;
|
||||||
|
|
||||||
// undef >>a X -> 0
|
|
||||||
// undef >>a X -> undef (if it's exact)
|
|
||||||
if (match(Op0, m_Undef()))
|
|
||||||
return isExact ? UndefValue::get(Op0->getType())
|
|
||||||
: Constant::getNullValue(Op0->getType());
|
|
||||||
|
|
||||||
// (X << A) >> A -> X
|
// (X << A) >> A -> X
|
||||||
Value *X;
|
Value *X;
|
||||||
if (match(Op0, m_NSWShl(m_Value(X), m_Specific(Op1))))
|
if (match(Op0, m_NSWShl(m_Value(X), m_Specific(Op1))))
|
||||||
|
@ -216,3 +216,31 @@ define i32 @test27() {
|
|||||||
%b = shl i32 0, undef
|
%b = shl i32 0, undef
|
||||||
ret i32 %b
|
ret i32 %b
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; CHECK-LABEL: @test28
|
||||||
|
; CHECK: ret i32 undef
|
||||||
|
define i32 @test28(i32 %a) {
|
||||||
|
%b = shl nsw i32 undef, %a
|
||||||
|
ret i32 %b
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK-LABEL: @test29
|
||||||
|
; CHECK: ret i32 undef
|
||||||
|
define i32 @test29(i32 %a) {
|
||||||
|
%b = shl nuw i32 undef, %a
|
||||||
|
ret i32 %b
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK-LABEL: @test30
|
||||||
|
; CHECK: ret i32 undef
|
||||||
|
define i32 @test30(i32 %a) {
|
||||||
|
%b = shl nsw nuw i32 undef, %a
|
||||||
|
ret i32 %b
|
||||||
|
}
|
||||||
|
|
||||||
|
; CHECK-LABEL: @test31
|
||||||
|
; CHECK: ret i32 0
|
||||||
|
define i32 @test31(i32 %a) {
|
||||||
|
%b = shl i32 undef, %a
|
||||||
|
ret i32 %b
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user