1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-19 19:12:56 +02:00
llvm-mirror/tools/llvm-exegesis/lib/RegisterValue.cpp
Guillaume Chatelet 7529169fae [llvm-exegesis] Add predefined floating point values so we can test impact of special values on latency.
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
2018-09-17 11:09:32 +00:00

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