Home | History | Annotate | Download | only in MCTargetDesc
      1 //===-------- MipsELFStreamer.h - ELF Object Output -----------------------===//
      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 // This is a custom MCELFStreamer which allows us to insert some hooks before
     11 // emitting data into an actual object file.
     12 //
     13 //===----------------------------------------------------------------------===//
     14 
     15 #ifndef LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSELFSTREAMER_H
     16 #define LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSELFSTREAMER_H
     17 
     18 #include "MipsOptionRecord.h"
     19 #include "llvm/ADT/SmallVector.h"
     20 #include "llvm/MC/MCELFStreamer.h"
     21 #include <memory>
     22 
     23 namespace llvm {
     24 class MCAsmBackend;
     25 class MCCodeEmitter;
     26 class MCContext;
     27 class MCSubtargetInfo;
     28 
     29 class MipsELFStreamer : public MCELFStreamer {
     30   SmallVector<std::unique_ptr<MipsOptionRecord>, 8> MipsOptionRecords;
     31   MipsRegInfoRecord *RegInfoRecord;
     32   SmallVector<MCSymbol*, 4> Labels;
     33 
     34 
     35 public:
     36   MipsELFStreamer(MCContext &Context, MCAsmBackend &MAB, raw_pwrite_stream &OS,
     37                   MCCodeEmitter *Emitter)
     38       : MCELFStreamer(Context, MAB, OS, Emitter) {
     39 
     40     RegInfoRecord = new MipsRegInfoRecord(this, Context);
     41     MipsOptionRecords.push_back(
     42         std::unique_ptr<MipsRegInfoRecord>(RegInfoRecord));
     43   }
     44 
     45   /// Overriding this function allows us to add arbitrary behaviour before the
     46   /// \p Inst is actually emitted. For example, we can inspect the operands and
     47   /// gather sufficient information that allows us to reason about the register
     48   /// usage for the translation unit.
     49   void EmitInstruction(const MCInst &Inst, const MCSubtargetInfo &STI) override;
     50 
     51   /// Overriding this function allows us to record all labels that should be
     52   /// marked as microMIPS. Based on this data marking is done in
     53   /// EmitInstruction.
     54   void EmitLabel(MCSymbol *Symbol) override;
     55 
     56   /// Overriding this function allows us to dismiss all labels that are
     57   /// candidates for marking as microMIPS when .section directive is processed.
     58   void SwitchSection(MCSection *Section,
     59                      const MCExpr *Subsection = nullptr) override;
     60 
     61   /// Overriding this function allows us to dismiss all labels that are
     62   /// candidates for marking as microMIPS when .word directive is emitted.
     63   void EmitValueImpl(const MCExpr *Value, unsigned Size, SMLoc Loc) override;
     64 
     65   /// Emits all the option records stored up until the point it's called.
     66   void EmitMipsOptionRecords();
     67 
     68   /// Mark labels as microMIPS, if necessary for the subtarget.
     69   void createPendingLabelRelocs();
     70 };
     71 
     72 MCELFStreamer *createMipsELFStreamer(MCContext &Context, MCAsmBackend &MAB,
     73                                      raw_pwrite_stream &OS,
     74                                      MCCodeEmitter *Emitter, bool RelaxAll);
     75 } // namespace llvm.
     76 #endif
     77