Blame include/mini-gmp.h

Packit c5a612
/* mini-gmp, a minimalistic implementation of a GNU GMP subset.
Packit c5a612
Packit c5a612
Copyright 2011-2015, 2017 Free Software Foundation, Inc.
Packit c5a612
Packit c5a612
This file is part of the GNU MP Library.
Packit c5a612
Packit c5a612
The GNU MP Library is free software; you can redistribute it and/or modify
Packit c5a612
it under the terms of either:
Packit c5a612
Packit c5a612
  * the GNU Lesser General Public License as published by the Free
Packit c5a612
    Software Foundation; either version 3 of the License, or (at your
Packit c5a612
    option) any later version.
Packit c5a612
Packit c5a612
or
Packit c5a612
Packit c5a612
  * the GNU General Public License as published by the Free Software
Packit c5a612
    Foundation; either version 2 of the License, or (at your option) any
Packit c5a612
    later version.
Packit c5a612
Packit c5a612
or both in parallel, as here.
Packit c5a612
Packit c5a612
The GNU MP Library is distributed in the hope that it will be useful, but
Packit c5a612
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
Packit c5a612
or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit c5a612
for more details.
Packit c5a612
Packit c5a612
You should have received copies of the GNU General Public License and the
Packit c5a612
GNU Lesser General Public License along with the GNU MP Library.  If not,
Packit c5a612
see https://www.gnu.org/licenses/.  */
Packit c5a612
Packit c5a612
/* About mini-gmp: This is a minimal implementation of a subset of the
Packit c5a612
   GMP interface. It is intended for inclusion into applications which
Packit c5a612
   have modest bignums needs, as a fallback when the real GMP library
Packit c5a612
   is not installed.
Packit c5a612
Packit c5a612
   This file defines the public interface. */
