mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-19 11:02:59 +02:00
49 lines
1.7 KiB
C++
49 lines
1.7 KiB
C++
|
//===-- RegisterValue.cpp ---------------------------------------*- C++ -*-===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is distributed under the University of Illinois Open Source
|
||
|
// License. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#include "RegisterValue.h"
|
||
|
#include "llvm/ADT/APFloat.h"
|
||
|
|
||
|
namespace exegesis {
|
||
|
|
||
|
static llvm::APFloat getFloatValue(const llvm::fltSemantics &FltSemantics,
|
||
|
PredefinedValues Value) {
|
||
|
switch (Value) {
|
||
|
case PredefinedValues::POS_ZERO:
|
||
|
return llvm::APFloat::getZero(FltSemantics);
|
||
|
case PredefinedValues::NEG_ZERO:
|
||
|
return llvm::APFloat::getZero(FltSemantics, true);
|
||
|
case PredefinedValues::ONE:
|
||
|
return llvm::APFloat(FltSemantics, "1");
|
||
|
case PredefinedValues::TWO:
|
||
|
return llvm::APFloat(FltSemantics, "2");
|
||
|
case PredefinedValues::INF:
|
||
|
return llvm::APFloat::getInf(FltSemantics);
|
||
|
case PredefinedValues::QNAN:
|
||
|
return llvm::APFloat::getQNaN(FltSemantics);
|
||
|
case PredefinedValues::SMALLEST_NORM:
|
||
|
return llvm::APFloat::getSmallestNormalized(FltSemantics);
|
||
|
case PredefinedValues::LARGEST:
|
||
|
return llvm::APFloat::getLargest(FltSemantics);
|
||
|
case PredefinedValues::ULP:
|
||
|
return llvm::APFloat::getSmallest(FltSemantics);
|
||
|
case PredefinedValues::ONE_PLUS_ULP:
|
||
|
auto Output = getFloatValue(FltSemantics, PredefinedValues::ONE);
|
||
|
Output.next(false);
|
||
|
return Output;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
llvm::APInt bitcastFloatValue(const llvm::fltSemantics &FltSemantics,
|
||
|
PredefinedValues Value) {
|
||
|
return getFloatValue(FltSemantics, Value).bitcastToAPInt();
|
||
|
}
|
||
|
|
||
|
} // namespace exegesis
|