some work
This commit is contained in:
parent
d8c4d054d3
commit
87b0968e0d
|
@ -27,7 +27,7 @@ extern "C" {
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ccr_mce_privkey {
|
struct ccr_mce_privkey {
|
||||||
/* params */
|
/* params, n and t are input params */
|
||||||
int n, k, t;
|
int n, k, t;
|
||||||
|
|
||||||
/* goppa polynomial of degree t */
|
/* goppa polynomial of degree t */
|
||||||
|
@ -39,11 +39,11 @@ extern "C" {
|
||||||
/* inverse of P permutation */
|
/* inverse of P permutation */
|
||||||
ccr_perm pinv;
|
ccr_perm pinv;
|
||||||
|
|
||||||
|
/* systematic form permutation (inv.) */
|
||||||
|
ccr_perm psys;
|
||||||
|
|
||||||
/* parity check matrix */
|
/* parity check matrix */
|
||||||
ccr_mtx h;
|
ccr_mtx h;
|
||||||
|
|
||||||
/* TODO: also consider storing the squareroot-mod-poly mtx,
|
|
||||||
* although it's derivable from poly. */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ccr_nd_pubkey {
|
struct ccr_nd_pubkey {
|
||||||
|
|
|
@ -7,5 +7,10 @@
|
||||||
void ccr_mtx_add (int, int, ccr_mtx, ccr_mtx, ccr_mtx);
|
void ccr_mtx_add (int, int, ccr_mtx, ccr_mtx, ccr_mtx);
|
||||||
void ccr_mtx_multiply (int, int, int, ccr_mtx, ccr_mtx, ccr_mtx);
|
void ccr_mtx_multiply (int, int, int, ccr_mtx, ccr_mtx, ccr_mtx);
|
||||||
|
|
||||||
|
int ccr_log2 (int, int*);
|
||||||
|
int ccr_gen_irred_poly (ccr_mtx, int);
|
||||||
|
|
||||||
|
int ccr_goppa_check_mtx (ccr_mtx, int, int, ccr_mtx*, int*, int*);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
55
lib/mce.c
55
lib/mce.c
|
@ -0,0 +1,55 @@
|
||||||
|
|
||||||
|
#include "codecrypt.h"
|
||||||
|
#include "math.h"
|
||||||
|
#include "tools.h"
|
||||||
|
|
||||||
|
int ccr_mce_gen (struct ccr_mce_pubkey* Pub, struct ccr_mce_privkey* Priv)
|
||||||
|
{
|
||||||
|
/* params are taken from privkey matrix */
|
||||||
|
|
||||||
|
int ret;
|
||||||
|
int m;
|
||||||
|
ccr_mtx h;
|
||||||
|
int h_cols, h_rows;
|
||||||
|
|
||||||
|
/* param n must be power of 2 */
|
||||||
|
if (ccr_log2 (Priv->n, &m) ) {
|
||||||
|
ret = 1;
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* check sanity of t param, k<=n-mt */
|
||||||
|
if (Priv->n >= m * Priv->t) {
|
||||||
|
ret = 2;
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* allocate space for goppa polynomial */
|
||||||
|
Priv->poly = ccr_malloc (ccr_mtx_alloc_size (t + 1, 1) );
|
||||||
|
if (!Priv->poly) {
|
||||||
|
ret = 3;
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* generate the polynomial */
|
||||||
|
if (ccr_gen_irred_poly (Priv->poly, Priv->t) ) {
|
||||||
|
ret = 4;
|
||||||
|
goto fail_free_poly;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* create canonical check matrix */
|
||||||
|
if (ccr_goppa_check_mtx (Priv->poly, m, Priv->t, &h, &h_cols, &h_rows) ) {
|
||||||
|
ret = 5;
|
||||||
|
goto fail_free_poly;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(ccr_goppa_systematic_form(h,h_cols,h_rows,
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
fail_free_poly:
|
||||||
|
ccr_free (Priv->poly);
|
||||||
|
fail:
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue