36 POINT_CONVERSION_COMPRESSED = 2,
37 POINT_CONVERSION_UNCOMPRESSED = 4,
42 NID_X9_62_prime192v1 = 409,
43 NID_X9_62_prime192v2 = 410,
44 NID_X9_62_prime192v3 = 411,
45 NID_X9_62_prime239v1 = 412,
46 NID_X9_62_prime239v2 = 413,
47 NID_X9_62_prime239v3 = 414,
48 NID_X9_62_prime256v1 = 415,
62 NID_brainpoolP160r1 = 921,
63 NID_brainpoolP192r1 = 923,
64 NID_brainpoolP224r1 = 925,
65 NID_brainpoolP256r1 = 927,
66 NID_brainpoolP320r1 = 929,
67 NID_brainpoolP384r1 = 931,
68 NID_brainpoolP512r1 = 933,
71 OPENSSL_EC_NAMED_CURVE = 0x001
74#ifndef WOLFSSL_EC_TYPE_DEFINED
81#define WOLFSSL_EC_TYPE_DEFINED
109 WOLFSSL_BIGNUM *priv_key;
123#define WOLFSSL_EC_KEY_LOAD_PRIVATE 1
124#define WOLFSSL_EC_KEY_LOAD_PUBLIC 2
135 unsigned char *out,
unsigned int *len);
137int wolfSSL_ECPoint_d2i(
unsigned char *in,
unsigned int len,
143 byte *buf,
size_t len, WOLFSSL_BN_CTX *ctx);
147 size_t len, WOLFSSL_BN_CTX *ctx);
149int wolfSSL_i2o_ECPublicKey(
const WOLFSSL_EC_KEY *in,
unsigned char **out);
151void wolfSSL_EC_KEY_set_conv_form(
WOLFSSL_EC_KEY *eckey,
char form);
156 WOLFSSL_BIGNUM *in, WOLFSSL_BN_CTX *ctx);
160 const unsigned char* der,
int derSz);
163 const unsigned char* der,
int derSz,
int opt);
172 const WOLFSSL_BIGNUM *priv_key);
174WOLFSSL_BIGNUM *wolfSSL_EC_KEY_get0_private_key(
const WOLFSSL_EC_KEY *key);
177WOLFSSL_API
const char* wolfSSL_EC_curve_nid2nist(
int nid);
185void wolfSSL_EC_KEY_set_asn1_flag(
WOLFSSL_EC_KEY *key,
int asn1_flag);
190WOLFSSL_API
int wolfSSL_ECDSA_sign(
int type,
const unsigned char *digest,
191 int digestSz,
unsigned char *sig,
199 WOLFSSL_BN_CTX *ctx);
206 WOLFSSL_BIGNUM *order, WOLFSSL_BN_CTX *ctx);
219int wolfSSL_EC_POINT_get_affine_coordinates_GFp(
const WOLFSSL_EC_GROUP *group,
223 WOLFSSL_BN_CTX *ctx);
225int wolfSSL_EC_POINT_set_affine_coordinates_GFp(
const WOLFSSL_EC_GROUP *group,
227 const WOLFSSL_BIGNUM *x,
228 const WOLFSSL_BIGNUM *y,
229 WOLFSSL_BN_CTX *ctx);
232 const WOLFSSL_BIGNUM *n,
234 WOLFSSL_BN_CTX *ctx);
240 WOLFSSL_BN_CTX *ctx);
253 WOLFSSL_BN_CTX* ctx);
260#define EC_KEY_new wolfSSL_EC_KEY_new
261#define EC_KEY_free wolfSSL_EC_KEY_free
262#define EC_KEY_dup wolfSSL_EC_KEY_dup
263#define EC_KEY_get0_public_key wolfSSL_EC_KEY_get0_public_key
264#define EC_KEY_get0_group wolfSSL_EC_KEY_get0_group
265#define EC_KEY_set_private_key wolfSSL_EC_KEY_set_private_key
266#define EC_KEY_get0_private_key wolfSSL_EC_KEY_get0_private_key
267#define EC_KEY_new_by_curve_name wolfSSL_EC_KEY_new_by_curve_name
268#define EC_KEY_set_group wolfSSL_EC_KEY_set_group
269#define EC_KEY_generate_key wolfSSL_EC_KEY_generate_key
270#define EC_KEY_set_asn1_flag wolfSSL_EC_KEY_set_asn1_flag
271#define EC_KEY_set_public_key wolfSSL_EC_KEY_set_public_key
273#define ECDSA_size wolfSSL_ECDSA_size
274#define ECDSA_sign wolfSSL_ECDSA_sign
276#define EC_GROUP_free wolfSSL_EC_GROUP_free
277#define EC_GROUP_set_asn1_flag wolfSSL_EC_GROUP_set_asn1_flag
278#define EC_GROUP_new_by_curve_name wolfSSL_EC_GROUP_new_by_curve_name
279#define EC_GROUP_cmp wolfSSL_EC_GROUP_cmp
280#define EC_GROUP_get_curve_name wolfSSL_EC_GROUP_get_curve_name
281#define EC_GROUP_get_degree wolfSSL_EC_GROUP_get_degree
282#define EC_GROUP_get_order wolfSSL_EC_GROUP_get_order
283#define EC_GROUP_order_bits wolfSSL_EC_GROUP_order_bits
284#define EC_GROUP_method_of wolfSSL_EC_GROUP_method_of
286#define EC_METHOD_get_field_type wolfSSL_EC_METHOD_get_field_type
288#define EC_POINT_new wolfSSL_EC_POINT_new
289#define EC_POINT_free wolfSSL_EC_POINT_free
290#define EC_POINT_get_affine_coordinates_GFp \
291 wolfSSL_EC_POINT_get_affine_coordinates_GFp
292#define EC_POINT_set_affine_coordinates_GFp \
293 wolfSSL_EC_POINT_set_affine_coordinates_GFp
294#define EC_POINT_mul wolfSSL_EC_POINT_mul
295#define EC_POINT_clear_free wolfSSL_EC_POINT_clear_free
296#define EC_POINT_cmp wolfSSL_EC_POINT_cmp
297#define EC_POINT_copy wolfSSL_EC_POINT_copy
298#define EC_POINT_is_at_infinity wolfSSL_EC_POINT_is_at_infinity
300#define EC_get_builtin_curves wolfSSL_EC_get_builtin_curves
302#define ECPoint_i2d wolfSSL_ECPoint_i2d
303#define ECPoint_d2i wolfSSL_ECPoint_d2i
304#define EC_POINT_point2oct wolfSSL_EC_POINT_point2oct
305#define EC_POINT_oct2point wolfSSL_EC_POINT_oct2point
306#define EC_POINT_point2bn wolfSSL_EC_POINT_point2bn
307#define i2o_ECPublicKey wolfSSL_i2o_ECPublicKey
308#define EC_KEY_set_conv_form wolfSSL_EC_KEY_set_conv_form
311 #define EC_POINT_point2hex wolfSSL_EC_POINT_point2hex
314#define EC_POINT_dump wolfSSL_EC_POINT_dump
315#define EC_get_builtin_curves wolfSSL_EC_get_builtin_curves
317#define EC_curve_nid2nist wolfSSL_EC_curve_nid2nist