Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
This file contains ECDSA definitions and functions. More...
Go to the source code of this file.
| Typedefs | |
| typedef mbedtls_ecp_keypair | mbedtls_ecdsa_context | 
| The ECDSA context structure. | |
| Functions | |
| int | mbedtls_ecdsa_sign (mbedtls_ecp_group *grp, mbedtls_mpi *r, mbedtls_mpi *s, const mbedtls_mpi *d, const unsigned char *buf, size_t blen, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng) | 
| This function computes the ECDSA signature of a previously-hashed message. | |
| int | mbedtls_ecdsa_sign_det (mbedtls_ecp_group *grp, mbedtls_mpi *r, mbedtls_mpi *s, const mbedtls_mpi *d, const unsigned char *buf, size_t blen, mbedtls_md_type_t md_alg) | 
| This function computes the ECDSA signature of a previously-hashed message, deterministic version. | |
| int | mbedtls_ecdsa_verify (mbedtls_ecp_group *grp, const unsigned char *buf, size_t blen, const mbedtls_ecp_point *Q, const mbedtls_mpi *r, const mbedtls_mpi *s) | 
| This function verifies the ECDSA signature of a previously-hashed message. | |
| int | mbedtls_ecdsa_write_signature (mbedtls_ecdsa_context *ctx, mbedtls_md_type_t md_alg, const unsigned char *hash, size_t hlen, unsigned char *sig, size_t *slen, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng) | 
| This function computes the ECDSA signature and writes it to a buffer, serialized as defined in RFC-4492: Elliptic Curve Cryptography (ECC) Cipher Suites for Transport Layer Security (TLS). | |
| int | mbedtls_ecdsa_write_signature_det (mbedtls_ecdsa_context *ctx, const unsigned char *hash, size_t hlen, unsigned char *sig, size_t *slen, mbedtls_md_type_t md_alg) MBEDTLS_DEPRECATED | 
| This function computes an ECDSA signature and writes it to a buffer, serialized as defined in RFC-4492: Elliptic Curve Cryptography (ECC) Cipher Suites for Transport Layer Security (TLS). | |
| int | mbedtls_ecdsa_read_signature (mbedtls_ecdsa_context *ctx, const unsigned char *hash, size_t hlen, const unsigned char *sig, size_t slen) | 
| This function reads and verifies an ECDSA signature. | |
| int | mbedtls_ecdsa_genkey (mbedtls_ecdsa_context *ctx, mbedtls_ecp_group_id gid, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng) | 
| This function generates an ECDSA keypair on the given curve. | |
| int | mbedtls_ecdsa_from_keypair (mbedtls_ecdsa_context *ctx, const mbedtls_ecp_keypair *key) | 
| This function sets an ECDSA context from an EC key pair. | |
| void | mbedtls_ecdsa_init (mbedtls_ecdsa_context *ctx) | 
| This function initializes an ECDSA context. | |
| void | mbedtls_ecdsa_free (mbedtls_ecdsa_context *ctx) | 
| This function frees an ECDSA context. | |
Detailed Description
This file contains ECDSA definitions and functions.
The Elliptic Curve Digital Signature Algorithm (ECDSA) is defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography. The use of ECDSA for TLS is defined in RFC-4492: Elliptic Curve Cryptography (ECC) Cipher Suites for Transport Layer Security (TLS).
Definition in file ecdsa.h.
Typedef Documentation
Function Documentation
| void mbedtls_ecdsa_free | ( | mbedtls_ecdsa_context * | ctx ) | 
| int mbedtls_ecdsa_from_keypair | ( | mbedtls_ecdsa_context * | ctx, | 
| const mbedtls_ecp_keypair * | key | ||
| ) | 
| int mbedtls_ecdsa_genkey | ( | mbedtls_ecdsa_context * | ctx, | 
| mbedtls_ecp_group_id | gid, | ||
| int(*)(void *, unsigned char *, size_t) | f_rng, | ||
| void * | p_rng | ||
| ) | 
This function generates an ECDSA keypair on the given curve.
- See also:
- ecp.h
- Parameters:
- 
  ctx The ECDSA context to store the keypair in. gid The elliptic curve to use. One of the various MBEDTLS_ECP_DP_XXXmacros depending on configuration.f_rng The RNG function. p_rng The RNG context. 
