LLVM
8.0.1
|
#include "Target/Mips/MCTargetDesc/MipsELFStreamer.h"
Public Member Functions | |
MipsELFStreamer (MCContext &Context, std::unique_ptr< MCAsmBackend > MAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter) | |
void | EmitInstruction (const MCInst &Inst, const MCSubtargetInfo &STI, bool=false) override |
Overriding this function allows us to add arbitrary behaviour before the Inst is actually emitted. More... | |
void | EmitLabel (MCSymbol *Symbol, SMLoc Loc=SMLoc()) override |
Overriding this function allows us to record all labels that should be marked as microMIPS. More... | |
void | SwitchSection (MCSection *Section, const MCExpr *Subsection=nullptr) override |
Overriding this function allows us to dismiss all labels that are candidates for marking as microMIPS when .section directive is processed. More... | |
void | EmitValueImpl (const MCExpr *Value, unsigned Size, SMLoc Loc) override |
Overriding these functions allows us to dismiss all labels that are candidates for marking as microMIPS when .word/.long/.4byte etc directives are emitted. More... | |
void | EmitIntValue (uint64_t Value, unsigned Size) override |
Special case of EmitValue that avoids the client having to pass in a MCExpr for constant integers. More... | |
void | EmitCFIStartProcImpl (MCDwarfFrameInfo &Frame) override |
void | EmitCFIEndProcImpl (MCDwarfFrameInfo &Frame) override |
MCSymbol * | EmitCFILabel () override |
When emitting an object file, create and emit a real label. More... | |
void | EmitMipsOptionRecords () |
Emits all the option records stored up until the point it's called. More... | |
void | createPendingLabelRelocs () |
Mark labels as microMIPS, if necessary for the subtarget. More... | |
Public Member Functions inherited from llvm::MCELFStreamer | |
MCELFStreamer (MCContext &Context, std::unique_ptr< MCAsmBackend > TAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter) | |
~MCELFStreamer () override=default | |
void | reset () override |
state management More... | |
void | InitSections (bool NoExecStack) override |
Create the default sections and set the initial one. More... | |
void | ChangeSection (MCSection *Section, const MCExpr *Subsection) override |
Update streamer for a new active section. More... | |
void | EmitLabel (MCSymbol *Symbol, SMLoc Loc, MCFragment *F) override |
void | EmitAssemblerFlag (MCAssemblerFlag Flag) override |
Note in the output the specified Flag . More... | |
void | EmitThumbFunc (MCSymbol *Func) override |
Note in the output that the specified Func is a Thumb mode function (ARM target only). More... | |
void | EmitWeakReference (MCSymbol *Alias, const MCSymbol *Symbol) override |
Emit an weak reference from Alias to Symbol . More... | |
bool | EmitSymbolAttribute (MCSymbol *Symbol, MCSymbolAttr Attribute) override |
Add the given Attribute to Symbol . More... | |
void | EmitSymbolDesc (MCSymbol *Symbol, unsigned DescValue) override |
Set the DescValue for the Symbol . More... | |
void | EmitCommonSymbol (MCSymbol *Symbol, uint64_t Size, unsigned ByteAlignment) override |
Emit a common symbol. More... | |
void | emitELFSize (MCSymbol *Symbol, const MCExpr *Value) override |
Emit an ELF .size directive. More... | |
void | emitELFSymverDirective (StringRef AliasName, const MCSymbol *Aliasee) override |
Emit an ELF .symver directive. More... | |
void | EmitLocalCommonSymbol (MCSymbol *Symbol, uint64_t Size, unsigned ByteAlignment) override |
Emit a local common (.lcomm) symbol. More... | |
void | EmitZerofill (MCSection *Section, MCSymbol *Symbol=nullptr, uint64_t Size=0, unsigned ByteAlignment=0, SMLoc L=SMLoc()) override |
Emit the zerofill section and an optional symbol. More... | |
void | EmitTBSSSymbol (MCSection *Section, MCSymbol *Symbol, uint64_t Size, unsigned ByteAlignment=0) override |
Emit a thread local bss (.tbss) symbol. More... | |
void | EmitIdent (StringRef IdentString) override |
Emit the "identifiers" directive. More... | |
void | EmitValueToAlignment (unsigned, int64_t, unsigned, unsigned) override |
Emit some number of copies of Value until the byte alignment ByteAlignment is reached. More... | |
void | emitCGProfileEntry (const MCSymbolRefExpr *From, const MCSymbolRefExpr *To, uint64_t Count) override |
void | FinishImpl () override |
Streamer specific finalization. More... | |
void | EmitBundleAlignMode (unsigned AlignPow2) override |
Set the bundle alignment mode from now on in the section. More... | |
void | EmitBundleLock (bool AlignToEnd) override |
The following instructions are a bundle-locked group. More... | |
void | EmitBundleUnlock () override |
Ends a bundle-locked group. More... | |
Public Member Functions inherited from llvm::MCObjectStreamer | |
void | reset () override |
state management More... | |
bool | isIntegratedAssemblerRequired () const override |
Object streamers require the integrated assembler. More... | |
void | EmitFrames (MCAsmBackend *MAB) |
void | EmitCFISections (bool EH, bool Debug) override |
MCFragment * | getCurrentFragment () const |
void | insert (MCFragment *F) |
MCDataFragment * | getOrCreateDataFragment (const MCSubtargetInfo *STI=nullptr) |
Get a data fragment to write into, creating a new one if the current fragment is not a data fragment. More... | |
MCPaddingFragment * | getOrCreatePaddingFragment () |
void | visitUsedSymbol (const MCSymbol &Sym) override |
void | flushPendingLabels () |
Create a dummy fragment to assign any pending labels. More... | |
MCAssembler & | getAssembler () |
MCAssembler * | getAssemblerPtr () override |
void | EmitAssignment (MCSymbol *Symbol, const MCExpr *Value) override |
Emit an assignment of Value to Symbol . More... | |
void | EmitULEB128Value (const MCExpr *Value) override |
void | EmitSLEB128Value (const MCExpr *Value) override |
void | EmitWeakReference (MCSymbol *Alias, const MCSymbol *Symbol) override |
Emit an weak reference from Alias to Symbol . More... | |
void | ChangeSection (MCSection *Section, const MCExpr *Subsection) override |
Update streamer for a new active section. More... | |
void | EmitBundleAlignMode (unsigned AlignPow2) override |
Set the bundle alignment mode from now on in the section. More... | |
void | EmitBundleLock (bool AlignToEnd) override |
The following instructions are a bundle-locked group. More... | |
void | EmitBundleUnlock () override |
Ends a bundle-locked group. More... | |
void | EmitBytes (StringRef Data) override |
Emit the bytes in Data into the output. More... | |
void | EmitValueToAlignment (unsigned ByteAlignment, int64_t Value=0, unsigned ValueSize=1, unsigned MaxBytesToEmit=0) override |
Emit some number of copies of Value until the byte alignment ByteAlignment is reached. More... | |
void | EmitCodeAlignment (unsigned ByteAlignment, unsigned MaxBytesToEmit=0) override |
Emit nops until the byte alignment ByteAlignment is reached. More... | |
void | emitValueToOffset (const MCExpr *Offset, unsigned char Value, SMLoc Loc) override |
Emit some number of copies of Value until the byte offset Offset is reached. More... | |
void | EmitCodePaddingBasicBlockStart (const MCCodePaddingContext &Context) override |
void | EmitCodePaddingBasicBlockEnd (const MCCodePaddingContext &Context) override |
void | EmitDwarfLocDirective (unsigned FileNo, unsigned Line, unsigned Column, unsigned Flags, unsigned Isa, unsigned Discriminator, StringRef FileName) override |
This implements the DWARF2 '.loc fileno lineno ...' assembler directive. More... | |
void | EmitDwarfAdvanceLineAddr (int64_t LineDelta, const MCSymbol *LastLabel, const MCSymbol *Label, unsigned PointerSize) |
void | EmitDwarfAdvanceFrameAddr (const MCSymbol *LastLabel, const MCSymbol *Label) |
void | EmitCVLocDirective (unsigned FunctionId, unsigned FileNo, unsigned Line, unsigned Column, bool PrologueEnd, bool IsStmt, StringRef FileName, SMLoc Loc) override |
This implements the CodeView '.cv_loc' assembler directive. More... | |
void | EmitCVLinetableDirective (unsigned FunctionId, const MCSymbol *Begin, const MCSymbol *End) override |
This implements the CodeView '.cv_linetable' assembler directive. More... | |
void | EmitCVInlineLinetableDirective (unsigned PrimaryFunctionId, unsigned SourceFileId, unsigned SourceLineNum, const MCSymbol *FnStartSym, const MCSymbol *FnEndSym) override |
This implements the CodeView '.cv_inline_linetable' assembler directive. More... | |
void | EmitCVDefRangeDirective (ArrayRef< std::pair< const MCSymbol *, const MCSymbol *>> Ranges, StringRef FixedSizePortion) override |
This implements the CodeView '.cv_def_range' assembler directive. More... | |
void | EmitCVStringTableDirective () override |
This implements the CodeView '.cv_stringtable' assembler directive. More... | |
void | EmitCVFileChecksumsDirective () override |
This implements the CodeView '.cv_filechecksums' assembler directive. More... | |
void | EmitCVFileChecksumOffsetDirective (unsigned FileNo) override |
This implements the CodeView '.cv_filechecksumoffset' assembler directive. More... | |
void | EmitDTPRel32Value (const MCExpr *Value) override |
Emit the expression Value into the output as a dtprel (32-bit DTP relative) value. More... | |
void | EmitDTPRel64Value (const MCExpr *Value) override |
Emit the expression Value into the output as a dtprel (64-bit DTP relative) value. More... | |
void | EmitTPRel32Value (const MCExpr *Value) override |
Emit the expression Value into the output as a tprel (32-bit TP relative) value. More... | |
void | EmitTPRel64Value (const MCExpr *Value) override |
Emit the expression Value into the output as a tprel (64-bit TP relative) value. More... | |
void | EmitGPRel32Value (const MCExpr *Value) override |
Emit the expression Value into the output as a gprel32 (32-bit GP relative) value. More... | |
void | EmitGPRel64Value (const MCExpr *Value) override |
Emit the expression Value into the output as a gprel64 (64-bit GP relative) value. More... | |
bool | EmitRelocDirective (const MCExpr &Offset, StringRef Name, const MCExpr *Expr, SMLoc Loc, const MCSubtargetInfo &STI) override |
Emit a .reloc directive. More... | |
void | emitFill (const MCExpr &NumBytes, uint64_t FillValue, SMLoc Loc=SMLoc()) override |
Emit Size bytes worth of the value specified by FillValue . More... | |
void | emitFill (const MCExpr &NumValues, int64_t Size, int64_t Expr, SMLoc Loc=SMLoc()) override |
Emit NumValues copies of Size bytes. More... | |
void | EmitFileDirective (StringRef Filename) override |
Switch to a new logical file. More... | |
void | EmitAddrsig () override |
void | EmitAddrsigSym (const MCSymbol *Sym) override |
void | FinishImpl () override |
Streamer specific finalization. More... | |
void | emitAbsoluteSymbolDiff (const MCSymbol *Hi, const MCSymbol *Lo, unsigned Size) override |
Emit the absolute difference between two symbols if possible. More... | |
void | emitAbsoluteSymbolDiffAsULEB128 (const MCSymbol *Hi, const MCSymbol *Lo) override |
Emit the absolute difference between two symbols encoded with ULEB128. More... | |
bool | mayHaveInstructions (MCSection &Sec) const override |
Public Member Functions inherited from llvm::MCStreamer | |
MCStreamer (const MCStreamer &)=delete | |
MCStreamer & | operator= (const MCStreamer &)=delete |
virtual | ~MCStreamer () |
void | visitUsedExpr (const MCExpr &Expr) |
void | setTargetStreamer (MCTargetStreamer *TS) |
MCContext & | getContext () const |
void | setUseAssemblerInfoForParsing (bool v) |
bool | getUseAssemblerInfoForParsing () |
MCTargetStreamer * | getTargetStreamer () |
WinEH::FrameInfo * | EnsureValidWinFrameInfo (SMLoc Loc) |
Retreive the current frame info if one is available and it is not yet closed. More... | |
unsigned | getNumFrameInfos () |
ArrayRef< MCDwarfFrameInfo > | getDwarfFrameInfos () const |
bool | hasUnfinishedDwarfFrameInfo () |
unsigned | getNumWinFrameInfos () |
ArrayRef< std::unique_ptr< WinEH::FrameInfo > > | getWinFrameInfos () const |
void | generateCompactUnwindEncodings (MCAsmBackend *MAB) |
unsigned | EmitDwarfFileDirective (unsigned FileNo, StringRef Directory, StringRef Filename, MD5::MD5Result *Checksum=nullptr, Optional< StringRef > Source=None, unsigned CUID=0) |
Associate a filename with a specified logical file number. More... | |
virtual Expected< unsigned > | tryEmitDwarfFileDirective (unsigned FileNo, StringRef Directory, StringRef Filename, MD5::MD5Result *Checksum=nullptr, Optional< StringRef > Source=None, unsigned CUID=0) |
Associate a filename with a specified logical file number. More... | |
virtual void | emitDwarfFile0Directive (StringRef Directory, StringRef Filename, MD5::MD5Result *Checksum, Optional< StringRef > Source, unsigned CUID=0) |
Specify the "root" file of the compilation, using the ".file 0" extension. More... | |
virtual void | EmitCFIBKeyFrame () |
virtual bool | EmitCVFileDirective (unsigned FileNo, StringRef Filename, ArrayRef< uint8_t > Checksum, unsigned ChecksumKind) |
Associate a filename with a specified logical file number, and also specify that file's checksum information. More... | |
virtual bool | EmitCVFuncIdDirective (unsigned FunctionId) |
Introduces a function id for use with .cv_loc. More... | |
virtual bool | EmitCVInlineSiteIdDirective (unsigned FunctionId, unsigned IAFunc, unsigned IAFile, unsigned IALine, unsigned IACol, SMLoc Loc) |
Introduces an inline call site id for use with .cv_loc. More... | |
virtual void | EmitCVFPOData (const MCSymbol *ProcSym, SMLoc Loc={}) |
This implements the CodeView '.cv_fpo_data' assembler directive. More... | |
virtual MCSymbol * | getDwarfLineTableSymbol (unsigned CUID) |
void | EmitCFIStartProc (bool IsSimple, SMLoc Loc=SMLoc()) |
void | EmitCFIEndProc () |
virtual void | EmitCFIDefCfa (int64_t Register, int64_t Offset) |
virtual void | EmitCFIDefCfaOffset (int64_t Offset) |
virtual void | EmitCFIDefCfaRegister (int64_t Register) |
virtual void | EmitCFIOffset (int64_t Register, int64_t Offset) |
virtual void | EmitCFIPersonality (const MCSymbol *Sym, unsigned Encoding) |
virtual void | EmitCFILsda (const MCSymbol *Sym, unsigned Encoding) |
virtual void | EmitCFIRememberState () |
virtual void | EmitCFIRestoreState () |
virtual void | EmitCFISameValue (int64_t Register) |
virtual void | EmitCFIRestore (int64_t Register) |
virtual void | EmitCFIRelOffset (int64_t Register, int64_t Offset) |
virtual void | EmitCFIAdjustCfaOffset (int64_t Adjustment) |
virtual void | EmitCFIEscape (StringRef Values) |
virtual void | EmitCFIReturnColumn (int64_t Register) |
virtual void | EmitCFIGnuArgsSize (int64_t Size) |
virtual void | EmitCFISignalFrame () |
virtual void | EmitCFIUndefined (int64_t Register) |
virtual void | EmitCFIRegister (int64_t Register1, int64_t Register2) |
virtual void | EmitCFIWindowSave () |
virtual void | EmitCFINegateRAState () |
virtual void | EmitWinCFIStartProc (const MCSymbol *Symbol, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIEndProc (SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIFuncletOrFuncEnd (SMLoc Loc=SMLoc()) |
This is used on platforms, such as Windows on ARM64, that require function or funclet sizes to be emitted in .xdata before the End marker is emitted for the frame. More... | |
virtual void | EmitWinCFIStartChained (SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIEndChained (SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIPushReg (unsigned Register, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFISetFrame (unsigned Register, unsigned Offset, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIAllocStack (unsigned Size, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFISaveReg (unsigned Register, unsigned Offset, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFISaveXMM (unsigned Register, unsigned Offset, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIPushFrame (bool Code, SMLoc Loc=SMLoc()) |
virtual void | EmitWinCFIEndProlog (SMLoc Loc=SMLoc()) |
virtual void | EmitWinEHHandler (const MCSymbol *Sym, bool Unwind, bool Except, SMLoc Loc=SMLoc()) |
virtual void | EmitWinEHHandlerData (SMLoc Loc=SMLoc()) |
MCSection * | getAssociatedPDataSection (const MCSection *TextSec) |
Get the .pdata section used for the given section. More... | |
MCSection * | getAssociatedXDataSection (const MCSection *TextSec) |
Get the .xdata section used for the given section. More... | |
virtual void | EmitSyntaxDirective () |
void | EmitRawText (const Twine &String) |
If this file is backed by a assembly streamer, this dumps the specified string in the output .s file. More... | |
void | Finish () |
Finish emission of machine code. More... | |
virtual bool | isVerboseAsm () const |
Return true if this streamer supports verbose assembly and if it is enabled. More... | |
virtual bool | hasRawTextSupport () const |
Return true if this asm streamer supports emitting unformatted text to the .s file with EmitRawText. More... | |
virtual void | AddComment (const Twine &T, bool EOL=true) |
Add a textual comment. More... | |
virtual raw_ostream & | GetCommentOS () |
Return a raw_ostream that comments can be written to. More... | |
virtual void | emitRawComment (const Twine &T, bool TabPrefix=true) |
Print T and prefix it with the comment string (normally #) and optionally a tab. More... | |
virtual void | addExplicitComment (const Twine &T) |
Add explicit comment T. More... | |
virtual void | emitExplicitComments () |
Emit added explicit comments. More... | |
virtual void | AddBlankLine () |
AddBlankLine - Emit a blank line to a .s file to pretty it up. More... | |
MCSectionSubPair | getCurrentSection () const |
Return the current section that the streamer is emitting code to. More... | |
MCSection * | getCurrentSectionOnly () const |
MCSectionSubPair | getPreviousSection () const |
Return the previous section that the streamer is emitting code to. More... | |
unsigned | GetSymbolOrder (const MCSymbol *Sym) const |
Returns an index to represent the order a symbol was emitted in. More... | |
void | PushSection () |
Save the current and previous section on the section stack. More... | |
bool | PopSection () |
Restore the current and previous section from the section stack. More... | |
bool | SubSection (const MCExpr *Subsection) |
void | SwitchSectionNoChange (MCSection *Section, const MCExpr *Subsection=nullptr) |
Set the current section where code is being emitted to Section . More... | |
MCSymbol * | endSection (MCSection *Section) |
void | AssignFragment (MCSymbol *Symbol, MCFragment *Fragment) |
Sets the symbol's section. More... | |
virtual void | EmitEHSymAttributes (const MCSymbol *Symbol, MCSymbol *EHSymbol) |
virtual void | EmitLinkerOptions (ArrayRef< std::string > Kind) |
Emit the given list Options of strings as linker options into the output. More... | |
virtual void | EmitDataRegion (MCDataRegionType Kind) |
Note in the output the specified region Kind . More... | |
virtual void | EmitVersionMin (MCVersionMinType Type, unsigned Major, unsigned Minor, unsigned Update, VersionTuple SDKVersion) |
Specify the Mach-O minimum deployment target version. More... | |
virtual void | EmitBuildVersion (unsigned Platform, unsigned Major, unsigned Minor, unsigned Update, VersionTuple SDKVersion) |
Emit/Specify Mach-O build version command. More... | |
void | EmitVersionForTarget (const Triple &Target, const VersionTuple &SDKVersion) |
virtual void | BeginCOFFSymbolDef (const MCSymbol *Symbol) |
Start emitting COFF symbol definition. More... | |
virtual void | EmitCOFFSymbolStorageClass (int StorageClass) |
Emit the storage class of the symbol. More... | |
virtual void | EmitCOFFSymbolType (int Type) |
Emit the type of the symbol. More... | |
virtual void | EndCOFFSymbolDef () |
Marks the end of the symbol definition. More... | |
virtual void | EmitCOFFSafeSEH (MCSymbol const *Symbol) |
virtual void | EmitCOFFSymbolIndex (MCSymbol const *Symbol) |
Emits the symbol table index of a Symbol into the current section. More... | |
virtual void | EmitCOFFSectionIndex (MCSymbol const *Symbol) |
Emits a COFF section index. More... | |
virtual void | EmitCOFFSecRel32 (MCSymbol const *Symbol, uint64_t Offset) |
Emits a COFF section relative relocation. More... | |
virtual void | EmitCOFFImgRel32 (MCSymbol const *Symbol, int64_t Offset) |
Emits a COFF image relative relocation. More... | |
virtual void | EmitLOHDirective (MCLOHType Kind, const MCLOHArgs &Args) |
Emit a Linker Optimization Hint (LOH) directive. More... | |
virtual void | EmitBinaryData (StringRef Data) |
Functionally identical to EmitBytes. More... | |
void | EmitValue (const MCExpr *Value, unsigned Size, SMLoc Loc=SMLoc()) |
void | EmitULEB128IntValue (uint64_t Value) |
Special case of EmitULEB128Value that avoids the client having to pass in a MCExpr for constant integers. More... | |
void | EmitSLEB128IntValue (int64_t Value) |
Special case of EmitSLEB128Value that avoids the client having to pass in a MCExpr for constant integers. More... | |
void | EmitSymbolValue (const MCSymbol *Sym, unsigned Size, bool IsSectionRelative=false) |
Special case of EmitValue that avoids the client having to pass in a MCExpr for MCSymbols. More... | |
void | emitFill (uint64_t NumBytes, uint8_t FillValue) |
Emit NumBytes bytes worth of the value specified by FillValue. More... | |
void | EmitZeros (uint64_t NumBytes) |
Emit NumBytes worth of zeros. More... | |
Additional Inherited Members | |
Protected Member Functions inherited from llvm::MCObjectStreamer | |
MCObjectStreamer (MCContext &Context, std::unique_ptr< MCAsmBackend > TAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter) | |
~MCObjectStreamer () | |
bool | changeSectionImpl (MCSection *Section, const MCExpr *Subsection) |
void | flushPendingLabels (MCFragment *F, uint64_t FOffset=0) |
If any labels have been emitted but not assigned fragments, ensure that they get assigned, either to F if possible or to a new data fragment. More... | |
Protected Member Functions inherited from llvm::MCStreamer | |
MCStreamer (MCContext &Ctx) | |
WinEH::FrameInfo * | getCurrentWinFrameInfo () |
virtual void | EmitWindowsUnwindTables () |
virtual void | EmitRawTextImpl (StringRef String) |
EmitRawText - If this file is backed by an assembly streamer, this dumps the specified string in the output .s file. More... | |
bool | checkCVLocSection (unsigned FuncId, unsigned FileNo, SMLoc Loc) |
Returns true if the the .cv_loc directive is in the right section. More... | |
Definition at line 31 of file MipsELFStreamer.h.
MipsELFStreamer::MipsELFStreamer | ( | MCContext & | Context, |
std::unique_ptr< MCAsmBackend > | MAB, | ||
std::unique_ptr< MCObjectWriter > | OW, | ||
std::unique_ptr< MCCodeEmitter > | Emitter | ||
) |
Definition at line 26 of file MipsELFStreamer.cpp.
Referenced by llvm::createMipsELFStreamer().
void MipsELFStreamer::createPendingLabelRelocs | ( | ) |
Mark labels as microMIPS, if necessary for the subtarget.
Definition at line 73 of file MipsELFStreamer.cpp.
References llvm::MCObjectStreamer::getAssembler(), llvm::MCStreamer::getTargetStreamer(), llvm::MipsTargetELFStreamer::isMicroMipsEnabled(), llvm::MCAssembler::registerSymbol(), and llvm::ELF::STO_MIPS_MICROMIPS.
Referenced by llvm::MipsTargetELFStreamer::emitDirectiveInsn(), and EmitInstruction().
|
overridevirtual |
Reimplemented from llvm::MCObjectStreamer.
Definition at line 68 of file MipsELFStreamer.cpp.
References llvm::MCContext::createTempSymbol(), llvm::MCELFStreamer::EmitLabel(), llvm::MCDwarfFrameInfo::End, and llvm::MCStreamer::getContext().
|
overridevirtual |
When emitting an object file, create and emit a real label.
When emitting textual assembly, this should do nothing to avoid polluting our output.
Reimplemented from llvm::MCObjectStreamer.
Definition at line 62 of file MipsELFStreamer.cpp.
References llvm::MCContext::createTempSymbol(), llvm::MCELFStreamer::EmitLabel(), and llvm::MCStreamer::getContext().
|
overridevirtual |
Reimplemented from llvm::MCObjectStreamer.
Definition at line 57 of file MipsELFStreamer.cpp.
References llvm::MCDwarfFrameInfo::Begin, llvm::MCContext::createTempSymbol(), llvm::MCELFStreamer::EmitLabel(), and llvm::MCStreamer::getContext().
|
overridevirtual |
Overriding this function allows us to add arbitrary behaviour before the Inst
is actually emitted.
For example, we can inspect the operands and gather sufficient information that allows us to reason about the register usage for the translation unit.
Reimplemented from llvm::MCObjectStreamer.
Definition at line 37 of file MipsELFStreamer.cpp.
References Context, createPendingLabelRelocs(), llvm::MCObjectStreamer::EmitInstruction(), llvm::MCStreamer::getContext(), llvm::MCInst::getNumOperands(), llvm::MCInst::getOperand(), llvm::MCOperand::getReg(), llvm::MCContext::getRegisterInfo(), llvm::MCOperand::isReg(), Reg, and llvm::MipsRegInfoRecord::SetPhysRegUsed().
|
overridevirtual |
Special case of EmitValue that avoids the client having to pass in a MCExpr for constant integers.
EmitIntValue - Special case of EmitValue that avoids the client having to pass in a MCExpr for constant integers.
Reimplemented from llvm::MCStreamer.
Definition at line 106 of file MipsELFStreamer.cpp.
References llvm::MCStreamer::EmitIntValue().
Referenced by llvm::MipsRegInfoRecord::EmitMipsOptionRecord().
Overriding this function allows us to record all labels that should be marked as microMIPS.
Based on this data marking is done in EmitInstruction.
Reimplemented from llvm::MCELFStreamer.
Definition at line 89 of file MipsELFStreamer.cpp.
References llvm::MCELFStreamer::EmitLabel().
void MipsELFStreamer::EmitMipsOptionRecords | ( | ) |
Emits all the option records stored up until the point it's called.
Definition at line 111 of file MipsELFStreamer.cpp.
References I.
Referenced by llvm::MipsTargetELFStreamer::finish().
|
overridevirtual |
Overriding these functions allows us to dismiss all labels that are candidates for marking as microMIPS when .word/.long/.4byte etc directives are emitted.
Reimplemented from llvm::MCELFStreamer.
Definition at line 100 of file MipsELFStreamer.cpp.
References llvm::MCELFStreamer::EmitValueImpl().
|
overridevirtual |
Overriding this function allows us to dismiss all labels that are candidates for marking as microMIPS when .section directive is processed.
Reimplemented from llvm::MCStreamer.
Definition at line 94 of file MipsELFStreamer.cpp.
References llvm::MCStreamer::SwitchSection().
Referenced by llvm::MipsRegInfoRecord::EmitMipsOptionRecord().