X-Git-Url: https://www.bearssl.org/gitweb//home/git/?p=BearSSL;a=blobdiff_plain;f=src%2Fec%2Fec_prime_i15.c;h=85affe5a9c0b78ec59d35621330188539dfdcf1a;hp=04bdd5da977d31935384817d3ae420d48d3d76d7;hb=9dc6211237abcc4a4854818f8e5d7b8973bf31e3;hpb=28e4e120b84dacdf53963639f1a8a6fec2793662 diff --git a/src/ec/ec_prime_i15.c b/src/ec/ec_prime_i15.c index 04bdd5d..85affe5 100644 --- a/src/ec/ec_prime_i15.c +++ b/src/ec/ec_prime_i15.c @@ -716,6 +716,14 @@ api_order(int curve, size_t *len) return cd->order; } +static size_t +api_xoff(int curve, size_t *len) +{ + api_generator(curve, len); + *len >>= 1; + return 1; +} + static uint32_t api_mul(unsigned char *G, size_t Glen, const unsigned char *x, size_t xlen, int curve) @@ -733,6 +741,19 @@ api_mul(unsigned char *G, size_t Glen, return r; } +static size_t +api_mulgen(unsigned char *R, + const unsigned char *x, size_t xlen, int curve) +{ + const unsigned char *G; + size_t Glen; + + G = api_generator(curve, &Glen); + memcpy(R, G, Glen); + api_mul(R, Glen, x, xlen, curve); + return Glen; +} + static uint32_t api_muladd(unsigned char *A, const unsigned char *B, size_t len, const unsigned char *x, size_t xlen, @@ -750,6 +771,11 @@ api_muladd(unsigned char *A, const unsigned char *B, size_t len, cc = id_to_curve(curve); r = point_decode(&P, A, len, cc); + if (B == NULL) { + size_t Glen; + + B = api_generator(curve, &Glen); + } r &= point_decode(&Q, B, len, cc); point_mul(&P, x, xlen, cc); point_mul(&Q, y, ylen, cc); @@ -787,6 +813,8 @@ const br_ec_impl br_ec_prime_i15 = { (uint32_t)0x03800000, &api_generator, &api_order, + &api_xoff, &api_mul, + &api_mulgen, &api_muladd };