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
15 #include "llvm/ADT/APFloat.h"
16 #include "llvm/MC/MCExpr.h"
20 class NVPTXFloatMCExpr : public MCTargetExpr {
24 VK_NVPTX_SINGLE_PREC_FLOAT, // FP constant in single-precision
25 VK_NVPTX_DOUBLE_PREC_FLOAT // FP constant in double-precision
29 const VariantKind Kind;
32 explicit NVPTXFloatMCExpr(VariantKind _Kind, APFloat _Flt)
33 : Kind(_Kind), Flt(_Flt) {}
36 /// @name Construction
39 static const NVPTXFloatMCExpr *Create(VariantKind Kind, APFloat Flt,
42 static const NVPTXFloatMCExpr *CreateConstantFPSingle(APFloat Flt,
44 return Create(VK_NVPTX_SINGLE_PREC_FLOAT, Flt, Ctx);
47 static const NVPTXFloatMCExpr *CreateConstantFPDouble(APFloat Flt,
49 return Create(VK_NVPTX_DOUBLE_PREC_FLOAT, Flt, Ctx);
56 /// getOpcode - Get the kind of this expression.
57 VariantKind getKind() const { return Kind; }
59 /// getSubExpr - Get the child of this expression.
60 APFloat getAPFloat() const { return Flt; }
64 void PrintImpl(raw_ostream &OS) const override;
65 bool EvaluateAsRelocatableImpl(MCValue &Res,
66 const MCAsmLayout *Layout) const override {
69 void AddValueSymbols(MCAssembler *) const override {};
70 const MCSection *FindAssociatedSection() const override {
74 // There are no TLS NVPTXMCExprs at the moment.
75 void fixELFSymbolsInTLSFixups(MCAssembler &Asm) const override {}
77 static bool classof(const MCExpr *E) {
78 return E->getKind() == MCExpr::Target;
81 } // end namespace llvm