mirror of
https://github.com/apache/nuttx.git
synced 2026-05-10 23:40:21 +08:00
crypto: export algorithm about ecc
Transplanting the ECC algorithm from https://github.com/jestan/easy-ecc which is BSD lisence Signed-off-by: makejian <makejian@xiaomi.com>
This commit is contained in:
@@ -45,6 +45,7 @@ if(CONFIG_CRYPTO)
|
||||
list(APPEND SRCS chachapoly.c)
|
||||
list(APPEND SRCS ecb_enc.c)
|
||||
list(APPEND SRCS ecb3_enc.c)
|
||||
list(APPEND SRCS ecc.c)
|
||||
list(APPEND SRCS set_key.c)
|
||||
list(APPEND SRCS md5.c)
|
||||
list(APPEND SRCS poly1305.c)
|
||||
|
||||
@@ -49,6 +49,7 @@ CRYPTO_CSRCS += cast.c
|
||||
CRYPTO_CSRCS += chachapoly.c
|
||||
CRYPTO_CSRCS += ecb_enc.c
|
||||
CRYPTO_CSRCS += ecb3_enc.c
|
||||
CRYPTO_CSRCS += ecc.c
|
||||
CRYPTO_CSRCS += set_key.c
|
||||
CRYPTO_CSRCS += md5.c
|
||||
CRYPTO_CSRCS += poly1305.c
|
||||
|
||||
+1731
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,143 @@
|
||||
/****************************************************************************
|
||||
* include/crypto/ecc.h
|
||||
*
|
||||
* Copyright (c) 2013, Kenneth MacKay All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are
|
||||
* met: Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
* SPECIAL, HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __INCLUDE_CRYPTO_ECC_H
|
||||
#define __INCLUDE_CRYPTO_ECC_H
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* Curve selection options. */
|
||||
|
||||
#define secp128r1 16
|
||||
#define secp192r1 24
|
||||
#define secp256r1 32
|
||||
#define secp384r1 48
|
||||
|
||||
#ifndef ECC_CURVE
|
||||
# define ECC_CURVE secp256r1
|
||||
#endif
|
||||
|
||||
#if (ECC_CURVE != secp128r1 && \
|
||||
ECC_CURVE != secp192r1 && \
|
||||
ECC_CURVE != secp256r1 && \
|
||||
ECC_CURVE != secp384r1)
|
||||
# error "Must define ECC_CURVE to one of the available curves"
|
||||
#endif
|
||||
|
||||
#define ECC_BYTES ECC_CURVE
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
/* ecc_make_key() function.
|
||||
* Create a public/private key pair.
|
||||
*
|
||||
* Outputs:
|
||||
* publickey - Will be filled in with the public key.
|
||||
* privatekey - Will be filled in with the private key.
|
||||
*
|
||||
* Returns 1 if the key pair was generated successfully,
|
||||
* 0 if an error occurred.
|
||||
*/
|
||||
|
||||
int ecc_make_key(uint8_t publickey[ECC_BYTES + 1],
|
||||
uint8_t privatekey[ECC_BYTES]);
|
||||
|
||||
/* ecdh_shared_secret() function.
|
||||
* Compute a shared secret given your secret key and someone else's
|
||||
* public key.
|
||||
* Note: It is recommended that you hash the result of ecdh_shared_secret
|
||||
* before using it for symmetric encryption or HMAC.
|
||||
*
|
||||
* Inputs:
|
||||
* publickey - The public key of the remote party.
|
||||
* privatekey - Your private key.
|
||||
*
|
||||
* Outputs:
|
||||
* secret - Will be filled in with the shared secret value.
|
||||
*
|
||||
* Returns 1 if the shared secret was generated successfully,
|
||||
* 0 if an error occurred.
|
||||
*/
|
||||
|
||||
int ecdh_shared_secret(const uint8_t publickey[ECC_BYTES + 1],
|
||||
const uint8_t privatekey[ECC_BYTES],
|
||||
uint8_t secret[ECC_BYTES]);
|
||||
|
||||
/* ecdsa_sign() function.
|
||||
* Generate an ECDSA signature for a given hash value.
|
||||
*
|
||||
* Usage: Compute a hash of the data you wish to sign (SHA-2 is recommended)
|
||||
* and pass it in to this function along with your private key.
|
||||
*
|
||||
* Inputs:
|
||||
* privatekey - Your private key.
|
||||
* hash - The message hash to sign.
|
||||
*
|
||||
* Outputs:
|
||||
* signature - Will be filled in with the signature value.
|
||||
*
|
||||
* Returns 1 if the signature generated successfully, 0 if an error occurred.
|
||||
*/
|
||||
|
||||
int ecdsa_sign(const uint8_t privatekey[ECC_BYTES],
|
||||
const uint8_t hash[ECC_BYTES],
|
||||
uint8_t signature[ECC_BYTES * 2]);
|
||||
|
||||
/* ecdsa_verify() function.
|
||||
* Verify an ECDSA signature.
|
||||
*
|
||||
* Usage: Compute the hash of the signed data using the same hash as
|
||||
* the signer and pass it to this function along with the signer's
|
||||
* public key and the signature values (r and s).
|
||||
*
|
||||
* Inputs:
|
||||
* publickey - The signer's public key
|
||||
* hash - The hash of the signed data.
|
||||
* signature - The signature value.
|
||||
*
|
||||
* Returns 1 if the signature is valid, 0 if it is invalid.
|
||||
*/
|
||||
|
||||
int ecdsa_verify(const uint8_t publickey[ECC_BYTES + 1],
|
||||
const uint8_t hash[ECC_BYTES],
|
||||
const uint8_t signature[ECC_BYTES * 2]);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* __INCLUDE_CRYPTO_ECC_H */
|
||||
Reference in New Issue
Block a user