From: Ulf Möller Date: Thu, 27 Jan 2000 01:54:05 +0000 (+0000) Subject: New manpage. X-Git-Tag: OpenSSL_0_9_5beta1~188 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=fc58fa8bb8bfd7704079d28c97fccbf875227b83;p=oweals%2Fopenssl.git New manpage. --- diff --git a/doc/crypto/BN_mod_mul_montgomery.pod b/doc/crypto/BN_mod_mul_montgomery.pod new file mode 100644 index 0000000000..7d25dfbac4 --- /dev/null +++ b/doc/crypto/BN_mod_mul_montgomery.pod @@ -0,0 +1,94 @@ +=pod + +=head1 NAME + +BN_mod_mul_montgomery, BN_MONT_CTX_new, BN_MONT_CTX_init, +BN_MONT_CTX_free, BN_MONT_CTX_set, BN_MONT_CTX_copy, +BN_from_montgomery, BN_to_montgomery - Montgomery multiplication + +=head1 SYNOPSIS + + #include + + BN_MONT_CTX *BN_MONT_CTX_new(void); + void BN_MONT_CTX_init(BN_MONT_CTX *ctx); + void BN_MONT_CTX_free(BN_MONT_CTX *mont); + + int BN_MONT_CTX_set(BN_MONT_CTX *mont, const BIGNUM *m, BN_CTX *ctx); + BN_MONT_CTX *BN_MONT_CTX_copy(BN_MONT_CTX *to, BN_MONT_CTX *from); + + int BN_mod_mul_montgomery(BIGNUM *r, BIGNUM *a, BIGNUM *b, + BN_MONT_CTX *mont, BN_CTX *ctx); + + int BN_from_montgomery(BIGNUM *r, BIGNUM *a, BN_MONT_CTX *mont, + BN_CTX *ctx); + + int BN_to_montgomery(BIGNUM *r, BIGNUM *a, BN_MONT_CTX *mont, + BN_CTX *ctx); + +=head1 DESCRIPTION + +These functions implement Montgomery multiplication. They are used +automatically when BN_mod_exp(3) is called with suitable input, +but they may be useful when several operations are to be perfomed +using the same modulus. + +BN_MONT_CTX_new() allocates and initializes a B structure. +BN_MONT_CTX_init() initializes an existing uninitialized B. + +BN_MONT_CTX_set() sets up the B structure from the modulus B +by precomputing its inverse and a value R. + +BN_MONT_CTX_copy() copies the B B to B. + +BN_MONT_CTX_free() frees the components of the B, and, if +it was created by BN_MONT_CTX_new(), also the structure itself. + +BN_mod_mul_mont() computes Mont(B,B):=B*B*R^-1 and places +the result in B. + +BN_from_montgomery() performs the Montgomery reduction B = B*R^-1. + +BN_to_montgomery() computes Mont(B,R^2). + +For all functions, B is a previously allocated B used for +temporary variables. + +The B structure is defined as follows: + + typedef struct bn_mont_ctx_st + { + int use_word; /* 0 for word form, 1 for bignum form */ + int ri; /* number of bits in R */ + BIGNUM RR; /* R^2 (used to convert to Montgomery form) */ + BIGNUM N; /* The modulus */ + BIGNUM Ni; /* The inverse of N (bignum form) */ + BN_ULONG n0; /* The inverse of N in word form */ + int flags; + } BN_MONT_CTX; + +BN_to_montgomery() is a macro. + +=head1 RETURN VALUES + +BN_MONT_CTX_new() returns the newly allocated B, and NULL +on error. + +BN_MONT_CTX_init() and BN_MONT_CTX_free() have no return values. + +For the other functions, 1 is returned for success, 0 on error. +The error codes can be obtained by ERR_get_error(3). + +=head1 SEE ALSO + +bn(3), err(3), BN_add(3), BN_CTX_new(3) + +=head1 HISTORY + +BN_MONT_CTX_new(), BN_MONT_CTX_free(), BN_MONT_CTX_set(), +BN_mod_mul_montgomery(), BN_from_montgomery() and BN_to_montgomery() +are available in all versions of SSLeay and OpenSSL. + +BN_MONT_CTX_init() and BN_MONT_CTX_copy() were added in SSLeay 0.9.1b. + +=cut