- Returns:
- 0on success.
- 
An MBEDTLS_ERR_ECP_XXXcode on failure.
Definition at line 251 of file ecdsa_alt.c.
| void mbedtls_ecdsa_init | ( | mbedtls_ecdsa_context * | ctx ) | 
| int mbedtls_ecdsa_read_signature | ( | mbedtls_ecdsa_context * | ctx, | 
| const unsigned char * | hash, | ||
| size_t | hlen, | ||
| const unsigned char * | sig, | ||
| size_t | slen | ||
| ) | 
This function reads and verifies an ECDSA signature.
- Note:
- If the bitlength of the message hash is larger than the bitlength of the group order, then the hash is truncated as defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography, section 4.1.4, step 3.
- See also:
- ecp.h
- Parameters:
- 
  ctx The ECDSA context. hash The message hash. hlen The size of the hash. sig The signature to read and verify. slen The size of sig.
- Returns:
- 0on success.
- MBEDTLS_ERR_ECP_BAD_INPUT_DATA if signature is invalid.
- 
MBEDTLS_ERR_ECP_SIG_LEN_MISMATCH if there is a valid signature in sig, but its length is less thansiglen.
- 
An MBEDTLS_ERR_ECP_XXXorMBEDTLS_ERR_MPI_XXXerror code on failure for any other reason.
| int mbedtls_ecdsa_sign | ( | mbedtls_ecp_group * | grp, | 
| mbedtls_mpi * | r, | ||
| mbedtls_mpi * | s, | ||
| const mbedtls_mpi * | d, | ||
| const unsigned char * | buf, | ||
| size_t | blen, | ||
| int(*)(void *, unsigned char *, size_t) | f_rng, | ||
| void * | p_rng | ||
| ) | 
This function computes the ECDSA signature of a previously-hashed message.
- Note:
- The deterministic version is usually preferred.
- If the bitlength of the message hash is larger than the bitlength of the group order, then the hash is truncated as defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography, section 4.1.3, step 5.
- See also:
- ecp.h
- Parameters:
- 
  grp The ECP group. r The first output integer. s The second output integer. d The private signing key. buf The message hash. blen The length of buf.f_rng The RNG function. p_rng The RNG context. 
- Returns:
- 0on success.
- 
An MBEDTLS_ERR_ECP_XXXorMBEDTLS_MPI_XXXerror code on failure.
Definition at line 66 of file ecdsa_alt.c.
| int mbedtls_ecdsa_sign_det | ( | mbedtls_ecp_group * | grp, | 
| mbedtls_mpi * | r, | ||
| mbedtls_mpi * | s, | ||
| const mbedtls_mpi * | d, | ||
| const unsigned char * | buf, | ||
| size_t | blen, | ||
| mbedtls_md_type_t | md_alg | ||
| ) | 
This function computes the ECDSA signature of a previously-hashed message, deterministic version.
For more information, see RFC-6979: Deterministic Usage of the Digital Signature Algorithm (DSA) and Elliptic Curve Digital Signature Algorithm (ECDSA).
- Note:
- If the bitlength of the message hash is larger than the bitlength of the group order, then the hash is truncated as defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography, section 4.1.3, step 5.
- See also:
- ecp.h
- Parameters:
- 
  grp The ECP group. r The first output integer. s The second output integer. d The private signing key. buf The message hash. blen The length of buf.md_alg The MD algorithm used to hash the message. 
- Returns:
- 0on success.
- 
An MBEDTLS_ERR_ECP_XXXorMBEDTLS_MPI_XXXerror code on failure.
| int mbedtls_ecdsa_verify | ( | mbedtls_ecp_group * | grp, | 
| const unsigned char * | buf, | ||
| size_t | blen, | ||
| const mbedtls_ecp_point * | Q, | ||
| const mbedtls_mpi * | r, | ||
| const mbedtls_mpi * | s | ||
| ) | 
This function verifies the ECDSA signature of a previously-hashed message.
- Note:
- If the bitlength of the message hash is larger than the bitlength of the group order, then the hash is truncated as defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography, section 4.1.4, step 3.
- See also:
- ecp.h
- Parameters:
- 
  grp The ECP group. buf The message hash. blen The length of buf.Q The public key to use for verification. r The first integer of the signature. s The second integer of the signature. 
