1cd488efeSGuillaume Chatelet //===-- RegisterValue.cpp ---------------------------------------*- C++ -*-===//
2cd488efeSGuillaume Chatelet //
32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
52946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6cd488efeSGuillaume Chatelet //
7cd488efeSGuillaume Chatelet //===----------------------------------------------------------------------===//
8cd488efeSGuillaume Chatelet
9cd488efeSGuillaume Chatelet #include "RegisterValue.h"
10cd488efeSGuillaume Chatelet #include "llvm/ADT/APFloat.h"
11*90c64a34SReid Kleckner #include "llvm/ADT/StringRef.h"
12cd488efeSGuillaume Chatelet
1332401afdSFangrui Song namespace llvm {
14cd488efeSGuillaume Chatelet namespace exegesis {
15cd488efeSGuillaume Chatelet
getFloatValue(const fltSemantics & FltSemantics,PredefinedValues Value)1650cdd56bSClement Courbet static APFloat getFloatValue(const fltSemantics &FltSemantics,
17cd488efeSGuillaume Chatelet PredefinedValues Value) {
18cd488efeSGuillaume Chatelet switch (Value) {
19cd488efeSGuillaume Chatelet case PredefinedValues::POS_ZERO:
2050cdd56bSClement Courbet return APFloat::getZero(FltSemantics);
21cd488efeSGuillaume Chatelet case PredefinedValues::NEG_ZERO:
2250cdd56bSClement Courbet return APFloat::getZero(FltSemantics, true);
23cd488efeSGuillaume Chatelet case PredefinedValues::ONE:
2450cdd56bSClement Courbet return APFloat(FltSemantics, "1");
25cd488efeSGuillaume Chatelet case PredefinedValues::TWO:
2650cdd56bSClement Courbet return APFloat(FltSemantics, "2");
27cd488efeSGuillaume Chatelet case PredefinedValues::INF:
2850cdd56bSClement Courbet return APFloat::getInf(FltSemantics);
29cd488efeSGuillaume Chatelet case PredefinedValues::QNAN:
3050cdd56bSClement Courbet return APFloat::getQNaN(FltSemantics);
31cd488efeSGuillaume Chatelet case PredefinedValues::SMALLEST_NORM:
3250cdd56bSClement Courbet return APFloat::getSmallestNormalized(FltSemantics);
33cd488efeSGuillaume Chatelet case PredefinedValues::LARGEST:
3450cdd56bSClement Courbet return APFloat::getLargest(FltSemantics);
35cd488efeSGuillaume Chatelet case PredefinedValues::ULP:
3650cdd56bSClement Courbet return APFloat::getSmallest(FltSemantics);
37cd488efeSGuillaume Chatelet case PredefinedValues::ONE_PLUS_ULP:
38cd488efeSGuillaume Chatelet auto Output = getFloatValue(FltSemantics, PredefinedValues::ONE);
39cd488efeSGuillaume Chatelet Output.next(false);
40cd488efeSGuillaume Chatelet return Output;
41cd488efeSGuillaume Chatelet }
42a2fd56c3SSimon Pilgrim llvm_unreachable("Unhandled exegesis::PredefinedValues");
43cd488efeSGuillaume Chatelet }
44cd488efeSGuillaume Chatelet
bitcastFloatValue(const fltSemantics & FltSemantics,PredefinedValues Value)4550cdd56bSClement Courbet APInt bitcastFloatValue(const fltSemantics &FltSemantics,
46cd488efeSGuillaume Chatelet PredefinedValues Value) {
47cd488efeSGuillaume Chatelet return getFloatValue(FltSemantics, Value).bitcastToAPInt();
48cd488efeSGuillaume Chatelet }
49cd488efeSGuillaume Chatelet
50cd488efeSGuillaume Chatelet } // namespace exegesis
5132401afdSFangrui Song } // namespace llvm
52