ref: 8a1c587c9c41e6ba34b50377d81465dfff8a2b20
parent: 24007b91208f732400e3f63a7f8d1d134e454d7b
author: cinap_lenrek <cinap_lenrek@felloff.net>
date: Fri Feb 10 15:42:56 EST 2017
ec(2): document ecencodepub(), ecdecodepub() and ecpubfree() and list all the curve parameter functions
--- a/sys/man/2/ec
+++ b/sys/man/2/ec
@@ -1,5 +1,10 @@
.TH EC 2
.SH NAME
+secp256r1,
+secp256k1,
+secp384r1,
+ecdominit,
+ecdomfree,
ecassign,
ecadd,
ecmul,
@@ -8,7 +13,10 @@
ecverify,
ecpubverify,
ecdsasign,
-ecdsaverify \- elliptic curve cryptography
+ecdsaverify,
+ecencodepub,
+ecdecodepub,
+ecpubfree \- elliptic curve cryptography
.SH SYNOPSIS
.B #include <u.h>
.br
@@ -19,37 +27,55 @@
.B #include <libsec.h>
.PP
.B
-void ecdominit(ECdomain *dom, void (*init)(mpint *p, mpint *a, mpint *b, mpint *x, mpint *y, mpint *n, mpint *h));
+void secp256r1(mpint *p, mpint *a, mpint *b, mpint *x, mpint *y, mpint *n, mpint *h)
.PP
.B
-void ecdomfree(ECdomain *dom);
+void secp256k1(mpint *p, mpint *a, mpint *b, mpint *x, mpint *y, mpint *n, mpint *h)
.PP
.B
-void ecassign(ECdomain *dom, ECpoint *old, ECpoint *new);
+void secp384r1(mpint *p, mpint *a, mpint *b, mpint *x, mpint *y, mpint *n, mpint *h)
.PP
.B
-void ecadd(ECdomain *dom, ECpoint *a, ECpoint *b, ECpoint *s);
+void ecdominit(ECdomain *dom, void (*init)(mpint *p, mpint *a, mpint *b, mpint *x, mpint *y, mpint *n, mpint *h))
.PP
.B
-void ecmul(ECdomain *dom, ECpoint *a, mpint *k, ECpoint *s);
+void ecdomfree(ECdomain *dom)
.PP
.B
-ECpoint* strtoec(ECdomain *dom, char *s, char **rptr, ECpoint *p);
+void ecassign(ECdomain *dom, ECpoint *old, ECpoint *new)
.PP
.B
-ECpriv* ecgen(ECdomain *dom, ECpriv *p);
+void ecadd(ECdomain *dom, ECpoint *a, ECpoint *b, ECpoint *s)
.PP
.B
-int ecverify(ECdomain *dom, ECpoint *p);
+void ecmul(ECdomain *dom, ECpoint *a, mpint *k, ECpoint *s)
.PP
.B
-int ecpubverify(ECdomain *dom, ECpub *p);
+ECpoint* strtoec(ECdomain *dom, char *s, char **rptr, ECpoint *p)
.PP
.B
-void ecdsasign(ECdomain *dom, ECpriv *priv, uchar *dig, int dlen, mpint *r, mpint *s);
+ECpriv* ecgen(ECdomain *dom, ECpriv *p)
.PP
.B
-int ecdsaverify(ECdomain *dom, ECpub *pub, uchar *dig, int dlen, mpint *r, mpint *s);
+int ecverify(ECdomain *dom, ECpoint *p)
+.PP
+.B
+int ecpubverify(ECdomain *dom, ECpub *p)
+.PP
+.B
+void ecdsasign(ECdomain *dom, ECpriv *priv, uchar *dig, int dlen, mpint *r, mpint *s)
+.PP
+.B
+int ecdsaverify(ECdomain *dom, ECpub *pub, uchar *dig, int dlen, mpint *r, mpint *s)
+.PP
+.B
+int ecencodepub(ECdomain *dom, ECpub *pub, uchar *data, int len)
+.PP
+.B
+ECpub* ecdecodepub(ECdomain *dom, uchar *data, int len)
+.PP
+.B
+void ecpubfree(ECpub *p);
.DT
.SH DESCRIPTION
These functions implement elliptic curve cryptography.
@@ -115,6 +141,19 @@
writes the signature to
.BR r " and " s
which are assumed to be allocated properly.
+.PP
+.B ecencodepub
+and
+.B ecdecodepub
+handle encoding and decoding of public keys in uncompressed format.
+Note that
+.B ecdecodepub
+also verifies that the public key is valid in the specified domain.
+.PP
+.B ecpubfree
+frees a
+.B ECpub
+structure and its associated members.
.SH RETURN VALUE
.B *verify
functions return