Generic cipher wrapper for mbed TLS. More...
#include "config.h"
#include "cipher.h"
#include "cipher_internal.h"
#include "platform_util.h"
#include <stdlib.h>
#include <string.h>
#include "ccm.h"
#include "platform.h"
Macros | |
#define | CIPHER_VALIDATE_RET(cond) MBEDTLS_INTERNAL_VALIDATE_RET( cond, MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA ) |
#define | CIPHER_VALIDATE(cond) MBEDTLS_INTERNAL_VALIDATE( cond ) |
Functions | |
const int * | mbedtls_cipher_list (void) |
This function retrieves the list of ciphers supported by the generic cipher module. More... | |
const mbedtls_cipher_info_t * | mbedtls_cipher_info_from_type (const mbedtls_cipher_type_t cipher_type) |
This function retrieves the cipher-information structure associated with the given cipher type. More... | |
const mbedtls_cipher_info_t * | mbedtls_cipher_info_from_string (const char *cipher_name) |
This function retrieves the cipher-information structure associated with the given cipher name. More... | |
const mbedtls_cipher_info_t * | mbedtls_cipher_info_from_values (const mbedtls_cipher_id_t cipher_id, int key_bitlen, const mbedtls_cipher_mode_t mode) |
This function retrieves the cipher-information structure associated with the given cipher ID, key size and mode. More... | |
void | mbedtls_cipher_init (mbedtls_cipher_context_t *ctx) |
This function initializes a cipher_context as NONE. More... | |
void | mbedtls_cipher_free (mbedtls_cipher_context_t *ctx) |
This function frees and clears the cipher-specific context of ctx . Freeing ctx itself remains the responsibility of the caller. More... | |
int | mbedtls_cipher_setup (mbedtls_cipher_context_t *ctx, const mbedtls_cipher_info_t *cipher_info) |
This function initializes and fills the cipher-context structure with the appropriate values. It also clears the structure. More... | |
int | mbedtls_cipher_setkey (mbedtls_cipher_context_t *ctx, const unsigned char *key, int key_bitlen, const mbedtls_operation_t operation) |
This function sets the key to use with the given context. More... | |
int | mbedtls_cipher_set_iv (mbedtls_cipher_context_t *ctx, const unsigned char *iv, size_t iv_len) |
This function sets the initialization vector (IV) or nonce. More... | |
int | mbedtls_cipher_reset (mbedtls_cipher_context_t *ctx) |
This function resets the cipher state. More... | |
int | mbedtls_cipher_update (mbedtls_cipher_context_t *ctx, const unsigned char *input, size_t ilen, unsigned char *output, size_t *olen) |
The generic cipher update function. It encrypts or decrypts using the given cipher context. Writes as many block-sized blocks of data as possible to output. Any data that cannot be written immediately is either added to the next block, or flushed when mbedtls_cipher_finish() is called. Exception: For MBEDTLS_MODE_ECB, expects a single block in size. For example, 16 Bytes for AES. More... | |
int | mbedtls_cipher_finish (mbedtls_cipher_context_t *ctx, unsigned char *output, size_t *olen) |
The generic cipher finalization function. If data still needs to be flushed from an incomplete block, the data contained in it is padded to the size of the last block, and written to the output buffer. More... | |
int | mbedtls_cipher_crypt (mbedtls_cipher_context_t *ctx, const unsigned char *iv, size_t iv_len, const unsigned char *input, size_t ilen, unsigned char *output, size_t *olen) |
The generic all-in-one encryption/decryption function, for all ciphers except AEAD constructs. More... | |
int | mbedtls_cipher_auth_encrypt (mbedtls_cipher_context_t *ctx, const unsigned char *iv, size_t iv_len, const unsigned char *ad, size_t ad_len, const unsigned char *input, size_t ilen, unsigned char *output, size_t *olen, unsigned char *tag, size_t tag_len) |
The generic autenticated encryption (AEAD) function. More... | |
int | mbedtls_cipher_auth_decrypt (mbedtls_cipher_context_t *ctx, const unsigned char *iv, size_t iv_len, const unsigned char *ad, size_t ad_len, const unsigned char *input, size_t ilen, unsigned char *output, size_t *olen, const unsigned char *tag, size_t tag_len) |
The generic autenticated decryption (AEAD) function. More... | |
Generic cipher wrapper for mbed TLS.
Copyright (C) 2006-2015, ARM Limited, All Rights Reserved SPDX-License-Identifier: Apache-2.0
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
This file is part of mbed TLS (https://tls.mbed.org)
#define CIPHER_VALIDATE | ( | cond | ) | MBEDTLS_INTERNAL_VALIDATE( cond ) |
#define CIPHER_VALIDATE_RET | ( | cond | ) | MBEDTLS_INTERNAL_VALIDATE_RET( cond, MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA ) |
int mbedtls_cipher_auth_decrypt | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | iv, | ||
size_t | iv_len, | ||
const unsigned char * | ad, | ||
size_t | ad_len, | ||
const unsigned char * | input, | ||
size_t | ilen, | ||
unsigned char * | output, | ||
size_t * | olen, | ||
const unsigned char * | tag, | ||
size_t | tag_len | ||
) |
The generic autenticated decryption (AEAD) function.
ctx | The generic cipher context. This must be initialized and and bound to a key. |
iv | The IV to use, or NONCE_COUNTER for CTR-mode ciphers. This must be a readable buffer of at least iv_len Bytes. |
iv_len | The IV length for ciphers with variable-size IV. This parameter is discarded by ciphers with fixed-size IV. |
ad | The additional data to be authenticated. This must be a readable buffer of at least ad_len Bytes. |
ad_len | The length of ad . |
input | The buffer holding the input data. This must be a readable buffer of at least ilen Bytes. |
ilen | The length of the input data. |
output | The buffer for the output data. This must be able to hold at least ilen Bytes. |
olen | The length of the output data, to be updated with the actual number of Bytes written. This must not be NULL . |
tag | The buffer holding the authentication tag. This must be a readable buffer of at least tag_len Bytes. |
tag_len | The length of the authentication tag. |
0
on success. int mbedtls_cipher_auth_encrypt | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | iv, | ||
size_t | iv_len, | ||
const unsigned char * | ad, | ||
size_t | ad_len, | ||
const unsigned char * | input, | ||
size_t | ilen, | ||
unsigned char * | output, | ||
size_t * | olen, | ||
unsigned char * | tag, | ||
size_t | tag_len | ||
) |
The generic autenticated encryption (AEAD) function.
ctx | The generic cipher context. This must be initialized and bound to a key. |
iv | The IV to use, or NONCE_COUNTER for CTR-mode ciphers. This must be a readable buffer of at least iv_len Bytes. |
iv_len | The IV length for ciphers with variable-size IV. This parameter is discarded by ciphers with fixed-size IV. |
ad | The additional data to authenticate. This must be a readable buffer of at least ad_len Bytes. |
ad_len | The length of ad . |
input | The buffer holding the input data. This must be a readable buffer of at least ilen Bytes. |
ilen | The length of the input data. |
output | The buffer for the output data. This must be able to hold at least ilen Bytes. |
olen | The length of the output data, to be updated with the actual number of Bytes written. This must not be NULL . |
tag | The buffer for the authentication tag. This must be a writable buffer of at least tag_len Bytes. |
tag_len | The desired length of the authentication tag. |
0
on success. int mbedtls_cipher_crypt | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | iv, | ||
size_t | iv_len, | ||
const unsigned char * | input, | ||
size_t | ilen, | ||
unsigned char * | output, | ||
size_t * | olen | ||
) |
The generic all-in-one encryption/decryption function, for all ciphers except AEAD constructs.
ctx | The generic cipher context. This must be initialized. |
iv | The IV to use, or NONCE_COUNTER for CTR-mode ciphers. This must be a readable buffer of at least iv_len Bytes. |
iv_len | The IV length for ciphers with variable-size IV. This parameter is discarded by ciphers with fixed-size IV. |
input | The buffer holding the input data. This must be a readable buffer of at least ilen Bytes. |
ilen | The length of the input data in Bytes. |
output | The buffer for the output data. This must be able to hold at least ilen + block_size . This must not be the same buffer as input . |
olen | The length of the output data, to be updated with the actual number of Bytes written. This must not be NULL . |
iv
= NULL and iv_len
= 0.0
on success. int mbedtls_cipher_finish | ( | mbedtls_cipher_context_t * | ctx, |
unsigned char * | output, | ||
size_t * | olen | ||
) |
The generic cipher finalization function. If data still needs to be flushed from an incomplete block, the data contained in it is padded to the size of the last block, and written to the output
buffer.
ctx | The generic cipher context. This must be initialized and bound to a key. |
output | The buffer to write data to. This needs to be a writable buffer of at least block_size Bytes. |
olen | The length of the data written to the output buffer. This may not be NULL . |
0
on success. void mbedtls_cipher_free | ( | mbedtls_cipher_context_t * | ctx | ) |
This function frees and clears the cipher-specific context of ctx
. Freeing ctx
itself remains the responsibility of the caller.
ctx | The context to be freed. If this is NULL , the function has no effect, otherwise this must point to an initialized context. |
const mbedtls_cipher_info_t* mbedtls_cipher_info_from_string | ( | const char * | cipher_name | ) |
This function retrieves the cipher-information structure associated with the given cipher name.
cipher_name | Name of the cipher to search for. This must not be NULL . |
cipher_name
. NULL
if the associated cipher information is not found. const mbedtls_cipher_info_t* mbedtls_cipher_info_from_type | ( | const mbedtls_cipher_type_t | cipher_type | ) |
This function retrieves the cipher-information structure associated with the given cipher type.
cipher_type | Type of the cipher to search for. |
cipher_type
. NULL
if the associated cipher information is not found. const mbedtls_cipher_info_t* mbedtls_cipher_info_from_values | ( | const mbedtls_cipher_id_t | cipher_id, |
int | key_bitlen, | ||
const mbedtls_cipher_mode_t | mode | ||
) |
This function retrieves the cipher-information structure associated with the given cipher ID, key size and mode.
cipher_id | The ID of the cipher to search for. For example, MBEDTLS_CIPHER_ID_AES. |
key_bitlen | The length of the key in bits. |
mode | The cipher mode. For example, MBEDTLS_MODE_CBC. |
cipher_id
. NULL
if the associated cipher information is not found. void mbedtls_cipher_init | ( | mbedtls_cipher_context_t * | ctx | ) |
This function initializes a cipher_context
as NONE.
ctx | The context to be initialized. This must not be NULL . |
const int* mbedtls_cipher_list | ( | void | ) |
This function retrieves the list of ciphers supported by the generic cipher module.
int mbedtls_cipher_reset | ( | mbedtls_cipher_context_t * | ctx | ) |
This function resets the cipher state.
ctx | The generic cipher context. This must be initialized. |
0
on success. int mbedtls_cipher_set_iv | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | iv, | ||
size_t | iv_len | ||
) |
This function sets the initialization vector (IV) or nonce.
ctx | The generic cipher context. This must be initialized and bound to a cipher information structure. |
iv | The IV to use, or NONCE_COUNTER for CTR-mode ciphers. This must be a readable buffer of at least iv_len Bytes. |
iv_len | The IV length for ciphers with variable-size IV. This parameter is discarded by ciphers with fixed-size IV. |
0
on success. int mbedtls_cipher_setkey | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | key, | ||
int | key_bitlen, | ||
const mbedtls_operation_t | operation | ||
) |
This function sets the key to use with the given context.
ctx | The generic cipher context. This must be initialized and bound to a cipher information structure. |
key | The key to use. This must be a readable buffer of at least key_bitlen Bits. |
key_bitlen | The key length to use, in Bits. |
operation | The operation that the key will be used for: MBEDTLS_ENCRYPT or MBEDTLS_DECRYPT. |
0
on success. int mbedtls_cipher_setup | ( | mbedtls_cipher_context_t * | ctx, |
const mbedtls_cipher_info_t * | cipher_info | ||
) |
This function initializes and fills the cipher-context structure with the appropriate values. It also clears the structure.
ctx | The context to initialize. This must be initialized. |
cipher_info | The cipher to use. |
0
on success. int mbedtls_cipher_update | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | input, | ||
size_t | ilen, | ||
unsigned char * | output, | ||
size_t * | olen | ||
) |
The generic cipher update function. It encrypts or decrypts using the given cipher context. Writes as many block-sized blocks of data as possible to output. Any data that cannot be written immediately is either added to the next block, or flushed when mbedtls_cipher_finish() is called. Exception: For MBEDTLS_MODE_ECB, expects a single block in size. For example, 16 Bytes for AES.
ilen
as a multiple of the block size of the cipher.ctx | The generic cipher context. This must be initialized and bound to a key. |
input | The buffer holding the input data. This must be a readable buffer of at least ilen Bytes. |
ilen | The length of the input data. |
output | The buffer for the output data. This must be able to hold at least ilen + block_size . This must not be the same buffer as input . |
olen | The length of the output data, to be updated with the actual number of Bytes written. This must not be NULL . |
0
on success.