blob: 73180bc0b8ac2b06398844640ee77052d62f3eb8 [file] [log] [blame]
Ulrich Weigand41789de2013-05-23 22:26:41 +00001//===-- PPCMCExpr.h - PPC 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_POWERPC_MCTARGETDESC_PPCMCEXPR_H
11#define LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCMCEXPR_H
Ulrich Weigand41789de2013-05-23 22:26:41 +000012
Chandler Carruth8a8cd2b2014-01-07 11:48:04 +000013#include "llvm/MC/MCAsmLayout.h"
Ulrich Weigand41789de2013-05-23 22:26:41 +000014#include "llvm/MC/MCExpr.h"
15#include "llvm/MC/MCValue.h"
Ulrich Weigand41789de2013-05-23 22:26:41 +000016
17namespace llvm {
18
19class PPCMCExpr : public MCTargetExpr {
20public:
21 enum VariantKind {
22 VK_PPC_None,
Ulrich Weigandd51c09f2013-06-21 14:42:20 +000023 VK_PPC_LO,
Ulrich Weigande67c5652013-06-21 14:42:49 +000024 VK_PPC_HI,
Ulrich Weigande9126f52013-06-21 14:43:42 +000025 VK_PPC_HA,
26 VK_PPC_HIGHER,
27 VK_PPC_HIGHERA,
28 VK_PPC_HIGHEST,
29 VK_PPC_HIGHESTA
Ulrich Weigand41789de2013-05-23 22:26:41 +000030 };
31
32private:
33 const VariantKind Kind;
34 const MCExpr *Expr;
Ulrich Weigand266db7f2013-07-08 20:20:51 +000035 bool IsDarwin;
Ulrich Weigand41789de2013-05-23 22:26:41 +000036
Jim Grosbach13760bd2015-05-30 01:25:56 +000037 int64_t evaluateAsInt64(int64_t Value) const;
Joerg Sonnenbergerbfef1dd2014-08-10 12:41:50 +000038
David Blaikie9f380a32015-03-16 18:06:57 +000039 explicit PPCMCExpr(VariantKind Kind, const MCExpr *Expr, bool IsDarwin)
40 : Kind(Kind), Expr(Expr), IsDarwin(IsDarwin) {}
Ulrich Weigand41789de2013-05-23 22:26:41 +000041
42public:
43 /// @name Construction
44 /// @{
45
Jim Grosbach13760bd2015-05-30 01:25:56 +000046 static const PPCMCExpr *create(VariantKind Kind, const MCExpr *Expr,
Ulrich Weigand266db7f2013-07-08 20:20:51 +000047 bool isDarwin, MCContext &Ctx);
Ulrich Weigand41789de2013-05-23 22:26:41 +000048
Jim Grosbach13760bd2015-05-30 01:25:56 +000049 static const PPCMCExpr *createLo(const MCExpr *Expr,
Ulrich Weigand266db7f2013-07-08 20:20:51 +000050 bool isDarwin, MCContext &Ctx) {
Jim Grosbach13760bd2015-05-30 01:25:56 +000051 return create(VK_PPC_LO, Expr, isDarwin, Ctx);
Ulrich Weigand41789de2013-05-23 22:26:41 +000052 }
53
Jim Grosbach13760bd2015-05-30 01:25:56 +000054 static const PPCMCExpr *createHi(const MCExpr *Expr,
Ulrich Weigand266db7f2013-07-08 20:20:51 +000055 bool isDarwin, MCContext &Ctx) {
Jim Grosbach13760bd2015-05-30 01:25:56 +000056 return create(VK_PPC_HI, Expr, isDarwin, Ctx);
Ulrich Weigande67c5652013-06-21 14:42:49 +000057 }
58
Jim Grosbach13760bd2015-05-30 01:25:56 +000059 static const PPCMCExpr *createHa(const MCExpr *Expr,
Ulrich Weigand266db7f2013-07-08 20:20:51 +000060 bool isDarwin, MCContext &Ctx) {
Jim Grosbach13760bd2015-05-30 01:25:56 +000061 return create(VK_PPC_HA, Expr, isDarwin, Ctx);
Ulrich Weigand41789de2013-05-23 22:26:41 +000062 }
63
64 /// @}
65 /// @name Accessors
66 /// @{
67
68 /// getOpcode - Get the kind of this expression.
69 VariantKind getKind() const { return Kind; }
70
71 /// getSubExpr - Get the child of this expression.
72 const MCExpr *getSubExpr() const { return Expr; }
73
Ulrich Weigand96e65782013-06-20 16:23:52 +000074 /// isDarwinSyntax - True if expression is to be printed using Darwin syntax.
Ulrich Weigand266db7f2013-07-08 20:20:51 +000075 bool isDarwinSyntax() const { return IsDarwin; }
Ulrich Weigand96e65782013-06-20 16:23:52 +000076
77
Ulrich Weigand41789de2013-05-23 22:26:41 +000078 /// @}
79
Jim Grosbach13760bd2015-05-30 01:25:56 +000080 void printImpl(raw_ostream &OS) const override;
81 bool evaluateAsRelocatableImpl(MCValue &Res,
Joerg Sonnenberger752b91b2014-08-10 11:35:12 +000082 const MCAsmLayout *Layout,
83 const MCFixup *Fixup) const override;
Rafael Espindolae2c66242014-06-25 15:45:33 +000084 void visitUsedExpr(MCStreamer &Streamer) const override;
Jim Grosbach13760bd2015-05-30 01:25:56 +000085 MCSection *findAssociatedSection() const override {
86 return getSubExpr()->findAssociatedSection();
Ulrich Weigand41789de2013-05-23 22:26:41 +000087 }
88
89 // There are no TLS PPCMCExprs at the moment.
Craig Topper0d3fa922014-04-29 07:57:37 +000090 void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {}
Ulrich Weigand41789de2013-05-23 22:26:41 +000091
Jim Grosbach13760bd2015-05-30 01:25:56 +000092 bool evaluateAsConstant(int64_t &Res) const;
Joerg Sonnenbergerbfef1dd2014-08-10 12:41:50 +000093
Ulrich Weigand41789de2013-05-23 22:26:41 +000094 static bool classof(const MCExpr *E) {
95 return E->getKind() == MCExpr::Target;
96 }
97};
98} // end namespace llvm
99
100#endif