NimBLE-Arduino 2.2.0
|
– Interface to EC-DSA implementation. More...
Go to the source code of this file.
Functions | |
int | uECC_sign (const uint8_t *p_private_key, const uint8_t *p_message_hash, unsigned p_hash_size, uint8_t *p_signature, uECC_Curve curve) |
Generate an ECDSA signature for a given hash value. | |
int | uECC_verify (const uint8_t *p_public_key, const uint8_t *p_message_hash, unsigned int p_hash_size, const uint8_t *p_signature, uECC_Curve curve) |
Verify an ECDSA signature. | |
– Interface to EC-DSA implementation.
Overview: This software is an implementation of EC-DSA. This implementation uses curve NIST p-256.
Security: The curve NIST p-256 provides approximately 128 bits of security.
Usage: - To sign: Compute a hash of the data you wish to sign (SHA-2 is recommended) and pass it in to ecdsa_sign function along with your private key and a random number. You must use a new non-predictable random number to generate each new signature.
int uECC_sign | ( | const uint8_t * | p_private_key, |
const uint8_t * | p_message_hash, | ||
unsigned | p_hash_size, | ||
uint8_t * | p_signature, | ||
uECC_Curve | curve | ||
) |
Generate an ECDSA signature for a given hash value.
p_private_key | IN – Your private key. |
p_message_hash | IN – The hash of the message to sign. |
p_hash_size | IN – The size of p_message_hash in bytes. |
p_signature | OUT – Will be filled in with the signature value. Must be at least 2 * curve size long (for secp256r1, signature must be 64 bytes long). |
int uECC_verify | ( | const uint8_t * | p_public_key, |
const uint8_t * | p_message_hash, | ||
unsigned int | p_hash_size, | ||
const uint8_t * | p_signature, | ||
uECC_Curve | curve | ||
) |
Verify an ECDSA signature.
p_public_key | IN – The signer's public key. |
p_message_hash | IN – The hash of the signed data. |
p_hash_size | IN – The size of p_message_hash in bytes. |
p_signature | IN – The signature values. |