#include "os.h" | |
#include <mp.h> | |
#include <libsec.h> | |
/* find a prime p of length n and a generator alpha of Z^*_p */ | |
/* Alg 4.86 Menezes et al () Handbook, p.164 */ | |
void | |
gensafeprime(mpint *p, mpint *alpha, int n, int accuracy) | |
{ | |
mpint *q, *b; | |
q = mpnew(n-1); | |
while(1){ | |
genprime(q, n-1, accuracy); | |
mpleft(q, 1, p); | |
mpadd(p, mpone, p); /* p = 2*q+1 */ | |
if(probably_prime(p, accuracy)) | |
break; | |
} | |
/* now find a generator alpha of the multiplicative */ | |
/* group Z*_p of order p-1=2q */ | |
b = mpnew(0); | |
while(1){ | |
mprand(n, genrandom, alpha); | |
mpmod(alpha, p, alpha); | |
mpmul(alpha, alpha, b); | |
mpmod(b, p, b); | |
if(mpcmp(b, mpone) == 0) | |
continue; | |
mpexp(alpha, q, p, b); | |
if(mpcmp(b, mpone) != 0) | |
break; | |
} | |
mpfree(b); | |
mpfree(q); | |
} |