1 /* Fixed-point arithmetic support.
2 Copyright (C) 2006-2023 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 #ifndef GCC_FIXED_VALUE_H
21 #define GCC_FIXED_VALUE_H
23 struct GTY(()) fixed_value
25 double_int data
; /* Store data up to 2 wide integers. */
26 scalar_mode_pod mode
; /* Use machine mode to know IBIT and FBIT. */
29 #define FIXED_VALUE_TYPE struct fixed_value
31 #define MAX_FCONST0 18 /* For storing 18 fixed-point zeros per
32 fract, ufract, accum, and uaccum modes . */
33 #define MAX_FCONST1 8 /* For storing 8 fixed-point ones per accum
35 /* Constant fixed-point values 0 and 1. */
36 extern FIXED_VALUE_TYPE fconst0
[MAX_FCONST0
];
37 extern FIXED_VALUE_TYPE fconst1
[MAX_FCONST1
];
39 /* Macros to access fconst0 and fconst1 via machine modes. */
40 #define FCONST0(mode) fconst0[mode - QQmode]
41 #define FCONST1(mode) fconst1[mode - HAmode]
43 /* Return a CONST_FIXED with value R and mode M. */
44 #define CONST_FIXED_FROM_FIXED_VALUE(r, m) \
45 const_fixed_from_fixed_value (r, m)
46 extern rtx
const_fixed_from_fixed_value (FIXED_VALUE_TYPE
, machine_mode
);
48 /* Construct a FIXED_VALUE from a bit payload and machine mode MODE.
49 The bits in PAYLOAD are sign-extended/zero-extended according to MODE. */
50 extern FIXED_VALUE_TYPE
fixed_from_double_int (double_int
, scalar_mode
);
52 /* Return a CONST_FIXED from a bit payload and machine mode MODE.
53 The bits in PAYLOAD are sign-extended/zero-extended according to MODE. */
55 const_fixed_from_double_int (double_int payload
,
59 const_fixed_from_fixed_value (fixed_from_double_int (payload
, mode
),
63 /* Initialize from a decimal or hexadecimal string. */
64 extern void fixed_from_string (FIXED_VALUE_TYPE
*, const char *,
67 /* In tree.cc: wrap up a FIXED_VALUE_TYPE in a tree node. */
68 extern tree
build_fixed (tree
, FIXED_VALUE_TYPE
);
70 /* Extend or truncate to a new mode. */
71 extern bool fixed_convert (FIXED_VALUE_TYPE
*, scalar_mode
,
72 const FIXED_VALUE_TYPE
*, bool);
74 /* Convert to a fixed-point mode from an integer. */
75 extern bool fixed_convert_from_int (FIXED_VALUE_TYPE
*, scalar_mode
,
76 double_int
, bool, bool);
78 /* Convert to a fixed-point mode from a real. */
79 extern bool fixed_convert_from_real (FIXED_VALUE_TYPE
*, scalar_mode
,
80 const REAL_VALUE_TYPE
*, bool);
82 /* Convert to a real mode from a fixed-point. */
83 extern void real_convert_from_fixed (REAL_VALUE_TYPE
*, scalar_mode
,
84 const FIXED_VALUE_TYPE
*);
86 /* Compare two fixed-point objects for bitwise identity. */
87 extern bool fixed_identical (const FIXED_VALUE_TYPE
*, const FIXED_VALUE_TYPE
*);
89 /* Calculate a hash value. */
90 extern unsigned int fixed_hash (const FIXED_VALUE_TYPE
*);
92 #define FIXED_VALUES_IDENTICAL(x, y) fixed_identical (&(x), &(y))
94 /* Determine whether a fixed-point value X is negative. */
95 #define FIXED_VALUE_NEGATIVE(x) fixed_isneg (&(x))
97 /* Render F as a decimal floating point constant. */
98 extern void fixed_to_decimal (char *str
, const FIXED_VALUE_TYPE
*, size_t);
100 /* Binary or unary arithmetic on tree_code. */
101 extern bool fixed_arithmetic (FIXED_VALUE_TYPE
*, int, const FIXED_VALUE_TYPE
*,
102 const FIXED_VALUE_TYPE
*, bool);
104 /* Compare fixed-point values by tree_code. */
105 extern bool fixed_compare (int, const FIXED_VALUE_TYPE
*,
106 const FIXED_VALUE_TYPE
*);
108 /* Determine whether a fixed-point value X is negative. */
109 extern bool fixed_isneg (const FIXED_VALUE_TYPE
*);
111 #endif /* GCC_FIXED_VALUE_H */