Correct a bug in BN_kronecker.

Sketch the test for BN_kronecker.
This commit is contained in:
Bodo Möller 2000-11-28 07:53:35 +00:00
parent 24b44446e2
commit d79cab27a5
2 changed files with 11 additions and 1 deletions

View file

@ -146,7 +146,7 @@ int BN_kronecker(const BIGNUM *a, const BIGNUM *b, BN_CTX *ctx)
if (BN_is_zero(A))
{
ret = BN_is_one(B);
ret = BN_is_one(B) ? ret : 0;
goto end;
}

View file

@ -902,7 +902,17 @@ int test_exp(BIO *bp, BN_CTX *ctx)
int test_kron(BIO *bp, BN_CTX *ctx)
{
/* We test BN_kronecker(a, b, ctx) just for b odd (Jacobi symbol).
* In this case we know that if b is prime, then BN_kronecker(a, b, ctx)
* is congruent to $a^{(b-1)/2}$, modulo $b$ (Legendre symbol).
* So we generate a random prime b and compare these values
* for a number of random a's. (That is, we run the Solovay-Strassen
* primality test to confirm that b is prime, except that we
* don't want to test whether b is prime but whether BN_kronecker
* works.) */
/* XXX */
return(1);
}