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