mirror of
https://github.com/apache/nuttx.git
synced 2026-05-10 07:18:49 +08:00
85ba80a90e
Add BSD-2-Clause SPDX license identifier to ECC source and header files. Signed-off-by: makejian <makejian@xiaomi.com>
150 lines
4.9 KiB
C
150 lines
4.9 KiB
C
/****************************************************************************
|
|
* include/crypto/ecc.h
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* 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]);
|
|
|
|
int ecc_make_key_uncomp(uint8_t publickey_x[ECC_BYTES],
|
|
uint8_t publickey_y[ECC_BYTES],
|
|
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 */
|