LLVM  12.0.0git
Go to the documentation of this file.
1 //==- HexagonMCExpr.h - Hexagon specific MC expression classes --*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
12 #include "llvm/MC/MCExpr.h"
14 namespace llvm {
15 class HexagonMCExpr : public MCTargetExpr {
16 public:
17  static HexagonMCExpr *create(MCExpr const *Expr, MCContext &Ctx);
18  void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override;
19  bool evaluateAsRelocatableImpl(MCValue &Res, const MCAsmLayout *Layout,
20  const MCFixup *Fixup) const override;
21  void visitUsedExpr(MCStreamer &Streamer) const override;
22  MCFragment *findAssociatedFragment() const override;
23  void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override;
24  static bool classof(MCExpr const *E);
25  MCExpr const *getExpr() const;
26  void setMustExtend(bool Val = true);
27  bool mustExtend() const;
28  void setMustNotExtend(bool Val = true);
29  bool mustNotExtend() const;
30  void setS27_2_reloc(bool Val = true);
31  bool s27_2_reloc() const;
32  void setSignMismatch(bool Val = true);
33  bool signMismatch() const;
35 private:
36  HexagonMCExpr(MCExpr const *Expr);
37  MCExpr const *Expr;
38  bool MustNotExtend;
39  bool MustExtend;
40  bool S27_2_reloc;
41  bool SignMismatch;
42 };
43 } // end namespace llvm
void setMustExtend(bool Val=true)
This class represents lattice values for constants.
Definition: AllocatorList.h:23
This represents an "assembler immediate".
Definition: MCValue.h:37
bool s27_2_reloc() const
void setMustNotExtend(bool Val=true)
Encode information on a single operation to perform on a byte sequence (e.g., an encoded instruction)...
Definition: MCFixup.h:82
bool evaluateAsRelocatableImpl(MCValue &Res, const MCAsmLayout *Layout, const MCFixup *Fixup) const override
Encapsulates the layout of an assembly file at a particular point in time.
Definition: MCAsmLayout.h:28
MCFragment * findAssociatedFragment() const override
Base class for the full range of assembler expressions which are needed for parsing.
Definition: MCExpr.h:35
This is an extension point for target-specific MCExpr subclasses to implement.
Definition: MCExpr.h:644
static bool classof(MCExpr const *E)
Context object for machine code objects.
Definition: MCContext.h:67
void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override
void setS27_2_reloc(bool Val=true)
This class is intended to be used as a base class for asm properties and features specific to the tar...
Definition: MCAsmInfo.h:56
Streaming machine code generation interface.
Definition: MCStreamer.h:196
MCExpr const * getExpr() const
static HexagonMCExpr * create(MCExpr const *Expr, MCContext &Ctx)
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override
void setSignMismatch(bool Val=true)
bool mustNotExtend() const
PowerPC TLS Dynamic Call Fixup
bool signMismatch() const
void visitUsedExpr(MCStreamer &Streamer) const override
bool mustExtend() const
This class implements an extremely fast bulk output stream that can only output to a stream...
Definition: raw_ostream.h:46