From: Benjamin Kramer Date: Fri, 8 Jul 2011 12:08:24 +0000 (+0000) Subject: Apparently we can't expect a BinaryOperator here. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=3492a4af129f6068739bbbe3f8c7fbe7e4af2fcb;p=oota-llvm.git 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 --- diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp index 2a362ebfc2d..2afec3328b9 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp @@ -2502,14 +2502,14 @@ void SelectionDAGBuilder::visitShift(const User &I, unsigned Opcode) { } void SelectionDAGBuilder::visitSDiv(const User &I) { - const BinaryOperator *BO = cast(&I); SDValue Op1 = getValue(I.getOperand(0)); SDValue Op2 = getValue(I.getOperand(1)); // Turn exact SDivs into multiplications. // FIXME: This should be in DAGCombiner, but it doesn't have access to the // exact bit. - if (BO->isExact() && !isa(Op1) && + if (isa(&I) && cast(&I)->isExact() && + !isa(Op1) && isa(Op2) && !cast(Op2)->isNullValue()) setValue(&I, TLI.BuildExactSDIV(Op1, Op2, getCurDebugLoc(), DAG)); else