xref: /llvm-project/llvm/tools/llvm-exegesis/lib/RegisterValue.cpp (revision 90c64a3456b972432a21ef043b205c18a91e011b)
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