Print PseudoSourceValue.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55291 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/include/llvm/CodeGen/PseudoSourceValue.h b/include/llvm/CodeGen/PseudoSourceValue.h
index 115e565..4620456 100644
--- a/include/llvm/CodeGen/PseudoSourceValue.h
+++ b/include/llvm/CodeGen/PseudoSourceValue.h
@@ -18,6 +18,7 @@
namespace llvm {
class MachineFrameInfo;
+ class raw_ostream;
/// PseudoSourceValue - Special value supplied for machine level alias
/// analysis. It indicates that the a memory access references the functions
@@ -28,6 +29,7 @@
PseudoSourceValue();
virtual void print(std::ostream &OS) const;
+ virtual void print(raw_ostream &OS) const;
/// isConstant - Test whether this PseudoSourceValue has a constant value.
///
@@ -59,6 +61,16 @@
/// A SV referencing the jump table
static const PseudoSourceValue *getJumpTable();
};
+
+inline std::ostream &operator<<(std::ostream &OS,const PseudoSourceValue &PSV) {
+ PSV.print(OS);
+ return OS;
+}
+inline raw_ostream &operator<<(raw_ostream &OS, const PseudoSourceValue &PSV) {
+ PSV.print(OS);
+ return OS;
+}
+
} // End llvm namespace
#endif
diff --git a/lib/CodeGen/MachineInstr.cpp b/lib/CodeGen/MachineInstr.cpp
index 00987d7..41df5df 100644
--- a/lib/CodeGen/MachineInstr.cpp
+++ b/lib/CodeGen/MachineInstr.cpp
@@ -756,8 +756,8 @@
OS << "<unknown>";
else if (!V->getName().empty())
OS << V->getName();
- else if (isa<PseudoSourceValue>(V))
- OS << *V;
+ else if (const PseudoSourceValue *PSV = dyn_cast<PseudoSourceValue>(V))
+ OS << *PSV;
else
OS << V;
diff --git a/lib/CodeGen/PseudoSourceValue.cpp b/lib/CodeGen/PseudoSourceValue.cpp
index bcf4ea8..ac41609 100644
--- a/lib/CodeGen/PseudoSourceValue.cpp
+++ b/lib/CodeGen/PseudoSourceValue.cpp
@@ -16,6 +16,7 @@
#include "llvm/DerivedTypes.h"
#include "llvm/Support/Compiler.h"
#include "llvm/Support/ManagedStatic.h"
+#include "llvm/Support/raw_ostream.h"
#include <map>
namespace llvm {
@@ -43,6 +44,9 @@
void PseudoSourceValue::print(std::ostream &OS) const {
OS << PSVNames[this - *PSVs];
}
+ void PseudoSourceValue::print(raw_ostream &OS) const {
+ OS << PSVNames[this - *PSVs];
+ }
/// FixedStackPseudoSourceValue - A specialized PseudoSourceValue
/// for holding FixedStack values, which must include a frame
@@ -58,6 +62,9 @@
virtual void print(std::ostream &OS) const {
OS << "FixedStack" << FI;
}
+ virtual void print(raw_ostream &OS) const {
+ OS << "FixedStack" << FI;
+ }
};
static ManagedStatic<std::map<int, const PseudoSourceValue *> > FSValues;