mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-19 19:12:56 +02:00
7529169fae
Summary: This will be useful to generate many configurations and test instruction regimes (NaN, Inf, subnormal, normal). Reviewers: courbet Subscribers: mgorny, tschuett, llvm-commits Differential Revision: https://reviews.llvm.org/D51858 llvm-svn: 342369
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
|