[MCJIT] Improve a RuntimeDyldChecker diagnostic.

When a RuntimeDyldChecker test requests an invalid operand for an instruction,
print the decoded instruction to aid diagnosis.

llvm-svn: 213202
This commit is contained in:
Lang Hames 2014-07-16 22:02:20 +00:00
parent 5332411cd7
commit 8b20530689
1 changed files with 7 additions and 3 deletions

View File

@ -233,9 +233,13 @@ namespace llvm {
std::string ErrMsg;
raw_string_ostream ErrMsgStream(ErrMsg);
ErrMsgStream << "Invalid operand index '" << format("%i", OpIdx)
<< " for instruction '" << Symbol
<< ". Instruction has only "
<< format("%i", Inst.getNumOperands()) << " operands.";
<< "' for instruction '" << Symbol
<< "'. Instruction has only "
<< format("%i", Inst.getNumOperands())
<< " operands.\nInstruction is:\n ";
Inst.dump_pretty(ErrMsgStream,
Checker.Disassembler->getContext().getAsmInfo(),
Checker.InstPrinter);
return std::make_pair(EvalResult(ErrMsgStream.str()), "");
}