This file contains AES definitions and functions. More...


Go to the source code of this file.
Classes | |
| struct | mbedtls_aes_context |
| The AES context-type definition. More... | |
Macros | |
| #define | MBEDTLS_AES_ENCRYPT 1 |
| #define | MBEDTLS_AES_DECRYPT 0 |
| #define | MBEDTLS_ERR_AES_INVALID_KEY_LENGTH -0x0020 |
| #define | MBEDTLS_ERR_AES_INVALID_INPUT_LENGTH -0x0022 |
| #define | MBEDTLS_ERR_AES_BAD_INPUT_DATA -0x0021 |
| #define | MBEDTLS_ERR_AES_FEATURE_UNAVAILABLE -0x0023 |
| #define | MBEDTLS_ERR_AES_HW_ACCEL_FAILED -0x0025 |
| #define | MBEDTLS_DEPRECATED |
Typedefs | |
| typedef struct mbedtls_aes_context | mbedtls_aes_context |
| The AES context-type definition. More... | |
Functions | |
| void | mbedtls_aes_init (mbedtls_aes_context *ctx) |
| This function initializes the specified AES context. More... | |
| void | mbedtls_aes_free (mbedtls_aes_context *ctx) |
| This function releases and clears the specified AES context. More... | |
| int | mbedtls_aes_setkey_enc (mbedtls_aes_context *ctx, const unsigned char *key, unsigned int keybits) |
| This function sets the encryption key. More... | |
| int | mbedtls_aes_setkey_dec (mbedtls_aes_context *ctx, const unsigned char *key, unsigned int keybits) |
| This function sets the decryption key. More... | |
| int | mbedtls_aes_crypt_ecb (mbedtls_aes_context *ctx, int mode, const unsigned char input[16], unsigned char output[16]) |
| This function performs an AES single-block encryption or decryption operation. More... | |
| int | mbedtls_internal_aes_encrypt (mbedtls_aes_context *ctx, const unsigned char input[16], unsigned char output[16]) |
Internal AES block encryption function. This is only exposed to allow overriding it using MBEDTLS_AES_ENCRYPT_ALT. More... | |
| int | mbedtls_internal_aes_decrypt (mbedtls_aes_context *ctx, const unsigned char input[16], unsigned char output[16]) |
Internal AES block decryption function. This is only exposed to allow overriding it using see MBEDTLS_AES_DECRYPT_ALT. More... | |
| MBEDTLS_DEPRECATED void | mbedtls_aes_encrypt (mbedtls_aes_context *ctx, const unsigned char input[16], unsigned char output[16]) |
| Deprecated internal AES block encryption function without return value. More... | |
| MBEDTLS_DEPRECATED void | mbedtls_aes_decrypt (mbedtls_aes_context *ctx, const unsigned char input[16], unsigned char output[16]) |
| Deprecated internal AES block decryption function without return value. More... | |
| int | mbedtls_aes_self_test (int verbose) |
| Checkup routine. More... | |
This file contains AES definitions and functions.
The Advanced Encryption Standard (AES) specifies a FIPS-approved
cryptographic algorithm that can be used to protect electronic
data.
The AES algorithm is a symmetric block cipher that can
encrypt and decrypt information. For more information, see
<em>FIPS Publication 197: Advanced Encryption Standard</em> and
<em>ISO/IEC 18033-2:2006: Information technology -- Security
techniques -- Encryption algorithms -- Part 2: Asymmetric
ciphers</em>.
The AES-XTS block mode is standardized by NIST SP 800-38E
<https://nvlpubs.nist.gov/nistpubs/legacy/sp/nistspecialpublication800-38e.pdf>
and described in detail by IEEE P1619
<https://ieeexplore.ieee.org/servlet/opac?punumber=4375278>.
| #define MBEDTLS_AES_DECRYPT 0 |
AES decryption.
| #define MBEDTLS_AES_ENCRYPT 1 |
AES encryption.
| #define MBEDTLS_DEPRECATED |
| #define MBEDTLS_ERR_AES_BAD_INPUT_DATA -0x0021 |
Invalid input data.
| #define MBEDTLS_ERR_AES_FEATURE_UNAVAILABLE -0x0023 |
Feature not available. For example, an unsupported AES key size.
| #define MBEDTLS_ERR_AES_HW_ACCEL_FAILED -0x0025 |
AES hardware accelerator failed.
| #define MBEDTLS_ERR_AES_INVALID_INPUT_LENGTH -0x0022 |
Invalid data input length.
| #define MBEDTLS_ERR_AES_INVALID_KEY_LENGTH -0x0020 |
Invalid key length.
| typedef struct mbedtls_aes_context mbedtls_aes_context |
The AES context-type definition.
| int mbedtls_aes_crypt_ecb | ( | mbedtls_aes_context * | ctx, |
| int | mode, | ||
| const unsigned char | input[16], | ||
| unsigned char | output[16] | ||
| ) |
This function performs an AES single-block encryption or decryption operation.
It performs the operation defined in the mode parameter (encrypt or decrypt), on the input data buffer defined in the input parameter.
mbedtls_aes_init(), and either mbedtls_aes_setkey_enc() or mbedtls_aes_setkey_dec() must be called before the first call to this API with the same context.
| ctx | The AES context to use for encryption or decryption. It must be initialized and bound to a key. |
| mode | The AES operation: MBEDTLS_AES_ENCRYPT or MBEDTLS_AES_DECRYPT. |
| input | The buffer holding the input data. It must be readable and at least 16 Bytes long. |
| output | The buffer where the output data will be written. It must be writeable and at least 16 Bytes long. |
0 on success. 
| MBEDTLS_DEPRECATED void mbedtls_aes_decrypt | ( | mbedtls_aes_context * | ctx, |
| const unsigned char | input[16], | ||
| unsigned char | output[16] | ||
| ) |
Deprecated internal AES block decryption function without return value.
| ctx | The AES context to use for decryption. |
| input | Ciphertext block. |
| output | Output (plaintext) block. |

