LLVM 20.0.0git
|
#include "Target/Hexagon/MCTargetDesc/HexagonMCExpr.h"
Public Member Functions | |
void | printImpl (raw_ostream &OS, const MCAsmInfo *MAI) const override |
bool | evaluateAsRelocatableImpl (MCValue &Res, const MCAssembler *Asm, const MCFixup *Fixup) const override |
void | visitUsedExpr (MCStreamer &Streamer) const override |
MCFragment * | findAssociatedFragment () const override |
void | fixELFSymbolsInTLSFixups (MCAssembler &Asm) const override |
MCExpr const * | getExpr () const |
void | setMustExtend (bool Val=true) |
bool | mustExtend () const |
void | setMustNotExtend (bool Val=true) |
bool | mustNotExtend () const |
void | setS27_2_reloc (bool Val=true) |
bool | s27_2_reloc () const |
void | setSignMismatch (bool Val=true) |
bool | signMismatch () const |
Public Member Functions inherited from llvm::MCTargetExpr | |
virtual void | printImpl (raw_ostream &OS, const MCAsmInfo *MAI) const =0 |
virtual bool | evaluateAsRelocatableImpl (MCValue &Res, const MCAssembler *Asm, const MCFixup *Fixup) const =0 |
virtual bool | isEqualTo (const MCExpr *x) const |
virtual bool | isSymbolUsedInExpression (const MCSymbol *Sym) const |
virtual bool | inlineAssignedExpr () const |
virtual void | visitUsedExpr (MCStreamer &Streamer) const =0 |
virtual MCFragment * | findAssociatedFragment () const =0 |
virtual void | fixELFSymbolsInTLSFixups (MCAssembler &) const =0 |
Public Member Functions inherited from llvm::MCExpr | |
MCExpr (const MCExpr &)=delete | |
MCExpr & | operator= (const MCExpr &)=delete |
ExprKind | getKind () const |
SMLoc | getLoc () const |
void | print (raw_ostream &OS, const MCAsmInfo *MAI, bool InParens=false) const |
void | dump () const |
bool | isSymbolUsedInExpression (const MCSymbol *Sym) const |
Returns whether the given symbol is used anywhere in the expression or subexpressions. | |
bool | evaluateAsAbsolute (int64_t &Res, const MCAssembler &Asm, const SectionAddrMap &Addrs) const |
Try to evaluate the expression to an absolute value. | |
bool | evaluateAsAbsolute (int64_t &Res) const |
bool | evaluateAsAbsolute (int64_t &Res, const MCAssembler &Asm) const |
bool | evaluateAsAbsolute (int64_t &Res, const MCAssembler *Asm) const |
bool | evaluateKnownAbsolute (int64_t &Res, const MCAssembler &Asm) const |
Aggressive variant of evaluateAsRelocatable when relocations are unavailable (e.g. | |
bool | evaluateAsRelocatable (MCValue &Res, const MCAssembler *Asm, const MCFixup *Fixup) const |
Try to evaluate the expression to a relocatable value, i.e. | |
bool | evaluateAsValue (MCValue &Res, const MCAssembler &Asm) const |
Try to evaluate the expression to the form (a - b + constant) where neither a nor b are variables. | |
MCFragment * | findAssociatedFragment () const |
Find the "associated section" for this expression, which is currently defined as the absolute section for constants, or otherwise the section associated with the first defined symbol in the expression. | |
Static Public Member Functions | |
static HexagonMCExpr * | create (MCExpr const *Expr, MCContext &Ctx) |
Static Public Member Functions inherited from llvm::MCTargetExpr | |
static bool | classof (const MCExpr *E) |
Additional Inherited Members | |
Public Types inherited from llvm::MCExpr | |
enum | ExprKind : uint8_t { Binary , Constant , SymbolRef , Unary , Target } |
Protected Member Functions inherited from llvm::MCTargetExpr | |
MCTargetExpr () | |
virtual | ~MCTargetExpr ()=default |
Protected Member Functions inherited from llvm::MCExpr | |
MCExpr (ExprKind Kind, SMLoc Loc, unsigned SubclassData=0) | |
bool | evaluateAsRelocatableImpl (MCValue &Res, const MCAssembler *Asm, const MCFixup *Fixup, const SectionAddrMap *Addrs, bool InSet) const |
unsigned | getSubclassData () const |
Definition at line 15 of file HexagonMCExpr.h.
|
static |
Definition at line 23 of file HexagonMCExpr.cpp.
Referenced by llvm::HexagonAsmPrinter::EmitSled(), GetSymbolRef(), llvm::HexagonLowerToMC(), llvm::HexagonAsmPrinter::HexagonProcessInstruction(), and ScaleVectorOffset().
|
overridevirtual |
Implements llvm::MCTargetExpr.
Definition at line 27 of file HexagonMCExpr.cpp.
References llvm::MCExpr::evaluateAsRelocatable(), and Fixup.
|
overridevirtual |
Implements llvm::MCTargetExpr.
Definition at line 37 of file HexagonMCExpr.cpp.
References llvm::MCExpr::findAssociatedFragment().
|
overridevirtual |
Implements llvm::MCTargetExpr.
Definition at line 78 of file HexagonMCExpr.cpp.
References fixELFSymbolsInTLSFixupsImpl(), and getExpr().
Definition at line 83 of file HexagonMCExpr.cpp.
Referenced by fixELFSymbolsInTLSFixups().
bool HexagonMCExpr::mustExtend | ( | ) | const |
Definition at line 90 of file HexagonMCExpr.cpp.
Referenced by llvm::HexagonMCInstrInfo::mustExtend().
bool HexagonMCExpr::mustNotExtend | ( | ) | const |
Definition at line 95 of file HexagonMCExpr.cpp.
Referenced by llvm::HexagonMCInstrInfo::mustNotExtend().
|
overridevirtual |
Implements llvm::MCTargetExpr.
Definition at line 106 of file HexagonMCExpr.cpp.
References OS, and llvm::MCExpr::print().
bool HexagonMCExpr::s27_2_reloc | ( | ) | const |
Definition at line 97 of file HexagonMCExpr.cpp.
Referenced by llvm::HexagonMCInstrInfo::s27_2_reloc().
Definition at line 85 of file HexagonMCExpr.cpp.
References assert().
Referenced by llvm::HexagonMCInstrInfo::setMustExtend().
Definition at line 91 of file HexagonMCExpr.cpp.
References assert().
Referenced by llvm::HexagonMCInstrInfo::setMustNotExtend().
Definition at line 98 of file HexagonMCExpr.cpp.
Referenced by llvm::HexagonMCInstrInfo::setS27_2_reloc().
Definition at line 110 of file HexagonMCExpr.cpp.
bool HexagonMCExpr::signMismatch | ( | ) | const |
Definition at line 114 of file HexagonMCExpr.cpp.
|
overridevirtual |
Implements llvm::MCTargetExpr.
Definition at line 33 of file HexagonMCExpr.cpp.
References llvm::MCStreamer::visitUsedExpr().