mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			182 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C
		
	
	
	
| /* Include file for internal GNU MP types and definitions.
 | |
| 
 | |
| Copyright (C) 1991, 1993, 1994, 1995, 1996, 2011 Free Software Foundation, Inc.
 | |
| 
 | |
| This file is part of the GNU MP Library.
 | |
| 
 | |
| The GNU MP Library is free software; you can redistribute it and/or modify
 | |
| it under the terms of the GNU Lesser General Public License as published by
 | |
| the Free Software Foundation; either version 2.1 of the License, or (at your
 | |
| option) any later version.
 | |
| 
 | |
| The GNU MP Library 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 Lesser General Public
 | |
| License for more details.
 | |
| 
 | |
| You should have received a copy of the GNU Lesser General Public License
 | |
| along with the GNU MP Library; see the file COPYING.LIB.  If not, write to
 | |
| the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
 | |
| MA 02111-1307, USA. */
 | |
| 
 | |
| #include <stdlib.h>
 | |
| #include "quadmath-imp.h"
 | |
| 
 | |
| #undef alloca
 | |
| #define alloca __builtin_alloca
 | |
| 
 | |
| #define ABS(x) (x >= 0 ? x : -x)
 | |
| #ifndef MIN
 | |
| #define MIN(l,o) ((l) < (o) ? (l) : (o))
 | |
| #endif
 | |
| #ifndef MAX
 | |
| #define MAX(h,i) ((h) > (i) ? (h) : (i))
 | |
| #endif
 | |
| 
 | |
| #define BITS_PER_MP_LIMB (__SIZEOF_LONG__ * __CHAR_BIT__)
 | |
| #define BYTES_PER_MP_LIMB (BITS_PER_MP_LIMB / __CHAR_BIT__)
 | |
| typedef unsigned long int	mp_limb_t;
 | |
| typedef long int		mp_limb_signed_t;
 | |
| 
 | |
| typedef mp_limb_t *             mp_ptr;
 | |
| typedef const mp_limb_t *	mp_srcptr;
 | |
| typedef long int                mp_size_t;
 | |
| typedef long int                mp_exp_t;
 | |
| 
 | |
| /* Define stuff for longlong.h.  */
 | |
| typedef unsigned int UQItype	__attribute__ ((mode (QI)));
 | |
| typedef 	 int SItype	__attribute__ ((mode (SI)));
 | |
| typedef unsigned int USItype	__attribute__ ((mode (SI)));
 | |
| typedef		 int DItype	__attribute__ ((mode (DI)));
 | |
| typedef unsigned int UDItype	__attribute__ ((mode (DI)));
 | |
| 
 | |
| typedef mp_limb_t UWtype;
 | |
| typedef unsigned int UHWtype;
 | |
| #define W_TYPE_SIZE BITS_PER_MP_LIMB
 | |
| 
 | |
| #ifdef HAVE_HIDDEN_VISIBILITY
 | |
| #define attribute_hidden __attribute__((__visibility__ ("hidden")))
 | |
| #else
 | |
| #define attribute_hidden
 | |
| #endif
 | |
| 
 | |
| #include "../../libgcc/longlong.h"
 | |
| 
 | |
| /* Copy NLIMBS *limbs* from SRC to DST.  */
 | |
| #define MPN_COPY_INCR(DST, SRC, NLIMBS) \
 | |
|   do {									\
 | |
|     mp_size_t __i;							\
 | |
|     for (__i = 0; __i < (NLIMBS); __i++)				\
 | |
|       (DST)[__i] = (SRC)[__i];						\
 | |
|   } while (0)
 | |
| #define MPN_COPY_DECR(DST, SRC, NLIMBS) \
 | |
|   do {									\
 | |
|     mp_size_t __i;							\
 | |
|     for (__i = (NLIMBS) - 1; __i >= 0; __i--)				\
 | |
|       (DST)[__i] = (SRC)[__i];						\
 | |
|   } while (0)
 | |
| #define MPN_COPY MPN_COPY_INCR
 | |
| 
 | |
| /* Zero NLIMBS *limbs* AT DST.  */
 | |
| #define MPN_ZERO(DST, NLIMBS) \
 | |
|   do {									\
 | |
|     mp_size_t __i;							\
 | |
|     for (__i = 0; __i < (NLIMBS); __i++)				\
 | |
|       (DST)[__i] = 0;							\
 | |
|   } while (0)
 | |
| 
 | |
| #define MPN_MUL_N_RECURSE(prodp, up, vp, size, tspace) \
 | |
|   do {									\
 | |
|     if ((size) < KARATSUBA_THRESHOLD)					\
 | |
|       impn_mul_n_basecase (prodp, up, vp, size);			\
 | |
|     else								\
 | |
|       impn_mul_n (prodp, up, vp, size, tspace);			\
 | |
|   } while (0);
 | |
| 
 | |
