This patch changes a static_cast to dyn_cast
authorJack Carter <jcarter@mips.com>
Tue, 5 Feb 2013 07:47:41 +0000 (07:47 +0000)
committerJack Carter <jcarter@mips.com>
Tue, 5 Feb 2013 07:47:41 +0000 (07:47 +0000)
for MipsELFStreamer objects.

Contributer: Jack Carter

llvm-svn: 174354

llvm/include/llvm/MC/MCStreamer.h
llvm/lib/Target/Mips/MCTargetDesc/MipsELFStreamer.h
llvm/lib/Target/Mips/MipsAsmPrinter.cpp

index 3631325..8d7d542 100644 (file)
@@ -57,6 +57,7 @@ namespace llvm {
       SK_ARMELFStreamer,
       SK_MachOStreamer,
       SK_PureStreamer,
+      SK_MipsELFStreamer,
       SK_WinCOFFStreamer
     };
 
index 0d067e0..360dbe1 100644 (file)
@@ -19,12 +19,16 @@ public:
   MipsELFStreamer(MCContext &Context, MCAsmBackend &TAB,
                   raw_ostream &OS, MCCodeEmitter *Emitter,
                   bool RelaxAll, bool NoExecStack)
-    : MCELFStreamer(Context, TAB, OS, Emitter) {
+    : MCELFStreamer(SK_MipsELFStreamer, Context, TAB, OS, Emitter) {
   }
 
   ~MipsELFStreamer() {}
   void emitELFHeaderFlagsCG(const MipsSubtarget &Subtarget);
 //  void emitELFHeaderFlagCG(unsigned Val);
+
+  static bool classof(const MCStreamer *S) {
+    return S->getKind() == SK_MipsELFStreamer;
+  }
 };
 
   MCELFStreamer* createMipsELFStreamer(MCContext &Context, MCAsmBackend &TAB,
index df6baaf..07a4faa 100644 (file)
@@ -551,8 +551,8 @@ void MipsAsmPrinter::EmitEndOfAsmFile(Module &M) {
   // Emit Mips ELF register info
   Subtarget->getMReginfo().emitMipsReginfoSectionCG(
              OutStreamer, getObjFileLowering(), *Subtarget);
-  MipsELFStreamer & MES = static_cast<MipsELFStreamer &>(OutStreamer);
-  MES.emitELFHeaderFlagsCG(*Subtarget);
+  if (MipsELFStreamer *MES = dyn_cast<MipsELFStreamer>(&OutStreamer))
+    MES->emitELFHeaderFlagsCG(*Subtarget);
 }
 
 MachineLocation