Crypto: modernize ec.h

Add const, use u8
This commit is contained in:
Nekotekina 2021-01-14 13:27:24 +03:00
parent 376e564cff
commit 8b01d05146
2 changed files with 105 additions and 104 deletions

View file

@ -21,6 +21,7 @@ static void bn_zero(u8 *d, u32 n)
{
memset(d, 0, n);
}
void bn_copy(u8* d, u8* a, u32 n)
{
memcpy(d, a, n);
@ -30,7 +31,8 @@ int bn_compare(u8 *a, u8 *b, u32 n)
{
u32 i;
for (i = 0; i < n; i++) {
for (i = 0; i < n; i++)
{
if (a[i] < b[i])
return -1;
if (a[i] > b[i])
@ -47,7 +49,8 @@ static u8 bn_add_1(u8 *d, u8 *a, u8 *b, u32 n)
u8 c;
c = 0;
for (i = n - 1; i < n; i--) {
for (i = n - 1; i < n; i--)
{
dig = a[i] + b[i] + c;
c = dig >> 8;
d[i] = dig;
@ -63,7 +66,8 @@ static u8 bn_sub_1(u8 *d, u8 *a, u8 *b, u32 n)
u8 c;
c = 1;
for (i = n - 1; i < n; i--) {
for (i = n - 1; i < n; i--)
{
dig = a[i] + 255 - b[i] + c;
c = dig >> 8;
d[i] = dig;
@ -121,7 +125,8 @@ static void bn_mon_muladd_dig(u8 *d, u8 *a, u8 b, u8 *N, u32 n)
dig = d[n - 1] + a[n - 1] * b + N[n - 1] * z;
dig >>= 8;
for (i = n - 2; i < n; i--) {
for (i = n - 2; i < n; i--)
{
dig += d[i] + a[i] * b + N[i] * z;
d[i + 1] = dig;
dig >>= 8;
@ -177,7 +182,8 @@ static void bn_mon_exp(u8 *d, u8 *a, u8 *N, u32 n, u8 *e, u32 en)
bn_to_mon(d, N, n);
for (i = 0; i < en; i++)
for (mask = 0x80; mask != 0; mask >>= 1) {
for (mask = 0x80; mask != 0; mask >>= 1)
{
bn_mon_mul(t, d, d, N, n);
if ((e[i] & mask) != 0)
bn_mon_mul(d, t, a, N, n);
@ -196,17 +202,8 @@ void bn_mon_inv(u8 *d, u8 *a, u8 *N, u32 n)
bn_mon_exp(d, a, N, n, t, n);
}
void bn_copy(u8 *d, u8 *a, u32 n);
int bn_compare(u8 *a, u8 *b, u32 n);
void bn_reduce(u8 *d, u8 *N, u32 n);
void bn_add(u8 *d, u8 *a, u8 *b, u8 *N, u32 n);
void bn_sub(u8 *d, u8 *a, u8 *b, u8 *N, u32 n);
void bn_to_mon(u8 *d, u8 *N, u32 n);
void bn_from_mon(u8 *d, u8 *N, u32 n);
void bn_mon_mul(u8 *d, u8 *a, u8 *b, u8 *N, u32 n);
void bn_mon_inv(u8 *d, u8 *a, u8 *N, u32 n);
struct point {
struct point
{
u8 x[20];
u8 y[20];
};
@ -267,13 +264,13 @@ static void elt_inv(u8 *d, u8 *a)
bn_mon_inv(d, s, ec_p, 20);
}
static void point_to_mon(struct point *p)
static void point_to_mon(point* p)
{
bn_to_mon(p->x, ec_p, 20);
bn_to_mon(p->y, ec_p, 20);
}
static void point_from_mon(struct point *p)
static void point_from_mon(point* p)
{
bn_from_mon(p->x, ec_p, 20);
bn_from_mon(p->y, ec_p, 20);
@ -303,21 +300,21 @@ static int point_is_on_curve(u8 *p)
}
#endif
static void point_zero(struct point *p)
static void point_zero(point* p)
{
elt_zero(p->x);
elt_zero(p->y);
}
static int point_is_zero(struct point *p)
static int point_is_zero(point* p)
{
return elt_is_zero(p->x) && elt_is_zero(p->y);
}
static void point_double(struct point *r, struct point *p)
static void point_double(point* r, point* p)
{
u8 s[20], t[20];
struct point pp;
point pp;
u8 *px, *py, *rx, *ry;
pp = *p;
@ -327,7 +324,8 @@ static void point_double(struct point *r, struct point *p)
rx = r->x;
ry = r->y;
if (elt_is_zero(py)) {
if (elt_is_zero(py))
{
point_zero(r);
return;
}
@ -349,11 +347,11 @@ static void point_double(struct point *r, struct point *p)
elt_sub(ry, ry, py); // ry = -s*(rx-px) - py
}
static void point_add(struct point *r, struct point *p, struct point *q)
static void point_add(point* r, point* p, point* q)
{
u8 s[20], t[20], u[20];
u8 *px, *py, *qx, *qy, *rx, *ry;
struct point pp, qq;
point pp, qq;
pp = *p;
qq = *q;
@ -365,13 +363,15 @@ static void point_add(struct point *r, struct point *p, struct point *q)
rx = r->x;
ry = r->y;
if (point_is_zero(&pp)) {
if (point_is_zero(&pp))
{
elt_copy(rx, qx);
elt_copy(ry, qy);
return;
}
if (point_is_zero(&qq)) {
if (point_is_zero(&qq))
{
elt_copy(rx, px);
elt_copy(ry, py);
return;
@ -379,7 +379,8 @@ static void point_add(struct point *r, struct point *p, struct point *q)
elt_sub(u, qx, px);
if (elt_is_zero(u)) {
if (elt_is_zero(u))
{
elt_sub(u, qy, py);
if (elt_is_zero(u))
point_double(r, &pp);
@ -402,7 +403,7 @@ static void point_add(struct point *r, struct point *p, struct point *q)
elt_sub(ry, ry, py); // ry = -s*(rx-px) - py
}
static void point_mul(struct point *d, u8 *a, struct point *b) // a is bignum
static void point_mul(point* d, u8* a, point* b) // a is bignum
{
u32 i;
u8 mask;
@ -410,7 +411,8 @@ static void point_mul(struct point *d, u8 *a, struct point *b) // a is bignum
point_zero(d);
for (i = 0; i < 21; i++)
for (mask = 0x80; mask != 0; mask >>= 1) {
for (mask = 0x80; mask != 0; mask >>= 1)
{
point_double(d, d);
if ((a[i] & mask) != 0)
point_add(d, d, b);
@ -465,7 +467,7 @@ static void ec_priv_to_pub(u8 *k, u8 *Q)
}
#endif
int ecdsa_set_curve(u8* p, u8* a, u8* b, u8* N, u8* Gx, u8* Gy)
int ecdsa_set_curve(const u8* p, const u8* a, const u8* b, const u8* N, const u8* Gx, const u8* Gy)
{
memcpy(ec_p, p, 20);
memcpy(ec_a, a, 20);
@ -482,14 +484,14 @@ int ecdsa_set_curve(u8* p, u8* a, u8* b, u8* N, u8* Gx, u8* Gy)
return 0;
}
void ecdsa_set_pub(u8 *Q)
void ecdsa_set_pub(const u8* Q)
{
memcpy(ec_Q.x, Q, 20);
memcpy(ec_Q.y, Q+20, 20);
point_to_mon(&ec_Q);
}
void ecdsa_set_priv(u8 *k)
void ecdsa_set_priv(const u8* k)
{
memcpy(ec_k, k, sizeof ec_k);
}

View file

@ -4,10 +4,9 @@
// Licensed under the terms of the GNU GPL, version 3
// http://www.gnu.org/licenses/gpl-3.0.txt
#include <string.h>
#include <stdio.h>
#include "util/types.hpp"
int ecdsa_set_curve(unsigned char *p, unsigned char *a, unsigned char *b, unsigned char *N, unsigned char *Gx, unsigned char *Gy);
void ecdsa_set_pub(unsigned char *Q);
void ecdsa_set_priv(unsigned char *k);
int ecdsa_verify(unsigned char *hash, unsigned char *R, unsigned char *S);
int ecdsa_set_curve(const u8* p, const u8* a, const u8* b, const u8* N, const u8* Gx, const u8* Gy);
void ecdsa_set_pub(const u8* Q);
void ecdsa_set_priv(const u8* k);
int ecdsa_verify(u8* hash, u8* R, u8* S);