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;