2012-12-07 15:50:40 +00:00
|
|
|
//===- MCELFStreamer.h - MCStreamer ELF Object File Interface ---*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_MC_MCELFSTREAMER_H
|
|
|
|
#define LLVM_MC_MCELFSTREAMER_H
|
|
|
|
|
|
|
|
#include "llvm/ADT/SmallPtrSet.h"
|
|
|
|
#include "llvm/MC/MCDirectives.h"
|
|
|
|
#include "llvm/MC/MCObjectStreamer.h"
|
|
|
|
#include "llvm/MC/SectionKind.h"
|
2012-12-08 05:19:49 +00:00
|
|
|
#include "llvm/Support/DataTypes.h"
|
2012-12-07 15:50:40 +00:00
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
class MCAsmBackend;
|
|
|
|
class MCAssembler;
|
|
|
|
class MCCodeEmitter;
|
|
|
|
class MCExpr;
|
|
|
|
class MCInst;
|
|
|
|
class raw_ostream;
|
|
|
|
|
|
|
|
class MCELFStreamer : public MCObjectStreamer {
|
2013-01-31 23:29:57 +00:00
|
|
|
public:
|
2015-04-14 22:14:34 +00:00
|
|
|
MCELFStreamer(MCContext &Context, MCAsmBackend &TAB, raw_pwrite_stream &OS,
|
2014-01-26 06:06:37 +00:00
|
|
|
MCCodeEmitter *Emitter)
|
2015-04-14 22:14:34 +00:00
|
|
|
: MCObjectStreamer(Context, TAB, OS, Emitter), SeenIdent(false) {}
|
2014-01-26 06:06:37 +00:00
|
|
|
|
2015-04-11 02:11:45 +00:00
|
|
|
~MCELFStreamer() override;
|
2012-12-07 15:50:40 +00:00
|
|
|
|
2014-09-17 09:25:36 +00:00
|
|
|
/// state management
|
|
|
|
void reset() override {
|
2015-04-16 10:53:22 +00:00
|
|
|
SeenIdent = false;
|
|
|
|
BundleGroups.clear();
|
2014-09-17 09:25:36 +00:00
|
|
|
MCObjectStreamer::reset();
|
|
|
|
}
|
|
|
|
|
2015-05-02 00:44:14 +00:00
|
|
|
/// \name MCStreamer Interface
|
2012-12-07 15:50:40 +00:00
|
|
|
/// @{
|
|
|
|
|
2014-10-15 16:12:52 +00:00
|
|
|
void InitSections(bool NoExecStack) override;
|
2015-05-21 19:20:38 +00:00
|
|
|
void ChangeSection(MCSection *Section, const MCExpr *Subsection) override;
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitLabel(MCSymbol *Symbol) override;
|
|
|
|
void EmitAssemblerFlag(MCAssemblerFlag Flag) override;
|
|
|
|
void EmitThumbFunc(MCSymbol *Func) override;
|
|
|
|
void EmitWeakReference(MCSymbol *Alias, const MCSymbol *Symbol) override;
|
|
|
|
bool EmitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute) override;
|
|
|
|
void EmitSymbolDesc(MCSymbol *Symbol, unsigned DescValue) override;
|
|
|
|
void EmitCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
|
|
|
unsigned ByteAlignment) override;
|
|
|
|
void BeginCOFFSymbolDef(const MCSymbol *Symbol) override;
|
|
|
|
void EmitCOFFSymbolStorageClass(int StorageClass) override;
|
|
|
|
void EmitCOFFSymbolType(int Type) override;
|
|
|
|
void EndCOFFSymbolDef() override;
|
2012-12-07 15:50:40 +00:00
|
|
|
|
2015-06-02 00:25:12 +00:00
|
|
|
void emitELFSize(MCSymbolELF *Symbol, const MCExpr *Value) override;
|
2012-12-07 15:50:40 +00:00
|
|
|
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitLocalCommonSymbol(MCSymbol *Symbol, uint64_t Size,
|
|
|
|
unsigned ByteAlignment) override;
|
2012-12-07 15:50:40 +00:00
|
|
|
|
2015-05-21 19:20:38 +00:00
|
|
|
void EmitZerofill(MCSection *Section, MCSymbol *Symbol = nullptr,
|
2014-03-08 07:02:02 +00:00
|
|
|
uint64_t Size = 0, unsigned ByteAlignment = 0) override;
|
2015-05-21 19:20:38 +00:00
|
|
|
void EmitTBSSSymbol(MCSection *Section, MCSymbol *Symbol, uint64_t Size,
|
|
|
|
unsigned ByteAlignment = 0) override;
|
2014-04-22 17:27:29 +00:00
|
|
|
void EmitValueImpl(const MCExpr *Value, unsigned Size,
|
2015-09-20 23:35:59 +00:00
|
|
|
SMLoc Loc = SMLoc()) override;
|
2012-12-07 15:50:40 +00:00
|
|
|
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitFileDirective(StringRef Filename) override;
|
2012-12-07 15:50:40 +00:00
|
|
|
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitIdent(StringRef IdentString) override;
|
2013-10-16 01:05:45 +00:00
|
|
|
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitValueToAlignment(unsigned, int64_t, unsigned, unsigned) override;
|
2013-09-19 23:21:01 +00:00
|
|
|
|
2014-03-08 07:02:02 +00:00
|
|
|
void FinishImpl() override;
|
2013-01-31 23:29:57 +00:00
|
|
|
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitBundleAlignMode(unsigned AlignPow2) override;
|
|
|
|
void EmitBundleLock(bool AlignToEnd) override;
|
|
|
|
void EmitBundleUnlock() override;
|
2012-12-20 19:05:53 +00:00
|
|
|
|
2014-02-28 10:00:38 +00:00
|
|
|
private:
|
2015-05-25 14:57:35 +00:00
|
|
|
bool isBundleLocked() const;
|
2014-03-08 07:02:02 +00:00
|
|
|
void EmitInstToFragment(const MCInst &Inst, const MCSubtargetInfo &) override;
|
|
|
|
void EmitInstToData(const MCInst &Inst, const MCSubtargetInfo &) override;
|
2014-02-28 10:00:38 +00:00
|
|
|
|
2012-12-07 15:50:40 +00:00
|
|
|
void fixSymbolsInTLSFixups(const MCExpr *expr);
|
|
|
|
|
2015-04-12 23:42:25 +00:00
|
|
|
/// \brief Merge the content of the fragment \p EF into the fragment \p DF.
|
2015-06-17 22:01:28 +00:00
|
|
|
void mergeFragment(MCDataFragment *, MCDataFragment *);
|
2015-04-12 23:42:25 +00:00
|
|
|
|
2013-10-16 01:05:45 +00:00
|
|
|
bool SeenIdent;
|
|
|
|
|
2015-04-12 23:42:25 +00:00
|
|
|
/// BundleGroups - The stack of fragments holding the bundle-locked
|
|
|
|
/// instructions.
|
|
|
|
llvm::SmallVector<MCDataFragment *, 4> BundleGroups;
|
2012-12-07 15:50:40 +00:00
|
|
|
};
|
|
|
|
|
2013-10-05 16:42:21 +00:00
|
|
|
MCELFStreamer *createARMELFStreamer(MCContext &Context, MCAsmBackend &TAB,
|
2015-04-14 22:14:34 +00:00
|
|
|
raw_pwrite_stream &OS,
|
|
|
|
MCCodeEmitter *Emitter, bool RelaxAll,
|
|
|
|
bool IsThumb);
|
2013-10-05 16:42:21 +00:00
|
|
|
|
2012-12-07 15:50:40 +00:00
|
|
|
} // end namespace llvm
|
|
|
|
|
|
|
|
#endif
|