Use llvm_unreachable() instead of report_fatal_error() if the machine model is incomplete
authorMatthias Braun <matze@braunis.de>
Fri, 17 Jul 2015 17:50:11 +0000 (17:50 +0000)
committerMatthias Braun <matze@braunis.de>
Fri, 17 Jul 2015 17:50:11 +0000 (17:50 +0000)
This error is for developers only so it makes sense to abort and get a
backtrace.

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

lib/CodeGen/TargetSchedule.cpp

index 299380d9268b8033d5c577195212e3a2cc19b9d6..fc656396ade81ec9a2521a2d7698ad6a1526258a 100644 (file)
@@ -211,11 +211,9 @@ unsigned TargetSchedModel::computeOperandLatency(
   if (SCDesc->isValid() && !DefMI->getOperand(DefOperIdx).isImplicit()
       && !DefMI->getDesc().OpInfo[DefOperIdx].isOptionalDef()
       && SchedModel.isComplete()) {
-    std::string Err;
-    raw_string_ostream ss(Err);
-    ss << "DefIdx " << DefIdx << " exceeds machine model writes for "
-       << *DefMI;
-    report_fatal_error(ss.str());
+    errs() << "DefIdx " << DefIdx << " exceeds machine model writes for "
+           << *DefMI;
+    llvm_unreachable("incomplete machine model");
   }
 #endif
   // FIXME: Automatically giving all implicit defs defaultDefLatency is