aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2010-03-11 18:04:42 -0800
committerRuss Cox <rsc@swtch.com>2010-03-11 18:04:42 -0800
commit1619f52cbc2096dd2fc93b189890bc8fd0771681 (patch)
treeb0cec0fc0820afda64968abc2e4d5bc2e9b2a295 /src
parenta1afc8529d03515d361110edcabb73402527be89 (diff)
downloadplan9port-1619f52cbc2096dd2fc93b189890bc8fd0771681.tar.gz
plan9port-1619f52cbc2096dd2fc93b189890bc8fd0771681.tar.bz2
plan9port-1619f52cbc2096dd2fc93b189890bc8fd0771681.zip
probably_prime: run more than one Miller-Rabin round
R=rsc http://codereview.appspot.com/462041
Diffstat (limited to 'src')
-rw-r--r--src/libsec/port/probably_prime.c29
1 files changed, 17 insertions, 12 deletions
diff --git a/src/libsec/port/probably_prime.c b/src/libsec/port/probably_prime.c
index beb03251..2e750393 100644
--- a/src/libsec/port/probably_prime.c
+++ b/src/libsec/port/probably_prime.c
@@ -9,7 +9,7 @@
int
probably_prime(mpint *n, int nrep)
{
- int j, k, rep, nbits, isprime = 1;
+ int j, k, rep, nbits, isprime;
mpint *nm1, *q, *x, *y, *r;
if(n->sign < 0)
@@ -49,32 +49,37 @@ probably_prime(mpint *n, int nrep)
mpright(nm1, k, q); /* q = (n-1)/2**k */
for(rep = 0; rep < nrep; rep++){
-
- /* x = random in [2, n-2] */
- r = mprand(nbits, prng, nil);
- mpmod(r, nm1, x);
- mpfree(r);
- if(mpcmp(x, mpone) <= 0)
- continue;
+ for(;;){
+ /* find x = random in [2, n-2] */
+ r = mprand(nbits, prng, nil);
+ mpmod(r, nm1, x);
+ mpfree(r);
+ if(mpcmp(x, mpone) > 0)
+ break;
+ }
/* y = x**q mod n */
mpexp(x, q, n, y);
if(mpcmp(y, mpone) == 0 || mpcmp(y, nm1) == 0)
- goto done;
+ continue;
- for(j = 1; j < k; j++){
+ for(j = 1;; j++){
+ if(j >= k) {
+ isprime = 0;
+ goto done;
+ }
mpmul(y, y, x);
mpmod(x, n, y); /* y = y*y mod n */
if(mpcmp(y, nm1) == 0)
- goto done;
+ break;
if(mpcmp(y, mpone) == 0){
isprime = 0;
goto done;
}
}
- isprime = 0;
}
+ isprime = 1;
done:
mpfree(y);
mpfree(x);