| #define __MPN(x) __quadmath_mpn_##x
 | |
| 
 | |
| /* Internal mpn calls */
 | |
| #define impn_mul_n_basecase	__MPN(impn_mul_n_basecase)
 | |
| #define impn_mul_n		__MPN(impn_mul_n)
 | |
| 
 | |
| /* Prototypes for internal mpn calls.  */
 | |
| void impn_mul_n_basecase (mp_ptr prodp, mp_srcptr up, mp_srcptr vp,
 | |
| 			  mp_size_t size) attribute_hidden;
 | |
| void impn_mul_n (mp_ptr prodp, mp_srcptr up, mp_srcptr vp, mp_size_t size,
 | |
| 		 mp_ptr tspace) attribute_hidden;
 | |
| 
 | |
| #define mpn_add_n		__MPN(add_n)
 | |
| #define mpn_addmul_1		__MPN(addmul_1)
 | |
| #define mpn_cmp			__MPN(cmp)
 | |
| #define mpn_divrem		__MPN(divrem)
 | |
| #define mpn_lshift		__MPN(lshift)
 | |
| #define mpn_mul			__MPN(mul)
 | |
| #define mpn_mul_1		__MPN(mul_1)
 | |
| #define mpn_rshift		__MPN(rshift)
 | |
| #define mpn_sub_n		__MPN(sub_n)
 | |
| #define mpn_submul_1		__MPN(submul_1)
 | |
| 
 | |
| mp_limb_t mpn_add_n (mp_ptr, mp_srcptr, mp_srcptr, mp_size_t)
 | |
|      attribute_hidden;
 | |
| mp_limb_t mpn_addmul_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t)
 | |
|      attribute_hidden;
 | |
| int mpn_cmp (mp_srcptr, mp_srcptr, mp_size_t) attribute_hidden;
 | |
| mp_limb_t mpn_divrem (mp_ptr, mp_size_t, mp_ptr, mp_size_t, mp_srcptr,
 | |
| 		      mp_size_t) attribute_hidden;
 | |
| mp_limb_t mpn_lshift (mp_ptr, mp_srcptr, mp_size_t, unsigned int)
 | |
|      attribute_hidden;
 | |
| mp_limb_t mpn_mul (mp_ptr, mp_srcptr, mp_size_t, mp_srcptr, mp_size_t)
 | |
|      attribute_hidden;
 | |
| mp_limb_t mpn_mul_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t)
 | |
|      attribute_hidden;
 | |
| mp_limb_t mpn_rshift (mp_ptr, mp_srcptr, mp_size_t, unsigned int)
 | |
|      attribute_hidden;
 | |
| mp_limb_t mpn_sub_n (mp_ptr, mp_srcptr, mp_srcptr, mp_size_t)
 | |
|      attribute_hidden;
 | |
| mp_limb_t mpn_submul_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t)
 | |
|      attribute_hidden;
 | |
| 
 | |
| #define mpn_extract_flt128 __MPN(extract_flt128)
 | |
| mp_size_t mpn_extract_flt128 (mp_ptr res_ptr, mp_size_t size, int *expt,
 | |
| 			      int *is_neg, __float128 value) attribute_hidden;
 | |
| 
 | |
| #define mpn_construct_float128 __MPN(construct_float128)
 | |
| __float128 mpn_construct_float128 (mp_srcptr frac_ptr, int expt, int sign)
 | |
|      attribute_hidden;
 | |
| 
 | |
| #define mpn_divmod(qp,np,nsize,dp,dsize) mpn_divrem (qp,0,np,nsize,dp,dsize)
 | |
| 
 | |
| static inline mp_limb_t
 | |
| mpn_add_1 (register mp_ptr res_ptr,
 | |
| 	   register mp_srcptr s1_ptr,
 | |
| 	   register mp_size_t s1_size,
 | |
| 	   register mp_limb_t s2_limb)
 | |
| {
 | |
|   register mp_limb_t x;
 | |
| 
 | |
|   x = *s1_ptr++;
 | |
|   s2_limb = x + s2_limb;
 | |
|   *res_ptr++ = s2_limb;
 | |
|   if (s2_limb < x)
 | |
|     {
 | |
|       while (--s1_size != 0)
 | |
| 	{
 | |
| 	  x = *s1_ptr++ + 1;
 | |
| 	  *res_ptr++ = x;
 | |
| 	  if (x != 0)
 | |
| 	    goto fin;
 | |
| 	}
 | |
| 
 | |
|       return 1;
 | |
|     }
 | |
| 
 | |
|  fin:
 | |
|   if (res_ptr != s1_ptr)
 | |
|     {
 | |
|       mp_size_t i;
 | |
|       for (i = 0; i < s1_size - 1; i++)
 | |
| 	res_ptr[i] = s1_ptr[i];
 | |
|     }
 | |
|   return 0;
 | |
| }
 |