]> granicus.if.org Git - clang/commitdiff
Fail early with a clear assert if an operation with multiple uses somehow ends
authorLang Hames <lhames@gmail.com>
Thu, 4 Oct 2012 03:23:25 +0000 (03:23 +0000)
committerLang Hames <lhames@gmail.com>
Thu, 4 Oct 2012 03:23:25 +0000 (03:23 +0000)
up being contracted during codegen.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@165197 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExprScalar.cpp

index 0d68ff5a69c5a266199b988a9de624e2f411ed35..0e8afb04d00f4ebf7c946e7128a4df17e19e4b5b 100644 (file)
@@ -2045,11 +2045,15 @@ static Value* tryEmitFMulAdd(const BinOpInfo &op,
   // We have a potentially fusable op. Look for a mul on one of the operands.
   if (llvm::BinaryOperator* LHSBinOp = dyn_cast<llvm::BinaryOperator>(op.LHS)) {
     if (LHSBinOp->getOpcode() == llvm::Instruction::FMul) {
+      assert(LHSBinOp->getNumUses() == 0 &&
+             "Operations with multiple uses shouldn't be contracted.");
       return buildFMulAdd(LHSBinOp, op.RHS, CGF, Builder, false, isSub);
     }
   } else if (llvm::BinaryOperator* RHSBinOp =
                dyn_cast<llvm::BinaryOperator>(op.RHS)) {
     if (RHSBinOp->getOpcode() == llvm::Instruction::FMul) {
+      assert(RHSBinOp->getNumUses() == 0 &&
+             "Operations with multiple uses shouldn't be contracted.");
       return buildFMulAdd(RHSBinOp, op.LHS, CGF, Builder, isSub, false);
     }
   }