⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bn_internal.pod

📁 开源的ssl算法openssl,版本0.9.8H
💻 POD
字号:
=pod=head1 NAMEbn_mul_words, bn_mul_add_words, bn_sqr_words, bn_div_words,bn_add_words, bn_sub_words, bn_mul_comba4, bn_mul_comba8,bn_sqr_comba4, bn_sqr_comba8, bn_cmp_words, bn_mul_normal,bn_mul_low_normal, bn_mul_recursive, bn_mul_part_recursive,bn_mul_low_recursive, bn_mul_high, bn_sqr_normal, bn_sqr_recursive,bn_expand, bn_wexpand, bn_expand2, bn_fix_top, bn_check_top,bn_print, bn_dump, bn_set_max, bn_set_high, bn_set_low - BIGNUMlibrary internal functions=head1 SYNOPSIS BN_ULONG bn_mul_words(BN_ULONG *rp, BN_ULONG *ap, int num, BN_ULONG w); BN_ULONG bn_mul_add_words(BN_ULONG *rp, BN_ULONG *ap, int num,   BN_ULONG w); void     bn_sqr_words(BN_ULONG *rp, BN_ULONG *ap, int num); BN_ULONG bn_div_words(BN_ULONG h, BN_ULONG l, BN_ULONG d); BN_ULONG bn_add_words(BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,   int num); BN_ULONG bn_sub_words(BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,   int num); void bn_mul_comba4(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b); void bn_mul_comba8(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b); void bn_sqr_comba4(BN_ULONG *r, BN_ULONG *a); void bn_sqr_comba8(BN_ULONG *r, BN_ULONG *a); int bn_cmp_words(BN_ULONG *a, BN_ULONG *b, int n); void bn_mul_normal(BN_ULONG *r, BN_ULONG *a, int na, BN_ULONG *b,   int nb); void bn_mul_low_normal(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, int n); void bn_mul_recursive(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, int n2,   int dna,int dnb,BN_ULONG *tmp); void bn_mul_part_recursive(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b,   int n, int tna,int tnb, BN_ULONG *tmp); void bn_mul_low_recursive(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b,   int n2, BN_ULONG *tmp); void bn_mul_high(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, BN_ULONG *l,   int n2, BN_ULONG *tmp); void bn_sqr_normal(BN_ULONG *r, BN_ULONG *a, int n, BN_ULONG *tmp); void bn_sqr_recursive(BN_ULONG *r, BN_ULONG *a, int n2, BN_ULONG *tmp); void mul(BN_ULONG r, BN_ULONG a, BN_ULONG w, BN_ULONG c); void mul_add(BN_ULONG r, BN_ULONG a, BN_ULONG w, BN_ULONG c); void sqr(BN_ULONG r0, BN_ULONG r1, BN_ULONG a); BIGNUM *bn_expand(BIGNUM *a, int bits); BIGNUM *bn_wexpand(BIGNUM *a, int n); BIGNUM *bn_expand2(BIGNUM *a, int n); void bn_fix_top(BIGNUM *a); void bn_check_top(BIGNUM *a); void bn_print(BIGNUM *a); void bn_dump(BN_ULONG *d, int n); void bn_set_max(BIGNUM *a); void bn_set_high(BIGNUM *r, BIGNUM *a, int n); void bn_set_low(BIGNUM *r, BIGNUM *a, int n);=head1 DESCRIPTIONThis page documents the internal functions used by the OpenSSLB<BIGNUM> implementation. They are described here to facilitatedebugging and extending the library. They are I<not> to be used byapplications.=head2 The BIGNUM structure typedef struct bignum_st        {        int top;      /* number of words used in d */        BN_ULONG *d;  /* pointer to an array containing the integer value */        int max;      /* size of the d array */        int neg;      /* sign */        } BIGNUM;The integer value is stored in B<d>, a malloc()ed array of words (B<BN_ULONG>),least significant word first. A B<BN_ULONG> can be either 16, 32 or 64 bitsin size, depending on the 'number of bits' (B<BITS2>) specified inC<openssl/bn.h>.B<max> is the size of the B<d> array that has been allocated.  B<top>is the number of words being used, so for a value of 4, bn.d[0]=4 andbn.top=1.  B<neg> is 1 if the number is negative.  When a B<BIGNUM> isB<0>, the B<d> field can be B<NULL> and B<top> == B<0>.Various routines in this library require the use of temporaryB<BIGNUM> variables during their execution.  Since dynamic memoryallocation to create B<BIGNUM>s is rather expensive when used inconjunction with repeated subroutine calls, the B<BN_CTX> structure isused.  This structure contains B<BN_CTX_NUM> B<BIGNUM>s, seeL<BN_CTX_start(3)|BN_CTX_start(3)>.=head2 Low-level arithmetic operationsThese functions are implemented in C and for several platforms inassembly language:bn_mul_words(B<rp>, B<ap>, B<num>, B<w>) operates on the B<num> wordarrays B<rp> and B<ap>.  It computes B<ap> * B<w>, places the resultin B<rp>, and returns the high word (carry).bn_mul_add_words(B<rp>, B<ap>, B<num>, B<w>) operates on the B<num>word arrays B<rp> and B<ap>.  It computes B<ap> * B<w> + B<rp>, placesthe result in B<rp>, and returns the high word (carry).bn_sqr_words(B<rp>, B<ap>, B<n>) operates on the B<num> word arrayB<ap> and the 2*B<num> word array B<ap>.  It computes B<ap> * B<ap>word-wise, and places the low and high bytes of the result in B<rp>.bn_div_words(B<h>, B<l>, B<d>) divides the two word number (B<h>,B<l>)by B<d> and returns the result.bn_add_words(B<rp>, B<ap>, B<bp>, B<num>) operates on the B<num> wordarrays B<ap>, B<bp> and B<rp>.  It computes B<ap> + B<bp>, places theresult in B<rp>, and returns the high word (carry).bn_sub_words(B<rp>, B<ap>, B<bp>, B<num>) operates on the B<num> wordarrays B<ap>, B<bp> and B<rp>.  It computes B<ap> - B<bp>, places theresult in B<rp>, and returns the carry (1 if B<bp> E<gt> B<ap>, 0otherwise).bn_mul_comba4(B<r>, B<a>, B<b>) operates on the 4 word arrays B<a> andB<b> and the 8 word array B<r>.  It computes B<a>*B<b> and places theresult in B<r>.bn_mul_comba8(B<r>, B<a>, B<b>) operates on the 8 word arrays B<a> andB<b> and the 16 word array B<r>.  It computes B<a>*B<b> and places theresult in B<r>.bn_sqr_comba4(B<r>, B<a>, B<b>) operates on the 4 word arrays B<a> andB<b> and the 8 word array B<r>.bn_sqr_comba8(B<r>, B<a>, B<b>) operates on the 8 word arrays B<a> andB<b> and the 16 word array B<r>.The following functions are implemented in C:bn_cmp_words(B<a>, B<b>, B<n>) operates on the B<n> word arrays B<a>and B<b>.  It returns 1, 0 and -1 if B<a> is greater than, equal andless than B<b>.bn_mul_normal(B<r>, B<a>, B<na>, B<b>, B<nb>) operates on the B<na>word array B<a>, the B<nb> word array B<b> and the B<na>+B<nb> wordarray B<r>.  It computes B<a>*B<b> and places the result in B<r>.bn_mul_low_normal(B<r>, B<a>, B<b>, B<n>) operates on the B<n> wordarrays B<r>, B<a> and B<b>.  It computes the B<n> low words ofB<a>*B<b> and places the result in B<r>.bn_mul_recursive(B<r>, B<a>, B<b>, B<n2>, B<dna>, B<dnb>, B<t>) operateson the word arrays B<a> and B<b> of length B<n2>+B<dna> and B<n2>+B<dnb>(B<dna> and B<dnb> are currently allowed to be 0 or negative) and the 2*B<n2>word arrays B<r> and B<t>.  B<n2> must be a power of 2.  It computesB<a>*B<b> and places the result in B<r>.bn_mul_part_recursive(B<r>, B<a>, B<b>, B<n>, B<tna>, B<tnb>, B<tmp>)operates on the word arrays B<a> and B<b> of length B<n>+B<tna> andB<n>+B<tnb> and the 4*B<n> word arrays B<r> and B<tmp>.bn_mul_low_recursive(B<r>, B<a>, B<b>, B<n2>, B<tmp>) operates on theB<n2> word arrays B<r> and B<tmp> and the B<n2>/2 word arrays B<a>and B<b>.bn_mul_high(B<r>, B<a>, B<b>, B<l>, B<n2>, B<tmp>) operates on theB<n2> word arrays B<r>, B<a>, B<b> and B<l> (?) and the 3*B<n2> wordarray B<tmp>.BN_mul() calls bn_mul_normal(), or an optimized implementation if thefactors have the same size: bn_mul_comba8() is used if they are 8words long, bn_mul_recursive() if they are larger thanB<BN_MULL_SIZE_NORMAL> and the size is an exact multiple of the wordsize, and bn_mul_part_recursive() for others that are larger thanB<BN_MULL_SIZE_NORMAL>.bn_sqr_normal(B<r>, B<a>, B<n>, B<tmp>) operates on the B<n> word arrayB<a> and the 2*B<n> word arrays B<tmp> and B<r>.The implementations use the following macros which, depending on thearchitecture, may use "long long" C operations or inline assembler.They are defined in C<bn_lcl.h>.mul(B<r>, B<a>, B<w>, B<c>) computes B<w>*B<a>+B<c> and places thelow word of the result in B<r> and the high word in B<c>.mul_add(B<r>, B<a>, B<w>, B<c>) computes B<w>*B<a>+B<r>+B<c> andplaces the low word of the result in B<r> and the high word in B<c>.sqr(B<r0>, B<r1>, B<a>) computes B<a>*B<a> and places the low wordof the result in B<r0> and the high word in B<r1>.=head2 Size changesbn_expand() ensures that B<b> has enough space for a B<bits> bitnumber.  bn_wexpand() ensures that B<b> has enough space for anB<n> word number.  If the number has to be expanded, both macroscall bn_expand2(), which allocates a new B<d> array and copies thedata.  They return B<NULL> on error, B<b> otherwise.The bn_fix_top() macro reduces B<a-E<gt>top> to point to the mostsignificant non-zero word plus one when B<a> has shrunk.=head2 Debuggingbn_check_top() verifies that C<((a)-E<gt>top E<gt>= 0 && (a)-E<gt>topE<lt>= (a)-E<gt>max)>.  A violation will cause the program to abort.bn_print() prints B<a> to stderr. bn_dump() prints B<n> words at B<d>(in reverse order, i.e. most significant word first) to stderr.bn_set_max() makes B<a> a static number with a B<max> of its current size.This is used by bn_set_low() and bn_set_high() to make B<r> a read-onlyB<BIGNUM> that contains the B<n> low or high words of B<a>.If B<BN_DEBUG> is not defined, bn_check_top(), bn_print(), bn_dump()and bn_set_max() are defined as empty macros.=head1 SEE ALSOL<bn(3)|bn(3)>=cut

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -