1 /* Copyright (c) 2017  SiFive Inc. All rights reserved.
2 
3    This copyrighted material is made available to anyone wishing to use,
4    modify, copy, or redistribute it subject to the terms and conditions
5    of the FreeBSD License.   This program is distributed in the hope that
6    it will be useful, but WITHOUT ANY WARRANTY expressed or implied,
7    including the implied warranties of MERCHANTABILITY or FITNESS FOR
8    A PARTICULAR PURPOSE.  A copy of this license is available at
9    http://www.opensource.org/licenses.
10 */
11 
12 #ifndef _MACHINE_FENV_H
13 #define _MACHINE_FENV_H
14 
15 #include <stddef.h>
16 
17 #if defined(__riscv_flen) || defined(__riscv_zfinx)
18 
19 /* Per "The RISC-V Instruction Set Manual: Volume I: User-Level ISA:
20  * Version 2.1", Section 8.2, "Floating-Point Control and Status
21  * Register":
22  *
23  * Flag Mnemonic Flag Meaning
24  * ------------- -----------------
25  * NV            Invalid Operation
26  * DZ            Divide by Zero
27  * OF            Overflow
28  * UF            Underflow
29  * NX            Inexact
30  */
31 
32 #define FE_INVALID   0x00000010
33 #define FE_DIVBYZERO 0x00000008
34 #define FE_OVERFLOW  0x00000004
35 #define FE_UNDERFLOW 0x00000002
36 #define FE_INEXACT   0x00000001
37 
38 #define FE_ALL_EXCEPT (FE_INVALID|FE_DIVBYZERO|FE_OVERFLOW|FE_UNDERFLOW|FE_INEXACT)
39 
40 /* Per "The RISC-V Instruction Set Manual: Volume I: User-Level ISA:
41  * Version 2.1", Section 8.2, "Floating-Point Control and Status
42  * Register":
43  *
44  * Rounding Mode  Mnemonic Meaning  Meaning
45  * -------------  ----------------  -------
46  * 000            RNE               Round to Nearest, ties to Even
47  * 001            RTZ               Round towards Zero
48  * 010            RDN               Round Down (towards −∞)
49  * 011            RUP               Round Up (towards +∞)
50  * 100            RMM               Round to Nearest, ties to Max Magnitude
51  * 101                              Invalid. Reserved for future use.
52  * 110                              Invalid. Reserved for future use.
53  * 111                              In instruction’s rm field, selects dynamic rounding mode;
54  *                                  In Rounding Mode register, Invalid
55  */
56 
57 #define FE_TONEAREST_MM 0x00000004
58 #define FE_UPWARD     	0x00000003
59 #define FE_DOWNWARD   	0x00000002
60 #define FE_TOWARDZERO 	0x00000001
61 #define FE_TONEAREST  	0x00000000
62 
63 #define FE_RMODE_MASK   0x7
64 #else
65 #define FE_TONEAREST	0
66 #endif
67 
68 /* Per "The RISC-V Instruction Set Manual: Volume I: User-Level ISA:
69  * Version 2.1":
70  *
71  * "The F extension adds 32 floating-point registers, f0–f31, each 32
72  * bits wide, and a floating-point control and status register fcsr,
73  * which contains the operating mode and exception status of the
74  * floating-point unit."
75  */
76 
77 typedef size_t fenv_t;
78 typedef size_t fexcept_t;
79 
80 #if !defined(__declare_fenv_inline) && defined(__declare_extern_inline)
81 #define	__declare_fenv_inline(type) __declare_extern_inline(type)
82 #endif
83 
84 #ifdef __declare_fenv_inline
85 #if defined(__riscv_flen) || defined(__riscv_zfinx)
86 #include <machine/fenv-fp.h>
87 #else
88 #include <machine/fenv-softfloat.h>
89 #endif
90 #endif
91 
92 #endif /* _MACHINE_FENV_H */
93