From 0fc65b37a1e7585ca2347bf61dcb8bc3a6b146a4 Mon Sep 17 00:00:00 2001 From: rsc Date: Sun, 21 Mar 2004 14:04:56 +0000 Subject: Add most of libsec. --- src/libsec/port/eggen.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 src/libsec/port/eggen.c (limited to 'src/libsec/port/eggen.c') diff --git a/src/libsec/port/eggen.c b/src/libsec/port/eggen.c new file mode 100644 index 00000000..9ea7d998 --- /dev/null +++ b/src/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