1 /* Copyright (C) 2003-2018 Free Software Foundation, Inc.
3 This file is free software; you can redistribute it and/or modify it
4 under the terms of the GNU General Public License as published by the
5 Free Software Foundation; either version 3, or (at your option) any
8 This file is distributed in the hope that it will be useful, but
9 WITHOUT ANY WARRANTY; without even the implied warranty of
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 General Public License for more details.
13 Under Section 7 of GPL version 3, you are granted additional
14 permissions described in the GCC Runtime Library Exception, version
15 3.1, as published by the Free Software Foundation.
17 You should have received a copy of the GNU General Public License and
18 a copy of the GCC Runtime Library Exception along with this program;
19 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
20 <http://www.gnu.org/licenses/>. */
23 /* Calculate division table for SH5Media integer division
24 Contributed by Joern Rennecke
25 joern.rennecke@superh.com */
31 #define N_ENTRIES (1 << BITS)
32 #define CUTOFF_BITS 20
36 double max_defect
= 0.;
39 double min_defect
= 1e9
;
42 double max_defect2
= 0.;
45 double min_defect2
= 0.;
48 double min_defect3
= 01e9
;
52 double max_defect3
= 0.;
57 note_defect3 (int val
, double d2
, double y2d
, double x
)
59 int cutoff_val
= val
>> CUTOFF_BITS
;
65 cutoff
= (cutoff_val
* (1<<CUTOFF_BITS
) - val
) * y2d
;
66 defect
= cutoff
+ val
* d2
;
69 if (defect
> max_defect3
)
73 max_defect3_val
= val
;
75 if (defect
< min_defect3
)
79 min_defect3_val
= val
;
83 /* This function assumes 32-bit integers. */
85 calc_defect (double x
, int constant
, int factor
)
87 double y0
= (constant
- (int) floor ((x
* factor
* 64.))) / 16384.;
88 double y1
= 2 * y0
-y0
* y0
* (x
+ BIAS
/ (1.*(1LL<<30)));
93 y1
= floor (y1
* (1024 * 1024 * 1024)) / (1024 * 1024 * 1024);
105 y2d0
= floor (y1
* x
* (1LL << 60-16));
106 y2d1
= (int) (long long) y2d0
;
107 y2d
= - floor ((y1
- y0
/ (1<<30-14)) * y2d1
) / (1LL<<44);
109 if (d2
> max_defect2
)
114 if (d2
< min_defect2
)
119 /* zero times anything is trivially zero. */
120 note_defect3 ((1 << CUTOFF_BITS
) - 1, d2
, y2d
, x
);
121 note_defect3 (1 << CUTOFF_BITS
, d2
, y2d
, x
);
122 note_defect3 ((1U << 31) - (1 << CUTOFF_BITS
), d2
, y2d
, x
);
123 note_defect3 ((1U << 31) - 1, d2
, y2d
, x
);
124 note_defect3 (-1, d2
, y2d
, x
);
125 note_defect3 (-(1 << CUTOFF_BITS
), d2
, y2d
, x
);
126 note_defect3 ((1U << 31) - (1 << CUTOFF_BITS
) + 1, d2
, y2d
, x
);
127 note_defect3 (-(1U << 31), d2
, y2d
, x
);
135 unsigned char factors
[N_ENTRIES
];
136 short constants
[N_ENTRIES
];
137 int steps
= N_ENTRIES
/ 2;
138 double step
= 1. / steps
;
139 double eps30
= 1. / (1024 * 1024 * 1024);
141 for (i
= 0; i
< N_ENTRIES
; i
++)
143 double x_low
= (i
< steps
? 1. : -3.) + i
* step
;
144 double x_high
= x_low
+ step
- eps30
;
146 int factor
, constant
;
147 double low_defect
, med_defect
, high_defect
, max_defect
;
149 factor
= (1./x_low
- 1./x_high
) / step
* 256. + 0.5;
153 /* Use minimum of error function for x_med. */
154 x_med
= sqrt (256./factor
);
157 low_defect
= 1. / x_low
+ x_low
* factor
/ 256.;
158 high_defect
= 1. / x_high
+ x_high
* factor
/ 256.;
159 med_defect
= 1. / x_med
+ x_med
* factor
/ 256.;
161 = ((low_defect
> high_defect
) ^ (x_med
< 0)) ? low_defect
: high_defect
;
162 constant
= (med_defect
+ max_defect
) * 0.5 * 16384. + 0.5;
163 if (constant
< -32768 || constant
> 32767)
165 constants
[i
] = constant
;
166 calc_defect (x_low
, constant
, factor
);
167 calc_defect (x_med
, constant
, factor
);
168 calc_defect (x_high
, constant
, factor
);
170 printf ("/* This table has been generated by divtab.c .\n");
171 printf ("Defects for bias %d:\n", BIAS
);
172 printf (" Max defect: %e at %e\n", max_defect
, max_defect_x
);
173 printf (" Min defect: %e at %e\n", min_defect
, min_defect_x
);
174 printf (" Max 2nd step defect: %e at %e\n", max_defect2
, max_defect2_x
);
175 printf (" Min 2nd step defect: %e at %e\n", min_defect2
, min_defect2_x
);
176 printf (" Max div defect: %e at %d:%e\n", max_defect3
, max_defect3_val
,
178 printf (" Min div defect: %e at %d:%e\n", min_defect3
, min_defect3_val
,
180 printf (" Defect at 1: %e\n",
181 calc_defect (1., constants
[0], factors
[0]));
182 printf (" Defect at -2: %e */\n",
183 calc_defect (-2., constants
[steps
], factors
[steps
]));
184 printf ("\t.section\t.rodata\n");
185 printf ("\t.balign 2\n");
186 printf ("/* negative division constants */\n");
187 for (i
= steps
; i
< 2 * steps
; i
++)
188 printf ("\t.word\t%d\n", constants
[i
]);
189 printf ("/* negative division factors */\n");
190 for (i
= steps
; i
< 2*steps
; i
++)
191 printf ("\t.byte\t%d\n", factors
[i
]);
192 printf ("\t.skip %d\n", steps
);
193 printf ("\t.global GLOBAL(div_table):\n");
194 printf ("GLOBAL(div_table):\n");
195 printf ("\t.skip %d\n", steps
);
196 printf ("/* positive division factors */\n");
197 for (i
= 0; i
< steps
; i
++)
198 printf ("\t.byte\t%d\n", factors
[i
]);
199 printf ("/* positive division constants */\n");
200 for (i
= 0; i
< steps
; i
++)
201 printf ("\t.word\t%d\n", constants
[i
]);