Browse Source

make dsmul for verify always take base point to simplify api

master
Mike Hamburg 9 years ago
parent
commit
023ef46b1d
4 changed files with 12 additions and 17 deletions
  1. +5
    -6
      include/decaf.h
  2. +2
    -3
      src/decaf.c
  3. +2
    -4
      src/decaf_crypto.c
  4. +3
    -4
      src/decaf_fast.c

+ 5
- 6
include/decaf.h View File

@@ -38,6 +38,7 @@
#define NONNULL1 __attribute__((nonnull(1))) #define NONNULL1 __attribute__((nonnull(1)))
#define NONNULL2 __attribute__((nonnull(1,2))) #define NONNULL2 __attribute__((nonnull(1,2)))
#define NONNULL3 __attribute__((nonnull(1,2,3))) #define NONNULL3 __attribute__((nonnull(1,2,3)))
#define NONNULL4 __attribute__((nonnull(1,2,3,4)))
#define NONNULL5 __attribute__((nonnull(1,2,3,4,5))) #define NONNULL5 __attribute__((nonnull(1,2,3,4,5)))


/* Internal word types */ /* Internal word types */
@@ -407,13 +408,12 @@ void decaf_448_point_double_scalarmul (


/** /**
* @brief Multiply two base points by two scalars: * @brief Multiply two base points by two scalars:
* scaled = scalar1*base1 + scalar2*base2.
* scaled = scalar1*decaf_448_point_base + scalar2*base2.
* *
* Otherwise quivalent to two calls to decaf_448_point_scalarmul, but may be
* Otherwise equivalent to decaf_448_point_double_scalarmul, but may be
* faster. * faster.
* *
* @param [out] scaled The scaled point base*scalar * @param [out] scaled The scaled point base*scalar
* @param [in] base1 A precomputed first point to be scaled.
* @param [in] scalar1 A first scalar to multiply by. * @param [in] scalar1 A first scalar to multiply by.
* @param [in] base2 A second point to be scaled. * @param [in] base2 A second point to be scaled.
* @param [in] scalar2 A second scalar to multiply by. * @param [in] scalar2 A second scalar to multiply by.
@@ -421,13 +421,12 @@ void decaf_448_point_double_scalarmul (
* @warning: This function takes variable time, and may leak the scalars * @warning: This function takes variable time, and may leak the scalars
* used. It is designed for signature verification. * used. It is designed for signature verification.
*/ */
void decaf_448_precomputed_double_scalarmul_non_secret (
void decaf_448_base_double_scalarmul_non_secret (
decaf_448_point_t combo, decaf_448_point_t combo,
const decaf_448_precomputed_s *base1,
const decaf_448_scalar_t scalar1, const decaf_448_scalar_t scalar1,
const decaf_448_point_t base2, const decaf_448_point_t base2,
const decaf_448_scalar_t scalar2 const decaf_448_scalar_t scalar2
) API_VIS NONNULL5 NOINLINE;
) API_VIS NONNULL4 NOINLINE;


/** /**
* @brief Test that a point is valid, for debugging purposes. * @brief Test that a point is valid, for debugging purposes.


+ 2
- 3
src/decaf.c View File

@@ -805,12 +805,11 @@ void decaf_448_precomputed_scalarmul (
decaf_448_point_scalarmul(a,b->p[0],scalar); decaf_448_point_scalarmul(a,b->p[0],scalar);
} }


void decaf_448_precomputed_double_scalarmul_non_secret (
void decaf_448_base_double_scalarmul_non_secret (
decaf_448_point_t combo, decaf_448_point_t combo,
const decaf_448_precomputed_s *base1,
const decaf_448_scalar_t scalar1, const decaf_448_scalar_t scalar1,
const decaf_448_point_t base2, const decaf_448_point_t base2,
const decaf_448_scalar_t scalar2 const decaf_448_scalar_t scalar2
) { ) {
decaf_448_point_double_scalarmul(combo, base1->p[0], scalar1, base2, scalar2);
decaf_448_point_double_scalarmul(combo, decaf_448_point_base, scalar1, base2, scalar2);
} }

+ 2
- 4
src/decaf_crypto.c View File

@@ -186,10 +186,8 @@ decaf_448_verify_shake (
ret &= decaf_448_point_decode(pubpoint, pub, DECAF_FALSE); ret &= decaf_448_point_decode(pubpoint, pub, DECAF_FALSE);
ret &= decaf_448_scalar_decode(response, &sig[DECAF_448_SER_BYTES]); ret &= decaf_448_scalar_decode(response, &sig[DECAF_448_SER_BYTES]);


decaf_448_precomputed_double_scalarmul_non_secret (
pubpoint,
decaf_448_precomputed_base, response,
pubpoint, challenge
decaf_448_base_double_scalarmul_non_secret (
pubpoint, response, pubpoint, challenge
); );


ret &= decaf_448_point_eq(pubpoint, point); ret &= decaf_448_point_eq(pubpoint, point);


+ 3
- 4
src/decaf_fast.c View File

@@ -1417,9 +1417,8 @@ sv prepare_wnaf_table(
} }
} }


void decaf_448_precomputed_double_scalarmul_non_secret (
void decaf_448_base_double_scalarmul_non_secret (
decaf_448_point_t combo, decaf_448_point_t combo,
const decaf_448_precomputed_s *base1,
const decaf_448_scalar_t scalar1, const decaf_448_scalar_t scalar1,
const decaf_448_point_t base2, const decaf_448_point_t base2,
const decaf_448_scalar_t scalar2 const decaf_448_scalar_t scalar2
@@ -1479,9 +1478,9 @@ void decaf_448_precomputed_double_scalarmul_non_secret (
tab &= (1<<(t-1)) - 1; tab &= (1<<(t-1)) - 1;


if (invert) { if (invert) {
sub_niels_from_pt(combo, base1->table[(j<<(t-1)) + tab], j==n-1 && i);
sub_niels_from_pt(combo, decaf_448_precomputed_base->table[(j<<(t-1)) + tab], j==n-1 && i);
} else { } else {
add_niels_to_pt(combo, base1->table[(j<<(t-1)) + tab], j==n-1 && i);
add_niels_to_pt(combo, decaf_448_precomputed_base->table[(j<<(t-1)) + tab], j==n-1 && i);
} }
} }
} }


Loading…
Cancel
Save