Spaces:
Build error
Build error
/* | |
*---------------------------------------------------------------------- | |
* | |
* tclTomMathDecls.h -- | |
* | |
* This file contains the declarations for the 'libtommath' | |
* functions that are exported by the Tcl library. | |
* | |
* Copyright (c) 2005 by Kevin B. Kenny. All rights reserved. | |
* | |
* See the file "license.terms" for information on usage and redistribution | |
* of this file, and for a DISCLAIMER OF ALL WARRANTIES. | |
*/ | |
/* | |
* Define the version of the Stubs table that's exported for tommath | |
*/ | |
/* Define custom memory allocation for libtommath */ | |
/* MODULE_SCOPE void* TclBNAlloc( size_t ); */ | |
/* MODULE_SCOPE void* TclBNCalloc( size_t, size_t ); */ | |
/* MODULE_SCOPE void* TclBNRealloc( void*, size_t ); */ | |
/* MODULE_SCOPE void TclBNFree( void* ); */ | |
/* Rename the global symbols in libtommath to avoid linkage conflicts */ | |
/* | |
* WARNING: This file is automatically generated by the tools/genStubs.tcl | |
* script. Any modifications to the function declarations below should be made | |
* in the generic/tclInt.decls script. | |
*/ | |
/* !BEGIN!: Do not edit below this line. */ | |
extern "C" { | |
/* | |
* Exported function declarations: | |
*/ | |
/* 0 */ | |
EXTERN int TclBN_epoch(void); | |
/* 1 */ | |
EXTERN int TclBN_revision(void); | |
/* 2 */ | |
EXTERN mp_err TclBN_mp_add(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 3 */ | |
EXTERN mp_err TclBN_mp_add_d(const mp_int *a, mp_digit b, | |
mp_int *c); | |
/* 4 */ | |
EXTERN mp_err TclBN_mp_and(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 5 */ | |
EXTERN void TclBN_mp_clamp(mp_int *a); | |
/* 6 */ | |
EXTERN void TclBN_mp_clear(mp_int *a); | |
/* 7 */ | |
EXTERN void TclBN_mp_clear_multi(mp_int *a, ...); | |
/* 8 */ | |
EXTERN mp_ord TclBN_mp_cmp(const mp_int *a, const mp_int *b); | |
/* 9 */ | |
EXTERN mp_ord TclBN_mp_cmp_d(const mp_int *a, mp_digit b); | |
/* 10 */ | |
EXTERN mp_ord TclBN_mp_cmp_mag(const mp_int *a, const mp_int *b); | |
/* 11 */ | |
EXTERN mp_err TclBN_mp_copy(const mp_int *a, mp_int *b); | |
/* 12 */ | |
EXTERN int TclBN_mp_count_bits(const mp_int *a); | |
/* 13 */ | |
EXTERN mp_err TclBN_mp_div(const mp_int *a, const mp_int *b, | |
mp_int *q, mp_int *r); | |
/* 14 */ | |
EXTERN mp_err TclBN_mp_div_d(const mp_int *a, mp_digit b, | |
mp_int *q, mp_digit *r); | |
/* 15 */ | |
EXTERN mp_err TclBN_mp_div_2(const mp_int *a, mp_int *q); | |
/* 16 */ | |
EXTERN mp_err TclBN_mp_div_2d(const mp_int *a, int b, mp_int *q, | |
mp_int *r); | |
/* 17 */ | |
EXTERN mp_err TclBN_mp_div_3(const mp_int *a, mp_int *q, | |
mp_digit *r); | |
/* 18 */ | |
EXTERN void TclBN_mp_exch(mp_int *a, mp_int *b); | |
/* 19 */ | |
EXTERN mp_err TclBN_mp_expt_d(const mp_int *a, unsigned int b, | |
mp_int *c); | |
/* 20 */ | |
EXTERN mp_err TclBN_mp_grow(mp_int *a, int size); | |
/* 21 */ | |
EXTERN mp_err TclBN_mp_init(mp_int *a); | |
/* 22 */ | |
EXTERN mp_err TclBN_mp_init_copy(mp_int *a, const mp_int *b); | |
/* 23 */ | |
EXTERN mp_err TclBN_mp_init_multi(mp_int *a, ...); | |
/* 24 */ | |
EXTERN mp_err TclBN_mp_init_set(mp_int *a, mp_digit b); | |
/* 25 */ | |
EXTERN mp_err TclBN_mp_init_size(mp_int *a, int size); | |
/* 26 */ | |
EXTERN mp_err TclBN_mp_lshd(mp_int *a, int shift); | |
/* 27 */ | |
EXTERN mp_err TclBN_mp_mod(const mp_int *a, const mp_int *b, | |
mp_int *r); | |
/* 28 */ | |
EXTERN mp_err TclBN_mp_mod_2d(const mp_int *a, int b, mp_int *r); | |
/* 29 */ | |
EXTERN mp_err TclBN_mp_mul(const mp_int *a, const mp_int *b, | |
mp_int *p); | |
/* 30 */ | |
EXTERN mp_err TclBN_mp_mul_d(const mp_int *a, mp_digit b, | |
mp_int *p); | |
/* 31 */ | |
EXTERN mp_err TclBN_mp_mul_2(const mp_int *a, mp_int *p); | |
/* 32 */ | |
EXTERN mp_err TclBN_mp_mul_2d(const mp_int *a, int d, mp_int *p); | |
/* 33 */ | |
EXTERN mp_err TclBN_mp_neg(const mp_int *a, mp_int *b); | |
/* 34 */ | |
EXTERN mp_err TclBN_mp_or(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 35 */ | |
EXTERN mp_err TclBN_mp_radix_size(const mp_int *a, int radix, | |
int *size); | |
/* 36 */ | |
EXTERN mp_err TclBN_mp_read_radix(mp_int *a, const char *str, | |
int radix); | |
/* 37 */ | |
EXTERN void TclBN_mp_rshd(mp_int *a, int shift); | |
/* 38 */ | |
EXTERN mp_err TclBN_mp_shrink(mp_int *a); | |
/* 39 */ | |
EXTERN void TclBN_mp_set(mp_int *a, mp_digit b); | |
/* 40 */ | |
EXTERN mp_err TclBN_mp_sqr(const mp_int *a, mp_int *b); | |
/* 41 */ | |
EXTERN mp_err TclBN_mp_sqrt(const mp_int *a, mp_int *b); | |
/* 42 */ | |
EXTERN mp_err TclBN_mp_sub(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 43 */ | |
EXTERN mp_err TclBN_mp_sub_d(const mp_int *a, mp_digit b, | |
mp_int *c); | |
/* 44 */ | |
EXTERN mp_err TclBN_mp_to_unsigned_bin(const mp_int *a, | |
unsigned char *b); | |
/* 45 */ | |
EXTERN mp_err TclBN_mp_to_unsigned_bin_n(const mp_int *a, | |
unsigned char *b, unsigned long *outlen); | |
/* 46 */ | |
EXTERN mp_err TclBN_mp_toradix_n(const mp_int *a, char *str, | |
int radix, int maxlen); | |
/* 47 */ | |
EXTERN size_t TclBN_mp_unsigned_bin_size(const mp_int *a); | |
/* 48 */ | |
EXTERN mp_err TclBN_mp_xor(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 49 */ | |
EXTERN void TclBN_mp_zero(mp_int *a); | |
/* 50 */ | |
EXTERN void TclBN_reverse(unsigned char *s, int len); | |
/* 51 */ | |
EXTERN mp_err TclBN_fast_s_mp_mul_digs(const mp_int *a, | |
const mp_int *b, mp_int *c, int digs); | |
/* 52 */ | |
EXTERN mp_err TclBN_fast_s_mp_sqr(const mp_int *a, mp_int *b); | |
/* 53 */ | |
EXTERN mp_err TclBN_mp_karatsuba_mul(const mp_int *a, | |
const mp_int *b, mp_int *c); | |
/* 54 */ | |
EXTERN mp_err TclBN_mp_karatsuba_sqr(const mp_int *a, mp_int *b); | |
/* 55 */ | |
EXTERN mp_err TclBN_mp_toom_mul(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 56 */ | |
EXTERN mp_err TclBN_mp_toom_sqr(const mp_int *a, mp_int *b); | |
/* 57 */ | |
EXTERN mp_err TclBN_s_mp_add(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 58 */ | |
EXTERN mp_err TclBN_s_mp_mul_digs(const mp_int *a, const mp_int *b, | |
mp_int *c, int digs); | |
/* 59 */ | |
EXTERN mp_err TclBN_s_mp_sqr(const mp_int *a, mp_int *b); | |
/* 60 */ | |
EXTERN mp_err TclBN_s_mp_sub(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 61 */ | |
EXTERN mp_err TclBN_mp_init_set_int(mp_int *a, unsigned long i); | |
/* 62 */ | |
EXTERN mp_err TclBN_mp_set_int(mp_int *a, unsigned long i); | |
/* 63 */ | |
EXTERN int TclBN_mp_cnt_lsb(const mp_int *a); | |
/* 64 */ | |
EXTERN int TclBNInitBignumFromLong(mp_int *bignum, long initVal); | |
/* 65 */ | |
EXTERN int TclBNInitBignumFromWideInt(mp_int *bignum, | |
Tcl_WideInt initVal); | |
/* 66 */ | |
EXTERN int TclBNInitBignumFromWideUInt(mp_int *bignum, | |
Tcl_WideUInt initVal); | |
/* 67 */ | |
EXTERN mp_err TclBN_mp_expt_d_ex(const mp_int *a, mp_digit b, | |
mp_int *c, int fast); | |
/* 68 */ | |
EXTERN void TclBN_mp_set_ull(mp_int *a, Tcl_WideUInt i); | |
/* 69 */ | |
EXTERN Tcl_WideUInt TclBN_mp_get_mag_ull(const mp_int *a); | |
/* 70 */ | |
EXTERN void TclBN_mp_set_ll(mp_int *a, Tcl_WideInt i); | |
/* Slot 71 is reserved */ | |
/* Slot 72 is reserved */ | |
/* 73 */ | |
EXTERN mp_err TclBN_mp_tc_and(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 74 */ | |
EXTERN mp_err TclBN_mp_tc_or(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 75 */ | |
EXTERN mp_err TclBN_mp_tc_xor(const mp_int *a, const mp_int *b, | |
mp_int *c); | |
/* 76 */ | |
EXTERN mp_err TclBN_mp_signed_rsh(const mp_int *a, int b, | |
mp_int *c); | |
/* Slot 77 is reserved */ | |
/* 78 */ | |
EXTERN int TclBN_mp_to_ubin(const mp_int *a, unsigned char *buf, | |
size_t maxlen, size_t *written); | |
/* 79 */ | |
EXTERN mp_err TclBN_mp_div_ld(const mp_int *a, Tcl_WideUInt b, | |
mp_int *q, Tcl_WideUInt *r); | |
/* 80 */ | |
EXTERN int TclBN_mp_to_radix(const mp_int *a, char *str, | |
size_t maxlen, size_t *written, int radix); | |
typedef struct TclTomMathStubs { | |
int magic; | |
void *hooks; | |
int (*tclBN_epoch) (void); /* 0 */ | |
int (*tclBN_revision) (void); /* 1 */ | |
mp_err (*tclBN_mp_add) (const mp_int *a, const mp_int *b, mp_int *c); /* 2 */ | |
mp_err (*tclBN_mp_add_d) (const mp_int *a, mp_digit b, mp_int *c); /* 3 */ | |
mp_err (*tclBN_mp_and) (const mp_int *a, const mp_int *b, mp_int *c); /* 4 */ | |
void (*tclBN_mp_clamp) (mp_int *a); /* 5 */ | |
void (*tclBN_mp_clear) (mp_int *a); /* 6 */ | |
void (*tclBN_mp_clear_multi) (mp_int *a, ...); /* 7 */ | |
mp_ord (*tclBN_mp_cmp) (const mp_int *a, const mp_int *b); /* 8 */ | |
mp_ord (*tclBN_mp_cmp_d) (const mp_int *a, mp_digit b); /* 9 */ | |
mp_ord (*tclBN_mp_cmp_mag) (const mp_int *a, const mp_int *b); /* 10 */ | |
mp_err (*tclBN_mp_copy) (const mp_int *a, mp_int *b); /* 11 */ | |
int (*tclBN_mp_count_bits) (const mp_int *a); /* 12 */ | |
mp_err (*tclBN_mp_div) (const mp_int *a, const mp_int *b, mp_int *q, mp_int *r); /* 13 */ | |
mp_err (*tclBN_mp_div_d) (const mp_int *a, mp_digit b, mp_int *q, mp_digit *r); /* 14 */ | |
mp_err (*tclBN_mp_div_2) (const mp_int *a, mp_int *q); /* 15 */ | |
mp_err (*tclBN_mp_div_2d) (const mp_int *a, int b, mp_int *q, mp_int *r); /* 16 */ | |
mp_err (*tclBN_mp_div_3) (const mp_int *a, mp_int *q, mp_digit *r); /* 17 */ | |
void (*tclBN_mp_exch) (mp_int *a, mp_int *b); /* 18 */ | |
mp_err (*tclBN_mp_expt_d) (const mp_int *a, unsigned int b, mp_int *c); /* 19 */ | |
mp_err (*tclBN_mp_grow) (mp_int *a, int size); /* 20 */ | |
mp_err (*tclBN_mp_init) (mp_int *a); /* 21 */ | |
mp_err (*tclBN_mp_init_copy) (mp_int *a, const mp_int *b); /* 22 */ | |
mp_err (*tclBN_mp_init_multi) (mp_int *a, ...); /* 23 */ | |
mp_err (*tclBN_mp_init_set) (mp_int *a, mp_digit b); /* 24 */ | |
mp_err (*tclBN_mp_init_size) (mp_int *a, int size); /* 25 */ | |
mp_err (*tclBN_mp_lshd) (mp_int *a, int shift); /* 26 */ | |
mp_err (*tclBN_mp_mod) (const mp_int *a, const mp_int *b, mp_int *r); /* 27 */ | |
mp_err (*tclBN_mp_mod_2d) (const mp_int *a, int b, mp_int *r); /* 28 */ | |
mp_err (*tclBN_mp_mul) (const mp_int *a, const mp_int *b, mp_int *p); /* 29 */ | |
mp_err (*tclBN_mp_mul_d) (const mp_int *a, mp_digit b, mp_int *p); /* 30 */ | |
mp_err (*tclBN_mp_mul_2) (const mp_int *a, mp_int *p); /* 31 */ | |
mp_err (*tclBN_mp_mul_2d) (const mp_int *a, int d, mp_int *p); /* 32 */ | |
mp_err (*tclBN_mp_neg) (const mp_int *a, mp_int *b); /* 33 */ | |
mp_err (*tclBN_mp_or) (const mp_int *a, const mp_int *b, mp_int *c); /* 34 */ | |
mp_err (*tclBN_mp_radix_size) (const mp_int *a, int radix, int *size); /* 35 */ | |
mp_err (*tclBN_mp_read_radix) (mp_int *a, const char *str, int radix); /* 36 */ | |
void (*tclBN_mp_rshd) (mp_int *a, int shift); /* 37 */ | |
mp_err (*tclBN_mp_shrink) (mp_int *a); /* 38 */ | |
void (*tclBN_mp_set) (mp_int *a, mp_digit b); /* 39 */ | |
mp_err (*tclBN_mp_sqr) (const mp_int *a, mp_int *b); /* 40 */ | |
mp_err (*tclBN_mp_sqrt) (const mp_int *a, mp_int *b); /* 41 */ | |
mp_err (*tclBN_mp_sub) (const mp_int *a, const mp_int *b, mp_int *c); /* 42 */ | |
mp_err (*tclBN_mp_sub_d) (const mp_int *a, mp_digit b, mp_int *c); /* 43 */ | |
mp_err (*tclBN_mp_to_unsigned_bin) (const mp_int *a, unsigned char *b); /* 44 */ | |
mp_err (*tclBN_mp_to_unsigned_bin_n) (const mp_int *a, unsigned char *b, unsigned long *outlen); /* 45 */ | |
mp_err (*tclBN_mp_toradix_n) (const mp_int *a, char *str, int radix, int maxlen); /* 46 */ | |
size_t (*tclBN_mp_unsigned_bin_size) (const mp_int *a); /* 47 */ | |
mp_err (*tclBN_mp_xor) (const mp_int *a, const mp_int *b, mp_int *c); /* 48 */ | |
void (*tclBN_mp_zero) (mp_int *a); /* 49 */ | |
void (*tclBN_reverse) (unsigned char *s, int len); /* 50 */ | |
mp_err (*tclBN_fast_s_mp_mul_digs) (const mp_int *a, const mp_int *b, mp_int *c, int digs); /* 51 */ | |
mp_err (*tclBN_fast_s_mp_sqr) (const mp_int *a, mp_int *b); /* 52 */ | |
mp_err (*tclBN_mp_karatsuba_mul) (const mp_int *a, const mp_int *b, mp_int *c); /* 53 */ | |
mp_err (*tclBN_mp_karatsuba_sqr) (const mp_int *a, mp_int *b); /* 54 */ | |
mp_err (*tclBN_mp_toom_mul) (const mp_int *a, const mp_int *b, mp_int *c); /* 55 */ | |
mp_err (*tclBN_mp_toom_sqr) (const mp_int *a, mp_int *b); /* 56 */ | |
mp_err (*tclBN_s_mp_add) (const mp_int *a, const mp_int *b, mp_int *c); /* 57 */ | |
mp_err (*tclBN_s_mp_mul_digs) (const mp_int *a, const mp_int *b, mp_int *c, int digs); /* 58 */ | |
mp_err (*tclBN_s_mp_sqr) (const mp_int *a, mp_int *b); /* 59 */ | |
mp_err (*tclBN_s_mp_sub) (const mp_int *a, const mp_int *b, mp_int *c); /* 60 */ | |
mp_err (*tclBN_mp_init_set_int) (mp_int *a, unsigned long i); /* 61 */ | |
mp_err (*tclBN_mp_set_int) (mp_int *a, unsigned long i); /* 62 */ | |
int (*tclBN_mp_cnt_lsb) (const mp_int *a); /* 63 */ | |
int (*tclBNInitBignumFromLong) (mp_int *bignum, long initVal); /* 64 */ | |
int (*tclBNInitBignumFromWideInt) (mp_int *bignum, Tcl_WideInt initVal); /* 65 */ | |
int (*tclBNInitBignumFromWideUInt) (mp_int *bignum, Tcl_WideUInt initVal); /* 66 */ | |
mp_err (*tclBN_mp_expt_d_ex) (const mp_int *a, mp_digit b, mp_int *c, int fast); /* 67 */ | |
void (*tclBN_mp_set_ull) (mp_int *a, Tcl_WideUInt i); /* 68 */ | |
Tcl_WideUInt (*tclBN_mp_get_mag_ull) (const mp_int *a); /* 69 */ | |
void (*tclBN_mp_set_ll) (mp_int *a, Tcl_WideInt i); /* 70 */ | |
void (*reserved71)(void); | |
void (*reserved72)(void); | |
mp_err (*tclBN_mp_tc_and) (const mp_int *a, const mp_int *b, mp_int *c); /* 73 */ | |
mp_err (*tclBN_mp_tc_or) (const mp_int *a, const mp_int *b, mp_int *c); /* 74 */ | |
mp_err (*tclBN_mp_tc_xor) (const mp_int *a, const mp_int *b, mp_int *c); /* 75 */ | |
mp_err (*tclBN_mp_signed_rsh) (const mp_int *a, int b, mp_int *c); /* 76 */ | |
void (*reserved77)(void); | |
int (*tclBN_mp_to_ubin) (const mp_int *a, unsigned char *buf, size_t maxlen, size_t *written); /* 78 */ | |
mp_err (*tclBN_mp_div_ld) (const mp_int *a, Tcl_WideUInt b, mp_int *q, Tcl_WideUInt *r); /* 79 */ | |
int (*tclBN_mp_to_radix) (const mp_int *a, char *str, size_t maxlen, size_t *written, int radix); /* 80 */ | |
} TclTomMathStubs; | |
extern const TclTomMathStubs *tclTomMathStubsPtr; | |
} | |
/* | |
* Inline function declarations: | |
*/ | |
/* Slot 71 is reserved */ | |
/* Slot 72 is reserved */ | |
/* Slot 77 is reserved */ | |
/* !END!: Do not edit above this line. */ | |