LLVM  8.0.0svn
Go to the documentation of this file.
1 //===-- AVRMCExpr.h - AVR specific MC expression classes --------*- C++ -*-===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
10 #ifndef LLVM_AVR_MCEXPR_H
11 #define LLVM_AVR_MCEXPR_H
13 #include "llvm/MC/MCExpr.h"
17 namespace llvm {
19 /// A expression in AVR machine code.
20 class AVRMCExpr : public MCTargetExpr {
21 public:
22  /// Specifies the type of an expression.
23  enum VariantKind {
26  VK_AVR_HI8, ///< Corresponds to `hi8()`.
27  VK_AVR_LO8, ///< Corresponds to `lo8()`.
28  VK_AVR_HH8, ///< Corresponds to `hlo8() and hh8()`.
29  VK_AVR_HHI8, ///< Corresponds to `hhi8()`.
31  VK_AVR_PM_LO8, ///< Corresponds to `pm_lo8()`.
32  VK_AVR_PM_HI8, ///< Corresponds to `pm_hi8()`.
33  VK_AVR_PM_HH8, ///< Corresponds to `pm_hh8()`.
35  VK_AVR_LO8_GS, ///< Corresponds to `lo8(gs())`.
36  VK_AVR_HI8_GS, ///< Corresponds to `hi8(gs())`.
37  VK_AVR_GS, ///< Corresponds to `gs()`.
38  };
40 public:
41  /// Creates an AVR machine code expression.
42  static const AVRMCExpr *create(VariantKind Kind, const MCExpr *Expr,
43  bool isNegated, MCContext &Ctx);
45  /// Gets the type of the expression.
46  VariantKind getKind() const { return Kind; }
47  /// Gets the name of the expression.
48  const char *getName() const;
49  const MCExpr *getSubExpr() const { return SubExpr; }
50  /// Gets the fixup which corresponds to the expression.
51  AVR::Fixups getFixupKind() const;
52  /// Evaluates the fixup as a constant value.
53  bool evaluateAsConstant(int64_t &Result) const;
55  bool isNegated() const { return Negated; }
56  void setNegated(bool negated = true) { Negated = negated; }
58  void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override;
59  bool evaluateAsRelocatableImpl(MCValue &Res, const MCAsmLayout *Layout,
60  const MCFixup *Fixup) const override;
62  void visitUsedExpr(MCStreamer &streamer) const override;
64  MCFragment *findAssociatedFragment() const override {
66  }
68  void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {}
70  static bool classof(const MCExpr *E) {
71  return E->getKind() == MCExpr::Target;
72  }
74 public:
77 private:
78  int64_t evaluateAsInt64(int64_t Value) const;
80  const VariantKind Kind;
81  const MCExpr *SubExpr;
82  bool Negated;
84 private:
85  explicit AVRMCExpr(VariantKind Kind, const MCExpr *Expr, bool Negated)
86  : Kind(Kind), SubExpr(Expr), Negated(Negated) {}
87  ~AVRMCExpr() {}
88 };
90 } // end namespace llvm
92 #endif // LLVM_AVR_MCEXPR_H
This class represents lattice values for constants.
Definition: AllocatorList.h:24
This represents an "assembler immediate".
Definition: MCValue.h:40
Corresponds to gs().
Definition: AVRMCExpr.h:37
VariantKind getKind() const
Gets the type of the expression.
Definition: AVRMCExpr.h:46
Encode information on a single operation to perform on a byte sequence (e.g., an encoded instruction)...
Definition: MCFixup.h:74
void visitUsedExpr(MCStreamer &streamer) const override
Definition: AVRMCExpr.cpp:188
Specifies the type of an expression.
Definition: AVRMCExpr.h:23
amdgpu Simplify well known AMD library false Value Value const Twine & Name
Encapsulates the layout of an assembly file at a particular point in time.
Definition: MCAsmLayout.h:29
A expression in AVR machine code.
Definition: AVRMCExpr.h:20
Base class for the full range of assembler expressions which are needed for parsing.
Definition: MCExpr.h:36
This is an extension point for target-specific MCExpr subclasses to implement.
Definition: MCExpr.h:581
static bool classof(const MCExpr *E)
Definition: AVRMCExpr.h:70
Context object for machine code objects.
Definition: MCContext.h:63
void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override
Definition: AVRMCExpr.h:68
const MCExpr * getSubExpr() const
Definition: AVRMCExpr.h:49
void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override
Definition: AVRMCExpr.cpp:44
AVR::Fixups getFixupKind() const
Gets the fixup which corresponds to the expression.
Definition: AVRMCExpr.cpp:145
void setNegated(bool negated=true)
Definition: AVRMCExpr.h:56
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:189
Corresponds to hlo8() and hh8().
Definition: AVRMCExpr.h:28
Corresponds to pm_lo8().
Definition: AVRMCExpr.h:31
bool evaluateAsConstant(int64_t &Result) const
Evaluates the fixup as a constant value.
Definition: AVRMCExpr.cpp:55
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
const char * getName() const
Gets the name of the expression.
Definition: AVRMCExpr.cpp:192
Corresponds to lo8(gs()).
Definition: AVRMCExpr.h:35
Corresponds to hi8().
Definition: AVRMCExpr.h:26
PowerPC TLS Dynamic Call Fixup
Corresponds to pm_hh8().
Definition: AVRMCExpr.h:33
Corresponds to hi8(gs()).
Definition: AVRMCExpr.h:36
ExprKind getKind() const
Definition: MCExpr.h:73
The set of supported fixups.
Definition: AVRFixupKinds.h:27
MCFragment * findAssociatedFragment() const
Find the "associated section" for this expression, which is currently defined as the absolute section...
Definition: MCExpr.cpp:862
bool evaluateAsRelocatableImpl(MCValue &Res, const MCAsmLayout *Layout, const MCFixup *Fixup) const override
Definition: AVRMCExpr.cpp:72
Corresponds to pm_hi8().
Definition: AVRMCExpr.h:32
MCFragment * findAssociatedFragment() const override
Definition: AVRMCExpr.h:64
bool isNegated() const
Definition: AVRMCExpr.h:55
Corresponds to lo8().
Definition: AVRMCExpr.h:27
static const AVRMCExpr * create(VariantKind Kind, const MCExpr *Expr, bool isNegated, MCContext &Ctx)
Creates an AVR machine code expression.
Definition: AVRMCExpr.cpp:39
static VariantKind getKindByName(StringRef Name)
Definition: AVRMCExpr.cpp:203
LLVM Value Representation.
Definition: Value.h:73
This class implements an extremely fast bulk output stream that can only output to a stream...
Definition: raw_ostream.h:46
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:49
Corresponds to hhi8().
Definition: AVRMCExpr.h:29
Target specific expression.
Definition: MCExpr.h:43