|
Digi XBee(R) ANSI C Host Library
|
This file contains AES definitions and functions. More...
#include "mbedtls/config.h"#include <stddef.h>#include <stdint.h>Go to the source code of this file.
Data Structures | |
| struct | mbedtls_aes_context |
| The AES context-type definition. More... | |
Macros | |
| #define | MBEDTLS_AES_ENCRYPT 1 |
| AES encryption. More... | |
| #define | MBEDTLS_AES_DECRYPT 0 |
| AES decryption. More... | |
| #define | MBEDTLS_ERR_AES_INVALID_KEY_LENGTH -0x0020 |
| Invalid key length. More... | |
| #define | MBEDTLS_ERR_AES_INVALID_INPUT_LENGTH -0x0022 |
| Invalid data input length. More... | |
| #define | MBEDTLS_ERR_AES_BAD_INPUT_DATA -0x0021 |
| Invalid input data. More... | |
| #define | MBEDTLS_ERR_AES_FEATURE_UNAVAILABLE -0x0023 |
| Feature not available. More... | |
| #define | MBEDTLS_ERR_AES_HW_ACCEL_FAILED -0x0025 |
| AES hardware accelerator failed. More... | |
| #define | MBEDTLS_DEPRECATED |
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. More... | |
| int | mbedtls_internal_aes_decrypt (mbedtls_aes_context *ctx, const unsigned char input[16], unsigned char output[16]) |
| Internal AES block decryption function. 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... | |
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 FIPS Publication 197: Advanced Encryption Standard and ISO/IEC 18033-2:2006: Information technology – Security techniques – Encryption algorithms – Part 2: Asymmetric ciphers.
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_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.
| 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_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.
1.8.11