b2a00c8984
libgcc/ 2007-09-27 H.J. Lu <hongjiu.lu@intel.com> * Makefile.in (dfp-filenames): Replace decimal_globals, decimal_data, binarydecimal and convert_data with bid_decimal_globals, bid_decimal_data, bid_binarydecimal and bid_convert_data, respectively. libgcc/config/libbid/ 2007-09-27 H.J. Lu <hongjiu.lu@intel.com> * bid128_fromstring.c: Removed. * bid_dpd.c: New from libbid 2007-09-26. * bid128_to_int16.c: Likewise. * bid128_to_int8.c: Likewise. * bid128_to_uint8.c: Likewise. * bid128_to_uint16.c: Likewise. * bid64_to_int16.c: Likewise. * bid64_to_int8.c: Likewise. * bid64_to_uint16.c: Likewise. * bid64_to_uint8.c: Likewise. * bid128_2_str.h: Updated from libbid 2007-09-26. * bid128_2_str_macros.h: Likewise. * bid128_2_str_tables.c: Likewise. * bid128_add.c: Likewise. * bid128.c: Likewise. * bid128_compare.c: Likewise. * bid128_div.c: Likewise. * bid128_fma.c: Likewise. * bid128_logb.c: Likewise. * bid128_minmax.c: Likewise. * bid128_mul.c: Likewise. * bid128_next.c: Likewise. * bid128_noncomp.c: Likewise. * bid128_quantize.c: Likewise. * bid128_rem.c: Likewise. * bid128_round_integral.c: Likewise. * bid128_scalb.c: Likewise. * bid128_sqrt.c: Likewise. * bid128_string.c: Likewise. * bid128_to_int32.c: Likewise. * bid128_to_int64.c: Likewise. * bid128_to_uint32.c: Likewise. * bid128_to_uint64.c: Likewise. * bid32_to_bid128.c: Likewise. * bid32_to_bid64.c: Likewise. * bid64_add.c: Likewise. * bid64_compare.c: Likewise. * bid64_div.c: Likewise. * bid64_fma.c: Likewise. * bid64_logb.c: Likewise. * bid64_minmax.c: Likewise. * bid64_mul.c: Likewise. * bid64_next.c: Likewise. * bid64_noncomp.c: Likewise. * bid64_quantize.c: Likewise. * bid64_rem.c: Likewise. * bid64_round_integral.c: Likewise. * bid64_scalb.c: Likewise. * bid64_sqrt.c: Likewise. * bid64_string.c: Likewise. * bid64_to_bid128.c: Likewise. * bid64_to_int32.c: Likewise. * bid64_to_int64.c: Likewise. * bid64_to_uint32.c: Likewise. * bid64_to_uint64.c: Likewise. * bid_b2d.h: Likewise. * bid_binarydecimal.c: Likewise. * bid_conf.h: Likewise. * bid_convert_data.c: Likewise. * bid_decimal_data.c: Likewise. * bid_decimal_globals.c: Likewise. * bid_div_macros.h: Likewise. * bid_flag_operations.c: Likewise. * bid_from_int.c: Likewise. * bid_functions.h: Likewise. * bid_gcc_intrinsics.h: Likewise. * bid_inline_add.h: Likewise. * bid_internal.h: Likewise. * bid_round.c: Likewise. * bid_sqrt_macros.h: Likewise. * _addsub_dd.c: Likewise. * _addsub_sd.c: Likewise. * _addsub_td.c: Likewise. * _dd_to_df.c: Likewise. * _dd_to_di.c: Likewise. * _dd_to_sd.c: Likewise. * _dd_to_sf.c: Likewise. * _dd_to_si.c: Likewise. * _dd_to_td.c: Likewise. * _dd_to_tf.c: Likewise. * _dd_to_udi.c: Likewise. * _dd_to_usi.c: Likewise. * _dd_to_xf.c: Likewise. * _df_to_dd.c: Likewise. * _df_to_sd.c: Likewise. * _df_to_td.c: Likewise. * _di_to_dd.c: Likewise. * _di_to_sd.c: Likewise. * _di_to_td.c: Likewise. * _div_dd.c: Likewise. * _div_sd.c: Likewise. * _div_td.c: Likewise. * _eq_dd.c: Likewise. * _eq_sd.c: Likewise. * _eq_td.c: Likewise. * _ge_dd.c: Likewise. * _ge_sd.c: Likewise. * _ge_td.c: Likewise. * _gt_dd.c: Likewise. * _gt_sd.c: Likewise. * _gt_td.c: Likewise. * _isinfd128.c: Likewise. * _isinfd32.c: Likewise. * _isinfd64.c: Likewise. * _le_dd.c: Likewise. * _le_sd.c: Likewise. * _le_td.c: Likewise. * _lt_dd.c: Likewise. * _lt_sd.c: Likewise. * _lt_td.c: Likewise. * _mul_dd.c: Likewise. * _mul_sd.c: Likewise. * _mul_td.c: Likewise. * _ne_dd.c: Likewise. * _ne_sd.c: Likewise. * _ne_td.c: Likewise. * _sd_to_dd.c: Likewise. * _sd_to_df.c: Likewise. * _sd_to_di.c: Likewise. * _sd_to_sf.c: Likewise. * _sd_to_si.c: Likewise. * _sd_to_td.c: Likewise. * _sd_to_tf.c: Likewise. * _sd_to_udi.c: Likewise. * _sd_to_usi.c: Likewise. * _sd_to_xf.c: Likewise. * _sf_to_dd.c: Likewise. * _sf_to_sd.c: Likewise. * _sf_to_td.c: Likewise. * _si_to_dd.c: Likewise. * _si_to_sd.c: Likewise. * _si_to_td.c: Likewise. * _td_to_dd.c: Likewise. * _td_to_df.c: Likewise. * _td_to_di.c: Likewise. * _td_to_sd.c: Likewise. * _td_to_sf.c: Likewise. * _td_to_si.c: Likewise. * _td_to_tf.c: Likewise. * _td_to_udi.c: Likewise. * _td_to_usi.c: Likewise. * _td_to_xf.c: Likewise. * _tf_to_dd.c: Likewise. * _tf_to_sd.c: Likewise. * _tf_to_td.c: Likewise. * _udi_to_dd.c: Likewise. * _udi_to_sd.c: Likewise. * _udi_to_td.c: Likewise. * _unord_dd.c: Likewise. * _unord_sd.c: Likewise. * _unord_td.c: Likewise. * _usi_to_dd.c: Likewise. * _usi_to_sd.c: Likewise. * _usi_to_td.c: Likewise. * _xf_to_dd.c: Likewise. * _xf_to_sd.c: Likewise. * _xf_to_td.c: Likewise. 2007-09-27 H.J. Lu <hongjiu.lu@intel.com> * b2d.h: Renamed to ... * bid_b2d.h: This. * bid128_to_string.c: Renamed to ... * bid128_string.c: This. * bid_intrinsics.h: Renamed to ... * bid_gcc_intrinsics.h: This. * bid_string.c: Renamed to ... * bid64_string.c: This. * binarydecimal.c: Renamed to ... * bid_decimal_globals.c: This. * convert_data.c: Renamed to ... * bid_convert_data.c: This. * decimal_data.c: Renamed to ... * bid_decimal_data.c: This. * decimal_globals.c: Renamed to ... * bid_decimal_globals.c: This. * div_macros.h: Renamed to ... * bid_div_macros.h: This. * inline_bid_add.h: Renamed to ... * bid_inline_add.h: This. * sqrt_macros.h: Renamed to ... * bid_sqrt_macros.h: This. From-SVN: r128841
155 lines
7.0 KiB
C
155 lines
7.0 KiB
C
/* Copyright (C) 2007 Free Software Foundation, Inc.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC is free software; you can redistribute it and/or modify it under
|
|
the terms of the GNU General Public License as published by the Free
|
|
Software Foundation; either version 2, or (at your option) any later
|
|
version.
|
|
|
|
In addition to the permissions in the GNU General Public License, the
|
|
Free Software Foundation gives you unlimited permission to link the
|
|
compiled version of this file into combinations with other programs,
|
|
and to distribute those combinations without any restriction coming
|
|
from the use of this file. (The General Public License restrictions
|
|
do apply in other respects; for example, they cover modification of
|
|
the file, and distribution when not linked into a combine
|
|
executable.)
|
|
|
|
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GCC; see the file COPYING. If not, write to the Free
|
|
Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
|
|
02110-1301, USA. */
|
|
|
|
#define __L0_Normalize_10to18( X_hi, X_lo ) \
|
|
{ \
|
|
UINT64 L0_tmp; \
|
|
L0_tmp = (X_lo) + Twoto60_m_10to18; \
|
|
if (L0_tmp & Twoto60) \
|
|
{(X_hi)=(X_hi)+1;(X_lo)=((L0_tmp<<4)>>4);} \
|
|
}
|
|
|
|
|
|
#define __L0_Normalize_10to9( X_hi, X_lo ) \
|
|
{ \
|
|
UINT32 L0_tmp; \
|
|
L0_tmp = (X_lo) + Twoto30_m_10to9; \
|
|
if (L0_tmp & 0x40000000) \
|
|
{(X_hi)=(X_hi)+1;(X_lo)=((L0_tmp<<2)>>2);} \
|
|
}
|
|
|
|
|
|
#define __L0_Split_MiDi_2( X, ptr ) \
|
|
{ \
|
|
UINT32 L0_head, L0_tail, L0_tmp; \
|
|
L0_head = (X) >> 10; \
|
|
L0_tail = ((X)&(0x03FF))+(L0_head<<5)-(L0_head<<3); \
|
|
L0_tmp = (L0_tail)>>10; L0_head += L0_tmp; \
|
|
L0_tail = (L0_tail&(0x03FF))+(L0_tmp<<5)-(L0_tmp<<3); \
|
|
if (L0_tail > 999){L0_tail -= 1000; L0_head += 1;} \
|
|
*((ptr)++) = L0_head; *((ptr)++) = L0_tail; \
|
|
}
|
|
|
|
|
|
#define __L0_Split_MiDi_3( X, ptr ) \
|
|
{ \
|
|
UINT32 L0_X, L0_head, L0_mid, L0_tail, L0_tmp; \
|
|
L0_X = (UINT32)((X)); \
|
|
L0_head = ((L0_X>>17)*34359)>>18; \
|
|
L0_X -= L0_head*1000000; \
|
|
if (L0_X >= 1000000){L0_X -= 1000000;L0_head+=1;} \
|
|
L0_mid = L0_X >> 10; \
|
|
L0_tail = (L0_X & (0x03FF))+(L0_mid<<5)-(L0_mid<<3); \
|
|
L0_tmp = (L0_tail)>>10; L0_mid += L0_tmp; \
|
|
L0_tail = (L0_tail&(0x3FF))+(L0_tmp<<5)-(L0_tmp<<3); \
|
|
if (L0_tail>999){L0_tail-=1000;L0_mid+=1;} \
|
|
*((ptr)++)=L0_head;*((ptr)++)=L0_mid; \
|
|
*((ptr)++)=L0_tail; \
|
|
}
|
|
|
|
#define __L1_Split_MiDi_6( X, ptr ) \
|
|
{ \
|
|
UINT32 L1_X_hi, L1_X_lo; \
|
|
UINT64 L1_Xhi_64, L1_Xlo_64; \
|
|
L1_Xhi_64 = ( ((X)>>28)*Inv_Tento9 ) >> 33; \
|
|
L1_Xlo_64 = (X) - L1_Xhi_64*(UINT64)Tento9; \
|
|
if (L1_Xlo_64 >= (UINT64)Tento9) \
|
|
{L1_Xlo_64-=(UINT64)Tento9;L1_Xhi_64+=1;} \
|
|
L1_X_hi=(UINT32)L1_Xhi_64; L1_X_lo=(UINT32)L1_Xlo_64; \
|
|
__L0_Split_MiDi_3(L1_X_hi,(ptr)); \
|
|
__L0_Split_MiDi_3(L1_X_lo,(ptr)); \
|
|
}
|
|
|
|
#define __L1_Split_MiDi_6_Lead( X, ptr ) \
|
|
{ \
|
|
UINT32 L1_X_hi, L1_X_lo; \
|
|
UINT64 L1_Xhi_64, L1_Xlo_64; \
|
|
if ((X)>=(UINT64)Tento9){ \
|
|
L1_Xhi_64 = ( ((X)>>28)*Inv_Tento9 ) >> 33; \
|
|
L1_Xlo_64 = (X) - L1_Xhi_64*(UINT64)Tento9; \
|
|
if (L1_Xlo_64 >= (UINT64)Tento9) \
|
|
{L1_Xlo_64-=(UINT64)Tento9;L1_Xhi_64+=1;} \
|
|
L1_X_hi=(UINT32)L1_Xhi_64; \
|
|
L1_X_lo=(UINT32)L1_Xlo_64; \
|
|
if (L1_X_hi>=Tento6){ \
|
|
__L0_Split_MiDi_3(L1_X_hi,(ptr)); \
|
|
__L0_Split_MiDi_3(L1_X_lo,(ptr)); \
|
|
} \
|
|
else if (L1_X_hi>=Tento3){ \
|
|
__L0_Split_MiDi_2(L1_X_hi,(ptr)); \
|
|
__L0_Split_MiDi_3(L1_X_lo,(ptr)); \
|
|
} \
|
|
else { \
|
|
*((ptr)++) = L1_X_hi; \
|
|
__L0_Split_MiDi_3(L1_X_lo,(ptr)); \
|
|
} \
|
|
} \
|
|
else { \
|
|
L1_X_lo = (UINT32)(X); \
|
|
if (L1_X_lo>=Tento6){ \
|
|
__L0_Split_MiDi_3(L1_X_lo,(ptr)); \
|
|
} \
|
|
else if (L1_X_lo>=Tento3){ \
|
|
__L0_Split_MiDi_2(L1_X_lo,(ptr)); \
|
|
} \
|
|
else { \
|
|
*((ptr)++) = L1_X_lo; \
|
|
} \
|
|
} \
|
|
}
|
|
|
|
|
|
#define __L0_MiDi2Str( X, c_ptr ) \
|
|
{ \
|
|
char *L0_src; \
|
|
L0_src = midi_tbl[(X)]; \
|
|
*((c_ptr)++) = *(L0_src++); \
|
|
*((c_ptr)++) = *(L0_src++); \
|
|
*((c_ptr)++) = *(L0_src); \
|
|
}
|
|
|
|
#define __L0_MiDi2Str_Lead( X, c_ptr ) \
|
|
{ \
|
|
char *L0_src; \
|
|
L0_src = midi_tbl[(X)]; \
|
|
if ((X)>=100){ \
|
|
*((c_ptr)++) = *(L0_src++); \
|
|
*((c_ptr)++) = *(L0_src++); \
|
|
*((c_ptr)++) = *(L0_src); \
|
|
} \
|
|
else if ((X)>=10){ \
|
|
L0_src++; \
|
|
*((c_ptr)++) = *(L0_src++); \
|
|
*((c_ptr)++) = *(L0_src); \
|
|
} \
|
|
else { \
|
|
L0_src++;L0_src++; \
|
|
*((c_ptr)++) = *(L0_src); \
|
|
} \
|
|
}
|