tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

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_ */