mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-25 02:28:18 +00:00
Treat xor of signbit like an add.
llvm-svn: 35586
This commit is contained in:
parent
d14447833a
commit
a3e0bb4ebb
@ -1427,7 +1427,16 @@ SCEVHandle ScalarEvolutionsImpl::createSCEV(Value *V) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case Instruction::Xor:
|
||||||
|
// If the RHS of the xor is a signbit, then this is just an add.
|
||||||
|
// Instcombine turns add of signbit into xor as a strength reduction step.
|
||||||
|
if (ConstantInt *CI = dyn_cast<ConstantInt>(I->getOperand(1))) {
|
||||||
|
if (CI->getValue().isSignBit())
|
||||||
|
return SCEVAddExpr::get(getSCEV(I->getOperand(0)),
|
||||||
|
getSCEV(I->getOperand(1)));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case Instruction::Shl:
|
case Instruction::Shl:
|
||||||
// Turn shift left of a constant amount into a multiply.
|
// Turn shift left of a constant amount into a multiply.
|
||||||
if (ConstantInt *SA = dyn_cast<ConstantInt>(I->getOperand(1))) {
|
if (ConstantInt *SA = dyn_cast<ConstantInt>(I->getOperand(1))) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user