mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Teach MachineBasicBlock::print() to annotate instructions and blocks with
SlotIndexes when available. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117392 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -23,6 +23,7 @@ class Pass; | ||||
| class BasicBlock; | ||||
| class MachineFunction; | ||||
| class MCSymbol; | ||||
| class SlotIndexes; | ||||
| class StringRef; | ||||
| class raw_ostream; | ||||
|  | ||||
| @@ -361,7 +362,7 @@ public: | ||||
|  | ||||
|   // Debugging methods. | ||||
|   void dump() const; | ||||
|   void print(raw_ostream &OS) const; | ||||
|   void print(raw_ostream &OS, SlotIndexes* = 0) const; | ||||
|  | ||||
|   /// getNumber - MachineBasicBlocks are uniquely numbered at the function | ||||
|   /// level, unless they're not in a MachineFunction yet, in which case this | ||||
|   | ||||
| @@ -244,7 +244,7 @@ public: | ||||
|   /// print - Print out the MachineFunction in a format suitable for debugging | ||||
|   /// to the specified stream. | ||||
|   /// | ||||
|   void print(raw_ostream &OS) const; | ||||
|   void print(raw_ostream &OS, SlotIndexes* = 0) const; | ||||
|  | ||||
|   /// viewCFG - This function is meant for use from the debugger.  You can just | ||||
|   /// say 'call F->viewCFG()' and a ghostview window should pop up from the | ||||
|   | ||||
| @@ -141,19 +141,7 @@ void LiveIntervals::print(raw_ostream &OS, const Module* ) const { | ||||
|  | ||||
| void LiveIntervals::printInstrs(raw_ostream &OS) const { | ||||
|   OS << "********** MACHINEINSTRS **********\n"; | ||||
|  | ||||
|   for (MachineFunction::iterator mbbi = mf_->begin(), mbbe = mf_->end(); | ||||
|        mbbi != mbbe; ++mbbi) { | ||||
|     OS << "BB#" << mbbi->getNumber() | ||||
|        << ":\t\t# derived from " << mbbi->getName() << "\n"; | ||||
|     for (MachineBasicBlock::iterator mii = mbbi->begin(), | ||||
|            mie = mbbi->end(); mii != mie; ++mii) { | ||||
|       if (mii->isDebugValue()) | ||||
|         OS << "    \t" << *mii; | ||||
|       else | ||||
|         OS << getInstructionIndex(mii) << '\t' << *mii; | ||||
|     } | ||||
|   } | ||||
|   mf_->print(OS, indexes_); | ||||
| } | ||||
|  | ||||
| void LiveIntervals::dumpInstrs() const { | ||||
|   | ||||
| @@ -17,6 +17,7 @@ | ||||
| #include "llvm/CodeGen/MachineDominators.h" | ||||
| #include "llvm/CodeGen/MachineFunction.h" | ||||
| #include "llvm/CodeGen/MachineLoopInfo.h" | ||||
| #include "llvm/CodeGen/SlotIndexes.h" | ||||
| #include "llvm/MC/MCAsmInfo.h" | ||||
| #include "llvm/MC/MCContext.h" | ||||
| #include "llvm/Target/TargetRegisterInfo.h" | ||||
| @@ -176,7 +177,7 @@ StringRef MachineBasicBlock::getName() const { | ||||
|     return "(null)"; | ||||
| } | ||||
|  | ||||
| void MachineBasicBlock::print(raw_ostream &OS) const { | ||||
| void MachineBasicBlock::print(raw_ostream &OS, SlotIndexes *Indexes) const { | ||||
|   const MachineFunction *MF = getParent(); | ||||
|   if (!MF) { | ||||
|     OS << "Can't print out MachineBasicBlock because parent MachineFunction" | ||||
| @@ -186,6 +187,9 @@ void MachineBasicBlock::print(raw_ostream &OS) const { | ||||
|  | ||||
|   if (Alignment) { OS << "Alignment " << Alignment << "\n"; } | ||||
|  | ||||
|   if (Indexes) | ||||
|     OS << Indexes->getMBBStartIdx(this) << '\t'; | ||||
|  | ||||
|   OS << "BB#" << getNumber() << ": "; | ||||
|  | ||||
|   const char *Comma = ""; | ||||
| @@ -198,8 +202,9 @@ void MachineBasicBlock::print(raw_ostream &OS) const { | ||||
|   if (hasAddressTaken()) { OS << Comma << "ADDRESS TAKEN"; Comma = ", "; } | ||||
|   OS << '\n'; | ||||
|  | ||||
|   const TargetRegisterInfo *TRI = MF->getTarget().getRegisterInfo();   | ||||
|   const TargetRegisterInfo *TRI = MF->getTarget().getRegisterInfo(); | ||||
|   if (!livein_empty()) { | ||||
|     if (Indexes) OS << '\t'; | ||||
|     OS << "    Live Ins:"; | ||||
|     for (livein_iterator I = livein_begin(),E = livein_end(); I != E; ++I) | ||||
|       OutputReg(OS, *I, TRI); | ||||
| @@ -207,19 +212,26 @@ void MachineBasicBlock::print(raw_ostream &OS) const { | ||||
|   } | ||||
|   // Print the preds of this block according to the CFG. | ||||
|   if (!pred_empty()) { | ||||
|     if (Indexes) OS << '\t'; | ||||
|     OS << "    Predecessors according to CFG:"; | ||||
|     for (const_pred_iterator PI = pred_begin(), E = pred_end(); PI != E; ++PI) | ||||
|       OS << " BB#" << (*PI)->getNumber(); | ||||
|     OS << '\n'; | ||||
|   } | ||||
|    | ||||
|  | ||||
|   for (const_iterator I = begin(); I != end(); ++I) { | ||||
|     if (Indexes) { | ||||
|       if (Indexes->hasIndex(I)) | ||||
|         OS << Indexes->getInstructionIndex(I); | ||||
|       OS << '\t'; | ||||
|     } | ||||
|     OS << '\t'; | ||||
|     I->print(OS, &getParent()->getTarget()); | ||||
|   } | ||||
|  | ||||
|   // Print the successors of this block according to the CFG. | ||||
|   if (!succ_empty()) { | ||||
|     if (Indexes) OS << '\t'; | ||||
|     OS << "    Successors according to CFG:"; | ||||
|     for (const_succ_iterator SI = succ_begin(), E = succ_end(); SI != E; ++SI) | ||||
|       OS << " BB#" << (*SI)->getNumber(); | ||||
|   | ||||
| @@ -280,7 +280,7 @@ void MachineFunction::dump() const { | ||||
|   print(dbgs()); | ||||
| } | ||||
|  | ||||
| void MachineFunction::print(raw_ostream &OS) const { | ||||
| void MachineFunction::print(raw_ostream &OS, SlotIndexes *Indexes) const { | ||||
|   OS << "# Machine code for function " << Fn->getName() << ":\n"; | ||||
|  | ||||
|   // Print Frame Information | ||||
| @@ -329,7 +329,7 @@ void MachineFunction::print(raw_ostream &OS) const { | ||||
|    | ||||
|   for (const_iterator BB = begin(), E = end(); BB != E; ++BB) { | ||||
|     OS << '\n'; | ||||
|     BB->print(OS); | ||||
|     BB->print(OS, Indexes); | ||||
|   } | ||||
|  | ||||
|   OS << "\n# End machine code for function " << Fn->getName() << ".\n\n"; | ||||
|   | ||||
| @@ -168,6 +168,7 @@ namespace { | ||||
|     // Analysis information if available | ||||
|     LiveVariables *LiveVars; | ||||
|     const LiveIntervals *LiveInts; | ||||
|     SlotIndexes *Indexes; | ||||
|  | ||||
|     void visitMachineFunctionBefore(); | ||||
|     void visitMachineBasicBlockBefore(const MachineBasicBlock *MBB); | ||||
| @@ -249,11 +250,13 @@ bool MachineVerifier::runOnMachineFunction(MachineFunction &MF) { | ||||
|  | ||||
|   LiveVars = NULL; | ||||
|   LiveInts = NULL; | ||||
|   Indexes = NULL; | ||||
|   if (PASS) { | ||||
|     LiveInts = PASS->getAnalysisIfAvailable<LiveIntervals>(); | ||||
|     // We don't want to verify LiveVariables if LiveIntervals is available. | ||||
|     if (!LiveInts) | ||||
|       LiveVars = PASS->getAnalysisIfAvailable<LiveVariables>(); | ||||
|     Indexes = PASS->getAnalysisIfAvailable<SlotIndexes>(); | ||||
|   } | ||||
|  | ||||
|   visitMachineFunctionBefore(); | ||||
| @@ -291,7 +294,7 @@ void MachineVerifier::report(const char *msg, const MachineFunction *MF) { | ||||
|   assert(MF); | ||||
|   *OS << '\n'; | ||||
|   if (!foundErrors++) | ||||
|     MF->print(*OS); | ||||
|     MF->print(*OS, Indexes); | ||||
|   *OS << "*** Bad machine code: " << msg << " ***\n" | ||||
|       << "- function:    " << MF->getFunction()->getNameStr() << "\n"; | ||||
| } | ||||
| @@ -301,13 +304,19 @@ void MachineVerifier::report(const char *msg, const MachineBasicBlock *MBB) { | ||||
|   report(msg, MBB->getParent()); | ||||
|   *OS << "- basic block: " << MBB->getName() | ||||
|       << " " << (void*)MBB | ||||
|       << " (BB#" << MBB->getNumber() << ")\n"; | ||||
|       << " (BB#" << MBB->getNumber() << ")"; | ||||
|   if (Indexes) | ||||
|     *OS << " [" << Indexes->getMBBStartIdx(MBB) | ||||
|         << ';' <<  Indexes->getMBBEndIdx(MBB) << ')'; | ||||
|   *OS << '\n'; | ||||
| } | ||||
|  | ||||
| void MachineVerifier::report(const char *msg, const MachineInstr *MI) { | ||||
|   assert(MI); | ||||
|   report(msg, MI->getParent()); | ||||
|   *OS << "- instruction: "; | ||||
|   if (Indexes && Indexes->hasIndex(MI)) | ||||
|     *OS << Indexes->getInstructionIndex(MI) << '\t'; | ||||
|   MI->print(*OS, TM); | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user