1 //===-- NVPTXMCExpr.h - NVPTX specific MC expression classes ----*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // Modeled after ARMMCExpr
12 #ifndef LLVM_LIB_TARGET_NVPTX_NVPTXMCEXPR_H
13 #define LLVM_LIB_TARGET_NVPTX_NVPTXMCEXPR_H
15 #include "llvm/ADT/APFloat.h"
16 #include "llvm/MC/MCExpr.h"
21 class NVPTXFloatMCExpr
: public MCTargetExpr
{
25 VK_NVPTX_HALF_PREC_FLOAT
, // FP constant in half-precision
26 VK_NVPTX_SINGLE_PREC_FLOAT
, // FP constant in single-precision
27 VK_NVPTX_DOUBLE_PREC_FLOAT
// FP constant in double-precision
31 const VariantKind Kind
;
34 explicit NVPTXFloatMCExpr(VariantKind Kind
, APFloat Flt
)
35 : Kind(Kind
), Flt(std::move(Flt
)) {}
38 /// @name Construction
41 static const NVPTXFloatMCExpr
*create(VariantKind Kind
, const APFloat
&Flt
,
44 static const NVPTXFloatMCExpr
*createConstantFPHalf(const APFloat
&Flt
,
46 return create(VK_NVPTX_HALF_PREC_FLOAT
, Flt
, Ctx
);
49 static const NVPTXFloatMCExpr
*createConstantFPSingle(const APFloat
&Flt
,
51 return create(VK_NVPTX_SINGLE_PREC_FLOAT
, Flt
, Ctx
);
54 static const NVPTXFloatMCExpr
*createConstantFPDouble(const APFloat
&Flt
,
56 return create(VK_NVPTX_DOUBLE_PREC_FLOAT
, Flt
, Ctx
);
63 /// getOpcode - Get the kind of this expression.
64 VariantKind
getKind() const { return Kind
; }
66 /// getSubExpr - Get the child of this expression.
67 APFloat
getAPFloat() const { return Flt
; }
71 void printImpl(raw_ostream
&OS
, const MCAsmInfo
*MAI
) const override
;
72 bool evaluateAsRelocatableImpl(MCValue
&Res
,
73 const MCAsmLayout
*Layout
,
74 const MCFixup
*Fixup
) const override
{
77 void visitUsedExpr(MCStreamer
&Streamer
) const override
{};
78 MCFragment
*findAssociatedFragment() const override
{ return nullptr; }
80 // There are no TLS NVPTXMCExprs at the moment.
81 void fixELFSymbolsInTLSFixups(MCAssembler
&Asm
) const override
{}
83 static bool classof(const MCExpr
*E
) {
84 return E
->getKind() == MCExpr::Target
;
88 /// A wrapper for MCSymbolRefExpr that tells the assembly printer that the
89 /// symbol should be enclosed by generic().
90 class NVPTXGenericMCSymbolRefExpr
: public MCTargetExpr
{
92 const MCSymbolRefExpr
*SymExpr
;
94 explicit NVPTXGenericMCSymbolRefExpr(const MCSymbolRefExpr
*_SymExpr
)
95 : SymExpr(_SymExpr
) {}
98 /// @name Construction
101 static const NVPTXGenericMCSymbolRefExpr
102 *create(const MCSymbolRefExpr
*SymExpr
, MCContext
&Ctx
);
108 /// getOpcode - Get the kind of this expression.
109 const MCSymbolRefExpr
*getSymbolExpr() const { return SymExpr
; }
113 void printImpl(raw_ostream
&OS
, const MCAsmInfo
*MAI
) const override
;
114 bool evaluateAsRelocatableImpl(MCValue
&Res
,
115 const MCAsmLayout
*Layout
,
116 const MCFixup
*Fixup
) const override
{
119 void visitUsedExpr(MCStreamer
&Streamer
) const override
{};
120 MCFragment
*findAssociatedFragment() const override
{ return nullptr; }
122 // There are no TLS NVPTXMCExprs at the moment.
123 void fixELFSymbolsInTLSFixups(MCAssembler
&Asm
) const override
{}
125 static bool classof(const MCExpr
*E
) {
126 return E
->getKind() == MCExpr::Target
;
129 } // end namespace llvm