Replace .mips_hack_stocg with ".set micromips" and ".set nomicromips".
[oota-llvm.git] / lib / Target / Mips / MipsTargetStreamer.h
1 //===-- MipsTargetStreamer.h - Mips Target Streamer ------------*- C++ -*--===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 #ifndef MIPSTARGETSTREAMER_H
11 #define MIPSTARGETSTREAMER_H
12
13 #include "llvm/MC/MCELFStreamer.h"
14 #include "llvm/MC/MCStreamer.h"
15
16 namespace llvm {
17 class MipsTargetStreamer : public MCTargetStreamer {
18   virtual void anchor();
19
20 public:
21   virtual void emitMipsHackELFFlags(unsigned Flags) = 0;
22   virtual void emitDirectiveSetMicroMips() = 0;
23   virtual void emitDirectiveSetNoMicroMips() = 0;
24   virtual void emitDirectiveAbiCalls() = 0;
25   virtual void emitDirectiveOptionPic0() = 0;
26 };
27
28 // This part is for ascii assembly output
29 class MipsTargetAsmStreamer : public MipsTargetStreamer {
30   formatted_raw_ostream &OS;
31
32 public:
33   MipsTargetAsmStreamer(formatted_raw_ostream &OS);
34   virtual void emitMipsHackELFFlags(unsigned Flags);
35   virtual void emitDirectiveSetMicroMips();
36   virtual void emitDirectiveSetNoMicroMips();
37   virtual void emitDirectiveAbiCalls();
38   virtual void emitDirectiveOptionPic0();
39 };
40
41 // This part is for ELF object output
42 class MipsTargetELFStreamer : public MipsTargetStreamer {
43   bool MicroMipsEnabled;
44 public:
45   bool isMicroMipsEnabled() const { return MicroMipsEnabled; }
46   MCELFStreamer &getStreamer();
47   MipsTargetELFStreamer();
48
49   virtual void emitLabel(MCSymbol *Symbol) LLVM_OVERRIDE;
50
51   // FIXME: emitMipsHackELFFlags() will be removed from this class.
52   virtual void emitMipsHackELFFlags(unsigned Flags);
53   virtual void emitDirectiveSetMicroMips();
54   virtual void emitDirectiveSetNoMicroMips();
55   virtual void emitDirectiveAbiCalls();
56   virtual void emitDirectiveOptionPic0();
57 };
58 }
59 #endif