Mercurial > hg > CbC > CbC_llvm
view lib/Target/NVPTX/NVPTXMCExpr.cpp @ 0:95c75e76d11b LLVM3.4
LLVM 3.4
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 12 Dec 2013 13:56:28 +0900 |
parents | |
children | 54457678186b |
line wrap: on
line source
//===-- NVPTXMCExpr.cpp - NVPTX specific MC expression classes ------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #define DEBUG_TYPE "nvptx-mcexpr" #include "NVPTXMCExpr.h" #include "llvm/ADT/StringExtras.h" #include "llvm/MC/MCAssembler.h" #include "llvm/MC/MCContext.h" using namespace llvm; const NVPTXFloatMCExpr* NVPTXFloatMCExpr::Create(VariantKind Kind, APFloat Flt, MCContext &Ctx) { return new (Ctx) NVPTXFloatMCExpr(Kind, Flt); } void NVPTXFloatMCExpr::PrintImpl(raw_ostream &OS) const { bool Ignored; unsigned NumHex; APFloat APF = getAPFloat(); switch (Kind) { default: llvm_unreachable("Invalid kind!"); case VK_NVPTX_SINGLE_PREC_FLOAT: OS << "0f"; NumHex = 8; APF.convert(APFloat::IEEEsingle, APFloat::rmNearestTiesToEven, &Ignored); break; case VK_NVPTX_DOUBLE_PREC_FLOAT: OS << "0d"; NumHex = 16; APF.convert(APFloat::IEEEdouble, APFloat::rmNearestTiesToEven, &Ignored); break; } APInt API = APF.bitcastToAPInt(); std::string HexStr(utohexstr(API.getZExtValue())); if (HexStr.length() < NumHex) OS << std::string(NumHex - HexStr.length(), '0'); OS << utohexstr(API.getZExtValue()); }