Packit c5a612
Packit c5a612
#ifndef __MINI_GMP_H__
Packit c5a612
#define __MINI_GMP_H__
Packit c5a612
Packit c5a612
/* For size_t */
Packit c5a612
#include <stddef.h>
Packit c5a612
Packit c5a612
#if defined (__cplusplus)
Packit c5a612
extern "C" {
Packit c5a612
#endif
Packit c5a612
Packit c5a612
void mp_set_memory_functions (void *(*) (size_t),
Packit c5a612
			      void *(*) (void *, size_t, size_t),
Packit c5a612
			      void (*) (void *, size_t));
Packit c5a612
Packit c5a612
void mp_get_memory_functions (void *(**) (size_t),
Packit c5a612
			      void *(**) (void *, size_t, size_t),
Packit c5a612
			      void (**) (void *, size_t));
Packit c5a612
Packit c5a612
typedef unsigned long mp_limb_t;
Packit c5a612
typedef long mp_size_t;
Packit c5a612
typedef unsigned long mp_bitcnt_t;
Packit c5a612
Packit c5a612
typedef mp_limb_t *mp_ptr;
Packit c5a612
typedef const mp_limb_t *mp_srcptr;
Packit c5a612
Packit c5a612
typedef struct
Packit c5a612
{
Packit c5a612
  int _mp_alloc;		/* Number of *limbs* allocated and pointed
Packit c5a612
				   to by the _mp_d field.  */
Packit c5a612
  int _mp_size;			/* abs(_mp_size) is the number of limbs the
Packit c5a612
				   last field points to.  If _mp_size is
Packit c5a612
				   negative this is a negative number.  */
Packit c5a612
  mp_limb_t *_mp_d;		/* Pointer to the limbs.  */
Packit c5a612
} __mpz_struct;
Packit c5a612
Packit c5a612
typedef __mpz_struct mpz_t[1];
Packit c5a612
Packit c5a612
typedef __mpz_struct *mpz_ptr;
Packit c5a612
typedef const __mpz_struct *mpz_srcptr;
Packit c5a612
Packit c5a612
extern const int mp_bits_per_limb;
Packit c5a612
Packit c5a612
void mpn_copyi (mp_ptr, mp_srcptr, mp_size_t);
Packit c5a612
void mpn_copyd (mp_ptr, mp_srcptr, mp_size_t);
Packit c5a612
void mpn_zero (mp_ptr, mp_size_t);
Packit c5a612
Packit c5a612
int mpn_cmp (mp_srcptr, mp_srcptr, mp_size_t);
Packit c5a612
int mpn_zero_p (mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
mp_limb_t mpn_add_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t);
Packit c5a612
mp_limb_t mpn_add_n (mp_ptr, mp_srcptr, mp_srcptr, mp_size_t);
Packit c5a612
mp_limb_t mpn_add (mp_ptr, mp_srcptr, mp_size_t, mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
mp_limb_t mpn_sub_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t);
Packit c5a612
mp_limb_t mpn_sub_n (mp_ptr, mp_srcptr, mp_srcptr, mp_size_t);
Packit c5a612
mp_limb_t mpn_sub (mp_ptr, mp_srcptr, mp_size_t, mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
mp_limb_t mpn_mul_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t);
Packit c5a612
mp_limb_t mpn_addmul_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t);
Packit c5a612
mp_limb_t mpn_submul_1 (mp_ptr, mp_srcptr, mp_size_t, mp_limb_t);
Packit c5a612
Packit c5a612
mp_limb_t mpn_mul (mp_ptr, mp_srcptr, mp_size_t, mp_srcptr, mp_size_t);
Packit c5a612
void mpn_mul_n (mp_ptr, mp_srcptr, mp_srcptr, mp_size_t);
Packit c5a612
void mpn_sqr (mp_ptr, mp_srcptr, mp_size_t);
Packit c5a612
int mpn_perfect_square_p (mp_srcptr, mp_size_t);
Packit c5a612
mp_size_t mpn_sqrtrem (mp_ptr, mp_ptr, mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
mp_limb_t mpn_lshift (mp_ptr, mp_srcptr, mp_size_t, unsigned int);
Packit c5a612
mp_limb_t mpn_rshift (mp_ptr, mp_srcptr, mp_size_t, unsigned int);
Packit c5a612
Packit c5a612
mp_bitcnt_t mpn_scan0 (mp_srcptr, mp_bitcnt_t);
Packit c5a612
mp_bitcnt_t mpn_scan1 (mp_srcptr, mp_bitcnt_t);
Packit c5a612
Packit c5a612
void mpn_com (mp_ptr, mp_srcptr, mp_size_t);
Packit c5a612
mp_limb_t mpn_neg (mp_ptr, mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
mp_bitcnt_t mpn_popcount (mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
mp_limb_t mpn_invert_3by2 (mp_limb_t, mp_limb_t);
Packit c5a612
#define mpn_invert_limb(x) mpn_invert_3by2 ((x), 0)
Packit c5a612
Packit c5a612
size_t mpn_get_str (unsigned char *, int, mp_ptr, mp_size_t);
Packit c5a612
mp_size_t mpn_set_str (mp_ptr, const unsigned char *, size_t, int);
Packit c5a612
Packit c5a612
void mpz_init (mpz_t);
Packit c5a612
void mpz_init2 (mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_clear (mpz_t);
Packit c5a612
Packit c5a612
#define mpz_odd_p(z)   (((z)->_mp_size != 0) & (int) (z)->_mp_d[0])
Packit c5a612
#define mpz_even_p(z)  (! mpz_odd_p (z))
Packit c5a612
Packit c5a612
int mpz_sgn (const mpz_t);
Packit c5a612
int mpz_cmp_si (const mpz_t, long);
Packit c5a612
int mpz_cmp_ui (const mpz_t, unsigned long);
Packit c5a612
int mpz_cmp (const mpz_t, const mpz_t);
Packit c5a612
int mpz_cmpabs_ui (const mpz_t, unsigned long);
Packit c5a612
int mpz_cmpabs (const mpz_t, const mpz_t);
Packit c5a612
int mpz_cmp_d (const mpz_t, double);
Packit c5a612
int mpz_cmpabs_d (const mpz_t, double);
Packit c5a612
Packit c5a612
void mpz_abs (mpz_t, const mpz_t);
Packit c5a612
void mpz_neg (mpz_t, const mpz_t);
Packit c5a612
void mpz_swap (mpz_t, mpz_t);
Packit c5a612
Packit c5a612
void mpz_add_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
void mpz_add (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_sub_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
void mpz_ui_sub (mpz_t, unsigned long, const mpz_t);
Packit c5a612
void mpz_sub (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
void mpz_mul_si (mpz_t, const mpz_t, long int);
Packit c5a612
void mpz_mul_ui (mpz_t, const mpz_t, unsigned long int);
Packit c5a612
void mpz_mul (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_mul_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_addmul_ui (mpz_t, const mpz_t, unsigned long int);
Packit c5a612
void mpz_addmul (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_submul_ui (mpz_t, const mpz_t, unsigned long int);
Packit c5a612
void mpz_submul (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
void mpz_cdiv_qr (mpz_t, mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_fdiv_qr (mpz_t, mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_tdiv_qr (mpz_t, mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_cdiv_q (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_fdiv_q (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_tdiv_q (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_cdiv_r (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_fdiv_r (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_tdiv_r (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
void mpz_cdiv_q_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_fdiv_q_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_tdiv_q_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_cdiv_r_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_fdiv_r_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_tdiv_r_2exp (mpz_t, const mpz_t, mp_bitcnt_t);
Packit c5a612
Packit c5a612
void mpz_mod (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
void mpz_divexact (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
int mpz_divisible_p (const mpz_t, const mpz_t);
Packit c5a612
int mpz_congruent_p (const mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
unsigned long mpz_cdiv_qr_ui (mpz_t, mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_fdiv_qr_ui (mpz_t, mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_tdiv_qr_ui (mpz_t, mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_cdiv_q_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_fdiv_q_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_tdiv_q_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_cdiv_r_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_fdiv_r_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_tdiv_r_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_cdiv_ui (const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_fdiv_ui (const mpz_t, unsigned long);
Packit c5a612
unsigned long mpz_tdiv_ui (const mpz_t, unsigned long);
Packit c5a612
Packit c5a612
unsigned long mpz_mod_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
Packit c5a612
void mpz_divexact_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
Packit c5a612
int mpz_divisible_ui_p (const mpz_t, unsigned long);
Packit c5a612
Packit c5a612
unsigned long mpz_gcd_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
void mpz_gcd (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_gcdext (mpz_t, mpz_t, mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_lcm_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
void mpz_lcm (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
int mpz_invert (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
void mpz_sqrtrem (mpz_t, mpz_t, const mpz_t);
Packit c5a612
void mpz_sqrt (mpz_t, const mpz_t);
Packit c5a612
int mpz_perfect_square_p (const mpz_t);
Packit c5a612
Packit c5a612
void mpz_pow_ui (mpz_t, const mpz_t, unsigned long);
Packit c5a612
void mpz_ui_pow_ui (mpz_t, unsigned long, unsigned long);
Packit c5a612
void mpz_powm (mpz_t, const mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_powm_ui (mpz_t, const mpz_t, unsigned long, const mpz_t);
Packit c5a612
Packit c5a612
void mpz_rootrem (mpz_t, mpz_t, const mpz_t, unsigned long);
Packit c5a612
int mpz_root (mpz_t, const mpz_t, unsigned long);
Packit c5a612
Packit c5a612
void mpz_fac_ui (mpz_t, unsigned long);
Packit c5a612
void mpz_2fac_ui (mpz_t, unsigned long);
Packit c5a612
void mpz_mfac_uiui (mpz_t, unsigned long, unsigned long);
Packit c5a612
void mpz_bin_uiui (mpz_t, unsigned long, unsigned long);
Packit c5a612
Packit c5a612
int mpz_probab_prime_p (const mpz_t, int);
Packit c5a612
Packit c5a612
int mpz_tstbit (const mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_setbit (mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_clrbit (mpz_t, mp_bitcnt_t);
Packit c5a612
void mpz_combit (mpz_t, mp_bitcnt_t);
Packit c5a612
Packit c5a612
void mpz_com (mpz_t, const mpz_t);
Packit c5a612
void mpz_and (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_ior (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
void mpz_xor (mpz_t, const mpz_t, const mpz_t);
Packit c5a612
Packit c5a612
mp_bitcnt_t mpz_popcount (const mpz_t);
Packit c5a612
mp_bitcnt_t mpz_hamdist (const mpz_t, const mpz_t);
Packit c5a612
mp_bitcnt_t mpz_scan0 (const mpz_t, mp_bitcnt_t);
Packit c5a612
mp_bitcnt_t mpz_scan1 (const mpz_t, mp_bitcnt_t);
Packit c5a612
Packit c5a612
int mpz_fits_slong_p (const mpz_t);
Packit c5a612
int mpz_fits_ulong_p (const mpz_t);
Packit c5a612
long int mpz_get_si (const mpz_t);
Packit c5a612
unsigned long int mpz_get_ui (const mpz_t);
Packit c5a612
double mpz_get_d (const mpz_t);
Packit c5a612
size_t mpz_size (const mpz_t);
Packit c5a612
mp_limb_t mpz_getlimbn (const mpz_t, mp_size_t);
Packit c5a612
Packit c5a612
void mpz_realloc2 (mpz_t, mp_bitcnt_t);
Packit c5a612
mp_srcptr mpz_limbs_read (mpz_srcptr);
Packit c5a612
mp_ptr mpz_limbs_modify (mpz_t, mp_size_t);
Packit c5a612
mp_ptr mpz_limbs_write (mpz_t, mp_size_t);
Packit c5a612
void mpz_limbs_finish (mpz_t, mp_size_t);
Packit c5a612
mpz_srcptr mpz_roinit_n (mpz_t, mp_srcptr, mp_size_t);
Packit c5a612
Packit c5a612
#define MPZ_ROINIT_N(xp, xs) {{0, (xs),(xp) }}
Packit c5a612
Packit c5a612
void mpz_set_si (mpz_t, signed long int);
Packit c5a612
void mpz_set_ui (mpz_t, unsigned long int);
Packit c5a612
void mpz_set (mpz_t, const mpz_t);
Packit c5a612
void mpz_set_d (mpz_t, double);
Packit c5a612
Packit c5a612
void mpz_init_set_si (mpz_t, signed long int);
Packit c5a612
void mpz_init_set_ui (mpz_t, unsigned long int);
Packit c5a612
void mpz_init_set (mpz_t, const mpz_t);
Packit c5a612
void mpz_init_set_d (mpz_t, double);
Packit c5a612
Packit c5a612
size_t mpz_sizeinbase (const mpz_t, int);
Packit c5a612
char *mpz_get_str (char *, int, const mpz_t);
Packit c5a612
int mpz_set_str (mpz_t, const char *, int);
Packit c5a612
int mpz_init_set_str (mpz_t, const char *, int);
Packit c5a612
Packit c5a612
/* This long list taken from gmp.h. */
Packit c5a612
/* For reference, "defined(EOF)" cannot be used here.  In g++ 2.95.4,
Packit c5a612
   <iostream> defines EOF but not FILE.  */
Packit c5a612
#if defined (FILE)                                              \
Packit c5a612
  || defined (H_STDIO)                                          \
Packit c5a612
  || defined (_H_STDIO)               /* AIX */                 \
Packit c5a612
  || defined (_STDIO_H)               /* glibc, Sun, SCO */     \
Packit c5a612
  || defined (_STDIO_H_)              /* BSD, OSF */            \
Packit c5a612
  || defined (__STDIO_H)              /* Borland */             \
Packit c5a612
  || defined (__STDIO_H__)            /* IRIX */                \
Packit c5a612
  || defined (_STDIO_INCLUDED)        /* HPUX */                \
Packit c5a612
  || defined (__dj_include_stdio_h_)  /* DJGPP */               \
Packit c5a612
  || defined (_FILE_DEFINED)          /* Microsoft */           \
Packit c5a612
  || defined (__STDIO__)              /* Apple MPW MrC */       \
Packit c5a612
  || defined (_MSL_STDIO_H)           /* Metrowerks */          \
Packit c5a612
  || defined (_STDIO_H_INCLUDED)      /* QNX4 */		\
Packit c5a612
  || defined (_ISO_STDIO_ISO_H)       /* Sun C++ */		\
Packit c5a612
  || defined (__STDIO_LOADED)         /* VMS */
Packit c5a612
size_t mpz_out_str (FILE *, int, const mpz_t);
Packit c5a612
#endif
Packit c5a612
Packit c5a612
void mpz_import (mpz_t, size_t, int, size_t, int, size_t, const void *);
Packit c5a612
void *mpz_export (void *, size_t *, int, size_t, int, size_t, const mpz_t);
Packit c5a612
Packit c5a612
#if defined (__cplusplus)
Packit c5a612
}
Packit c5a612
#endif
Packit c5a612
#endif /* __MINI_GMP_H__ */