blob: f0a6bb9b5f4b829029ecbcf0fe555b09c4a71faf [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
Joerg Sonnenbergerbfef1dd2014-08-10 12:41:50 +000037 int64_t EvaluateAsInt64(int64_t Value) const;
38
Ulrich Weigand96e65782013-06-20 16:23:52 +000039 explicit PPCMCExpr(VariantKind _Kind, const MCExpr *_Expr,
Ulrich Weigand266db7f2013-07-08 20:20:51 +000040 bool _IsDarwin)
41 : Kind(_Kind), Expr(_Expr), IsDarwin(_IsDarwin) {}
Ulrich Weigand41789de2013-05-23 22:26:41 +000042
43public:
44 /// @name Construction
45 /// @{
46
47 static const PPCMCExpr *Create(VariantKind Kind, const MCExpr *Expr,
Ulrich Weigand266db7f2013-07-08 20:20:51 +000048 bool isDarwin, MCContext &Ctx);
Ulrich Weigand41789de2013-05-23 22:26:41 +000049
Ulrich Weigand266db7f2013-07-08 20:20:51 +000050 static const PPCMCExpr *CreateLo(const MCExpr *Expr,
51 bool isDarwin, MCContext &Ctx) {
52 return Create(VK_PPC_LO, Expr, isDarwin, Ctx);
Ulrich Weigand41789de2013-05-23 22:26:41 +000053 }
54
Ulrich Weigand266db7f2013-07-08 20:20:51 +000055 static const PPCMCExpr *CreateHi(const MCExpr *Expr,
56 bool isDarwin, MCContext &Ctx) {
57 return Create(VK_PPC_HI, Expr, isDarwin, Ctx);
Ulrich Weigande67c5652013-06-21 14:42:49 +000058 }
59
Ulrich Weigand266db7f2013-07-08 20:20:51 +000060 static const PPCMCExpr *CreateHa(const MCExpr *Expr,
61 bool isDarwin, MCContext &Ctx) {
62 return Create(VK_PPC_HA, Expr, isDarwin, Ctx);
Ulrich Weigand41789de2013-05-23 22:26:41 +000063 }
64
65 /// @}
66 /// @name Accessors
67 /// @{
68
69 /// getOpcode - Get the kind of this expression.
70 VariantKind getKind() const { return Kind; }
71
72 /// getSubExpr - Get the child of this expression.
73 const MCExpr *getSubExpr() const { return Expr; }
74
Ulrich Weigand96e65782013-06-20 16:23:52 +000075 /// isDarwinSyntax - True if expression is to be printed using Darwin syntax.
Ulrich Weigand266db7f2013-07-08 20:20:51 +000076 bool isDarwinSyntax() const { return IsDarwin; }
Ulrich Weigand96e65782013-06-20 16:23:52 +000077
78
Ulrich Weigand41789de2013-05-23 22:26:41 +000079 /// @}
80
Craig Topper0d3fa922014-04-29 07:57:37 +000081 void PrintImpl(raw_ostream &OS) const override;
Ulrich Weigand41789de2013-05-23 22:26:41 +000082 bool EvaluateAsRelocatableImpl(MCValue &Res,
Joerg Sonnenberger752b91b2014-08-10 11:35:12 +000083 const MCAsmLayout *Layout,
84 const MCFixup *Fixup) const override;
Rafael Espindolae2c66242014-06-25 15:45:33 +000085 void visitUsedExpr(MCStreamer &Streamer) const override;
Craig Topper0d3fa922014-04-29 07:57:37 +000086 const MCSection *FindAssociatedSection() const override {
Ulrich Weigand41789de2013-05-23 22:26:41 +000087 return getSubExpr()->FindAssociatedSection();
88 }
89
90 // There are no TLS PPCMCExprs at the moment.
Craig Topper0d3fa922014-04-29 07:57:37 +000091 void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {}
Ulrich Weigand41789de2013-05-23 22:26:41 +000092
Joerg Sonnenbergerbfef1dd2014-08-10 12:41:50 +000093 bool EvaluateAsConstant(int64_t &Res) const;
94
Ulrich Weigand41789de2013-05-23 22:26:41 +000095 static bool classof(const MCExpr *E) {
96 return E->getKind() == MCExpr::Target;
97 }
98};
99} // end namespace llvm
100
101#endif