mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-02 07:17:36 +00:00
Apparently we can't expect a BinaryOperator here.
Should fix llvm-gcc selfhost. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@134699 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -2502,14 +2502,14 @@ void SelectionDAGBuilder::visitShift(const User &I, unsigned Opcode) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void SelectionDAGBuilder::visitSDiv(const User &I) {
|
void SelectionDAGBuilder::visitSDiv(const User &I) {
|
||||||
const BinaryOperator *BO = cast<BinaryOperator>(&I);
|
|
||||||
SDValue Op1 = getValue(I.getOperand(0));
|
SDValue Op1 = getValue(I.getOperand(0));
|
||||||
SDValue Op2 = getValue(I.getOperand(1));
|
SDValue Op2 = getValue(I.getOperand(1));
|
||||||
|
|
||||||
// Turn exact SDivs into multiplications.
|
// Turn exact SDivs into multiplications.
|
||||||
// FIXME: This should be in DAGCombiner, but it doesn't have access to the
|
// FIXME: This should be in DAGCombiner, but it doesn't have access to the
|
||||||
// exact bit.
|
// exact bit.
|
||||||
if (BO->isExact() && !isa<ConstantSDNode>(Op1) &&
|
if (isa<BinaryOperator>(&I) && cast<BinaryOperator>(&I)->isExact() &&
|
||||||
|
!isa<ConstantSDNode>(Op1) &&
|
||||||
isa<ConstantSDNode>(Op2) && !cast<ConstantSDNode>(Op2)->isNullValue())
|
isa<ConstantSDNode>(Op2) && !cast<ConstantSDNode>(Op2)->isNullValue())
|
||||||
setValue(&I, TLI.BuildExactSDIV(Op1, Op2, getCurDebugLoc(), DAG));
|
setValue(&I, TLI.BuildExactSDIV(Op1, Op2, getCurDebugLoc(), DAG));
|
||||||
else
|
else
|
||||||
|
|||||||
Reference in New Issue
Block a user