annotate libgcc/fixed-bit.h @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* This is a software fixed-point library.
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
2 Copyright (C) 2007-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 This file is part of GCC.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
7 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
8 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
9 version.
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
14 for more details.
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 Under Section 7 of GPL version 3, you are granted additional
kono
parents:
diff changeset
17 permissions described in the GCC Runtime Library Exception, version
kono
parents:
diff changeset
18 3.1, as published by the Free Software Foundation.
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 You should have received a copy of the GNU General Public License and
kono
parents:
diff changeset
21 a copy of the GCC Runtime Library Exception along with this program;
kono
parents:
diff changeset
22 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
kono
parents:
diff changeset
23 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 #ifndef _FIXED_BIT_H
kono
parents:
diff changeset
26 #define _FIXED_BIT_H
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 #ifdef LIBGCC2_GNU_PREFIX
kono
parents:
diff changeset
29 #define LIBGCC2_FIXEDBIT_GNU_PREFIX
kono
parents:
diff changeset
30 #endif
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 /* To use this file we need to define one of the following:
kono
parents:
diff changeset
33 QQ_MODE, UQQ_MODE, HQ_MODE, UHQ_MODE, SQ_MODE, USQ_MODE, DQ_MODE, UDQ_MODE,
kono
parents:
diff changeset
34 TQ_MODE, UTQ_MODE, HA_MODE, UHA_MODE, SA_MODE, USA_MODE, DA_MODE, UDA_MODE,
kono
parents:
diff changeset
35 TA_MODE, UTA_MODE.
kono
parents:
diff changeset
36 Then, all operators for this machine mode will be created.
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 Or, we need to define FROM_* TO_* for conversions from one mode to another
kono
parents:
diff changeset
39 mode. The mode could be one of the following:
kono
parents:
diff changeset
40 Fract: QQ, UQQ, HQ, UHQ, SQ, USQ, DQ, UDQ, TQ, UTQ
kono
parents:
diff changeset
41 Accum: HA, UHA, SA, USA, DA, UDA, TA, UTA
kono
parents:
diff changeset
42 Signed integer: QI, HI, SI, DI, TI
kono
parents:
diff changeset
43 Unsigned integer: UQI, UHI, USI, UDI, UTI
kono
parents:
diff changeset
44 Floating-point: SF, DF
kono
parents:
diff changeset
45 Ex: If we define FROM_QQ and TO_SI, the conversion from QQ to SI is
kono
parents:
diff changeset
46 generated. */
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 #ifdef __LIBGCC_HAS_SF_MODE__
kono
parents:
diff changeset
49 #define LIBGCC2_HAS_SF_MODE 1
kono
parents:
diff changeset
50 #else
kono
parents:
diff changeset
51 #define LIBGCC2_HAS_SF_MODE 0
kono
parents:
diff changeset
52 #endif
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 #ifdef __LIBGCC_HAS_DF_MODE__
kono
parents:
diff changeset
55 #define LIBGCC2_HAS_DF_MODE 1
kono
parents:
diff changeset
56 #else
kono
parents:
diff changeset
57 #define LIBGCC2_HAS_DF_MODE 0
kono
parents:
diff changeset
58 #endif
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 typedef int QItype __attribute__ ((mode (QI)));
kono
parents:
diff changeset
61 typedef unsigned int UQItype __attribute__ ((mode (QI)));
kono
parents:
diff changeset
62 typedef int HItype __attribute__ ((mode (HI)));
kono
parents:
diff changeset
63 typedef unsigned int UHItype __attribute__ ((mode (HI)));
kono
parents:
diff changeset
64 typedef _Fract QQtype __attribute__ ((mode (QQ)));
kono
parents:
diff changeset
65 typedef unsigned _Fract UQQtype __attribute__ ((mode (UQQ)));
kono
parents:
diff changeset
66 typedef _Fract HQtype __attribute__ ((mode (HQ)));
kono
parents:
diff changeset
67 typedef unsigned _Fract UHQtype __attribute__ ((mode (UHQ)));
kono
parents:
diff changeset
68 typedef _Fract HAtype __attribute__ ((mode (HA)));
kono
parents:
diff changeset
69 typedef unsigned _Fract UHAtype __attribute__ ((mode (UHA)));
kono
parents:
diff changeset
70 #define HAVE_QQ 1
kono
parents:
diff changeset
71 #define HAVE_UQQ 1
kono
parents:
diff changeset
72 #define HAVE_HQ 1
kono
parents:
diff changeset
73 #define HAVE_UHQ 1
kono
parents:
diff changeset
74 #define HAVE_HA 1
kono
parents:
diff changeset
75 #define HAVE_UHA 1
kono
parents:
diff changeset
76 #define HAVE_QI 1
kono
parents:
diff changeset
77 #define HAVE_UQI 1
kono
parents:
diff changeset
78 #define HAVE_HI 1
kono
parents:
diff changeset
79 #define HAVE_UHI 1
kono
parents:
diff changeset
80 #if MIN_UNITS_PER_WORD > 1
kono
parents:
diff changeset
81 /* These typedefs are usually forbidden on dsp's with UNITS_PER_WORD 1. */
kono
parents:
diff changeset
82 typedef int SItype __attribute__ ((mode (SI)));
kono
parents:
diff changeset
83 typedef unsigned int USItype __attribute__ ((mode (SI)));
kono
parents:
diff changeset
84 typedef _Fract SQtype __attribute__ ((mode (SQ)));
kono
parents:
diff changeset
85 typedef unsigned _Fract USQtype __attribute__ ((mode (USQ)));
kono
parents:
diff changeset
86 typedef _Fract SAtype __attribute__ ((mode (SA)));
kono
parents:
diff changeset
87 typedef unsigned _Fract USAtype __attribute__ ((mode (USA)));
kono
parents:
diff changeset
88 #define HAVE_SQ 1
kono
parents:
diff changeset
89 #define HAVE_USQ 1
kono
parents:
diff changeset
90 #define HAVE_SA 1
kono
parents:
diff changeset
91 #define HAVE_USA 1
kono
parents:
diff changeset
92 #define HAVE_SI 1
kono
parents:
diff changeset
93 #define HAVE_USI 1
kono
parents:
diff changeset
94 #if LONG_LONG_TYPE_SIZE > 32
kono
parents:
diff changeset
95 /* These typedefs are usually forbidden on archs with UNITS_PER_WORD 2. */
kono
parents:
diff changeset
96 typedef int DItype __attribute__ ((mode (DI)));
kono
parents:
diff changeset
97 typedef unsigned int UDItype __attribute__ ((mode (DI)));
kono
parents:
diff changeset
98 typedef _Fract DQtype __attribute__ ((mode (DQ)));
kono
parents:
diff changeset
99 typedef unsigned _Fract UDQtype __attribute__ ((mode (UDQ)));
kono
parents:
diff changeset
100 typedef _Fract DAtype __attribute__ ((mode (DA)));
kono
parents:
diff changeset
101 typedef unsigned _Fract UDAtype __attribute__ ((mode (UDA)));
kono
parents:
diff changeset
102 #define HAVE_DQ 1
kono
parents:
diff changeset
103 #define HAVE_UDQ 1
kono
parents:
diff changeset
104 #define HAVE_DA 1
kono
parents:
diff changeset
105 #define HAVE_UDA 1
kono
parents:
diff changeset
106 #define HAVE_DI 1
kono
parents:
diff changeset
107 #define HAVE_UDI 1
kono
parents:
diff changeset
108 #if MIN_UNITS_PER_WORD > 4
kono
parents:
diff changeset
109 /* These typedefs are usually forbidden on archs with UNITS_PER_WORD 4. */
kono
parents:
diff changeset
110 typedef int TItype __attribute__ ((mode (TI)));
kono
parents:
diff changeset
111 typedef unsigned int UTItype __attribute__ ((mode (TI)));
kono
parents:
diff changeset
112 typedef _Fract TQtype __attribute__ ((mode (TQ)));
kono
parents:
diff changeset
113 typedef unsigned _Fract UTQtype __attribute__ ((mode (UTQ)));
kono
parents:
diff changeset
114 typedef _Fract TAtype __attribute__ ((mode (TA)));
kono
parents:
diff changeset
115 typedef unsigned _Fract UTAtype __attribute__ ((mode (UTA)));
kono
parents:
diff changeset
116 #define HAVE_TQ 1
kono
parents:
diff changeset
117 #define HAVE_UTQ 1
kono
parents:
diff changeset
118 #define HAVE_TA 1
kono
parents:
diff changeset
119 #define HAVE_UTA 1
kono
parents:
diff changeset
120 #define HAVE_TI 1
kono
parents:
diff changeset
121 #define HAVE_UTI 1
kono
parents:
diff changeset
122 #endif
kono
parents:
diff changeset
123 #endif
kono
parents:
diff changeset
124 #endif
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126 #if LIBGCC2_HAS_SF_MODE
kono
parents:
diff changeset
127 typedef float SFtype __attribute__ ((mode (SF)));
kono
parents:
diff changeset
128 #define HAVE_SF 1
kono
parents:
diff changeset
129 #endif
kono
parents:
diff changeset
130 #if LIBGCC2_HAS_DF_MODE
kono
parents:
diff changeset
131 typedef float DFtype __attribute__ ((mode (DF)));
kono
parents:
diff changeset
132 #define HAVE_DF 1
kono
parents:
diff changeset
133 #endif
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 typedef int word_type __attribute__ ((mode (__word__)));
kono
parents:
diff changeset
136
kono
parents:
diff changeset
137 /* Based on modes, we create many defines. */
kono
parents:
diff changeset
138
kono
parents:
diff changeset
139 #if defined (QQ_MODE) && (HAVE_QQ == 1)
kono
parents:
diff changeset
140 #define FIXED_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
141 #define INT_C_TYPE QItype
kono
parents:
diff changeset
142 #define UINT_C_TYPE UQItype
kono
parents:
diff changeset
143 #define DINT_C_TYPE HItype
kono
parents:
diff changeset
144 #define DUINT_C_TYPE UHItype
kono
parents:
diff changeset
145 #define MODE_NAME QQ
kono
parents:
diff changeset
146 #define MODE_NAME_S qq
kono
parents:
diff changeset
147 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
148 #endif
kono
parents:
diff changeset
149
kono
parents:
diff changeset
150 #if defined (UQQ_MODE) && (HAVE_UQQ == 1)
kono
parents:
diff changeset
151 #define FIXED_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
152 #define INT_C_TYPE UQItype
kono
parents:
diff changeset
153 #define UINT_C_TYPE UQItype
kono
parents:
diff changeset
154 #define DINT_C_TYPE UHItype
kono
parents:
diff changeset
155 #define DUINT_C_TYPE UHItype
kono
parents:
diff changeset
156 #define MODE_NAME UQQ
kono
parents:
diff changeset
157 #define MODE_NAME_S uqq
kono
parents:
diff changeset
158 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
159 #endif
kono
parents:
diff changeset
160
kono
parents:
diff changeset
161 #if defined (HQ_MODE) && (HAVE_HQ == 1)
kono
parents:
diff changeset
162 #define FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
163 #define INT_C_TYPE HItype
kono
parents:
diff changeset
164 #define UINT_C_TYPE UHItype
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 #if HAVE_SI == 1
kono
parents:
diff changeset
167 #define DINT_C_TYPE SItype
kono
parents:
diff changeset
168 #define DUINT_C_TYPE USItype
kono
parents:
diff changeset
169 #else
kono
parents:
diff changeset
170 #define HINT_C_TYPE QItype
kono
parents:
diff changeset
171 #define HUINT_C_TYPE UQItype
kono
parents:
diff changeset
172 #endif
kono
parents:
diff changeset
173
kono
parents:
diff changeset
174 #define MODE_NAME HQ
kono
parents:
diff changeset
175 #define MODE_NAME_S hq
kono
parents:
diff changeset
176 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
177 #endif
kono
parents:
diff changeset
178
kono
parents:
diff changeset
179 #if defined (UHQ_MODE) && (HAVE_UHQ == 1)
kono
parents:
diff changeset
180 #define FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
181 #define INT_C_TYPE UHItype
kono
parents:
diff changeset
182 #define UINT_C_TYPE UHItype
kono
parents:
diff changeset
183
kono
parents:
diff changeset
184 #if HAVE_SI == 1
kono
parents:
diff changeset
185 #define DINT_C_TYPE USItype
kono
parents:
diff changeset
186 #define DUINT_C_TYPE USItype
kono
parents:
diff changeset
187 #else
kono
parents:
diff changeset
188 #define HINT_C_TYPE UQItype
kono
parents:
diff changeset
189 #define HUINT_C_TYPE UQItype
kono
parents:
diff changeset
190 #endif
kono
parents:
diff changeset
191
kono
parents:
diff changeset
192 #define MODE_NAME UHQ
kono
parents:
diff changeset
193 #define MODE_NAME_S uhq
kono
parents:
diff changeset
194 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
195 #endif
kono
parents:
diff changeset
196
kono
parents:
diff changeset
197 #if defined (SQ_MODE) && (HAVE_SQ == 1)
kono
parents:
diff changeset
198 #define FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
199 #define INT_C_TYPE SItype
kono
parents:
diff changeset
200 #define UINT_C_TYPE USItype
kono
parents:
diff changeset
201
kono
parents:
diff changeset
202 #if HAVE_DI == 1
kono
parents:
diff changeset
203 #define DINT_C_TYPE DItype
kono
parents:
diff changeset
204 #define DUINT_C_TYPE UDItype
kono
parents:
diff changeset
205 #else
kono
parents:
diff changeset
206 #define HINT_C_TYPE HItype
kono
parents:
diff changeset
207 #define HUINT_C_TYPE UHItype
kono
parents:
diff changeset
208 #endif
kono
parents:
diff changeset
209
kono
parents:
diff changeset
210 #define MODE_NAME SQ
kono
parents:
diff changeset
211 #define MODE_NAME_S sq
kono
parents:
diff changeset
212 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
213 #endif
kono
parents:
diff changeset
214
kono
parents:
diff changeset
215 #if defined (USQ_MODE) && (HAVE_USQ == 1)
kono
parents:
diff changeset
216 #define FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
217 #define INT_C_TYPE USItype
kono
parents:
diff changeset
218 #define UINT_C_TYPE USItype
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 #if HAVE_DI == 1
kono
parents:
diff changeset
221 #define DINT_C_TYPE UDItype
kono
parents:
diff changeset
222 #define DUINT_C_TYPE UDItype
kono
parents:
diff changeset
223 #else
kono
parents:
diff changeset
224 #define HINT_C_TYPE UHItype
kono
parents:
diff changeset
225 #define HUINT_C_TYPE UHItype
kono
parents:
diff changeset
226 #endif
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 #define MODE_NAME USQ
kono
parents:
diff changeset
229 #define MODE_NAME_S usq
kono
parents:
diff changeset
230 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
231 #endif
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 #if defined (DQ_MODE) && (HAVE_DQ == 1)
kono
parents:
diff changeset
234 #define FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
235 #define INT_C_TYPE DItype
kono
parents:
diff changeset
236 #define UINT_C_TYPE UDItype
kono
parents:
diff changeset
237
kono
parents:
diff changeset
238 #if HAVE_TI == 1
kono
parents:
diff changeset
239 #define DINT_C_TYPE TItype
kono
parents:
diff changeset
240 #define DUINT_C_TYPE UTItype
kono
parents:
diff changeset
241 #else
kono
parents:
diff changeset
242 #define HINT_C_TYPE SItype
kono
parents:
diff changeset
243 #define HUINT_C_TYPE USItype
kono
parents:
diff changeset
244 #endif
kono
parents:
diff changeset
245
kono
parents:
diff changeset
246 #define MODE_NAME DQ
kono
parents:
diff changeset
247 #define MODE_NAME_S dq
kono
parents:
diff changeset
248 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
249 #endif
kono
parents:
diff changeset
250
kono
parents:
diff changeset
251 #if defined (UDQ_MODE) && (HAVE_UDQ == 1)
kono
parents:
diff changeset
252 #define FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
253 #define INT_C_TYPE UDItype
kono
parents:
diff changeset
254 #define UINT_C_TYPE UDItype
kono
parents:
diff changeset
255
kono
parents:
diff changeset
256 #if HAVE_TI == 1
kono
parents:
diff changeset
257 #define DINT_C_TYPE UTItype
kono
parents:
diff changeset
258 #define DUINT_C_TYPE UTItype
kono
parents:
diff changeset
259 #else
kono
parents:
diff changeset
260 #define HINT_C_TYPE USItype
kono
parents:
diff changeset
261 #define HUINT_C_TYPE USItype
kono
parents:
diff changeset
262 #endif
kono
parents:
diff changeset
263
kono
parents:
diff changeset
264 #define MODE_NAME UDQ
kono
parents:
diff changeset
265 #define MODE_NAME_S udq
kono
parents:
diff changeset
266 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
267 #endif
kono
parents:
diff changeset
268
kono
parents:
diff changeset
269 #if defined (TQ_MODE) && (HAVE_TQ == 1)
kono
parents:
diff changeset
270 #define FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
271 #define INT_C_TYPE TItype
kono
parents:
diff changeset
272 #define UINT_C_TYPE UTItype
kono
parents:
diff changeset
273 #define HINT_C_TYPE DItype
kono
parents:
diff changeset
274 #define HUINT_C_TYPE UDItype
kono
parents:
diff changeset
275 #define MODE_NAME TQ
kono
parents:
diff changeset
276 #define MODE_NAME_S tq
kono
parents:
diff changeset
277 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
278 #endif
kono
parents:
diff changeset
279
kono
parents:
diff changeset
280 #if defined (UTQ_MODE) && (HAVE_UTQ == 1)
kono
parents:
diff changeset
281 #define FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
282 #define INT_C_TYPE UTItype
kono
parents:
diff changeset
283 #define UINT_C_TYPE UTItype
kono
parents:
diff changeset
284 #define HINT_C_TYPE UDItype
kono
parents:
diff changeset
285 #define HUINT_C_TYPE UDItype
kono
parents:
diff changeset
286 #define MODE_NAME UTQ
kono
parents:
diff changeset
287 #define MODE_NAME_S utq
kono
parents:
diff changeset
288 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
289 #endif
kono
parents:
diff changeset
290
kono
parents:
diff changeset
291 #if defined (HA_MODE) && (HAVE_HA == 1)
kono
parents:
diff changeset
292 #define FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
293 #define INT_C_TYPE HItype
kono
parents:
diff changeset
294 #define UINT_C_TYPE UHItype
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 #if HAVE_SI == 1
kono
parents:
diff changeset
297 #define DINT_C_TYPE SItype
kono
parents:
diff changeset
298 #define DUINT_C_TYPE USItype
kono
parents:
diff changeset
299 #else
kono
parents:
diff changeset
300 #define HINT_C_TYPE QItype
kono
parents:
diff changeset
301 #define HUINT_C_TYPE UQItype
kono
parents:
diff changeset
302 #endif
kono
parents:
diff changeset
303
kono
parents:
diff changeset
304 #define MODE_NAME HA
kono
parents:
diff changeset
305 #define MODE_NAME_S ha
kono
parents:
diff changeset
306 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
307 #endif
kono
parents:
diff changeset
308
kono
parents:
diff changeset
309 #if defined (UHA_MODE) && (HAVE_UHA == 1)
kono
parents:
diff changeset
310 #define FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
311 #define INT_C_TYPE UHItype
kono
parents:
diff changeset
312 #define UINT_C_TYPE UHItype
kono
parents:
diff changeset
313
kono
parents:
diff changeset
314 #if HAVE_SI == 1
kono
parents:
diff changeset
315 #define DINT_C_TYPE USItype
kono
parents:
diff changeset
316 #define DUINT_C_TYPE USItype
kono
parents:
diff changeset
317 #else
kono
parents:
diff changeset
318 #define HINT_C_TYPE UQItype
kono
parents:
diff changeset
319 #define HUINT_C_TYPE UQItype
kono
parents:
diff changeset
320 #endif
kono
parents:
diff changeset
321
kono
parents:
diff changeset
322 #define MODE_NAME UHA
kono
parents:
diff changeset
323 #define MODE_NAME_S uha
kono
parents:
diff changeset
324 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
325 #endif
kono
parents:
diff changeset
326
kono
parents:
diff changeset
327 #if defined (SA_MODE) && (HAVE_SA == 1)
kono
parents:
diff changeset
328 #define FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
329 #define INT_C_TYPE SItype
kono
parents:
diff changeset
330 #define UINT_C_TYPE USItype
kono
parents:
diff changeset
331
kono
parents:
diff changeset
332 #if HAVE_DI == 1
kono
parents:
diff changeset
333 #define DINT_C_TYPE DItype
kono
parents:
diff changeset
334 #define DUINT_C_TYPE UDItype
kono
parents:
diff changeset
335 #else
kono
parents:
diff changeset
336 #define HINT_C_TYPE HItype
kono
parents:
diff changeset
337 #define HUINT_C_TYPE UHItype
kono
parents:
diff changeset
338 #endif
kono
parents:
diff changeset
339
kono
parents:
diff changeset
340 #define MODE_NAME SA
kono
parents:
diff changeset
341 #define MODE_NAME_S sa
kono
parents:
diff changeset
342 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
343 #endif
kono
parents:
diff changeset
344
kono
parents:
diff changeset
345 #if defined (USA_MODE) && (HAVE_USA == 1)
kono
parents:
diff changeset
346 #define FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
347 #define INT_C_TYPE USItype
kono
parents:
diff changeset
348 #define UINT_C_TYPE USItype
kono
parents:
diff changeset
349
kono
parents:
diff changeset
350 #if HAVE_DI == 1
kono
parents:
diff changeset
351 #define DINT_C_TYPE UDItype
kono
parents:
diff changeset
352 #define DUINT_C_TYPE UDItype
kono
parents:
diff changeset
353 #else
kono
parents:
diff changeset
354 #define HINT_C_TYPE UHItype
kono
parents:
diff changeset
355 #define HUINT_C_TYPE UHItype
kono
parents:
diff changeset
356 #endif
kono
parents:
diff changeset
357
kono
parents:
diff changeset
358 #define MODE_NAME USA
kono
parents:
diff changeset
359 #define MODE_NAME_S usa
kono
parents:
diff changeset
360 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
361 #endif
kono
parents:
diff changeset
362
kono
parents:
diff changeset
363 #if defined (DA_MODE) && (HAVE_DA == 1)
kono
parents:
diff changeset
364 #define FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
365 #define INT_C_TYPE DItype
kono
parents:
diff changeset
366 #define UINT_C_TYPE UDItype
kono
parents:
diff changeset
367
kono
parents:
diff changeset
368 #if HAVE_TI == 1
kono
parents:
diff changeset
369 #define DINT_C_TYPE TItype
kono
parents:
diff changeset
370 #define DUINT_C_TYPE UTItype
kono
parents:
diff changeset
371 #else
kono
parents:
diff changeset
372 #define HINT_C_TYPE SItype
kono
parents:
diff changeset
373 #define HUINT_C_TYPE USItype
kono
parents:
diff changeset
374 #endif
kono
parents:
diff changeset
375
kono
parents:
diff changeset
376 #define MODE_NAME DA
kono
parents:
diff changeset
377 #define MODE_NAME_S da
kono
parents:
diff changeset
378 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
379 #endif
kono
parents:
diff changeset
380
kono
parents:
diff changeset
381 #if defined (UDA_MODE) && (HAVE_UDA == 1)
kono
parents:
diff changeset
382 #define FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
383 #define INT_C_TYPE UDItype
kono
parents:
diff changeset
384 #define UINT_C_TYPE UDItype
kono
parents:
diff changeset
385
kono
parents:
diff changeset
386 #if HAVE_TI == 1
kono
parents:
diff changeset
387 #define DINT_C_TYPE UTItype
kono
parents:
diff changeset
388 #define DUINT_C_TYPE UTItype
kono
parents:
diff changeset
389 #else
kono
parents:
diff changeset
390 #define HINT_C_TYPE USItype
kono
parents:
diff changeset
391 #define HUINT_C_TYPE USItype
kono
parents:
diff changeset
392 #endif
kono
parents:
diff changeset
393
kono
parents:
diff changeset
394 #define MODE_NAME UDA
kono
parents:
diff changeset
395 #define MODE_NAME_S uda
kono
parents:
diff changeset
396 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
397 #endif
kono
parents:
diff changeset
398
kono
parents:
diff changeset
399 #if defined (TA_MODE) && (HAVE_TA == 1)
kono
parents:
diff changeset
400 #define FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
401 #define INT_C_TYPE TItype
kono
parents:
diff changeset
402 #define UINT_C_TYPE UTItype
kono
parents:
diff changeset
403 #define HINT_C_TYPE DItype
kono
parents:
diff changeset
404 #define HUINT_C_TYPE UDItype
kono
parents:
diff changeset
405 #define MODE_NAME TA
kono
parents:
diff changeset
406 #define MODE_NAME_S ta
kono
parents:
diff changeset
407 #define MODE_UNSIGNED 0
kono
parents:
diff changeset
408 #endif
kono
parents:
diff changeset
409
kono
parents:
diff changeset
410 #if defined (UTA_MODE) && (HAVE_UTA == 1)
kono
parents:
diff changeset
411 #define FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
412 #define INT_C_TYPE UTItype
kono
parents:
diff changeset
413 #define UINT_C_TYPE UTItype
kono
parents:
diff changeset
414 #define HINT_C_TYPE UDItype
kono
parents:
diff changeset
415 #define HUINT_C_TYPE UDItype
kono
parents:
diff changeset
416 #define MODE_NAME UTA
kono
parents:
diff changeset
417 #define MODE_NAME_S uta
kono
parents:
diff changeset
418 #define MODE_UNSIGNED 1
kono
parents:
diff changeset
419 #endif
kono
parents:
diff changeset
420
kono
parents:
diff changeset
421 /* The following defines are based on the previous defines. */
kono
parents:
diff changeset
422
kono
parents:
diff changeset
423 #if defined (HINT_C_TYPE)
kono
parents:
diff changeset
424 #if __BYTE_ORDER__ != __ORDER_LITTLE_ENDIAN__
kono
parents:
diff changeset
425 struct INTstruct {HINT_C_TYPE high, low;};
kono
parents:
diff changeset
426 #else
kono
parents:
diff changeset
427 struct INTstruct {HINT_C_TYPE low, high;};
kono
parents:
diff changeset
428 #endif
kono
parents:
diff changeset
429
kono
parents:
diff changeset
430 typedef union
kono
parents:
diff changeset
431 {
kono
parents:
diff changeset
432 struct INTstruct s;
kono
parents:
diff changeset
433 INT_C_TYPE ll;
kono
parents:
diff changeset
434 } INTunion;
kono
parents:
diff changeset
435 #endif
kono
parents:
diff changeset
436
kono
parents:
diff changeset
437 #define FIXED_WIDTH (FIXED_SIZE * __CHAR_BIT__) /* in bits. */
kono
parents:
diff changeset
438 #define FIXED_C_TYPE1(NAME) NAME ## type
kono
parents:
diff changeset
439 #define FIXED_C_TYPE2(NAME) FIXED_C_TYPE1(NAME)
kono
parents:
diff changeset
440 #define FIXED_C_TYPE FIXED_C_TYPE2(MODE_NAME)
kono
parents:
diff changeset
441 #define FBITS1(NAME) __ ## NAME ## _FBIT__
kono
parents:
diff changeset
442 #define FBITS2(NAME) FBITS1(NAME)
kono
parents:
diff changeset
443 #define FBITS FBITS2(MODE_NAME)
kono
parents:
diff changeset
444 #define IBITS1(NAME) __ ## NAME ## _IBIT__
kono
parents:
diff changeset
445 #define IBITS2(NAME) IBITS1(NAME)
kono
parents:
diff changeset
446 #define IBITS IBITS2(MODE_NAME)
kono
parents:
diff changeset
447 #define I_F_BITS (FBITS + IBITS)
kono
parents:
diff changeset
448
kono
parents:
diff changeset
449 #ifdef LIBGCC2_FIXEDBIT_GNU_PREFIX
kono
parents:
diff changeset
450 #define FIXED_OP(OP,MODE,NUM) __gnu_ ## OP ## MODE ## NUM
kono
parents:
diff changeset
451 #else
kono
parents:
diff changeset
452 #define FIXED_OP(OP,MODE,NUM) __ ## OP ## MODE ## NUM
kono
parents:
diff changeset
453 #endif
kono
parents:
diff changeset
454
kono
parents:
diff changeset
455 #define FIXED_SATURATE1_TEMP(NAME) FIXED_OP(saturate1,NAME,)
kono
parents:
diff changeset
456 #define FIXED_SATURATE2_TEMP(NAME) FIXED_OP(saturate2,NAME,)
kono
parents:
diff changeset
457 #define FIXED_MULHELPER_TEMP(NAME) FIXED_OP(mulhelper,NAME,)
kono
parents:
diff changeset
458 #define FIXED_DIVHELPER_TEMP(NAME) FIXED_OP(divhelper,NAME,)
kono
parents:
diff changeset
459 #define FIXED_ASHLHELPER_TEMP(NAME) FIXED_OP(ashlhelper,NAME,)
kono
parents:
diff changeset
460 #define FIXED_ADD_TEMP(NAME) FIXED_OP(add,NAME,3)
kono
parents:
diff changeset
461 #define FIXED_SSADD_TEMP(NAME) FIXED_OP(ssadd,NAME,3)
kono
parents:
diff changeset
462 #define FIXED_USADD_TEMP(NAME) FIXED_OP(usadd,NAME,3)
kono
parents:
diff changeset
463 #define FIXED_SUB_TEMP(NAME) FIXED_OP(sub,NAME,3)
kono
parents:
diff changeset
464 #define FIXED_SSSUB_TEMP(NAME) FIXED_OP(sssub,NAME,3)
kono
parents:
diff changeset
465 #define FIXED_USSUB_TEMP(NAME) FIXED_OP(ussub,NAME,3)
kono
parents:
diff changeset
466 #define FIXED_MUL_TEMP(NAME) FIXED_OP(mul,NAME,3)
kono
parents:
diff changeset
467 #define FIXED_SSMUL_TEMP(NAME) FIXED_OP(ssmul,NAME,3)
kono
parents:
diff changeset
468 #define FIXED_USMUL_TEMP(NAME) FIXED_OP(usmul,NAME,3)
kono
parents:
diff changeset
469 #define FIXED_DIV_TEMP(NAME) FIXED_OP(div,NAME,3)
kono
parents:
diff changeset
470 #define FIXED_UDIV_TEMP(NAME) FIXED_OP(udiv,NAME,3)
kono
parents:
diff changeset
471 #define FIXED_SSDIV_TEMP(NAME) FIXED_OP(ssdiv,NAME,3)
kono
parents:
diff changeset
472 #define FIXED_USDIV_TEMP(NAME) FIXED_OP(usdiv,NAME,3)
kono
parents:
diff changeset
473 #define FIXED_NEG_TEMP(NAME) FIXED_OP(neg,NAME,2)
kono
parents:
diff changeset
474 #define FIXED_SSNEG_TEMP(NAME) FIXED_OP(ssneg,NAME,2)
kono
parents:
diff changeset
475 #define FIXED_USNEG_TEMP(NAME) FIXED_OP(usneg,NAME,2)
kono
parents:
diff changeset
476 #define FIXED_ASHL_TEMP(NAME) FIXED_OP(ashl,NAME,3)
kono
parents:
diff changeset
477 #define FIXED_ASHR_TEMP(NAME) FIXED_OP(ashr,NAME,3)
kono
parents:
diff changeset
478 #define FIXED_LSHR_TEMP(NAME) FIXED_OP(lshr,NAME,3)
kono
parents:
diff changeset
479 #define FIXED_SSASHL_TEMP(NAME) FIXED_OP(ssashl,NAME,3)
kono
parents:
diff changeset
480 #define FIXED_USASHL_TEMP(NAME) FIXED_OP(usashl,NAME,3)
kono
parents:
diff changeset
481 #define FIXED_CMP_TEMP(NAME) FIXED_OP(cmp,NAME,2)
kono
parents:
diff changeset
482
kono
parents:
diff changeset
483 #if defined (MODE_NAME)
kono
parents:
diff changeset
484 #if defined (DINT_C_TYPE)
kono
parents:
diff changeset
485 #define FIXED_SATURATE1 FIXED_SATURATE1_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
486 #else
kono
parents:
diff changeset
487 #define FIXED_SATURATE2 FIXED_SATURATE2_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
488 #endif
kono
parents:
diff changeset
489 #define FIXED_MULHELPER FIXED_MULHELPER_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
490 #define FIXED_DIVHELPER FIXED_DIVHELPER_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
491 #define FIXED_ASHLHELPER FIXED_ASHLHELPER_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
492 #define FIXED_ADD FIXED_ADD_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
493 #define FIXED_SUB FIXED_SUB_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
494 #define FIXED_MUL FIXED_MUL_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
495 #define FIXED_NEG FIXED_NEG_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
496 #define FIXED_ASHL FIXED_ASHL_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
497 #define FIXED_CMP FIXED_CMP_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
498
kono
parents:
diff changeset
499 /* The following functions are for all fixed-point modes. */
kono
parents:
diff changeset
500 #if defined (DINT_C_TYPE)
kono
parents:
diff changeset
501 extern void FIXED_SATURATE1 (DINT_C_TYPE *);
kono
parents:
diff changeset
502 #else
kono
parents:
diff changeset
503 extern void FIXED_SATURATE2 (INT_C_TYPE *, INT_C_TYPE *);
kono
parents:
diff changeset
504 #endif
kono
parents:
diff changeset
505 extern FIXED_C_TYPE FIXED_MULHELPER (FIXED_C_TYPE, FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
506 extern FIXED_C_TYPE FIXED_DIVHELPER (FIXED_C_TYPE, FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
507 extern FIXED_C_TYPE FIXED_ASHLHELPER (FIXED_C_TYPE, word_type, word_type);
kono
parents:
diff changeset
508 extern FIXED_C_TYPE FIXED_ADD (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
509 extern FIXED_C_TYPE FIXED_SUB (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
510 extern FIXED_C_TYPE FIXED_MUL (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
511 extern FIXED_C_TYPE FIXED_NEG (FIXED_C_TYPE);
kono
parents:
diff changeset
512 extern FIXED_C_TYPE FIXED_ASHL (FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
513 extern word_type FIXED_CMP (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
514 #endif
kono
parents:
diff changeset
515
kono
parents:
diff changeset
516 #if MODE_UNSIGNED == 0 /* Signed types. */
kono
parents:
diff changeset
517 #define PADDING_BITS (FIXED_WIDTH - 1 - I_F_BITS)
kono
parents:
diff changeset
518 #define NONPADDING_BITS (1 + I_F_BITS)
kono
parents:
diff changeset
519
kono
parents:
diff changeset
520 #if defined (MODE_NAME)
kono
parents:
diff changeset
521 #define FIXED_DIV FIXED_DIV_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
522 #define FIXED_ASHR FIXED_ASHR_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
523 #define FIXED_SSADD FIXED_SSADD_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
524 #define FIXED_SSSUB FIXED_SSSUB_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
525 #define FIXED_SSMUL FIXED_SSMUL_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
526 #define FIXED_SSDIV FIXED_SSDIV_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
527 #define FIXED_SSNEG FIXED_SSNEG_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
528 #define FIXED_SSASHL FIXED_SSASHL_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
529
kono
parents:
diff changeset
530 /* The following functions are for signed fixed-point modes. */
kono
parents:
diff changeset
531 extern FIXED_C_TYPE FIXED_DIV (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
532 extern FIXED_C_TYPE FIXED_ASHR (FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
533 extern FIXED_C_TYPE FIXED_SSADD (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
534 extern FIXED_C_TYPE FIXED_SSSUB (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
535 extern FIXED_C_TYPE FIXED_SSMUL (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
536 extern FIXED_C_TYPE FIXED_SSDIV (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
537 extern FIXED_C_TYPE FIXED_SSNEG (FIXED_C_TYPE);
kono
parents:
diff changeset
538 extern FIXED_C_TYPE FIXED_SSASHL (FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
539 #endif
kono
parents:
diff changeset
540
kono
parents:
diff changeset
541 #else /* Unsigned types. */
kono
parents:
diff changeset
542 #define PADDING_BITS (FIXED_WIDTH - I_F_BITS)
kono
parents:
diff changeset
543 #define NONPADDING_BITS (I_F_BITS)
kono
parents:
diff changeset
544
kono
parents:
diff changeset
545 #if defined (MODE_NAME)
kono
parents:
diff changeset
546 #define FIXED_UDIV FIXED_UDIV_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
547 #define FIXED_LSHR FIXED_LSHR_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
548 #define FIXED_USDIV FIXED_USDIV_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
549 #define FIXED_USADD FIXED_USADD_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
550 #define FIXED_USSUB FIXED_USSUB_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
551 #define FIXED_USMUL FIXED_USMUL_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
552 #define FIXED_USNEG FIXED_USNEG_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
553 #define FIXED_USASHL FIXED_USASHL_TEMP(MODE_NAME_S)
kono
parents:
diff changeset
554
kono
parents:
diff changeset
555 /* The following functions are for unsigned fixed-point modes. */
kono
parents:
diff changeset
556 extern FIXED_C_TYPE FIXED_UDIV (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
557 extern FIXED_C_TYPE FIXED_LSHR (FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
558 extern FIXED_C_TYPE FIXED_USADD (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
559 extern FIXED_C_TYPE FIXED_USSUB (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
560 extern FIXED_C_TYPE FIXED_USMUL (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
561 extern FIXED_C_TYPE FIXED_USDIV (FIXED_C_TYPE, FIXED_C_TYPE);
kono
parents:
diff changeset
562 extern FIXED_C_TYPE FIXED_USNEG (FIXED_C_TYPE);
kono
parents:
diff changeset
563 extern FIXED_C_TYPE FIXED_USASHL (FIXED_C_TYPE, word_type);
kono
parents:
diff changeset
564 #endif
kono
parents:
diff changeset
565
kono
parents:
diff changeset
566 #endif /* End of testing MODE_UNSIGNED. */
kono
parents:
diff changeset
567
kono
parents:
diff changeset
568 /* This define is to check if this mode have any padding bits. */
kono
parents:
diff changeset
569 #define HAVE_PADDING_BITS (PADDING_BITS > 0)
kono
parents:
diff changeset
570
kono
parents:
diff changeset
571 /* ------------------------------------------------------------------------ */
kono
parents:
diff changeset
572 /* The following defines are for conversions. */
kono
parents:
diff changeset
573
kono
parents:
diff changeset
574 #if defined (FROM_QI) && HAVE_QI == 1
kono
parents:
diff changeset
575 #define FROM_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
576 #define FROM_INT_C_TYPE QItype
kono
parents:
diff changeset
577 #define FROM_SINT_C_TYPE QItype
kono
parents:
diff changeset
578 #define FROM_UINT_C_TYPE UQItype
kono
parents:
diff changeset
579 #define FROM_MODE_NAME_S qi
kono
parents:
diff changeset
580 #define FROM_INT_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
581
kono
parents:
diff changeset
582 #elif defined (FROM_HI) && HAVE_HI == 1
kono
parents:
diff changeset
583 #define FROM_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
584 #define FROM_INT_C_TYPE HItype
kono
parents:
diff changeset
585 #define FROM_SINT_C_TYPE HItype
kono
parents:
diff changeset
586 #define FROM_UINT_C_TYPE UHItype
kono
parents:
diff changeset
587 #define FROM_MODE_NAME_S hi
kono
parents:
diff changeset
588 #define FROM_INT_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
589
kono
parents:
diff changeset
590 #elif defined (FROM_SI) && HAVE_SI == 1
kono
parents:
diff changeset
591 #define FROM_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
592 #define FROM_INT_C_TYPE SItype
kono
parents:
diff changeset
593 #define FROM_SINT_C_TYPE SItype
kono
parents:
diff changeset
594 #define FROM_UINT_C_TYPE USItype
kono
parents:
diff changeset
595 #define FROM_MODE_NAME_S si
kono
parents:
diff changeset
596 #define FROM_INT_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
597
kono
parents:
diff changeset
598 #elif defined (FROM_DI) && HAVE_DI == 1
kono
parents:
diff changeset
599 #define FROM_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
600 #define FROM_INT_C_TYPE DItype
kono
parents:
diff changeset
601 #define FROM_SINT_C_TYPE DItype
kono
parents:
diff changeset
602 #define FROM_UINT_C_TYPE UDItype
kono
parents:
diff changeset
603 #define FROM_MODE_NAME_S di
kono
parents:
diff changeset
604 #define FROM_INT_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
605
kono
parents:
diff changeset
606 #elif defined (FROM_TI) && HAVE_TI == 1
kono
parents:
diff changeset
607 #define FROM_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
608 #define FROM_INT_C_TYPE TItype
kono
parents:
diff changeset
609 #define FROM_SINT_C_TYPE TItype
kono
parents:
diff changeset
610 #define FROM_UINT_C_TYPE UTItype
kono
parents:
diff changeset
611 #define FROM_MODE_NAME_S ti
kono
parents:
diff changeset
612 #define FROM_INT_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
613
kono
parents:
diff changeset
614 #elif defined (FROM_UQI) && HAVE_UQI == 1
kono
parents:
diff changeset
615 #define FROM_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
616 #define FROM_INT_C_TYPE QItype
kono
parents:
diff changeset
617 #define FROM_SINT_C_TYPE QItype
kono
parents:
diff changeset
618 #define FROM_UINT_C_TYPE UQItype
kono
parents:
diff changeset
619 #define FROM_MODE_NAME_S qi
kono
parents:
diff changeset
620 #define FROM_INT_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
621
kono
parents:
diff changeset
622 #elif defined (FROM_UHI) && HAVE_UHI == 1
kono
parents:
diff changeset
623 #define FROM_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
624 #define FROM_INT_C_TYPE UHItype
kono
parents:
diff changeset
625 #define FROM_SINT_C_TYPE HItype
kono
parents:
diff changeset
626 #define FROM_UINT_C_TYPE UHItype
kono
parents:
diff changeset
627 #define FROM_MODE_NAME_S hi
kono
parents:
diff changeset
628 #define FROM_INT_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
629
kono
parents:
diff changeset
630 #elif defined (FROM_USI) && HAVE_USI == 1
kono
parents:
diff changeset
631 #define FROM_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
632 #define FROM_INT_C_TYPE USItype
kono
parents:
diff changeset
633 #define FROM_SINT_C_TYPE SItype
kono
parents:
diff changeset
634 #define FROM_UINT_C_TYPE USItype
kono
parents:
diff changeset
635 #define FROM_MODE_NAME_S si
kono
parents:
diff changeset
636 #define FROM_INT_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
637
kono
parents:
diff changeset
638 #elif defined (FROM_UDI) && HAVE_UDI == 1
kono
parents:
diff changeset
639 #define FROM_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
640 #define FROM_INT_C_TYPE UDItype
kono
parents:
diff changeset
641 #define FROM_SINT_C_TYPE DItype
kono
parents:
diff changeset
642 #define FROM_UINT_C_TYPE UDItype
kono
parents:
diff changeset
643 #define FROM_MODE_NAME_S di
kono
parents:
diff changeset
644 #define FROM_INT_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
645
kono
parents:
diff changeset
646 #elif defined (FROM_UTI) && HAVE_UTI == 1
kono
parents:
diff changeset
647 #define FROM_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
648 #define FROM_INT_C_TYPE UTItype
kono
parents:
diff changeset
649 #define FROM_SINT_C_TYPE TItype
kono
parents:
diff changeset
650 #define FROM_UINT_C_TYPE UTItype
kono
parents:
diff changeset
651 #define FROM_MODE_NAME_S ti
kono
parents:
diff changeset
652 #define FROM_INT_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
653
kono
parents:
diff changeset
654 #elif defined (FROM_SF) && HAVE_SF == 1
kono
parents:
diff changeset
655 #define FROM_TYPE 3 /* Floating-point. */
kono
parents:
diff changeset
656 #define FROM_FLOAT_C_TYPE SFtype
kono
parents:
diff changeset
657 #define FROM_MODE_NAME_S sf
kono
parents:
diff changeset
658
kono
parents:
diff changeset
659 #elif defined (FROM_DF) && HAVE_DF == 1
kono
parents:
diff changeset
660 #define FROM_TYPE 3 /* Floating-point. */
kono
parents:
diff changeset
661 #define FROM_FLOAT_C_TYPE DFtype
kono
parents:
diff changeset
662 #define FROM_MODE_NAME_S df
kono
parents:
diff changeset
663
kono
parents:
diff changeset
664 #elif defined (FROM_QQ) && HAVE_QQ == 1
kono
parents:
diff changeset
665 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
666 #define FROM_MODE_NAME QQ
kono
parents:
diff changeset
667 #define FROM_MODE_NAME_S qq
kono
parents:
diff changeset
668 #define FROM_INT_C_TYPE QItype
kono
parents:
diff changeset
669 #define FROM_SINT_C_TYPE QItype
kono
parents:
diff changeset
670 #define FROM_UINT_C_TYPE UQItype
kono
parents:
diff changeset
671 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
672 #define FROM_FIXED_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
673
kono
parents:
diff changeset
674 #elif defined (FROM_HQ) && HAVE_HQ == 1
kono
parents:
diff changeset
675 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
676 #define FROM_MODE_NAME HQ
kono
parents:
diff changeset
677 #define FROM_MODE_NAME_S hq
kono
parents:
diff changeset
678 #define FROM_INT_C_TYPE HItype
kono
parents:
diff changeset
679 #define FROM_SINT_C_TYPE HItype
kono
parents:
diff changeset
680 #define FROM_UINT_C_TYPE UHItype
kono
parents:
diff changeset
681 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
682 #define FROM_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
683
kono
parents:
diff changeset
684 #elif defined (FROM_SQ) && HAVE_SQ == 1
kono
parents:
diff changeset
685 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
686 #define FROM_MODE_NAME SQ
kono
parents:
diff changeset
687 #define FROM_MODE_NAME_S sq
kono
parents:
diff changeset
688 #define FROM_INT_C_TYPE SItype
kono
parents:
diff changeset
689 #define FROM_SINT_C_TYPE SItype
kono
parents:
diff changeset
690 #define FROM_UINT_C_TYPE USItype
kono
parents:
diff changeset
691 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
692 #define FROM_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
693
kono
parents:
diff changeset
694 #elif defined (FROM_DQ) && HAVE_DQ == 1
kono
parents:
diff changeset
695 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
696 #define FROM_MODE_NAME DQ
kono
parents:
diff changeset
697 #define FROM_MODE_NAME_S dq
kono
parents:
diff changeset
698 #define FROM_INT_C_TYPE DItype
kono
parents:
diff changeset
699 #define FROM_SINT_C_TYPE DItype
kono
parents:
diff changeset
700 #define FROM_UINT_C_TYPE UDItype
kono
parents:
diff changeset
701 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
702 #define FROM_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
703
kono
parents:
diff changeset
704 #elif defined (FROM_TQ) && HAVE_TQ == 1
kono
parents:
diff changeset
705 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
706 #define FROM_MODE_NAME TQ
kono
parents:
diff changeset
707 #define FROM_MODE_NAME_S tq
kono
parents:
diff changeset
708 #define FROM_INT_C_TYPE TItype
kono
parents:
diff changeset
709 #define FROM_SINT_C_TYPE TItype
kono
parents:
diff changeset
710 #define FROM_UINT_C_TYPE UTItype
kono
parents:
diff changeset
711 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
712 #define FROM_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
713
kono
parents:
diff changeset
714 #elif defined (FROM_UQQ) && HAVE_UQQ == 1
kono
parents:
diff changeset
715 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
716 #define FROM_MODE_NAME UQQ
kono
parents:
diff changeset
717 #define FROM_MODE_NAME_S uqq
kono
parents:
diff changeset
718 #define FROM_INT_C_TYPE UQItype
kono
parents:
diff changeset
719 #define FROM_SINT_C_TYPE QItype
kono
parents:
diff changeset
720 #define FROM_UINT_C_TYPE UQItype
kono
parents:
diff changeset
721 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
722 #define FROM_FIXED_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
723
kono
parents:
diff changeset
724 #elif defined (FROM_UHQ) && HAVE_UHQ == 1
kono
parents:
diff changeset
725 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
726 #define FROM_MODE_NAME UHQ
kono
parents:
diff changeset
727 #define FROM_MODE_NAME_S uhq
kono
parents:
diff changeset
728 #define FROM_INT_C_TYPE UHItype
kono
parents:
diff changeset
729 #define FROM_SINT_C_TYPE HItype
kono
parents:
diff changeset
730 #define FROM_UINT_C_TYPE UHItype
kono
parents:
diff changeset
731 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
732 #define FROM_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
733
kono
parents:
diff changeset
734 #elif defined (FROM_USQ) && HAVE_USQ == 1
kono
parents:
diff changeset
735 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
736 #define FROM_MODE_NAME USQ
kono
parents:
diff changeset
737 #define FROM_MODE_NAME_S usq
kono
parents:
diff changeset
738 #define FROM_INT_C_TYPE USItype
kono
parents:
diff changeset
739 #define FROM_SINT_C_TYPE SItype
kono
parents:
diff changeset
740 #define FROM_UINT_C_TYPE USItype
kono
parents:
diff changeset
741 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
742 #define FROM_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
743
kono
parents:
diff changeset
744 #elif defined (FROM_UDQ) && HAVE_UDQ == 1
kono
parents:
diff changeset
745 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
746 #define FROM_MODE_NAME UDQ
kono
parents:
diff changeset
747 #define FROM_MODE_NAME_S udq
kono
parents:
diff changeset
748 #define FROM_INT_C_TYPE UDItype
kono
parents:
diff changeset
749 #define FROM_SINT_C_TYPE DItype
kono
parents:
diff changeset
750 #define FROM_UINT_C_TYPE UDItype
kono
parents:
diff changeset
751 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
752 #define FROM_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
753
kono
parents:
diff changeset
754 #elif defined (FROM_UTQ) && HAVE_UTQ == 1
kono
parents:
diff changeset
755 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
756 #define FROM_MODE_NAME UTQ
kono
parents:
diff changeset
757 #define FROM_MODE_NAME_S utq
kono
parents:
diff changeset
758 #define FROM_INT_C_TYPE UTItype
kono
parents:
diff changeset
759 #define FROM_SINT_C_TYPE TItype
kono
parents:
diff changeset
760 #define FROM_UINT_C_TYPE UTItype
kono
parents:
diff changeset
761 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
762 #define FROM_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
763
kono
parents:
diff changeset
764 #elif defined (FROM_HA) && HAVE_HA == 1
kono
parents:
diff changeset
765 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
766 #define FROM_MODE_NAME HA
kono
parents:
diff changeset
767 #define FROM_MODE_NAME_S ha
kono
parents:
diff changeset
768 #define FROM_INT_C_TYPE HItype
kono
parents:
diff changeset
769 #define FROM_SINT_C_TYPE HItype
kono
parents:
diff changeset
770 #define FROM_UINT_C_TYPE UHItype
kono
parents:
diff changeset
771 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
772 #define FROM_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
773
kono
parents:
diff changeset
774 #elif defined (FROM_SA) && HAVE_SA == 1
kono
parents:
diff changeset
775 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
776 #define FROM_MODE_NAME SA
kono
parents:
diff changeset
777 #define FROM_MODE_NAME_S sa
kono
parents:
diff changeset
778 #define FROM_INT_C_TYPE SItype
kono
parents:
diff changeset
779 #define FROM_SINT_C_TYPE SItype
kono
parents:
diff changeset
780 #define FROM_UINT_C_TYPE USItype
kono
parents:
diff changeset
781 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
782 #define FROM_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
783
kono
parents:
diff changeset
784 #elif defined (FROM_DA) && HAVE_DA == 1
kono
parents:
diff changeset
785 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
786 #define FROM_MODE_NAME DA
kono
parents:
diff changeset
787 #define FROM_MODE_NAME_S da
kono
parents:
diff changeset
788 #define FROM_INT_C_TYPE DItype
kono
parents:
diff changeset
789 #define FROM_SINT_C_TYPE DItype
kono
parents:
diff changeset
790 #define FROM_UINT_C_TYPE UDItype
kono
parents:
diff changeset
791 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
792 #define FROM_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
793
kono
parents:
diff changeset
794 #elif defined (FROM_TA) && HAVE_TA == 1
kono
parents:
diff changeset
795 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
796 #define FROM_MODE_NAME TA
kono
parents:
diff changeset
797 #define FROM_MODE_NAME_S ta
kono
parents:
diff changeset
798 #define FROM_INT_C_TYPE TItype
kono
parents:
diff changeset
799 #define FROM_SINT_C_TYPE TItype
kono
parents:
diff changeset
800 #define FROM_UINT_C_TYPE UTItype
kono
parents:
diff changeset
801 #define FROM_MODE_UNSIGNED 0
kono
parents:
diff changeset
802 #define FROM_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
803
kono
parents:
diff changeset
804 #elif defined (FROM_UHA) && HAVE_UHA == 1
kono
parents:
diff changeset
805 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
806 #define FROM_MODE_NAME UHA
kono
parents:
diff changeset
807 #define FROM_MODE_NAME_S uha
kono
parents:
diff changeset
808 #define FROM_INT_C_TYPE UHItype
kono
parents:
diff changeset
809 #define FROM_SINT_C_TYPE HItype
kono
parents:
diff changeset
810 #define FROM_UINT_C_TYPE UHItype
kono
parents:
diff changeset
811 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
812 #define FROM_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
813
kono
parents:
diff changeset
814 #elif defined (FROM_USA) && HAVE_USA == 1
kono
parents:
diff changeset
815 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
816 #define FROM_MODE_NAME USA
kono
parents:
diff changeset
817 #define FROM_MODE_NAME_S usa
kono
parents:
diff changeset
818 #define FROM_INT_C_TYPE USItype
kono
parents:
diff changeset
819 #define FROM_SINT_C_TYPE SItype
kono
parents:
diff changeset
820 #define FROM_UINT_C_TYPE USItype
kono
parents:
diff changeset
821 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
822 #define FROM_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
823
kono
parents:
diff changeset
824 #elif defined (FROM_UDA) && HAVE_UDA == 1
kono
parents:
diff changeset
825 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
826 #define FROM_MODE_NAME UDA
kono
parents:
diff changeset
827 #define FROM_MODE_NAME_S uda
kono
parents:
diff changeset
828 #define FROM_INT_C_TYPE UDItype
kono
parents:
diff changeset
829 #define FROM_SINT_C_TYPE DItype
kono
parents:
diff changeset
830 #define FROM_UINT_C_TYPE UDItype
kono
parents:
diff changeset
831 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
832 #define FROM_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
833
kono
parents:
diff changeset
834 #elif defined (FROM_UTA) && HAVE_UTA == 1
kono
parents:
diff changeset
835 #define FROM_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
836 #define FROM_MODE_NAME UTA
kono
parents:
diff changeset
837 #define FROM_MODE_NAME_S uta
kono
parents:
diff changeset
838 #define FROM_INT_C_TYPE UTItype
kono
parents:
diff changeset
839 #define FROM_SINT_C_TYPE TItype
kono
parents:
diff changeset
840 #define FROM_UINT_C_TYPE UTItype
kono
parents:
diff changeset
841 #define FROM_MODE_UNSIGNED 1
kono
parents:
diff changeset
842 #define FROM_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
843
kono
parents:
diff changeset
844 #endif
kono
parents:
diff changeset
845
kono
parents:
diff changeset
846 #if defined (TO_QI) && HAVE_QI == 1 && !defined (FROM_QI)
kono
parents:
diff changeset
847 #define TO_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
848 #define TO_INT_C_TYPE QItype
kono
parents:
diff changeset
849 #define TO_SINT_C_TYPE QItype
kono
parents:
diff changeset
850 #define TO_UINT_C_TYPE UQItype
kono
parents:
diff changeset
851 #define TO_MODE_NAME_S qi
kono
parents:
diff changeset
852
kono
parents:
diff changeset
853 #elif defined (TO_HI) && HAVE_HI == 1 && !defined (FROM_HI)
kono
parents:
diff changeset
854 #define TO_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
855 #define TO_INT_C_TYPE HItype
kono
parents:
diff changeset
856 #define TO_SINT_C_TYPE HItype
kono
parents:
diff changeset
857 #define TO_UINT_C_TYPE UHItype
kono
parents:
diff changeset
858 #define TO_MODE_NAME_S hi
kono
parents:
diff changeset
859
kono
parents:
diff changeset
860 #elif defined (TO_SI) && HAVE_SI == 1 && !defined (FROM_SI)
kono
parents:
diff changeset
861 #define TO_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
862 #define TO_INT_C_TYPE SItype
kono
parents:
diff changeset
863 #define TO_SINT_C_TYPE SItype
kono
parents:
diff changeset
864 #define TO_UINT_C_TYPE USItype
kono
parents:
diff changeset
865 #define TO_MODE_NAME_S si
kono
parents:
diff changeset
866
kono
parents:
diff changeset
867 #elif defined (TO_DI) && HAVE_DI == 1 && !defined (FROM_DI)
kono
parents:
diff changeset
868 #define TO_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
869 #define TO_INT_C_TYPE DItype
kono
parents:
diff changeset
870 #define TO_SINT_C_TYPE DItype
kono
parents:
diff changeset
871 #define TO_UINT_C_TYPE UDItype
kono
parents:
diff changeset
872 #define TO_MODE_NAME_S di
kono
parents:
diff changeset
873
kono
parents:
diff changeset
874 #elif defined (TO_TI) && HAVE_TI == 1 && !defined (FROM_TI)
kono
parents:
diff changeset
875 #define TO_TYPE 1 /* Signed integer. */
kono
parents:
diff changeset
876 #define TO_INT_C_TYPE TItype
kono
parents:
diff changeset
877 #define TO_SINT_C_TYPE TItype
kono
parents:
diff changeset
878 #define TO_UINT_C_TYPE UTItype
kono
parents:
diff changeset
879 #define TO_MODE_NAME_S ti
kono
parents:
diff changeset
880
kono
parents:
diff changeset
881 #elif defined (TO_UQI) && HAVE_UQI == 1 && !defined (FROM_UQI)
kono
parents:
diff changeset
882 #define TO_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
883 #define TO_INT_C_TYPE UQItype
kono
parents:
diff changeset
884 #define TO_SINT_C_TYPE QItype
kono
parents:
diff changeset
885 #define TO_UINT_C_TYPE UQItype
kono
parents:
diff changeset
886 #define TO_MODE_NAME_S qi
kono
parents:
diff changeset
887
kono
parents:
diff changeset
888 #elif defined (TO_UHI) && HAVE_UHI == 1 && !defined (FROM_UHI)
kono
parents:
diff changeset
889 #define TO_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
890 #define TO_INT_C_TYPE UHItype
kono
parents:
diff changeset
891 #define TO_SINT_C_TYPE HItype
kono
parents:
diff changeset
892 #define TO_UINT_C_TYPE UHItype
kono
parents:
diff changeset
893 #define TO_MODE_NAME_S hi
kono
parents:
diff changeset
894
kono
parents:
diff changeset
895 #elif defined (TO_USI) && HAVE_USI == 1 && !defined (FROM_USI)
kono
parents:
diff changeset
896 #define TO_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
897 #define TO_INT_C_TYPE USItype
kono
parents:
diff changeset
898 #define TO_SINT_C_TYPE SItype
kono
parents:
diff changeset
899 #define TO_UINT_C_TYPE USItype
kono
parents:
diff changeset
900 #define TO_MODE_NAME_S si
kono
parents:
diff changeset
901
kono
parents:
diff changeset
902 #elif defined (TO_UDI) && HAVE_UDI == 1 && !defined (FROM_UDI)
kono
parents:
diff changeset
903 #define TO_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
904 #define TO_INT_C_TYPE UDItype
kono
parents:
diff changeset
905 #define TO_SINT_C_TYPE DItype
kono
parents:
diff changeset
906 #define TO_UINT_C_TYPE UDItype
kono
parents:
diff changeset
907 #define TO_MODE_NAME_S di
kono
parents:
diff changeset
908
kono
parents:
diff changeset
909 #elif defined (TO_UTI) && HAVE_UTI == 1 && !defined (FROM_UTI)
kono
parents:
diff changeset
910 #define TO_TYPE 2 /* Unsigned integer. */
kono
parents:
diff changeset
911 #define TO_INT_C_TYPE UTItype
kono
parents:
diff changeset
912 #define TO_SINT_C_TYPE TItype
kono
parents:
diff changeset
913 #define TO_UINT_C_TYPE UTItype
kono
parents:
diff changeset
914 #define TO_MODE_NAME_S ti
kono
parents:
diff changeset
915
kono
parents:
diff changeset
916 #elif defined (TO_SF) && HAVE_SF == 1 && !defined (FROM_SF)
kono
parents:
diff changeset
917 #define TO_TYPE 3 /* Floating-point. */
kono
parents:
diff changeset
918 #define TO_FLOAT_C_TYPE SFtype
kono
parents:
diff changeset
919 #define TO_MODE_NAME_S sf
kono
parents:
diff changeset
920
kono
parents:
diff changeset
921 #elif defined (TO_DF) && HAVE_DF == 1 && !defined (FROM_DF)
kono
parents:
diff changeset
922 #define TO_TYPE 3 /* Floating-point. */
kono
parents:
diff changeset
923 #define TO_FLOAT_C_TYPE DFtype
kono
parents:
diff changeset
924 #define TO_MODE_NAME_S df
kono
parents:
diff changeset
925
kono
parents:
diff changeset
926 #elif defined (TO_QQ) && HAVE_QQ == 1 && !defined (FROM_QQ)
kono
parents:
diff changeset
927 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
928 #define TO_MODE_NAME QQ
kono
parents:
diff changeset
929 #define TO_MODE_NAME_S qq
kono
parents:
diff changeset
930 #define TO_INT_C_TYPE QItype
kono
parents:
diff changeset
931 #define TO_SINT_C_TYPE QItype
kono
parents:
diff changeset
932 #define TO_UINT_C_TYPE UQItype
kono
parents:
diff changeset
933 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
934 #define TO_FIXED_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
935
kono
parents:
diff changeset
936 #elif defined (TO_HQ) && HAVE_HQ == 1 && !defined (FROM_HQ)
kono
parents:
diff changeset
937 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
938 #define TO_MODE_NAME HQ
kono
parents:
diff changeset
939 #define TO_MODE_NAME_S hq
kono
parents:
diff changeset
940 #define TO_INT_C_TYPE HItype
kono
parents:
diff changeset
941 #define TO_SINT_C_TYPE HItype
kono
parents:
diff changeset
942 #define TO_UINT_C_TYPE UHItype
kono
parents:
diff changeset
943 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
944 #define TO_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
945
kono
parents:
diff changeset
946 #elif defined (TO_SQ) && HAVE_SQ == 1 && !defined (FROM_SQ)
kono
parents:
diff changeset
947 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
948 #define TO_MODE_NAME SQ
kono
parents:
diff changeset
949 #define TO_MODE_NAME_S sq
kono
parents:
diff changeset
950 #define TO_INT_C_TYPE SItype
kono
parents:
diff changeset
951 #define TO_SINT_C_TYPE SItype
kono
parents:
diff changeset
952 #define TO_UINT_C_TYPE USItype
kono
parents:
diff changeset
953 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
954 #define TO_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
955
kono
parents:
diff changeset
956 #elif defined (TO_DQ) && HAVE_DQ == 1 && !defined (FROM_DQ)
kono
parents:
diff changeset
957 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
958 #define TO_MODE_NAME DQ
kono
parents:
diff changeset
959 #define TO_MODE_NAME_S dq
kono
parents:
diff changeset
960 #define TO_INT_C_TYPE DItype
kono
parents:
diff changeset
961 #define TO_SINT_C_TYPE DItype
kono
parents:
diff changeset
962 #define TO_UINT_C_TYPE UDItype
kono
parents:
diff changeset
963 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
964 #define TO_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
965
kono
parents:
diff changeset
966 #elif defined (TO_TQ) && HAVE_TQ == 1 && !defined (FROM_TQ)
kono
parents:
diff changeset
967 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
968 #define TO_MODE_NAME TQ
kono
parents:
diff changeset
969 #define TO_MODE_NAME_S tq
kono
parents:
diff changeset
970 #define TO_INT_C_TYPE TItype
kono
parents:
diff changeset
971 #define TO_SINT_C_TYPE TItype
kono
parents:
diff changeset
972 #define TO_UINT_C_TYPE UTItype
kono
parents:
diff changeset
973 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
974 #define TO_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
975
kono
parents:
diff changeset
976 #elif defined (TO_UQQ) && HAVE_UQQ == 1 && !defined (FROM_UQQ)
kono
parents:
diff changeset
977 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
978 #define TO_MODE_NAME UQQ
kono
parents:
diff changeset
979 #define TO_MODE_NAME_S uqq
kono
parents:
diff changeset
980 #define TO_INT_C_TYPE UQItype
kono
parents:
diff changeset
981 #define TO_SINT_C_TYPE QItype
kono
parents:
diff changeset
982 #define TO_UINT_C_TYPE UQItype
kono
parents:
diff changeset
983 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
984 #define TO_FIXED_SIZE 1 /* in bytes. */
kono
parents:
diff changeset
985
kono
parents:
diff changeset
986 #elif defined (TO_UHQ) && HAVE_UHQ == 1 && !defined (FROM_UHQ)
kono
parents:
diff changeset
987 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
988 #define TO_MODE_NAME UHQ
kono
parents:
diff changeset
989 #define TO_MODE_NAME_S uhq
kono
parents:
diff changeset
990 #define TO_INT_C_TYPE UHItype
kono
parents:
diff changeset
991 #define TO_SINT_C_TYPE HItype
kono
parents:
diff changeset
992 #define TO_UINT_C_TYPE UHItype
kono
parents:
diff changeset
993 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
994 #define TO_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
995
kono
parents:
diff changeset
996 #elif defined (TO_USQ) && HAVE_USQ == 1 && !defined (FROM_USQ)
kono
parents:
diff changeset
997 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
998 #define TO_MODE_NAME USQ
kono
parents:
diff changeset
999 #define TO_MODE_NAME_S usq
kono
parents:
diff changeset
1000 #define TO_INT_C_TYPE USItype
kono
parents:
diff changeset
1001 #define TO_SINT_C_TYPE SItype
kono
parents:
diff changeset
1002 #define TO_UINT_C_TYPE USItype
kono
parents:
diff changeset
1003 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1004 #define TO_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
1005
kono
parents:
diff changeset
1006 #elif defined (TO_UDQ) && HAVE_UDQ == 1 && !defined (FROM_UDQ)
kono
parents:
diff changeset
1007 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1008 #define TO_MODE_NAME UDQ
kono
parents:
diff changeset
1009 #define TO_MODE_NAME_S udq
kono
parents:
diff changeset
1010 #define TO_INT_C_TYPE UDItype
kono
parents:
diff changeset
1011 #define TO_SINT_C_TYPE DItype
kono
parents:
diff changeset
1012 #define TO_UINT_C_TYPE UDItype
kono
parents:
diff changeset
1013 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1014 #define TO_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
1015
kono
parents:
diff changeset
1016 #elif defined (TO_UTQ) && HAVE_UTQ == 1 && !defined (FROM_UTQ)
kono
parents:
diff changeset
1017 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1018 #define TO_MODE_NAME UTQ
kono
parents:
diff changeset
1019 #define TO_MODE_NAME_S utq
kono
parents:
diff changeset
1020 #define TO_INT_C_TYPE UTItype
kono
parents:
diff changeset
1021 #define TO_SINT_C_TYPE TItype
kono
parents:
diff changeset
1022 #define TO_UINT_C_TYPE UTItype
kono
parents:
diff changeset
1023 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1024 #define TO_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
1025
kono
parents:
diff changeset
1026 #elif defined (TO_HA) && HAVE_HA == 1 && !defined (FROM_HA)
kono
parents:
diff changeset
1027 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1028 #define TO_MODE_NAME HA
kono
parents:
diff changeset
1029 #define TO_MODE_NAME_S ha
kono
parents:
diff changeset
1030 #define TO_INT_C_TYPE HItype
kono
parents:
diff changeset
1031 #define TO_SINT_C_TYPE HItype
kono
parents:
diff changeset
1032 #define TO_UINT_C_TYPE UHItype
kono
parents:
diff changeset
1033 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
1034 #define TO_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
1035
kono
parents:
diff changeset
1036 #elif defined (TO_SA) && HAVE_SA == 1 && !defined (FROM_SA)
kono
parents:
diff changeset
1037 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1038 #define TO_MODE_NAME SA
kono
parents:
diff changeset
1039 #define TO_MODE_NAME_S sa
kono
parents:
diff changeset
1040 #define TO_INT_C_TYPE SItype
kono
parents:
diff changeset
1041 #define TO_SINT_C_TYPE SItype
kono
parents:
diff changeset
1042 #define TO_UINT_C_TYPE USItype
kono
parents:
diff changeset
1043 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
1044 #define TO_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
1045
kono
parents:
diff changeset
1046 #elif defined (TO_DA) && HAVE_DA == 1 && !defined (FROM_DA)
kono
parents:
diff changeset
1047 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1048 #define TO_MODE_NAME DA
kono
parents:
diff changeset
1049 #define TO_MODE_NAME_S da
kono
parents:
diff changeset
1050 #define TO_INT_C_TYPE DItype
kono
parents:
diff changeset
1051 #define TO_SINT_C_TYPE DItype
kono
parents:
diff changeset
1052 #define TO_UINT_C_TYPE UDItype
kono
parents:
diff changeset
1053 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
1054 #define TO_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
1055
kono
parents:
diff changeset
1056 #elif defined (TO_TA) && HAVE_TA == 1 && !defined (FROM_TA)
kono
parents:
diff changeset
1057 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1058 #define TO_MODE_NAME TA
kono
parents:
diff changeset
1059 #define TO_MODE_NAME_S ta
kono
parents:
diff changeset
1060 #define TO_INT_C_TYPE TItype
kono
parents:
diff changeset
1061 #define TO_SINT_C_TYPE TItype
kono
parents:
diff changeset
1062 #define TO_UINT_C_TYPE UTItype
kono
parents:
diff changeset
1063 #define TO_MODE_UNSIGNED 0
kono
parents:
diff changeset
1064 #define TO_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
1065
kono
parents:
diff changeset
1066 #elif defined (TO_UHA) && HAVE_UHA == 1 && !defined (FROM_UHA)
kono
parents:
diff changeset
1067 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1068 #define TO_MODE_NAME UHA
kono
parents:
diff changeset
1069 #define TO_MODE_NAME_S uha
kono
parents:
diff changeset
1070 #define TO_INT_C_TYPE UHItype
kono
parents:
diff changeset
1071 #define TO_SINT_C_TYPE HItype
kono
parents:
diff changeset
1072 #define TO_UINT_C_TYPE UHItype
kono
parents:
diff changeset
1073 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1074 #define TO_FIXED_SIZE 2 /* in bytes. */
kono
parents:
diff changeset
1075
kono
parents:
diff changeset
1076 #elif defined (TO_USA) && HAVE_USA == 1 && !defined (FROM_USA)
kono
parents:
diff changeset
1077 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1078 #define TO_MODE_NAME USA
kono
parents:
diff changeset
1079 #define TO_MODE_NAME_S usa
kono
parents:
diff changeset
1080 #define TO_INT_C_TYPE USItype
kono
parents:
diff changeset
1081 #define TO_SINT_C_TYPE SItype
kono
parents:
diff changeset
1082 #define TO_UINT_C_TYPE USItype
kono
parents:
diff changeset
1083 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1084 #define TO_FIXED_SIZE 4 /* in bytes. */
kono
parents:
diff changeset
1085
kono
parents:
diff changeset
1086 #elif defined (TO_UDA) && HAVE_UDA == 1 && !defined (FROM_UDA)
kono
parents:
diff changeset
1087 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1088 #define TO_MODE_NAME UDA
kono
parents:
diff changeset
1089 #define TO_MODE_NAME_S uda
kono
parents:
diff changeset
1090 #define TO_INT_C_TYPE UDItype
kono
parents:
diff changeset
1091 #define TO_SINT_C_TYPE DItype
kono
parents:
diff changeset
1092 #define TO_UINT_C_TYPE UDItype
kono
parents:
diff changeset
1093 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1094 #define TO_FIXED_SIZE 8 /* in bytes. */
kono
parents:
diff changeset
1095
kono
parents:
diff changeset
1096 #elif defined (TO_UTA) && HAVE_UTA == 1 && !defined (FROM_UTA)
kono
parents:
diff changeset
1097 #define TO_TYPE 4 /* Fixed-point. */
kono
parents:
diff changeset
1098 #define TO_MODE_NAME UTA
kono
parents:
diff changeset
1099 #define TO_MODE_NAME_S uta
kono
parents:
diff changeset
1100 #define TO_INT_C_TYPE UTItype
kono
parents:
diff changeset
1101 #define TO_SINT_C_TYPE TItype
kono
parents:
diff changeset
1102 #define TO_UINT_C_TYPE UTItype
kono
parents:
diff changeset
1103 #define TO_MODE_UNSIGNED 1
kono
parents:
diff changeset
1104 #define TO_FIXED_SIZE 16 /* in bytes. */
kono
parents:
diff changeset
1105
kono
parents:
diff changeset
1106 #endif
kono
parents:
diff changeset
1107
kono
parents:
diff changeset
1108 #if defined (FROM_MODE_NAME_S) && defined (TO_MODE_NAME_S)
kono
parents:
diff changeset
1109
kono
parents:
diff changeset
1110 #if FROM_TYPE == 1 /* Signed integer. */
kono
parents:
diff changeset
1111 #define FROM_INT_WIDTH (FROM_INT_SIZE * __CHAR_BIT__)
kono
parents:
diff changeset
1112 #endif
kono
parents:
diff changeset
1113
kono
parents:
diff changeset
1114 #if FROM_TYPE == 2 /* Unsigned integer. */
kono
parents:
diff changeset
1115 #define FROM_INT_WIDTH (FROM_INT_SIZE * __CHAR_BIT__)
kono
parents:
diff changeset
1116 #endif
kono
parents:
diff changeset
1117
kono
parents:
diff changeset
1118 #if FROM_TYPE == 4 /* Fixed-point. */
kono
parents:
diff changeset
1119 #define FROM_FIXED_C_TYPE FIXED_C_TYPE2(FROM_MODE_NAME)
kono
parents:
diff changeset
1120 #define FROM_FBITS FBITS2(FROM_MODE_NAME)
kono
parents:
diff changeset
1121 #define FROM_FIXED_WIDTH (FROM_FIXED_SIZE * __CHAR_BIT__)
kono
parents:
diff changeset
1122 #define FROM_FBITS FBITS2(FROM_MODE_NAME)
kono
parents:
diff changeset
1123 #define FROM_IBITS IBITS2(FROM_MODE_NAME)
kono
parents:
diff changeset
1124 #define FROM_I_F_BITS (FROM_FBITS + FROM_IBITS)
kono
parents:
diff changeset
1125
kono
parents:
diff changeset
1126 #if FROM_MODE_UNSIGNED == 0 /* Signed types. */
kono
parents:
diff changeset
1127 #define FROM_PADDING_BITS (FROM_FIXED_WIDTH - 1 - FROM_I_F_BITS)
kono
parents:
diff changeset
1128 #define FROM_NONPADDING_BITS (1 + FROM_I_F_BITS)
kono
parents:
diff changeset
1129 #else /* Unsigned types. */
kono
parents:
diff changeset
1130 #define FROM_PADDING_BITS (FROM_FIXED_WIDTH - FROM_I_F_BITS)
kono
parents:
diff changeset
1131 #define FROM_NONPADDING_BITS (FROM_I_F_BITS)
kono
parents:
diff changeset
1132 #endif
kono
parents:
diff changeset
1133 #define FROM_HAVE_PADDING_BITS (FROM_PADDING_BITS > 0)
kono
parents:
diff changeset
1134 #endif /* FROM_TYPE == 4 */
kono
parents:
diff changeset
1135
kono
parents:
diff changeset
1136 #if TO_TYPE == 4 /* Fixed-point. */
kono
parents:
diff changeset
1137 #define TO_FIXED_C_TYPE FIXED_C_TYPE2(TO_MODE_NAME)
kono
parents:
diff changeset
1138 #define TO_FBITS FBITS2(TO_MODE_NAME)
kono
parents:
diff changeset
1139 #define TO_FIXED_WIDTH (TO_FIXED_SIZE * __CHAR_BIT__)
kono
parents:
diff changeset
1140 #define TO_FBITS FBITS2(TO_MODE_NAME)
kono
parents:
diff changeset
1141 #define TO_IBITS IBITS2(TO_MODE_NAME)
kono
parents:
diff changeset
1142 #define TO_I_F_BITS (TO_FBITS + TO_IBITS)
kono
parents:
diff changeset
1143
kono
parents:
diff changeset
1144 #if TO_MODE_UNSIGNED == 0 /* Signed types. */
kono
parents:
diff changeset
1145 #define TO_PADDING_BITS (TO_FIXED_WIDTH - 1 - TO_I_F_BITS)
kono
parents:
diff changeset
1146 #define TO_NONPADDING_BITS (1 + TO_I_F_BITS)
kono
parents:
diff changeset
1147 #else /* Unsigned types. */
kono
parents:
diff changeset
1148 #define TO_PADDING_BITS (TO_FIXED_WIDTH - TO_I_F_BITS)
kono
parents:
diff changeset
1149 #define TO_NONPADDING_BITS (TO_I_F_BITS)
kono
parents:
diff changeset
1150 #endif
kono
parents:
diff changeset
1151 #define TO_HAVE_PADDING_BITS (TO_PADDING_BITS > 0)
kono
parents:
diff changeset
1152 #endif /* TO_TYPE == 4 */
kono
parents:
diff changeset
1153
kono
parents:
diff changeset
1154 #ifdef LIBGCC2_FIXEDBIT_GNU_PREFIX
kono
parents:
diff changeset
1155 #define FIXED_CONVERT_OP(OP,FROM,TO) __gnu_ ## OP ## FROM ## TO
kono
parents:
diff changeset
1156 #define FIXED_CONVERT_OP2(OP,FROM,TO) __gnu_ ## OP ## FROM ## TO ## 2
kono
parents:
diff changeset
1157 #else
kono
parents:
diff changeset
1158 #define FIXED_CONVERT_OP(OP,FROM,TO) __ ## OP ## FROM ## TO
kono
parents:
diff changeset
1159 #define FIXED_CONVERT_OP2(OP,FROM,TO) __ ## OP ## FROM ## TO ## 2
kono
parents:
diff changeset
1160 #endif
kono
parents:
diff changeset
1161 #define FRACT_TEMP(N1,N2) FIXED_CONVERT_OP(fract,N1,N2)
kono
parents:
diff changeset
1162 #define FRACT2_TEMP(N1,N2) FIXED_CONVERT_OP2(fract,N1,N2)
kono
parents:
diff changeset
1163 #define SATFRACT_TEMP(N1,N2) FIXED_CONVERT_OP(satfract,N1,N2)
kono
parents:
diff changeset
1164 #define SATFRACT2_TEMP(N1,N2) FIXED_CONVERT_OP2(satfract,N1,N2)
kono
parents:
diff changeset
1165 #define FRACTUNS_TEMP(N1,N2) FIXED_CONVERT_OP(fractuns,N1,N2)
kono
parents:
diff changeset
1166 #define SATFRACTUNS_TEMP(N1,N2) FIXED_CONVERT_OP(satfractuns,N1,N2)
kono
parents:
diff changeset
1167
kono
parents:
diff changeset
1168 /* Define conversions from fixed-point to fixed-point. */
kono
parents:
diff changeset
1169 #if FROM_TYPE == 4 && TO_TYPE == 4
kono
parents:
diff changeset
1170
kono
parents:
diff changeset
1171 #if FROM_FIXED_SIZE > TO_FIXED_SIZE
kono
parents:
diff changeset
1172 #define BIG_SINT_C_TYPE FROM_SINT_C_TYPE
kono
parents:
diff changeset
1173 #define BIG_UINT_C_TYPE FROM_UINT_C_TYPE
kono
parents:
diff changeset
1174 #define BIG_WIDTH FROM_FIXED_WIDTH
kono
parents:
diff changeset
1175 #else
kono
parents:
diff changeset
1176 #define BIG_SINT_C_TYPE TO_SINT_C_TYPE
kono
parents:
diff changeset
1177 #define BIG_UINT_C_TYPE TO_UINT_C_TYPE
kono
parents:
diff changeset
1178 #define BIG_WIDTH TO_FIXED_WIDTH
kono
parents:
diff changeset
1179 #endif
kono
parents:
diff changeset
1180
kono
parents:
diff changeset
1181 /* Check if FROM* and TO* are in the same machine class. */
kono
parents:
diff changeset
1182 #if ((FROM_MODE_UNSIGNED == TO_MODE_UNSIGNED) \
kono
parents:
diff changeset
1183 && ((FROM_IBITS == 0) == (TO_IBITS == 0)))
kono
parents:
diff changeset
1184 /* Same modes: append '2' to conversion function names */
kono
parents:
diff changeset
1185 #define FRACT FRACT2_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1186 #define SATFRACT SATFRACT2_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1187 #else
kono
parents:
diff changeset
1188 /* Different modes: don't append '2' to conversion function names */
kono
parents:
diff changeset
1189 #define FRACT FRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1190 #define SATFRACT SATFRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1191 #endif
kono
parents:
diff changeset
1192
kono
parents:
diff changeset
1193 extern TO_FIXED_C_TYPE FRACT (FROM_FIXED_C_TYPE);
kono
parents:
diff changeset
1194 extern TO_FIXED_C_TYPE SATFRACT (FROM_FIXED_C_TYPE);
kono
parents:
diff changeset
1195 #endif /* FROM_TYPE == 4 && TO_TYPE == 4 */
kono
parents:
diff changeset
1196
kono
parents:
diff changeset
1197 /* Define conversions from fixed-point to signed integer. */
kono
parents:
diff changeset
1198 #if FROM_TYPE == 4 && TO_TYPE == 1
kono
parents:
diff changeset
1199 #define FRACT FRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1200 extern TO_INT_C_TYPE FRACT (FROM_FIXED_C_TYPE);
kono
parents:
diff changeset
1201 #endif /* FROM_TYPE == 4 && TO_TYPE == 1 */
kono
parents:
diff changeset
1202
kono
parents:
diff changeset
1203 /* Define conversions from fixed-point to unsigned integer. */
kono
parents:
diff changeset
1204 #if FROM_TYPE == 4 && TO_TYPE == 2
kono
parents:
diff changeset
1205 #define FRACTUNS FRACTUNS_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1206 extern TO_INT_C_TYPE FRACTUNS (FROM_FIXED_C_TYPE);
kono
parents:
diff changeset
1207 #endif /* FROM_TYPE == 4 && TO_TYPE == 2 */
kono
parents:
diff changeset
1208
kono
parents:
diff changeset
1209 /* Define conversions from fixed-point to floating-point. */
kono
parents:
diff changeset
1210 #if FROM_TYPE == 4 && TO_TYPE == 3
kono
parents:
diff changeset
1211 #define BASE1(NUM) 0x1.0p ## NUM
kono
parents:
diff changeset
1212 #define BASE2(NUM) BASE1(NUM)
kono
parents:
diff changeset
1213 #define BASE BASE2(FROM_FBITS)
kono
parents:
diff changeset
1214 #define FRACT FRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1215 extern TO_FLOAT_C_TYPE FRACT (FROM_FIXED_C_TYPE);
kono
parents:
diff changeset
1216 #endif /* FROM_TYPE == 4 && TO_TYPE == 3 */
kono
parents:
diff changeset
1217
kono
parents:
diff changeset
1218 /* Define conversions from signed integer to fixed-point. */
kono
parents:
diff changeset
1219 #if FROM_TYPE == 1 && TO_TYPE == 4
kono
parents:
diff changeset
1220
kono
parents:
diff changeset
1221 #if FROM_INT_SIZE > TO_FIXED_SIZE
kono
parents:
diff changeset
1222 #define BIG_SINT_C_TYPE FROM_SINT_C_TYPE
kono
parents:
diff changeset
1223 #define BIG_UINT_C_TYPE FROM_UINT_C_TYPE
kono
parents:
diff changeset
1224 #define BIG_WIDTH FROM_INT_WIDTH
kono
parents:
diff changeset
1225 #else
kono
parents:
diff changeset
1226 #define BIG_SINT_C_TYPE TO_SINT_C_TYPE
kono
parents:
diff changeset
1227 #define BIG_UINT_C_TYPE TO_UINT_C_TYPE
kono
parents:
diff changeset
1228 #define BIG_WIDTH TO_FIXED_WIDTH
kono
parents:
diff changeset
1229 #endif
kono
parents:
diff changeset
1230
kono
parents:
diff changeset
1231 #define FRACT FRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1232 #define SATFRACT SATFRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1233 extern TO_FIXED_C_TYPE FRACT (FROM_INT_C_TYPE);
kono
parents:
diff changeset
1234 extern TO_FIXED_C_TYPE SATFRACT (FROM_INT_C_TYPE);
kono
parents:
diff changeset
1235 #endif /* FROM_TYPE == 1 && TO_TYPE == 4 */
kono
parents:
diff changeset
1236
kono
parents:
diff changeset
1237 /* Define conversions from unsigned integer to fixed-point. */
kono
parents:
diff changeset
1238 #if FROM_TYPE == 2 && TO_TYPE == 4
kono
parents:
diff changeset
1239
kono
parents:
diff changeset
1240 #if FROM_INT_SIZE > TO_FIXED_SIZE
kono
parents:
diff changeset
1241 #define BIG_SINT_C_TYPE FROM_SINT_C_TYPE
kono
parents:
diff changeset
1242 #define BIG_UINT_C_TYPE FROM_UINT_C_TYPE
kono
parents:
diff changeset
1243 #define BIG_WIDTH FROM_INT_WIDTH
kono
parents:
diff changeset
1244 #else
kono
parents:
diff changeset
1245 #define BIG_SINT_C_TYPE TO_SINT_C_TYPE
kono
parents:
diff changeset
1246 #define BIG_UINT_C_TYPE TO_UINT_C_TYPE
kono
parents:
diff changeset
1247 #define BIG_WIDTH TO_FIXED_WIDTH
kono
parents:
diff changeset
1248 #endif
kono
parents:
diff changeset
1249
kono
parents:
diff changeset
1250 #define FRACTUNS FRACTUNS_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1251 #define SATFRACTUNS SATFRACTUNS_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1252 extern TO_FIXED_C_TYPE FRACTUNS (FROM_INT_C_TYPE);
kono
parents:
diff changeset
1253 extern TO_FIXED_C_TYPE SATFRACTUNS (FROM_INT_C_TYPE);
kono
parents:
diff changeset
1254 #endif /* FROM_TYPE == 2 && TO_TYPE == 4 */
kono
parents:
diff changeset
1255
kono
parents:
diff changeset
1256 /* Define conversions from floating-point to fixed-point. */
kono
parents:
diff changeset
1257 #if FROM_TYPE == 3 && TO_TYPE == 4
kono
parents:
diff changeset
1258
kono
parents:
diff changeset
1259 #define BASE1(NUM) (0x1.0p ## NUM)
kono
parents:
diff changeset
1260 #define BASE2(NUM) BASE1(NUM)
kono
parents:
diff changeset
1261 #define BASE BASE2(TO_FBITS)
kono
parents:
diff changeset
1262
kono
parents:
diff changeset
1263 #define FIXED_MAX1(NUM1,NUM2) (0x1.0p ## NUM1 - 0x1.0p- ## NUM2)
kono
parents:
diff changeset
1264 #define FIXED_MAX2(NUM1,NUM2) FIXED_MAX1(NUM1,NUM2)
kono
parents:
diff changeset
1265 #define FIXED_MAX FIXED_MAX2(TO_IBITS,TO_FBITS)
kono
parents:
diff changeset
1266
kono
parents:
diff changeset
1267 #define FIXED_MIN1(NUM) (-0x1.0p ## NUM)
kono
parents:
diff changeset
1268 #define FIXED_MIN2(NUM) FIXED_MIN1(NUM)
kono
parents:
diff changeset
1269 #if TO_MODE_UNSIGNED == 0
kono
parents:
diff changeset
1270 #define FIXED_MIN FIXED_MIN2(TO_IBITS)
kono
parents:
diff changeset
1271 #else
kono
parents:
diff changeset
1272 #define FIXED_MIN 0.0
kono
parents:
diff changeset
1273 #endif
kono
parents:
diff changeset
1274
kono
parents:
diff changeset
1275 #define FRACT FRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1276 #define SATFRACT SATFRACT_TEMP(FROM_MODE_NAME_S,TO_MODE_NAME_S)
kono
parents:
diff changeset
1277 extern TO_FIXED_C_TYPE FRACT (FROM_FLOAT_C_TYPE);
kono
parents:
diff changeset
1278 extern TO_FIXED_C_TYPE SATFRACT (FROM_FLOAT_C_TYPE);
kono
parents:
diff changeset
1279 #endif /* FROM_TYPE == 3 && TO_TYPE == 4 */
kono
parents:
diff changeset
1280
kono
parents:
diff changeset
1281 #endif /* defined (FROM_MODE_NAME_S) && defined (TO_MODE_NAME_S) */
kono
parents:
diff changeset
1282
kono
parents:
diff changeset
1283 #endif /* _FIXED_BIT_H */