Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 1 | //===-- NVPTXMCExpr.h - NVPTX 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 | // Modeled after ARMMCExpr |
| 11 | |
Benjamin Kramer | a7c40ef | 2014-08-13 16:26:38 +0000 | [diff] [blame] | 12 | #ifndef LLVM_LIB_TARGET_NVPTX_NVPTXMCEXPR_H |
| 13 | #define LLVM_LIB_TARGET_NVPTX_NVPTXMCEXPR_H |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 14 | |
| 15 | #include "llvm/ADT/APFloat.h" |
| 16 | #include "llvm/MC/MCExpr.h" |
| 17 | |
| 18 | namespace llvm { |
| 19 | |
| 20 | class NVPTXFloatMCExpr : public MCTargetExpr { |
| 21 | public: |
| 22 | enum VariantKind { |
| 23 | VK_NVPTX_None, |
| 24 | VK_NVPTX_SINGLE_PREC_FLOAT, // FP constant in single-precision |
| 25 | VK_NVPTX_DOUBLE_PREC_FLOAT // FP constant in double-precision |
| 26 | }; |
| 27 | |
| 28 | private: |
| 29 | const VariantKind Kind; |
| 30 | const APFloat Flt; |
| 31 | |
David Blaikie | 9f380a3 | 2015-03-16 18:06:57 +0000 | [diff] [blame] | 32 | explicit NVPTXFloatMCExpr(VariantKind Kind, APFloat Flt) |
| 33 | : Kind(Kind), Flt(Flt) {} |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 34 | |
| 35 | public: |
| 36 | /// @name Construction |
| 37 | /// @{ |
| 38 | |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 39 | static const NVPTXFloatMCExpr *create(VariantKind Kind, APFloat Flt, |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 40 | MCContext &Ctx); |
| 41 | |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 42 | static const NVPTXFloatMCExpr *createConstantFPSingle(APFloat Flt, |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 43 | MCContext &Ctx) { |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 44 | return create(VK_NVPTX_SINGLE_PREC_FLOAT, Flt, Ctx); |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 45 | } |
| 46 | |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 47 | static const NVPTXFloatMCExpr *createConstantFPDouble(APFloat Flt, |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 48 | MCContext &Ctx) { |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 49 | return create(VK_NVPTX_DOUBLE_PREC_FLOAT, Flt, Ctx); |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 50 | } |
| 51 | |
| 52 | /// @} |
| 53 | /// @name Accessors |
| 54 | /// @{ |
| 55 | |
| 56 | /// getOpcode - Get the kind of this expression. |
| 57 | VariantKind getKind() const { return Kind; } |
| 58 | |
| 59 | /// getSubExpr - Get the child of this expression. |
| 60 | APFloat getAPFloat() const { return Flt; } |
| 61 | |
| 62 | /// @} |
| 63 | |
Matt Arsenault | 8b64355 | 2015-06-09 00:31:39 +0000 | [diff] [blame] | 64 | void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override; |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 65 | bool evaluateAsRelocatableImpl(MCValue &Res, |
Joerg Sonnenberger | 752b91b | 2014-08-10 11:35:12 +0000 | [diff] [blame] | 66 | const MCAsmLayout *Layout, |
| 67 | const MCFixup *Fixup) const override { |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 68 | return false; |
| 69 | } |
Rafael Espindola | e2c6624 | 2014-06-25 15:45:33 +0000 | [diff] [blame] | 70 | void visitUsedExpr(MCStreamer &Streamer) const override {}; |
Rafael Espindola | e3a20f5 | 2015-10-05 12:07:05 +0000 | [diff] [blame] | 71 | MCFragment *findAssociatedFragment() const override { return nullptr; } |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 72 | |
| 73 | // There are no TLS NVPTXMCExprs at the moment. |
Craig Topper | 2865c98 | 2014-04-29 07:57:44 +0000 | [diff] [blame] | 74 | void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {} |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 75 | |
| 76 | static bool classof(const MCExpr *E) { |
| 77 | return E->getKind() == MCExpr::Target; |
| 78 | } |
| 79 | }; |
Justin Holewinski | 3d2a976 | 2015-04-28 17:18:30 +0000 | [diff] [blame] | 80 | |
| 81 | /// A wrapper for MCSymbolRefExpr that tells the assembly printer that the |
| 82 | /// symbol should be enclosed by generic(). |
| 83 | class NVPTXGenericMCSymbolRefExpr : public MCTargetExpr { |
| 84 | private: |
| 85 | const MCSymbolRefExpr *SymExpr; |
| 86 | |
| 87 | explicit NVPTXGenericMCSymbolRefExpr(const MCSymbolRefExpr *_SymExpr) |
| 88 | : SymExpr(_SymExpr) {} |
| 89 | |
| 90 | public: |
| 91 | /// @name Construction |
| 92 | /// @{ |
| 93 | |
| 94 | static const NVPTXGenericMCSymbolRefExpr |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 95 | *create(const MCSymbolRefExpr *SymExpr, MCContext &Ctx); |
Justin Holewinski | 3d2a976 | 2015-04-28 17:18:30 +0000 | [diff] [blame] | 96 | |
| 97 | /// @} |
| 98 | /// @name Accessors |
| 99 | /// @{ |
| 100 | |
| 101 | /// getOpcode - Get the kind of this expression. |
| 102 | const MCSymbolRefExpr *getSymbolExpr() const { return SymExpr; } |
| 103 | |
| 104 | /// @} |
| 105 | |
Matt Arsenault | 8b64355 | 2015-06-09 00:31:39 +0000 | [diff] [blame] | 106 | void printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const override; |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 107 | bool evaluateAsRelocatableImpl(MCValue &Res, |
Justin Holewinski | 3d2a976 | 2015-04-28 17:18:30 +0000 | [diff] [blame] | 108 | const MCAsmLayout *Layout, |
| 109 | const MCFixup *Fixup) const override { |
| 110 | return false; |
| 111 | } |
| 112 | void visitUsedExpr(MCStreamer &Streamer) const override {}; |
Rafael Espindola | e3a20f5 | 2015-10-05 12:07:05 +0000 | [diff] [blame] | 113 | MCFragment *findAssociatedFragment() const override { return nullptr; } |
Justin Holewinski | 3d2a976 | 2015-04-28 17:18:30 +0000 | [diff] [blame] | 114 | |
| 115 | // There are no TLS NVPTXMCExprs at the moment. |
| 116 | void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {} |
| 117 | |
| 118 | static bool classof(const MCExpr *E) { |
| 119 | return E->getKind() == MCExpr::Target; |
| 120 | } |
| 121 | }; |
Justin Holewinski | a2a63d2 | 2013-08-06 14:13:27 +0000 | [diff] [blame] | 122 | } // end namespace llvm |
| 123 | |
| 124 | #endif |