blob: d1a4334ec640ad5770dd6ac2e7e988bec2e8bdf1 [file] [log] [blame]
Petar Jovanovica5da5882014-02-04 18:41:57 +00001//===-- MipsMCExpr.h - Mips 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//===----------------------------------------------------------------------===//
9
Benjamin Kramera7c40ef2014-08-13 16:26:38 +000010#ifndef LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSMCEXPR_H
11#define LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSMCEXPR_H
Petar Jovanovica5da5882014-02-04 18:41:57 +000012
Chandler Carruth442f7842014-03-04 10:07:28 +000013#include "llvm/MC/MCAsmLayout.h"
Petar Jovanovica5da5882014-02-04 18:41:57 +000014#include "llvm/MC/MCExpr.h"
15#include "llvm/MC/MCValue.h"
Petar Jovanovica5da5882014-02-04 18:41:57 +000016
17namespace llvm {
18
19class MipsMCExpr : public MCTargetExpr {
20public:
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000021 enum MipsExprKind {
22 MEK_None,
23 MEK_CALL_HI16,
24 MEK_CALL_LO16,
25 MEK_DTPREL_HI,
26 MEK_DTPREL_LO,
27 MEK_GOT,
28 MEK_GOTTPREL,
29 MEK_GOT_CALL,
30 MEK_GOT_DISP,
31 MEK_GOT_HI16,
32 MEK_GOT_LO16,
33 MEK_GOT_OFST,
34 MEK_GOT_PAGE,
35 MEK_GPREL,
36 MEK_HI,
37 MEK_HIGHER,
38 MEK_HIGHEST,
39 MEK_LO,
40 MEK_NEG,
41 MEK_PCREL_HI16,
42 MEK_PCREL_LO16,
43 MEK_TLSGD,
44 MEK_TLSLDM,
45 MEK_TPREL_HI,
46 MEK_TPREL_LO,
47 MEK_Special,
Petar Jovanovica5da5882014-02-04 18:41:57 +000048 };
49
50private:
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000051 const MipsExprKind Kind;
Petar Jovanovica5da5882014-02-04 18:41:57 +000052 const MCExpr *Expr;
53
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000054 explicit MipsMCExpr(MipsExprKind Kind, const MCExpr *Expr)
55 : Kind(Kind), Expr(Expr) {}
Petar Jovanovica5da5882014-02-04 18:41:57 +000056
57public:
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000058 static const MipsMCExpr *create(MipsExprKind Kind, const MCExpr *Expr,
59 MCContext &Ctx);
60 static const MipsMCExpr *createGpOff(MipsExprKind Kind, const MCExpr *Expr,
61 MCContext &Ctx);
Petar Jovanovica5da5882014-02-04 18:41:57 +000062
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000063 /// Get the kind of this expression.
64 MipsExprKind getKind() const { return Kind; }
Petar Jovanovica5da5882014-02-04 18:41:57 +000065
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000066 /// Get the child of this expression.
Petar Jovanovica5da5882014-02-04 18:41:57 +000067 const MCExpr *getSubExpr() const { return Expr; }
68
Matt Arsenault8b643552015-06-09 00:31:39 +000069 void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override;
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000070 bool evaluateAsRelocatableImpl(MCValue &Res, const MCAsmLayout *Layout,
Joerg Sonnenberger752b91b2014-08-10 11:35:12 +000071 const MCFixup *Fixup) const override;
Rafael Espindolae2c66242014-06-25 15:45:33 +000072 void visitUsedExpr(MCStreamer &Streamer) const override;
Rafael Espindolae3a20f52015-10-05 12:07:05 +000073 MCFragment *findAssociatedFragment() const override {
74 return getSubExpr()->findAssociatedFragment();
Petar Jovanovica5da5882014-02-04 18:41:57 +000075 }
76
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000077 void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override;
Petar Jovanovica5da5882014-02-04 18:41:57 +000078
79 static bool classof(const MCExpr *E) {
80 return E->getKind() == MCExpr::Target;
81 }
Daniel Sandersfe98b2f2016-05-03 13:35:44 +000082
83 bool isGpOff(MipsExprKind &Kind) const;
84 bool isGpOff() const {
85 MipsExprKind Kind;
86 return isGpOff(Kind);
87 }
Petar Jovanovica5da5882014-02-04 18:41:57 +000088};
89} // end namespace llvm
90
91#endif