mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
Re-apply LiveInterval index dumping patch, with fixes suggested by Bill
and others. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78003 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
11e9657eeb
commit
b525766479
60
include/llvm/CodeGen/Dump.h
Normal file
60
include/llvm/CodeGen/Dump.h
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
//===- llvm/Support/Dump.h - Easy way to tailor dump output -----*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// This file provides the PrefixPrinter interface to pass to MachineFunction
|
||||||
|
// and MachineBasicBlock print methods to output additional information before
|
||||||
|
// blocks and instructions are printed.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef LLVM_CODEGEN_DUMP_H
|
||||||
|
#define LLVM_CODEGEN_DUMP_H
|
||||||
|
|
||||||
|
#include <iosfwd>
|
||||||
|
|
||||||
|
namespace llvm {
|
||||||
|
|
||||||
|
class MachineBasicBlock;
|
||||||
|
class MachineInstr;
|
||||||
|
class raw_ostream;
|
||||||
|
|
||||||
|
/// PrefixPrinter - Print some additional information before printing
|
||||||
|
/// basic blocks and instructions.
|
||||||
|
class PrefixPrinter {
|
||||||
|
public:
|
||||||
|
virtual ~PrefixPrinter();
|
||||||
|
|
||||||
|
/// operator() - Print a prefix before each MachineBasicBlock
|
||||||
|
virtual raw_ostream &operator()(raw_ostream &out,
|
||||||
|
const MachineBasicBlock &) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// operator() - Print a prefix before each MachineInstr
|
||||||
|
virtual raw_ostream &operator()(raw_ostream &out,
|
||||||
|
const MachineInstr &) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// operator() - Print a prefix before each MachineBasicBlock
|
||||||
|
virtual std::ostream &operator()(std::ostream &out,
|
||||||
|
const MachineBasicBlock &) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// operator() - Print a prefix before each MachineInstr
|
||||||
|
virtual std::ostream &operator()(std::ostream &out,
|
||||||
|
const MachineInstr &) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // End llvm namespace
|
||||||
|
|
||||||
|
#endif
|
@ -538,6 +538,37 @@ namespace llvm {
|
|||||||
void printRegName(unsigned reg) const;
|
void printRegName(unsigned reg) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// IntervalPrefixPrinter - Print live interval indices before each
|
||||||
|
/// instruction.
|
||||||
|
class IntervalPrefixPrinter : public PrefixPrinter {
|
||||||
|
private:
|
||||||
|
const LiveIntervals &liinfo;
|
||||||
|
|
||||||
|
public:
|
||||||
|
IntervalPrefixPrinter(const LiveIntervals &lii)
|
||||||
|
: liinfo(lii) {};
|
||||||
|
|
||||||
|
// We need null implementations of the other virtual functions to
|
||||||
|
// avoid warnings about hidden virtual functions.
|
||||||
|
|
||||||
|
raw_ostream &operator()(raw_ostream &out,
|
||||||
|
const MachineBasicBlock &instr) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
raw_ostream &operator()(raw_ostream &out,
|
||||||
|
const MachineInstr &instr) const;
|
||||||
|
|
||||||
|
std::ostream &operator()(std::ostream &out,
|
||||||
|
const MachineBasicBlock &instr) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::ostream &operator()(std::ostream &out,
|
||||||
|
const MachineInstr &instr) const {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
};
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
#include "llvm/CodeGen/MachineInstr.h"
|
#include "llvm/CodeGen/MachineInstr.h"
|
||||||
#include "llvm/ADT/GraphTraits.h"
|
#include "llvm/ADT/GraphTraits.h"
|
||||||
|
#include "llvm/CodeGen/Dump.h"
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
@ -310,10 +311,18 @@ public:
|
|||||||
|
|
||||||
// Debugging methods.
|
// Debugging methods.
|
||||||
void dump() const;
|
void dump() const;
|
||||||
void print(std::ostream &OS) const;
|
void print(std::ostream &OS,
|
||||||
void print(std::ostream *OS) const { if (OS) print(*OS); }
|
const PrefixPrinter &prefix = PrefixPrinter()) const;
|
||||||
void print(raw_ostream &OS) const;
|
void print(std::ostream *OS,
|
||||||
void print(raw_ostream *OS) const { if (OS) print(*OS); }
|
const PrefixPrinter &prefix = PrefixPrinter()) const {
|
||||||
|
if (OS) print(*OS, prefix);
|
||||||
|
}
|
||||||
|
void print(raw_ostream &OS,
|
||||||
|
const PrefixPrinter &prefix = PrefixPrinter()) const;
|
||||||
|
void print(raw_ostream *OS,
|
||||||
|
const PrefixPrinter &prefix = PrefixPrinter()) const {
|
||||||
|
if (OS) print(*OS, prefix);
|
||||||
|
}
|
||||||
|
|
||||||
/// getNumber - MachineBasicBlocks are uniquely numbered at the function
|
/// getNumber - MachineBasicBlocks are uniquely numbered at the function
|
||||||
/// level, unless they're not in a MachineFunction yet, in which case this
|
/// level, unless they're not in a MachineFunction yet, in which case this
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include "llvm/ADT/ilist.h"
|
#include "llvm/ADT/ilist.h"
|
||||||
#include "llvm/Support/DebugLoc.h"
|
#include "llvm/Support/DebugLoc.h"
|
||||||
|
#include "llvm/CodeGen/Dump.h"
|
||||||
#include "llvm/CodeGen/MachineBasicBlock.h"
|
#include "llvm/CodeGen/MachineBasicBlock.h"
|
||||||
#include "llvm/Support/Allocator.h"
|
#include "llvm/Support/Allocator.h"
|
||||||
#include "llvm/Support/Recycler.h"
|
#include "llvm/Support/Recycler.h"
|
||||||
@ -206,8 +207,12 @@ public:
|
|||||||
/// print - Print out the MachineFunction in a format suitable for debugging
|
/// print - Print out the MachineFunction in a format suitable for debugging
|
||||||
/// to the specified stream.
|
/// to the specified stream.
|
||||||
///
|
///
|
||||||
void print(std::ostream &OS) const;
|
void print(std::ostream &OS,
|
||||||
void print(std::ostream *OS) const { if (OS) print(*OS); }
|
const PrefixPrinter &prefix = PrefixPrinter()) const;
|
||||||
|
void print(std::ostream *OS,
|
||||||
|
const PrefixPrinter &prefix = PrefixPrinter()) const {
|
||||||
|
if (OS) print(*OS, prefix);
|
||||||
|
}
|
||||||
|
|
||||||
/// viewCFG - This function is meant for use from the debugger. You can just
|
/// 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
|
/// say 'call F->viewCFG()' and a ghostview window should pop up from the
|
||||||
|
18
lib/CodeGen/Dump.cpp
Normal file
18
lib/CodeGen/Dump.cpp
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
//===- lib/Support/Dump.h - Virtual function homes --------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// This file provides the PrefixPrinter virtual function homes.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "llvm/CodeGen/Dump.h"
|
||||||
|
|
||||||
|
using namespace llvm;
|
||||||
|
|
||||||
|
PrefixPrinter::~PrefixPrinter() {}
|
@ -2501,3 +2501,9 @@ LiveRange LiveIntervals::addLiveRangeToEndOfBlock(unsigned reg,
|
|||||||
|
|
||||||
return LR;
|
return LR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
raw_ostream &
|
||||||
|
IntervalPrefixPrinter::operator()(raw_ostream &out,
|
||||||
|
const MachineInstr &instr) const {
|
||||||
|
return out << liinfo.getInstructionIndex(&instr);
|
||||||
|
}
|
||||||
|
@ -153,12 +153,14 @@ static inline void OutputReg(raw_ostream &os, unsigned RegNo,
|
|||||||
os << " %reg" << RegNo;
|
os << " %reg" << RegNo;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MachineBasicBlock::print(std::ostream &OS) const {
|
void MachineBasicBlock::print(std::ostream &OS,
|
||||||
|
const PrefixPrinter &prefix) const {
|
||||||
raw_os_ostream RawOS(OS);
|
raw_os_ostream RawOS(OS);
|
||||||
print(RawOS);
|
print(RawOS, prefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MachineBasicBlock::print(raw_ostream &OS) const {
|
void MachineBasicBlock::print(raw_ostream &OS,
|
||||||
|
const PrefixPrinter &prefix) const {
|
||||||
const MachineFunction *MF = getParent();
|
const MachineFunction *MF = getParent();
|
||||||
if(!MF) {
|
if(!MF) {
|
||||||
OS << "Can't print out MachineBasicBlock because parent MachineFunction"
|
OS << "Can't print out MachineBasicBlock because parent MachineFunction"
|
||||||
@ -191,7 +193,7 @@ void MachineBasicBlock::print(raw_ostream &OS) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (const_iterator I = begin(); I != end(); ++I) {
|
for (const_iterator I = begin(); I != end(); ++I) {
|
||||||
OS << "\t";
|
prefix(OS, *I) << "\t";
|
||||||
I->print(OS, &getParent()->getTarget());
|
I->print(OS, &getParent()->getTarget());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -218,7 +218,8 @@ void MachineFunction::dump() const {
|
|||||||
print(*cerr.stream());
|
print(*cerr.stream());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MachineFunction::print(std::ostream &OS) const {
|
void MachineFunction::print(std::ostream &OS,
|
||||||
|
const PrefixPrinter &prefix) const {
|
||||||
OS << "# Machine code for " << Fn->getNameStr () << "():\n";
|
OS << "# Machine code for " << Fn->getNameStr () << "():\n";
|
||||||
|
|
||||||
// Print Frame Information
|
// Print Frame Information
|
||||||
@ -260,8 +261,10 @@ void MachineFunction::print(std::ostream &OS) const {
|
|||||||
OS << "\n";
|
OS << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const_iterator BB = begin(); BB != end(); ++BB)
|
for (const_iterator BB = begin(); BB != end(); ++BB) {
|
||||||
BB->print(OS);
|
prefix(OS, *BB);
|
||||||
|
BB->print(OS, prefix);
|
||||||
|
}
|
||||||
|
|
||||||
OS << "\n# End machine code for " << Fn->getNameStr () << "().\n\n";
|
OS << "\n# End machine code for " << Fn->getNameStr () << "().\n\n";
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user