ecl.h (2549B)
1 /* This Source Code Form is subject to the terms of the Mozilla Public 2 * License, v. 2.0. If a copy of the MPL was not distributed with this 3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ 4 5 /* Although this is not an exported header file, code which uses elliptic 6 * curve point operations will need to include it. */ 7 8 #ifndef __ecl_h_ 9 #define __ecl_h_ 10 11 #include "blapi.h" 12 #include "ecl-exp.h" 13 #include "eclt.h" 14 15 SECStatus ec_Curve25519_pt_mul(SECItem *X, SECItem *k, SECItem *P); 16 SECStatus ec_Curve25519_pt_validate(const SECItem *px); 17 SECStatus ec_Curve25519_scalar_validate(const SECItem *scalar); 18 19 SECStatus ec_secp256r1_pt_mul(SECItem *X, SECItem *k, SECItem *P); 20 SECStatus ec_secp256r1_pt_validate(const SECItem *px); 21 SECStatus ec_secp256r1_scalar_validate(const SECItem *scalar); 22 23 SECStatus ec_secp256r1_sign_digest(ECPrivateKey *key, SECItem *signature, 24 const SECItem *digest, const unsigned char *kb, 25 const unsigned int kblen); 26 SECStatus ec_secp256r1_verify_digest(ECPublicKey *key, const SECItem *signature, 27 const SECItem *digest); 28 29 SECStatus ec_secp256r1_decompress(const SECItem *publicCompressed, SECItem *publicRaw); 30 31 SECStatus ec_secp521r1_pt_mul(SECItem *X, SECItem *k, SECItem *P); 32 SECStatus ec_secp521r1_pt_validate(const SECItem *px); 33 SECStatus ec_secp521r1_scalar_validate(const SECItem *scalar); 34 35 SECStatus ec_secp521r1_sign_digest(ECPrivateKey *key, SECItem *signature, 36 const SECItem *digest, const unsigned char *kb, 37 const unsigned int kblen); 38 SECStatus ec_secp521r1_verify_digest(ECPublicKey *key, const SECItem *signature, 39 const SECItem *digest); 40 SECStatus ec_secp521r1_decompress(const SECItem *publicCompressed, SECItem *publicRaw); 41 42 SECStatus ec_secp384r1_pt_mul(SECItem *X, SECItem *k, SECItem *P); 43 SECStatus ec_secp384r1_pt_validate(const SECItem *px); 44 SECStatus ec_secp384r1_scalar_validate(const SECItem *scalar); 45 46 SECStatus ec_secp384r1_sign_digest(ECPrivateKey *key, SECItem *signature, 47 const SECItem *digest, const unsigned char *kb, 48 const unsigned int kblen); 49 SECStatus ec_secp384r1_verify_digest(ECPublicKey *key, const SECItem *signature, 50 const SECItem *digest); 51 SECStatus ec_secp384r1_decompress(const SECItem *publicCompressed, SECItem *publicRaw); 52 53 #endif /* __ecl_h_ */