#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); }