diff options
Diffstat (limited to 'src/crypto/fipsmodule/ec/internal.h')
-rw-r--r-- | src/crypto/fipsmodule/ec/internal.h | 82 |
1 files changed, 41 insertions, 41 deletions
diff --git a/src/crypto/fipsmodule/ec/internal.h b/src/crypto/fipsmodule/ec/internal.h index de91e2b6..39c9349a 100644 --- a/src/crypto/fipsmodule/ec/internal.h +++ b/src/crypto/fipsmodule/ec/internal.h @@ -88,25 +88,25 @@ struct ec_method_st { int (*point_get_affine_coordinates)(const EC_GROUP *, const EC_POINT *, BIGNUM *x, BIGNUM *y, BN_CTX *); - /* Computes |r = g_scalar*generator + p_scalar*p| if |g_scalar| and |p_scalar| - * are both non-null. Computes |r = g_scalar*generator| if |p_scalar| is null. - * Computes |r = p_scalar*p| if g_scalar is null. At least one of |g_scalar| - * and |p_scalar| must be non-null, and |p| must be non-null if |p_scalar| is - * non-null. */ + // Computes |r = g_scalar*generator + p_scalar*p| if |g_scalar| and |p_scalar| + // are both non-null. Computes |r = g_scalar*generator| if |p_scalar| is null. + // Computes |r = p_scalar*p| if g_scalar is null. At least one of |g_scalar| + // and |p_scalar| must be non-null, and |p| must be non-null if |p_scalar| is + // non-null. int (*mul)(const EC_GROUP *group, EC_POINT *r, const BIGNUM *g_scalar, const EC_POINT *p, const BIGNUM *p_scalar, BN_CTX *ctx); - /* 'field_mul' and 'field_sqr' can be used by 'add' and 'dbl' so that the - * same implementations of point operations can be used with different - * optimized implementations of expensive field operations: */ + // 'field_mul' and 'field_sqr' can be used by 'add' and 'dbl' so that the + // same implementations of point operations can be used with different + // optimized implementations of expensive field operations: int (*field_mul)(const EC_GROUP *, BIGNUM *r, const BIGNUM *a, const BIGNUM *b, BN_CTX *); int (*field_sqr)(const EC_GROUP *, BIGNUM *r, const BIGNUM *a, BN_CTX *); int (*field_encode)(const EC_GROUP *, BIGNUM *r, const BIGNUM *a, - BN_CTX *); /* e.g. to Montgomery */ + BN_CTX *); // e.g. to Montgomery int (*field_decode)(const EC_GROUP *, BIGNUM *r, const BIGNUM *a, - BN_CTX *); /* e.g. from Montgomery */ + BN_CTX *); // e.g. from Montgomery } /* EC_METHOD */; const EC_METHOD *EC_GFp_mont_method(void); @@ -117,22 +117,22 @@ struct ec_group_st { EC_POINT *generator; BIGNUM order; - int curve_name; /* optional NID for named curve */ + int curve_name; // optional NID for named curve - const BN_MONT_CTX *mont_data; /* data for ECDSA inverse */ + const BN_MONT_CTX *order_mont; // data for ECDSA inverse - /* The following members are handled by the method functions, - * even if they appear generic */ + // The following members are handled by the method functions, + // even if they appear generic - BIGNUM field; /* For curves over GF(p), this is the modulus. */ + BIGNUM field; // For curves over GF(p), this is the modulus. - BIGNUM a, b; /* Curve coefficients. */ + BIGNUM a, b; // Curve coefficients. - int a_is_minus3; /* enable optimized point arithmetics for special case */ + int a_is_minus3; // enable optimized point arithmetics for special case - BN_MONT_CTX *mont; /* Montgomery structure. */ + BN_MONT_CTX *mont; // Montgomery structure. - BIGNUM one; /* The value one. */ + BIGNUM one; // The value one. } /* EC_GROUP */; struct ec_point_st { @@ -140,22 +140,22 @@ struct ec_point_st { BIGNUM X; BIGNUM Y; - BIGNUM Z; /* Jacobian projective coordinates: - * (X, Y, Z) represents (X/Z^2, Y/Z^3) if Z != 0 */ + BIGNUM Z; // Jacobian projective coordinates: + // (X, Y, Z) represents (X/Z^2, Y/Z^3) if Z != 0 } /* EC_POINT */; EC_GROUP *ec_group_new(const EC_METHOD *meth); int ec_group_copy(EC_GROUP *dest, const EC_GROUP *src); -/* ec_group_get_mont_data returns a Montgomery context for operations in the - * scalar field of |group|. It may return NULL in the case that |group| is not - * a built-in group. */ -const BN_MONT_CTX *ec_group_get_mont_data(const EC_GROUP *group); +// ec_group_get_order_mont returns a Montgomery context for operations modulo +// |group|'s order. It may return NULL in the case that |group| is not a +// built-in group. +const BN_MONT_CTX *ec_group_get_order_mont(const EC_GROUP *group); int ec_wNAF_mul(const EC_GROUP *group, EC_POINT *r, const BIGNUM *g_scalar, const EC_POINT *p, const BIGNUM *p_scalar, BN_CTX *ctx); -/* method functions in simple.c */ +// method functions in simple.c int ec_GFp_simple_group_init(EC_GROUP *); void ec_GFp_simple_group_finish(EC_GROUP *); int ec_GFp_simple_group_copy(EC_GROUP *, const EC_GROUP *); @@ -200,7 +200,7 @@ int ec_GFp_simple_field_mul(const EC_GROUP *, BIGNUM *r, const BIGNUM *a, int ec_GFp_simple_field_sqr(const EC_GROUP *, BIGNUM *r, const BIGNUM *a, BN_CTX *); -/* method functions in montgomery.c */ +// method functions in montgomery.c int ec_GFp_mont_group_init(EC_GROUP *); int ec_GFp_mont_group_set_curve(EC_GROUP *, const BIGNUM *p, const BIGNUM *a, const BIGNUM *b, BN_CTX *); @@ -225,8 +225,8 @@ void ec_GFp_nistp_recode_scalar_bits(uint8_t *sign, uint8_t *digit, uint8_t in); const EC_METHOD *EC_GFp_nistp224_method(void); const EC_METHOD *EC_GFp_nistp256_method(void); -/* EC_GFp_nistz256_method is a GFp method using montgomery multiplication, with - * x86-64 optimized P256. See http://eprint.iacr.org/2013/816. */ +// EC_GFp_nistz256_method is a GFp method using montgomery multiplication, with +// x86-64 optimized P256. See http://eprint.iacr.org/2013/816. const EC_METHOD *EC_GFp_nistz256_method(void); struct ec_key_st { @@ -235,8 +235,8 @@ struct ec_key_st { EC_POINT *pub_key; BIGNUM *priv_key; - /* fixed_k may contain a specific value of 'k', to be used in ECDSA signing. - * This is only for the FIPS power-on tests. */ + // fixed_k may contain a specific value of 'k', to be used in ECDSA signing. + // This is only for the FIPS power-on tests. BIGNUM *fixed_k; unsigned int enc_flag; @@ -253,13 +253,13 @@ struct built_in_curve { int nid; const uint8_t *oid; uint8_t oid_len; - /* comment is a human-readable string describing the curve. */ + // comment is a human-readable string describing the curve. const char *comment; - /* param_len is the number of bytes needed to store a field element. */ + // param_len is the number of bytes needed to store a field element. uint8_t param_len; - /* params points to an array of 6*|param_len| bytes which hold the field - * elements of the following (in big-endian order): prime, a, b, generator x, - * generator y, order. */ + // params points to an array of 6*|param_len| bytes which hold the field + // elements of the following (in big-endian order): prime, a, b, generator x, + // generator y, order. const uint8_t *params; const EC_METHOD *method; }; @@ -270,13 +270,13 @@ struct built_in_curves { struct built_in_curve curves[OPENSSL_NUM_BUILT_IN_CURVES]; }; -/* OPENSSL_built_in_curves returns a pointer to static information about - * standard curves. The array is terminated with an entry where |nid| is - * |NID_undef|. */ +// OPENSSL_built_in_curves returns a pointer to static information about +// standard curves. The array is terminated with an entry where |nid| is +// |NID_undef|. const struct built_in_curves *OPENSSL_built_in_curves(void); #if defined(__cplusplus) -} /* extern C */ +} // extern C #endif -#endif /* OPENSSL_HEADER_EC_INTERNAL_H */ +#endif // OPENSSL_HEADER_EC_INTERNAL_H |