aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/RenderMachineFunction.h
diff options
context:
space:
mode:
Diffstat (limited to 'lib/CodeGen/RenderMachineFunction.h')
-rw-r--r--lib/CodeGen/RenderMachineFunction.h18
1 files changed, 17 insertions, 1 deletions
diff --git a/lib/CodeGen/RenderMachineFunction.h b/lib/CodeGen/RenderMachineFunction.h
index 1e604da138..090b03ecd6 100644
--- a/lib/CodeGen/RenderMachineFunction.h
+++ b/lib/CodeGen/RenderMachineFunction.h
@@ -223,6 +223,11 @@ namespace llvm {
const char *renderSuffix = 0);
private:
+ class Spacer;
+
+ template <typename OStream>
+ friend OStream& operator<<(OStream &os, const Spacer &s);
+
std::string fqn;
@@ -238,9 +243,12 @@ namespace llvm {
// Utilities.
typedef enum { Dead, Defined, Used, AliveReg, AliveStack } LiveState;
-
LiveState getLiveStateAt(const LiveInterval *li, SlotIndex i) const;
+ typedef enum { Zero, Low, High } PressureState;
+ PressureState getPressureStateAt(const TargetRegisterClass *trc,
+ SlotIndex i) const;
+
// ---------- Rendering methods ----------
/// For inserting spaces when pretty printing.
@@ -286,6 +294,14 @@ namespace llvm {
void renderPressureTableLegend(const Spacer &indent,
OStream &os) const;
+ /// \brief Render a consecutive set of HTML cells of the same class using
+ /// the colspan attribute for run-length encoding.
+ template <typename OStream, typename CellType>
+ void renderCellsWithRLE(
+ const Spacer &indent, OStream &os,
+ const std::pair<CellType, unsigned> &rleAccumulator,
+ const std::map<CellType, std::string> &cellTypeStrs) const;
+
/// \brief Render code listing, potentially with register pressure
/// and live intervals shown alongside.
template <typename OStream>