Home | History | Annotate | Download | only in MCTargetDesc
      1 //===-- 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 
     10 #ifndef LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSMCEXPR_H
     11 #define LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSMCEXPR_H
     12 
     13 #include "llvm/MC/MCAsmLayout.h"
     14 #include "llvm/MC/MCExpr.h"
     15 #include "llvm/MC/MCValue.h"
     16 
     17 namespace llvm {
     18 
     19 class MipsMCExpr : public MCTargetExpr {
     20 public:
     21   enum VariantKind {
     22     VK_Mips_None,
     23     VK_Mips_LO,
     24     VK_Mips_HI,
     25     VK_Mips_HIGHER,
     26     VK_Mips_HIGHEST
     27   };
     28 
     29 private:
     30   const VariantKind Kind;
     31   const MCExpr *Expr;
     32 
     33   explicit MipsMCExpr(VariantKind Kind, const MCExpr *Expr)
     34     : Kind(Kind), Expr(Expr) {}
     35 
     36 public:
     37   static bool isSupportedBinaryExpr(MCSymbolRefExpr::VariantKind VK,
     38                                     const MCBinaryExpr *BE);
     39 
     40   static const MipsMCExpr *create(MCSymbolRefExpr::VariantKind VK,
     41                                   const MCExpr *Expr, MCContext &Ctx);
     42 
     43   /// getOpcode - Get the kind of this expression.
     44   VariantKind getKind() const { return Kind; }
     45 
     46   /// getSubExpr - Get the child of this expression.
     47   const MCExpr *getSubExpr() const { return Expr; }
     48 
     49   void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override;
     50   bool evaluateAsRelocatableImpl(MCValue &Res,
     51                                  const MCAsmLayout *Layout,
     52                                  const MCFixup *Fixup) const override;
     53   void visitUsedExpr(MCStreamer &Streamer) const override;
     54   MCFragment *findAssociatedFragment() const override {
     55     return getSubExpr()->findAssociatedFragment();
     56   }
     57 
     58   // There are no TLS MipsMCExprs at the moment.
     59   void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {}
     60 
     61   static bool classof(const MCExpr *E) {
     62     return E->getKind() == MCExpr::Target;
     63   }
     64 };
     65 } // end namespace llvm
     66 
     67 #endif
     68