- Returns:
- 0on success.
- MBEDTLS_ERR_ECP_BAD_INPUT_DATA if the signature is invalid.
- 
An MBEDTLS_ERR_ECP_XXXorMBEDTLS_MPI_XXXerror code on failure for any other reason.
Definition at line 165 of file ecdsa_alt.c.
| int mbedtls_ecdsa_write_signature | ( | mbedtls_ecdsa_context * | ctx, | 
| mbedtls_md_type_t | md_alg, | ||
| const unsigned char * | hash, | ||
| size_t | hlen, | ||
| unsigned char * | sig, | ||
| size_t * | slen, | ||
| int(*)(void *, unsigned char *, size_t) | f_rng, | ||
| void * | p_rng | ||
| ) | 
This function computes the ECDSA signature and writes it to a buffer, serialized as defined in RFC-4492: Elliptic Curve Cryptography (ECC) Cipher Suites for Transport Layer Security (TLS).
- Warning:
- It is not thread-safe to use the same context in multiple threads.
- Note:
- The deterministic version is used if MBEDTLS_ECDSA_DETERMINISTIC is defined. For more information, see RFC-6979: Deterministic Usage of the Digital Signature Algorithm (DSA) and Elliptic Curve Digital Signature Algorithm (ECDSA).
- 
The sigbuffer must be at least twice as large as the size of the curve used, plus 9. For example, 73 Bytes if a 256-bit curve is used. A buffer length of MBEDTLS_ECDSA_MAX_LEN is always safe.
- If the bitlength of the message hash is larger than the bitlength of the group order, then the hash is truncated as defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography, section 4.1.3, step 5.
- See also:
- ecp.h
- Parameters:
- 
  ctx The ECDSA context. md_alg The message digest that was used to hash the message. hash The message hash. hlen The length of the hash. sig The buffer that holds the signature. slen The length of the signature written. f_rng The RNG function. p_rng The RNG context. 
- Returns:
- 0on success.
- 
An MBEDTLS_ERR_ECP_XXX,MBEDTLS_ERR_MPI_XXXorMBEDTLS_ERR_ASN1_XXXerror code on failure.
| int mbedtls_ecdsa_write_signature_det | ( | mbedtls_ecdsa_context * | ctx, | 
| const unsigned char * | hash, | ||
| size_t | hlen, | ||
| unsigned char * | sig, | ||
| size_t * | slen, | ||
| mbedtls_md_type_t | md_alg | ||
| ) | 
This function computes an ECDSA signature and writes it to a buffer, serialized as defined in RFC-4492: Elliptic Curve Cryptography (ECC) Cipher Suites for Transport Layer Security (TLS).
The deterministic version is defined in RFC-6979: Deterministic Usage of the Digital Signature Algorithm (DSA) and Elliptic Curve Digital Signature Algorithm (ECDSA).
- Warning:
- It is not thread-safe to use the same context in multiple threads.
- Note:
- The sigbuffer must be at least twice as large as the size of the curve used, plus 9. For example, 73 Bytes if a 256-bit curve is used. A buffer length of MBEDTLS_ECDSA_MAX_LEN is always safe.
- If the bitlength of the message hash is larger than the bitlength of the group order, then the hash is truncated as defined in Standards for Efficient Cryptography Group (SECG): SEC1 Elliptic Curve Cryptography, section 4.1.3, step 5.
- See also:
- ecp.h
- Parameters:
- 
  ctx The ECDSA context. hash The message hash. hlen The length of the hash. sig The buffer that holds the signature. slen The length of the signature written. md_alg The MD algorithm used to hash the message. 
- Returns:
- 0on success.
- 
An MBEDTLS_ERR_ECP_XXX,MBEDTLS_ERR_MPI_XXXorMBEDTLS_ERR_ASN1_XXXerror code on failure.
Generated on Tue Jul 12 2022 12:46:24 by
 1.7.2
 1.7.2