| MBEDTLS_DEPRECATED void mbedtls_aes_encrypt | ( | mbedtls_aes_context * | ctx, |
| const unsigned char | input[16], | ||
| unsigned char | output[16] | ||
| ) |
Deprecated internal AES block encryption function without return value.
| ctx | The AES context to use for encryption. |
| input | Plaintext block. |
| output | Output (ciphertext) block. |

| void mbedtls_aes_free | ( | mbedtls_aes_context * | ctx | ) |
This function releases and clears the specified AES context.
| ctx | The AES context to clear. If this is NULL, this function does nothing. Otherwise, the context must have been at least initialized. |

| void mbedtls_aes_init | ( | mbedtls_aes_context * | ctx | ) |
This function initializes the specified AES context.
It must be the first API called before using
the context.
| ctx | The AES context to initialize. This must not be NULL. |
| int mbedtls_aes_self_test | ( | int | verbose | ) |
Checkup routine.
0 on success. 1 on failure. | int mbedtls_aes_setkey_dec | ( | mbedtls_aes_context * | ctx, |
| const unsigned char * | key, | ||
| unsigned int | keybits | ||
| ) |
This function sets the decryption key.
| ctx | The AES context to which the key should be bound. It must be initialized. |
| key | The decryption key. This must be a readable buffer of size keybits bits. |
| keybits | The size of data passed. Valid options are:
|
0 on success. | int mbedtls_aes_setkey_enc | ( | mbedtls_aes_context * | ctx, |
| const unsigned char * | key, | ||
| unsigned int | keybits | ||
| ) |
This function sets the encryption key.
| ctx | The AES context to which the key should be bound. It must be initialized. |
| key | The encryption key. This must be a readable buffer of size keybits bits. |
| keybits | The size of data passed in bits. Valid options are:
|
0 on success. | int mbedtls_internal_aes_decrypt | ( | mbedtls_aes_context * | ctx, |
| const unsigned char | input[16], | ||
| unsigned char | output[16] | ||
| ) |
Internal AES block decryption function. This is only exposed to allow overriding it using see MBEDTLS_AES_DECRYPT_ALT.
| ctx | The AES context to use for decryption. |
| input | The ciphertext block. |
| output | The output (plaintext) block. |
0 on success. | int mbedtls_internal_aes_encrypt | ( | mbedtls_aes_context * | ctx, |
| const unsigned char | input[16], | ||
| unsigned char | output[16] | ||
| ) |
Internal AES block encryption function. This is only exposed to allow overriding it using MBEDTLS_AES_ENCRYPT_ALT.
| ctx | The AES context to use for encryption. |
| input | The plaintext block. |
| output | The output (ciphertext) block. |
0 on success.