|
Mbed TLS v4.0.0
|
This file provides an API for key wrapping (KW) and key wrapping with padding (KWP) as defined in NIST SP 800-38F. https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-38F.pdf. More...
#include "mbedtls/private_access.h"#include "tf-psa-crypto/build_info.h"#include "psa/crypto_types.h"#include "psa/crypto_values.h"
Go to the source code of this file.
Enumerations | |
| enum | mbedtls_nist_kw_mode_t { MBEDTLS_KW_MODE_KW = 0, MBEDTLS_KW_MODE_KWP = 1 } |
Functions | |
| psa_status_t | mbedtls_nist_kw_wrap (mbedtls_svc_key_id_t key, mbedtls_nist_kw_mode_t mode, const unsigned char *input, size_t input_length, unsigned char *output, size_t output_size, size_t *output_length) |
| This function encrypts a buffer using key wrapping. More... | |
| psa_status_t | mbedtls_nist_kw_unwrap (mbedtls_svc_key_id_t key, mbedtls_nist_kw_mode_t mode, const unsigned char *input, size_t input_length, unsigned char *output, size_t output_size, size_t *output_length) |
| This function decrypts a buffer using key wrapping. More... | |
This file provides an API for key wrapping (KW) and key wrapping with padding (KWP) as defined in NIST SP 800-38F. https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-38F.pdf.
Key wrapping specifies a deterministic authenticated-encryption mode of operation, according to NIST SP 800-38F: Recommendation for Block Cipher Modes of Operation: Methods for Key Wrapping. Its purpose is to protect cryptographic keys.
Its equivalent is RFC 3394 for KW, and RFC 5649 for KWP. https://tools.ietf.org/html/rfc3394 https://tools.ietf.org/html/rfc5649
Definition in file nist_kw.h.
| psa_status_t mbedtls_nist_kw_unwrap | ( | mbedtls_svc_key_id_t | key, |
| mbedtls_nist_kw_mode_t | mode, | ||
| const unsigned char * | input, | ||
| size_t | input_length, | ||
| unsigned char * | output, | ||
| size_t | output_size, | ||
| size_t * | output_length | ||
| ) |
This function decrypts a buffer using key wrapping.
| key | The key wrapping PSA key ID to use for encryption. The key should have the following attributes:
| |
| mode | The key wrapping mode to use (MBEDTLS_KW_MODE_KW or MBEDTLS_KW_MODE_KWP) | |
| input | The buffer holding the input data. | |
| input_length | The length of the input data in Bytes. The input uses units of 8 Bytes called semiblocks. The input must be a multiple of semiblocks.
| |
| [out] | output | The buffer holding the output data. The output buffer's minimal length is 8 bytes shorter than in_len. |
| output_size | The capacity of the output buffer. | |
| [out] | output_length | The number of bytes written to the output buffer. 0 on failure. For KWP mode, the length could be up to 15 bytes shorter than in_len, depending on how much padding was added to the data. |
0 on success. | psa_status_t mbedtls_nist_kw_wrap | ( | mbedtls_svc_key_id_t | key, |
| mbedtls_nist_kw_mode_t | mode, | ||
| const unsigned char * | input, | ||
| size_t | input_length, | ||
| unsigned char * | output, | ||
| size_t | output_size, | ||
| size_t * | output_length | ||
| ) |
This function encrypts a buffer using key wrapping.
| key | The key wrapping PSA key ID to use for encryption. The key should have the following attributes:
| |
| mode | The key wrapping mode to use (MBEDTLS_KW_MODE_KW or MBEDTLS_KW_MODE_KWP) | |
| input | The buffer holding the input data. | |
| input_length | The length of the input data in Bytes. The input uses units of 8 Bytes called semiblocks.
| |
| [out] | output | The buffer holding the output data.
|
| output_size | The capacity of the output buffer. 0 on failure. | |
| [out] | output_length | On success, the number of bytes written to the output buffer. 0 on failure. |
0 on success.
1.8.6