From 37da2899f40661e3e9631e497da8dc59b971cbd0 Mon Sep 17 00:00:00 2001 From: "Charles.Forsyth" Date: Fri, 22 Dec 2006 17:07:39 +0000 Subject: 20060303a --- libsec/port/eggen.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 libsec/port/eggen.c (limited to 'libsec/port/eggen.c') diff --git a/libsec/port/eggen.c b/libsec/port/eggen.c new file mode 100644 index 00000000..9ea7d998 --- /dev/null +++ b/libsec/port/eggen.c @@ -0,0 +1,21 @@ +#include "os.h" +#include +#include + +EGpriv* +eggen(int nlen, int rounds) +{ + EGpub *pub; + EGpriv *priv; + + priv = egprivalloc(); + pub = &priv->pub; + pub->p = mpnew(0); + pub->alpha = mpnew(0); + pub->key = mpnew(0); + priv->secret = mpnew(0); + gensafeprime(pub->p, pub->alpha, nlen, rounds); + mprand(nlen-1, genrandom, priv->secret); + mpexp(pub->alpha, priv->secret, pub->p, pub->key); + return priv; +} -- cgit v1.2.3