1*9880d681SAndroid Build Coastguard Worker //===- MCELFStreamer.h - MCStreamer ELF Object File Interface ---*- C++ -*-===// 2*9880d681SAndroid Build Coastguard Worker // 3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure 4*9880d681SAndroid Build Coastguard Worker // 5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source 6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details. 7*9880d681SAndroid Build Coastguard Worker // 8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_MC_MCELFSTREAMER_H 11*9880d681SAndroid Build Coastguard Worker #define LLVM_MC_MCELFSTREAMER_H 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/SmallPtrSet.h" 14*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCDirectives.h" 15*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCObjectStreamer.h" 16*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/SectionKind.h" 17*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/DataTypes.h" 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker namespace llvm { 20*9880d681SAndroid Build Coastguard Worker class MCAsmBackend; 21*9880d681SAndroid Build Coastguard Worker class MCAssembler; 22*9880d681SAndroid Build Coastguard Worker class MCCodeEmitter; 23*9880d681SAndroid Build Coastguard Worker class MCExpr; 24*9880d681SAndroid Build Coastguard Worker class MCInst; 25*9880d681SAndroid Build Coastguard Worker class raw_ostream; 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Worker class MCELFStreamer : public MCObjectStreamer { 28*9880d681SAndroid Build Coastguard Worker public: MCELFStreamer(MCContext & Context,MCAsmBackend & TAB,raw_pwrite_stream & OS,MCCodeEmitter * Emitter)29*9880d681SAndroid Build Coastguard Worker MCELFStreamer(MCContext &Context, MCAsmBackend &TAB, raw_pwrite_stream &OS, 30*9880d681SAndroid Build Coastguard Worker MCCodeEmitter *Emitter) 31*9880d681SAndroid Build Coastguard Worker : MCObjectStreamer(Context, TAB, OS, Emitter), SeenIdent(false) {} 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker ~MCELFStreamer() override; 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker /// state management reset()36*9880d681SAndroid Build Coastguard Worker void reset() override { 37*9880d681SAndroid Build Coastguard Worker SeenIdent = false; 38*9880d681SAndroid Build Coastguard Worker BundleGroups.clear(); 39*9880d681SAndroid Build Coastguard Worker MCObjectStreamer::reset(); 40*9880d681SAndroid Build Coastguard Worker } 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Worker /// \name MCStreamer Interface 43*9880d681SAndroid Build Coastguard Worker /// @{ 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker void InitSections(bool NoExecStack) override; 46*9880d681SAndroid Build Coastguard Worker void ChangeSection(MCSection *Section, const MCExpr *Subsection) override; 47*9880d681SAndroid Build Coastguard Worker void EmitLabel(MCSymbol *Symbol) override; 48*9880d681SAndroid Build Coastguard Worker void EmitAssemblerFlag(MCAssemblerFlag Flag) override; 49*9880d681SAndroid Build Coastguard Worker void EmitThumbFunc(MCSymbol *Func) override; 50*9880d681SAndroid Build Coastguard Worker void EmitWeakReference(MCSymbol *Alias, const MCSymbol *Symbol) override; 51*9880d681SAndroid Build Coastguard Worker bool EmitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute) override; 52*9880d681SAndroid Build Coastguard Worker void EmitSymbolDesc(MCSymbol *Symbol, unsigned DescValue) override; 53*9880d681SAndroid Build Coastguard Worker void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size, 54*9880d681SAndroid Build Coastguard Worker unsigned ByteAlignment) override; 55*9880d681SAndroid Build Coastguard Worker void BeginCOFFSymbolDef(const MCSymbol *Symbol) override; 56*9880d681SAndroid Build Coastguard Worker void EmitCOFFSymbolStorageClass(int StorageClass) override; 57*9880d681SAndroid Build Coastguard Worker void EmitCOFFSymbolType(int Type) override; 58*9880d681SAndroid Build Coastguard Worker void EndCOFFSymbolDef() override; 59*9880d681SAndroid Build Coastguard Worker 60*9880d681SAndroid Build Coastguard Worker void emitELFSize(MCSymbolELF *Symbol, const MCExpr *Value) override; 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker void EmitLocalCommonSymbol(MCSymbol *Symbol, uint64_t Size, 63*9880d681SAndroid Build Coastguard Worker unsigned ByteAlignment) override; 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Worker void EmitZerofill(MCSection *Section, MCSymbol *Symbol = nullptr, 66*9880d681SAndroid Build Coastguard Worker uint64_t Size = 0, unsigned ByteAlignment = 0) override; 67*9880d681SAndroid Build Coastguard Worker void EmitTBSSSymbol(MCSection *Section, MCSymbol *Symbol, uint64_t Size, 68*9880d681SAndroid Build Coastguard Worker unsigned ByteAlignment = 0) override; 69*9880d681SAndroid Build Coastguard Worker void EmitValueImpl(const MCExpr *Value, unsigned Size, 70*9880d681SAndroid Build Coastguard Worker SMLoc Loc = SMLoc()) override; 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Worker void EmitFileDirective(StringRef Filename) override; 73*9880d681SAndroid Build Coastguard Worker 74*9880d681SAndroid Build Coastguard Worker void EmitIdent(StringRef IdentString) override; 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Worker void EmitValueToAlignment(unsigned, int64_t, unsigned, unsigned) override; 77*9880d681SAndroid Build Coastguard Worker 78*9880d681SAndroid Build Coastguard Worker void FinishImpl() override; 79*9880d681SAndroid Build Coastguard Worker 80*9880d681SAndroid Build Coastguard Worker void EmitBundleAlignMode(unsigned AlignPow2) override; 81*9880d681SAndroid Build Coastguard Worker void EmitBundleLock(bool AlignToEnd) override; 82*9880d681SAndroid Build Coastguard Worker void EmitBundleUnlock() override; 83*9880d681SAndroid Build Coastguard Worker 84*9880d681SAndroid Build Coastguard Worker private: 85*9880d681SAndroid Build Coastguard Worker bool isBundleLocked() const; 86*9880d681SAndroid Build Coastguard Worker void EmitInstToFragment(const MCInst &Inst, const MCSubtargetInfo &) override; 87*9880d681SAndroid Build Coastguard Worker void EmitInstToData(const MCInst &Inst, const MCSubtargetInfo &) override; 88*9880d681SAndroid Build Coastguard Worker 89*9880d681SAndroid Build Coastguard Worker void fixSymbolsInTLSFixups(const MCExpr *expr); 90*9880d681SAndroid Build Coastguard Worker 91*9880d681SAndroid Build Coastguard Worker /// \brief Merge the content of the fragment \p EF into the fragment \p DF. 92*9880d681SAndroid Build Coastguard Worker void mergeFragment(MCDataFragment *, MCDataFragment *); 93*9880d681SAndroid Build Coastguard Worker 94*9880d681SAndroid Build Coastguard Worker bool SeenIdent; 95*9880d681SAndroid Build Coastguard Worker 96*9880d681SAndroid Build Coastguard Worker /// BundleGroups - The stack of fragments holding the bundle-locked 97*9880d681SAndroid Build Coastguard Worker /// instructions. 98*9880d681SAndroid Build Coastguard Worker llvm::SmallVector<MCDataFragment *, 4> BundleGroups; 99*9880d681SAndroid Build Coastguard Worker }; 100*9880d681SAndroid Build Coastguard Worker 101*9880d681SAndroid Build Coastguard Worker MCELFStreamer *createARMELFStreamer(MCContext &Context, MCAsmBackend &TAB, 102*9880d681SAndroid Build Coastguard Worker raw_pwrite_stream &OS, 103*9880d681SAndroid Build Coastguard Worker MCCodeEmitter *Emitter, bool RelaxAll, 104*9880d681SAndroid Build Coastguard Worker bool IsThumb); 105*9880d681SAndroid Build Coastguard Worker 106*9880d681SAndroid Build Coastguard Worker } // end namespace llvm 107*9880d681SAndroid Build Coastguard Worker 108*9880d681SAndroid Build Coastguard Worker #endif 109