forked from OSchip/llvm-project
Pass a Banner argument to the machine code verifier both from
createMachineVerifierPass and MachineFunction::verify. The banner is printed before the machine code dump, just like the printer pass. llvm-svn: 122113
This commit is contained in:
parent
00871c71e9
commit
bf4550e3fb
|
@ -271,7 +271,7 @@ public:
|
|||
|
||||
/// verify - Run the current MachineFunction through the machine code
|
||||
/// verifier, useful for debugger use.
|
||||
void verify(Pass *p=NULL) const;
|
||||
void verify(Pass *p = NULL, const char *Banner = NULL) const;
|
||||
|
||||
// Provide accessors for the MachineBasicBlock list...
|
||||
typedef BasicBlockListType::iterator iterator;
|
||||
|
|
|
@ -206,7 +206,7 @@ namespace llvm {
|
|||
|
||||
/// createMachineVerifierPass - This pass verifies cenerated machine code
|
||||
/// instructions for correctness.
|
||||
FunctionPass *createMachineVerifierPass();
|
||||
FunctionPass *createMachineVerifierPass(const char *Banner = 0);
|
||||
|
||||
/// createDwarfEHPass - This pass mulches exception handling code into a form
|
||||
/// adapted to code generation. Required if using dwarf exception handling.
|
||||
|
|
|
@ -96,7 +96,7 @@ Spiller *createInlineSpiller(MachineFunctionPass &pass,
|
|||
MachineFunction &mf,
|
||||
VirtRegMap &vrm) {
|
||||
if (VerifySpills)
|
||||
mf.verify(&pass);
|
||||
mf.verify(&pass, "When creating inline spiller");
|
||||
return new InlineSpiller(pass, mf, vrm);
|
||||
}
|
||||
}
|
||||
|
@ -313,7 +313,7 @@ void InlineSpiller::spill(LiveInterval *li,
|
|||
LiveRangeEdit edit(*li, newIntervals, spillIs);
|
||||
spill(edit);
|
||||
if (VerifySpills)
|
||||
mf_.verify(&pass_);
|
||||
mf_.verify(&pass_, "After inline spill");
|
||||
}
|
||||
|
||||
void InlineSpiller::spill(LiveRangeEdit &edit) {
|
||||
|
|
|
@ -251,7 +251,7 @@ static void printAndVerify(PassManagerBase &PM,
|
|||
PM.add(createMachineFunctionPrinterPass(dbgs(), Banner));
|
||||
|
||||
if (VerifyMachineCode)
|
||||
PM.add(createMachineVerifierPass());
|
||||
PM.add(createMachineVerifierPass(Banner));
|
||||
}
|
||||
|
||||
/// addCommonCodeGenPasses - Add standard LLVM codegen passes used for both
|
||||
|
|
|
@ -46,14 +46,16 @@ using namespace llvm;
|
|||
namespace {
|
||||
struct MachineVerifier {
|
||||
|
||||
MachineVerifier(Pass *pass) :
|
||||
MachineVerifier(Pass *pass, const char *b) :
|
||||
PASS(pass),
|
||||
Banner(b),
|
||||
OutFileName(getenv("LLVM_VERIFY_MACHINEINSTRS"))
|
||||
{}
|
||||
|
||||
bool runOnMachineFunction(MachineFunction &MF);
|
||||
|
||||
Pass *const PASS;
|
||||
const char *Banner;
|
||||
const char *const OutFileName;
|
||||
raw_ostream *OS;
|
||||
const MachineFunction *MF;
|
||||
|
@ -196,9 +198,10 @@ namespace {
|
|||
|
||||
struct MachineVerifierPass : public MachineFunctionPass {
|
||||
static char ID; // Pass ID, replacement for typeid
|
||||
const char *const Banner;
|
||||
|
||||
MachineVerifierPass()
|
||||
: MachineFunctionPass(ID) {
|
||||
MachineVerifierPass(const char *b = 0)
|
||||
: MachineFunctionPass(ID), Banner(b) {
|
||||
initializeMachineVerifierPassPass(*PassRegistry::getPassRegistry());
|
||||
}
|
||||
|
||||
|
@ -208,7 +211,7 @@ namespace {
|
|||
}
|
||||
|
||||
bool runOnMachineFunction(MachineFunction &MF) {
|
||||
MF.verify(this);
|
||||
MF.verify(this, Banner);
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
@ -219,12 +222,13 @@ char MachineVerifierPass::ID = 0;
|
|||
INITIALIZE_PASS(MachineVerifierPass, "machineverifier",
|
||||
"Verify generated machine code", false, false)
|
||||
|
||||
FunctionPass *llvm::createMachineVerifierPass() {
|
||||
return new MachineVerifierPass();
|
||||
FunctionPass *llvm::createMachineVerifierPass(const char *Banner) {
|
||||
return new MachineVerifierPass(Banner);
|
||||
}
|
||||
|
||||
void MachineFunction::verify(Pass *p) const {
|
||||
MachineVerifier(p).runOnMachineFunction(const_cast<MachineFunction&>(*this));
|
||||
void MachineFunction::verify(Pass *p, const char *Banner) const {
|
||||
MachineVerifier(p, Banner)
|
||||
.runOnMachineFunction(const_cast<MachineFunction&>(*this));
|
||||
}
|
||||
|
||||
bool MachineVerifier::runOnMachineFunction(MachineFunction &MF) {
|
||||
|
@ -297,8 +301,11 @@ bool MachineVerifier::runOnMachineFunction(MachineFunction &MF) {
|
|||
void MachineVerifier::report(const char *msg, const MachineFunction *MF) {
|
||||
assert(MF);
|
||||
*OS << '\n';
|
||||
if (!foundErrors++)
|
||||
if (!foundErrors++) {
|
||||
if (Banner)
|
||||
*OS << "# " << Banner << '\n';
|
||||
MF->print(*OS, Indexes);
|
||||
}
|
||||
*OS << "*** Bad machine code: " << msg << " ***\n"
|
||||
<< "- function: " << MF->getFunction()->getNameStr() << "\n";
|
||||
}
|
||||
|
|
|
@ -484,7 +484,7 @@ bool RABasic::runOnMachineFunction(MachineFunction &mf) {
|
|||
// spiller. Always use -spiller=inline with -verify-regalloc. Even with the
|
||||
// inline spiller, some tests fail to verify because the coalescer does not
|
||||
// always generate verifiable code.
|
||||
MF->verify(this);
|
||||
MF->verify(this, "In RABasic::verify");
|
||||
|
||||
// Verify that LiveIntervals are partitioned into unions and disjoint within
|
||||
// the unions.
|
||||
|
|
|
@ -329,7 +329,7 @@ unsigned RAGreedy::trySplit(LiveInterval &VirtReg, AllocationOrder &Order,
|
|||
.splitAroundLoop(Loop->getLoop());
|
||||
|
||||
if (VerifyEnabled)
|
||||
MF->verify(this);
|
||||
MF->verify(this, "After splitting live range around loop");
|
||||
|
||||
// We have new split regs, don't assign anything.
|
||||
return 0;
|
||||
|
@ -404,7 +404,7 @@ bool RAGreedy::runOnMachineFunction(MachineFunction &mf) {
|
|||
|
||||
MF = &mf;
|
||||
if (VerifyEnabled)
|
||||
MF->verify(this);
|
||||
MF->verify(this, "Before greedy register allocator");
|
||||
|
||||
RegAllocBase::init(getAnalysis<VirtRegMap>(), getAnalysis<LiveIntervals>());
|
||||
DomTree = &getAnalysis<MachineDominatorTree>();
|
||||
|
|
Loading…
Reference in New Issue