Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
14 | pmbaty | 1 | //===- FPEnv.h ---- FP Environment ------------------------------*- C++ -*-===// |
2 | // |
||
3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
||
4 | // See https://llvm.org/LICENSE.txt for license information. |
||
5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
||
6 | // |
||
7 | //===----------------------------------------------------------------------===// |
||
8 | // |
||
9 | /// @file |
||
10 | /// This file contains the declarations of entities that describe floating |
||
11 | /// point environment and related functions. |
||
12 | // |
||
13 | //===----------------------------------------------------------------------===// |
||
14 | |||
15 | #ifndef LLVM_IR_FPENV_H |
||
16 | #define LLVM_IR_FPENV_H |
||
17 | |||
18 | #include "llvm/ADT/FloatingPointMode.h" |
||
19 | #include "llvm/IR/FMF.h" |
||
20 | #include <optional> |
||
21 | |||
22 | namespace llvm { |
||
23 | class StringRef; |
||
24 | |||
25 | namespace Intrinsic { |
||
26 | typedef unsigned ID; |
||
27 | } |
||
28 | |||
29 | class Instruction; |
||
30 | |||
31 | namespace fp { |
||
32 | |||
33 | /// Exception behavior used for floating point operations. |
||
34 | /// |
||
35 | /// Each of these values correspond to some metadata argument value of a |
||
36 | /// constrained floating point intrinsic. See the LLVM Language Reference Manual |
||
37 | /// for details. |
||
38 | enum ExceptionBehavior : uint8_t { |
||
39 | ebIgnore, ///< This corresponds to "fpexcept.ignore". |
||
40 | ebMayTrap, ///< This corresponds to "fpexcept.maytrap". |
||
41 | ebStrict ///< This corresponds to "fpexcept.strict". |
||
42 | }; |
||
43 | |||
44 | } |
||
45 | |||
46 | /// Returns a valid RoundingMode enumerator when given a string |
||
47 | /// that is valid as input in constrained intrinsic rounding mode |
||
48 | /// metadata. |
||
49 | std::optional<RoundingMode> convertStrToRoundingMode(StringRef); |
||
50 | |||
51 | /// For any RoundingMode enumerator, returns a string valid as input in |
||
52 | /// constrained intrinsic rounding mode metadata. |
||
53 | std::optional<StringRef> convertRoundingModeToStr(RoundingMode); |
||
54 | |||
55 | /// Returns a valid ExceptionBehavior enumerator when given a string |
||
56 | /// valid as input in constrained intrinsic exception behavior metadata. |
||
57 | std::optional<fp::ExceptionBehavior> convertStrToExceptionBehavior(StringRef); |
||
58 | |||
59 | /// For any ExceptionBehavior enumerator, returns a string valid as |
||
60 | /// input in constrained intrinsic exception behavior metadata. |
||
61 | std::optional<StringRef> convertExceptionBehaviorToStr(fp::ExceptionBehavior); |
||
62 | |||
63 | /// Returns true if the exception handling behavior and rounding mode |
||
64 | /// match what is used in the default floating point environment. |
||
65 | inline bool isDefaultFPEnvironment(fp::ExceptionBehavior EB, RoundingMode RM) { |
||
66 | return EB == fp::ebIgnore && RM == RoundingMode::NearestTiesToEven; |
||
67 | } |
||
68 | |||
69 | /// Returns constrained intrinsic id to represent the given instruction in |
||
70 | /// strictfp function. If the instruction is already a constrained intrinsic or |
||
71 | /// does not have a constrained intrinsic counterpart, the function returns |
||
72 | /// zero. |
||
73 | Intrinsic::ID getConstrainedIntrinsicID(const Instruction &Instr); |
||
74 | |||
75 | /// Returns true if the rounding mode RM may be QRM at compile time or |
||
76 | /// at run time. |
||
77 | inline bool canRoundingModeBe(RoundingMode RM, RoundingMode QRM) { |
||
78 | return RM == QRM || RM == RoundingMode::Dynamic; |
||
79 | } |
||
80 | |||
81 | /// Returns true if the possibility of a signaling NaN can be safely |
||
82 | /// ignored. |
||
83 | inline bool canIgnoreSNaN(fp::ExceptionBehavior EB, FastMathFlags FMF) { |
||
84 | return (EB == fp::ebIgnore || FMF.noNaNs()); |
||
85 | } |
||
86 | } |
||
87 | #endif |