1 |
205 |
julius |
/* flonum_const.c - Useful Flonum constants
|
2 |
|
|
Copyright 1987, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 2000, 2002,
|
3 |
|
|
2005, 2007 Free Software Foundation, Inc.
|
4 |
|
|
|
5 |
|
|
This file is part of GAS, the GNU Assembler.
|
6 |
|
|
|
7 |
|
|
GAS is free software; you can redistribute it and/or modify
|
8 |
|
|
it under the terms of the GNU General Public License as published by
|
9 |
|
|
the Free Software Foundation; either version 3, or (at your option)
|
10 |
|
|
any later version.
|
11 |
|
|
|
12 |
|
|
GAS is distributed in the hope that it will be useful,
|
13 |
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
14 |
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
15 |
|
|
GNU General Public License for more details.
|
16 |
|
|
|
17 |
|
|
You should have received a copy of the GNU General Public License
|
18 |
|
|
along with GAS; see the file COPYING. If not, write to the Free
|
19 |
|
|
Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
|
20 |
|
|
02110-1301, USA. */
|
21 |
|
|
|
22 |
|
|
#include "ansidecl.h"
|
23 |
|
|
#include "flonum.h"
|
24 |
|
|
/* JF: I added the last entry to this table, and I'm not
|
25 |
|
|
sure if its right or not. Could go either way. I wish
|
26 |
|
|
I really understood this stuff. */
|
27 |
|
|
|
28 |
|
|
const int table_size_of_flonum_powers_of_ten = 13;
|
29 |
|
|
|
30 |
|
|
static const LITTLENUM_TYPE zero[] = {
|
31 |
|
|
1
|
32 |
|
|
};
|
33 |
|
|
|
34 |
|
|
/***********************************************************************\
|
35 |
|
|
* *
|
36 |
|
|
* Warning: the low order bits may be WRONG here. *
|
37 |
|
|
* I took this from a suspect bc(1) script. *
|
38 |
|
|
* "minus_X"[] is supposed to be 10^(2^-X) expressed in base 2^16. *
|
39 |
|
|
* The radix point is just AFTER the highest element of the [] *
|
40 |
|
|
* *
|
41 |
|
|
* Because bc rounds DOWN for printing (I think), the lowest *
|
42 |
|
|
* significance littlenums should probably have 1 added to them. *
|
43 |
|
|
* *
|
44 |
|
|
\***********************************************************************/
|
45 |
|
|
|
46 |
|
|
/* JF: If this equals 6553/(2^16)+39321/(2^32)+... it approaches .1 */
|
47 |
|
|
static const LITTLENUM_TYPE minus_1[] = {
|
48 |
|
|
39322, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321,
|
49 |
|
|
39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 6553
|
50 |
|
|
};
|
51 |
|
|
|
52 |
|
|
static const LITTLENUM_TYPE plus_1[] = {
|
53 |
|
|
10
|
54 |
|
|
};
|
55 |
|
|
|
56 |
|
|
/* JF: If this equals 655/(2^16) + 23592/(2^32) + ... it approaches .01 */
|
57 |
|
|
static const LITTLENUM_TYPE minus_2[] = {
|
58 |
|
|
10486, 36700, 62914, 23592, 49807, 10485, 36700, 62914, 23592, 49807,
|
59 |
|
|
10485, 36700, 62914, 23592, 49807, 10485, 36700, 62914, 23592, 655
|
60 |
|
|
};
|
61 |
|
|
|
62 |
|
|
static const LITTLENUM_TYPE plus_2[] = {
|
63 |
|
|
100
|
64 |
|
|
};
|
65 |
|
|
|
66 |
|
|
/* This approaches .0001 */
|
67 |
|
|
static const LITTLENUM_TYPE minus_3[] = {
|
68 |
|
|
52534, 20027, 37329, 65116, 64067, 60397, 14784, 18979, 33659, 19503,
|
69 |
|
|
2726, 9542, 629, 2202, 40475, 10590, 4299, 47815, 36280, 6
|
70 |
|
|
};
|
71 |
|
|
|
72 |
|
|
static const LITTLENUM_TYPE plus_3[] = {
|
73 |
|
|
10000
|
74 |
|
|
};
|
75 |
|
|
|
76 |
|
|
/* JF: this approaches 1e-8 */
|
77 |
|
|
static const LITTLENUM_TYPE minus_4[] = {
|
78 |
|
|
22517, 49501, 54293, 19424, 60699, 6716, 24348, 22618, 23904, 21327,
|
79 |
|
|
3919, 44703, 19149, 28803, 48959, 6259, 50273, 62237, 42
|
80 |
|
|
};
|
81 |
|
|
|
82 |
|
|
/* This equals 1525 * 2^16 + 57600 */
|
83 |
|
|
static const LITTLENUM_TYPE plus_4[] = {
|
84 |
|
|
57600, 1525
|
85 |
|
|
};
|
86 |
|
|
|
87 |
|
|
/* This approaches 1e-16 */
|
88 |
|
|
static const LITTLENUM_TYPE minus_5[] = {
|
89 |
|
|
22199, 45957, 17005, 26266, 10526, 16260, 55017, 35680, 40443, 19789,
|
90 |
|
|
17356, 30195, 55905, 28426, 63010, 44197, 1844
|
91 |
|
|
};
|
92 |
|
|
|
93 |
|
|
static const LITTLENUM_TYPE plus_5[] = {
|
94 |
|
|
28609, 34546, 35
|
95 |
|
|
};
|
96 |
|
|
|
97 |
|
|
static const LITTLENUM_TYPE minus_6[] = {
|
98 |
|
|
30926, 26518, 13110, 43018, 54982, 48258, 24658, 15209, 63366, 11929,
|
99 |
|
|
20069, 43857, 60487, 51
|
100 |
|
|
};
|
101 |
|
|
|
102 |
|
|
static const LITTLENUM_TYPE plus_6[] = {
|
103 |
|
|
61313, 34220, 16731, 11629, 1262
|
104 |
|
|
};
|
105 |
|
|
|
106 |
|
|
static const LITTLENUM_TYPE minus_7[] = {
|
107 |
|
|
29819, 14733, 21490, 40602, 31315, 65186, 2695
|
108 |
|
|
};
|
109 |
|
|
|
110 |
|
|
static const LITTLENUM_TYPE plus_7[] = {
|
111 |
|
|
7937, 49002, 60772, 28216, 38893, 55975, 63988, 59711, 20227, 24
|
112 |
|
|
};
|
113 |
|
|
|
114 |
|
|
static const LITTLENUM_TYPE minus_8[] = {
|
115 |
|
|
27579, 64807, 12543, 794, 13907, 61297, 12013, 64360, 15961, 20566,
|
116 |
|
|
24178, 15922, 59427, 110
|
117 |
|
|
};
|
118 |
|
|
|
119 |
|
|
static const LITTLENUM_TYPE plus_8[] = {
|
120 |
|
|
15873, 11925, 39177, 991, 14589, 3861, 58415, 9076, 62956, 54223,
|
121 |
|
|
56328, 50180, 45274, 48333, 32537, 42547, 9731, 59679, 590
|
122 |
|
|
};
|
123 |
|
|
|
124 |
|
|
static const LITTLENUM_TYPE minus_9[] = {
|
125 |
|
|
11042, 8464, 58971, 63429, 6022, 63485, 5500, 53464, 47545, 50068,
|
126 |
|
|
56988, 22819, 49708, 54493, 9920, 47667, 40409, 35764, 10383, 54466,
|
127 |
|
|
32702, 17493, 32420, 34382, 22750, 20681, 12300
|
128 |
|
|
};
|
129 |
|
|
|
130 |
|
|
static const LITTLENUM_TYPE plus_9[] = {
|
131 |
|
|
20678, 27614, 28272, 53066, 55311, 54677, 29038, 9906, 26288, 44486,
|
132 |
|
|
13860, 7445, 54106, 15426, 21518, 25599, 29632, 52309, 61207, 26105,
|
133 |
|
|
10482, 21948, 51191, 32988, 60892, 62574, 61390, 24540, 21495, 5
|
134 |
|
|
};
|
135 |
|
|
|
136 |
|
|
static const LITTLENUM_TYPE minus_10[] = {
|
137 |
|
|
6214, 48771, 23471, 30163, 31763, 38013, 57001, 11770, 18263, 36366,
|
138 |
|
|
20742, 45086, 56969, 53231, 37856, 55814, 38057, 15692, 46761, 8713,
|
139 |
|
|
6102, 20083, 8269, 11839, 11571, 50963, 15649, 11698, 40675, 2308
|
140 |
|
|
};
|
141 |
|
|
|
142 |
|
|
static const LITTLENUM_TYPE plus_10[] = {
|
143 |
|
|
63839, 36576, 45712, 44516, 37803, 29482, 4966, 30556, 37961, 23310,
|
144 |
|
|
27070, 44972, 29507, 48257, 45209, 7494, 17831, 38728, 41577, 29443,
|
145 |
|
|
36016, 7955, 35339, 35479, 36011, 14553, 49618, 5588, 25396, 28
|
146 |
|
|
};
|
147 |
|
|
|
148 |
|
|
static const LITTLENUM_TYPE minus_11[] = {
|
149 |
|
|
16663, 56882, 61983, 7804, 36555, 32060, 34502, 1000, 14356, 21681,
|
150 |
|
|
6605, 34767, 51411, 59048, 53614, 39850, 30079, 6496, 6846, 26841,
|
151 |
|
|
40778, 19578, 59899, 44085, 54016, 24259, 11232, 21229, 21313, 81
|
152 |
|
|
};
|
153 |
|
|
|
154 |
|
|
static const LITTLENUM_TYPE plus_11[] = {
|
155 |
|
|
92, 9054, 62707, 17993, 7821, 56838, 13992, 21321, 29637, 48426,
|
156 |
|
|
42982, 38668, 49574, 28820, 18200, 18927, 53979, 16219, 37484, 2516,
|
157 |
|
|
44642, 14665, 11587, 41926, 13556, 23956, 54320, 6661, 55766, 805
|
158 |
|
|
};
|
159 |
|
|
|
160 |
|
|
static const LITTLENUM_TYPE minus_12[] = {
|
161 |
|
|
33202, 45969, 58804, 56734, 16482, 26007, 44984, 49334, 31007, 32944,
|
162 |
|
|
44517, 63329, 47131, 15291, 59465, 2264, 23218, 11829, 59771, 38798,
|
163 |
|
|
31051, 28748, 23129, 40541, 41562, 35108, 50620, 59014, 51817, 6613
|
164 |
|
|
};
|
165 |
|
|
|
166 |
|
|
static const LITTLENUM_TYPE plus_12[] = {
|
167 |
|
|
10098, 37922, 58070, 7432, 10470, 63465, 23718, 62190, 47420, 7009,
|
168 |
|
|
38443, 4587, 45596, 38472, 52129, 52779, 29012, 13559, 48688, 31678,
|
169 |
|
|
41753, 58662, 10668, 36067, 29906, 56906, 21461, 46556, 59571, 9
|
170 |
|
|
};
|
171 |
|
|
|
172 |
|
|
static const LITTLENUM_TYPE minus_13[] = {
|
173 |
|
|
45309, 27592, 37144, 34637, 34328, 41671, 34620, 24135, 53401, 22112,
|
174 |
|
|
21576, 45147, 39310, 44051, 48572, 3676, 46544, 59768, 33350, 2323,
|
175 |
|
|
49524, 61568, 3903, 36487, 36356, 30903, 14975, 9035, 29715, 667
|
176 |
|
|
};
|
177 |
|
|
|
178 |
|
|
static const LITTLENUM_TYPE plus_13[] = {
|
179 |
|
|
18788, 16960, 6318, 45685, 55400, 46230, 35794, 25588, 7253, 55541,
|
180 |
|
|
49716, 59760, 63592, 8191, 63765, 58530, 44667, 13294, 10001, 55586,
|
181 |
|
|
47887, 18738, 9509, 40896, 42506, 52580, 4171, 325, 12329, 98
|
182 |
|
|
};
|
183 |
|
|
|
184 |
|
|
/* Shut up complaints about differing pointer types. They only differ
|
185 |
|
|
in the const attribute, but there isn't any easy way to do this
|
186 |
|
|
*/
|
187 |
|
|
#define X (LITTLENUM_TYPE *)
|
188 |
|
|
|
189 |
|
|
const FLONUM_TYPE flonum_negative_powers_of_ten[] = {
|
190 |
|
|
{X zero, X zero, X zero, 0, '+'},
|
191 |
|
|
{X minus_1, X minus_1 + 19, X minus_1 + 19, -20, '+'},
|
192 |
|
|
{X minus_2, X minus_2 + 19, X minus_2 + 19, -20, '+'},
|
193 |
|
|
{X minus_3, X minus_3 + 19, X minus_3 + 19, -20, '+'},
|
194 |
|
|
{X minus_4, X minus_4 + 18, X minus_4 + 18, -20, '+'},
|
195 |
|
|
{X minus_5, X minus_5 + 16, X minus_5 + 16, -20, '+'},
|
196 |
|
|
{X minus_6, X minus_6 + 13, X minus_6 + 13, -20, '+'},
|
197 |
|
|
{X minus_7, X minus_7 + 6, X minus_7 + 6, -20, '+'},
|
198 |
|
|
{X minus_8, X minus_8 + 13, X minus_8 + 13, -40, '+'},
|
199 |
|
|
{X minus_9, X minus_9 + 26, X minus_9 + 26, -80, '+'},
|
200 |
|
|
{X minus_10, X minus_10 + 29, X minus_10 + 29, -136, '+'},
|
201 |
|
|
{X minus_11, X minus_11 + 29, X minus_11 + 29, -242, '+'},
|
202 |
|
|
{X minus_12, X minus_12 + 29, X minus_12 + 29, -455, '+'},
|
203 |
|
|
{X minus_13, X minus_13 + 29, X minus_13 + 29, -880, '+'},
|
204 |
|
|
};
|
205 |
|
|
|
206 |
|
|
const FLONUM_TYPE flonum_positive_powers_of_ten[] = {
|
207 |
|
|
{X zero, X zero, X zero, 0, '+'},
|
208 |
|
|
{X plus_1, X plus_1 + 0, X plus_1 + 0, 0, '+'},
|
209 |
|
|
{X plus_2, X plus_2 + 0, X plus_2 + 0, 0, '+'},
|
210 |
|
|
{X plus_3, X plus_3 + 0, X plus_3 + 0, 0, '+'},
|
211 |
|
|
{X plus_4, X plus_4 + 1, X plus_4 + 1, 0, '+'},
|
212 |
|
|
{X plus_5, X plus_5 + 2, X plus_5 + 2, 1, '+'},
|
213 |
|
|
{X plus_6, X plus_6 + 4, X plus_6 + 4, 2, '+'},
|
214 |
|
|
{X plus_7, X plus_7 + 9, X plus_7 + 9, 4, '+'},
|
215 |
|
|
{X plus_8, X plus_8 + 18, X plus_8 + 18, 8, '+'},
|
216 |
|
|
{X plus_9, X plus_9 + 29, X plus_9 + 29, 24, '+'},
|
217 |
|
|
{X plus_10, X plus_10 + 29, X plus_10 + 29, 77, '+'},
|
218 |
|
|
{X plus_11, X plus_11 + 29, X plus_11 + 29, 183, '+'},
|
219 |
|
|
{X plus_12, X plus_12 + 29, X plus_12 + 29, 396, '+'},
|
220 |
|
|
{X plus_13, X plus_13 + 29, X plus_13 + 29, 821, '+'},
|
221 |
|
|
};
|
222 |
|
|
|
223 |
|
|
#ifdef VMS
|
224 |
|
|
void
|
225 |
|
|
dummy1 ()
|
226 |
|
|
{
|
227 |
|
|
}
|
228 |
|
|
#endif
|