RetroArch
|
Generic cipher wrapper for mbed TLS. More...
#include "mbedtls/config.h"
#include "mbedtls/cipher.h"
#include "mbedtls/cipher_internal.h"
#include <stdlib.h>
#include <string.h>
#include "mbedtls/gcm.h"
#include "mbedtls/ccm.h"
#include "mbedtls/platform.h"
#include "arc4_alt.h"
Macros | |
#define | MBEDTLS_CIPHER_MODE_STREAM |
Functions | |
const int * | mbedtls_cipher_list (void) |
Returns 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) |
Returns 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) |
Returns 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) |
Returns the cipher information structure associated with the given cipher id, key size and mode. More... | |
void | mbedtls_cipher_init (mbedtls_cipher_context_t *ctx) |
Initialize a cipher_context (as NONE) More... | |
void | mbedtls_cipher_free (mbedtls_cipher_context_t *ctx) |
Free and clear 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) |
Initialises and fills the cipher context structure with the appropriate values. More... | |
int | mbedtls_cipher_setkey (mbedtls_cipher_context_t *ctx, const unsigned char *key, int key_bitlen, const mbedtls_operation_t operation) |
Set 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) |
Set the initialization vector (IV) or nonce. More... | |
int | mbedtls_cipher_reset (mbedtls_cipher_context_t *ctx) |
Finish preparation of the given context. More... | |
int | mbedtls_cipher_update_ad (mbedtls_cipher_context_t *ctx, const unsigned char *ad, size_t ad_len) |
Add additional data (for AEAD ciphers). Currently only supported with GCM. Must be called exactly once, after mbedtls_cipher_reset(). More... | |
int | mbedtls_cipher_update (mbedtls_cipher_context_t *ctx, const unsigned char *input, size_t ilen, unsigned char *output, size_t *olen) |
Generic cipher update function. Encrypts/decrypts using the given cipher context. Writes as many block size'd blocks of data as possible to output. Any data that cannot be written immediately will either be added to the next block, or flushed when cipher_final is called. Exception: for MBEDTLS_MODE_ECB, expects single block in size (e.g. 16 bytes for AES) More... | |
static void | add_pkcs_padding (unsigned char *output, size_t output_len, size_t data_len) |
static int | get_pkcs_padding (unsigned char *input, size_t input_len, size_t *data_len) |
static void | add_one_and_zeros_padding (unsigned char *output, size_t output_len, size_t data_len) |
static int | get_one_and_zeros_padding (unsigned char *input, size_t input_len, size_t *data_len) |
static void | add_zeros_and_len_padding (unsigned char *output, size_t output_len, size_t data_len) |
static int | get_zeros_and_len_padding (unsigned char *input, size_t input_len, size_t *data_len) |
static void | add_zeros_padding (unsigned char *output, size_t output_len, size_t data_len) |
static int | get_zeros_padding (unsigned char *input, size_t input_len, size_t *data_len) |
static int | get_no_padding (unsigned char *input, size_t input_len, size_t *data_len) |
int | mbedtls_cipher_finish (mbedtls_cipher_context_t *ctx, unsigned char *output, size_t *olen) |
Generic cipher finalisation function. If data still needs to be flushed from an incomplete block, data contained within it will be padded with the size of the last block, and written to the output buffer. More... | |
int | mbedtls_cipher_set_padding_mode (mbedtls_cipher_context_t *ctx, mbedtls_cipher_padding_t mode) |
Set padding mode, for cipher modes that use padding. (Default: PKCS7 padding.) More... | |
int | mbedtls_cipher_write_tag (mbedtls_cipher_context_t *ctx, unsigned char *tag, size_t tag_len) |
Write tag for AEAD ciphers. Currently only supported with GCM. Must be called after mbedtls_cipher_finish(). More... | |
int | mbedtls_cipher_check_tag (mbedtls_cipher_context_t *ctx, const unsigned char *tag, size_t tag_len) |
Check tag for AEAD ciphers. Currently only supported with GCM. Must be called after mbedtls_cipher_finish(). 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) |
Generic all-in-one encryption/decryption (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) |
Generic autenticated encryption (AEAD ciphers). 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) |
Generic autenticated decryption (AEAD ciphers). More... | |
Variables | |
static int | supported_init = 0 |
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 MBEDTLS_CIPHER_MODE_STREAM |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
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 | ||
) |
Generic autenticated decryption (AEAD ciphers).
ctx | generic cipher context |
iv | IV to use (or NONCE_COUNTER for CTR-mode ciphers) |
iv_len | IV length for ciphers with variable-size IV; discarded by ciphers with fixed-size IV. |
ad | Additional data to be authenticated. |
ad_len | Length of ad. |
input | buffer holding the input data |
ilen | length of the input data |
output | buffer for the output data. Should be able to hold at least ilen. |
olen | length of the output data, will be filled with the actual number of bytes written. |
tag | buffer holding the authentication tag |
tag_len | length of the authentication tag |
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 | ||
) |
Generic autenticated encryption (AEAD ciphers).
ctx | generic cipher context |
iv | IV to use (or NONCE_COUNTER for CTR-mode ciphers) |
iv_len | IV length for ciphers with variable-size IV; discarded by ciphers with fixed-size IV. |
ad | Additional data to authenticate. |
ad_len | Length of ad. |
input | buffer holding the input data |
ilen | length of the input data |
output | buffer for the output data. Should be able to hold at least ilen. |
olen | length of the output data, will be filled with the actual number of bytes written. |
tag | buffer for the authentication tag |
tag_len | desired tag length |
int mbedtls_cipher_check_tag | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | tag, | ||
size_t | tag_len | ||
) |
Check tag for AEAD ciphers. Currently only supported with GCM. Must be called after mbedtls_cipher_finish().
ctx | Generic cipher context |
tag | Buffer holding the tag |
tag_len | Length of the tag to check |
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 | ||
) |
Generic all-in-one encryption/decryption (for all ciphers except AEAD constructs).
ctx | generic cipher context |
iv | IV to use (or NONCE_COUNTER for CTR-mode ciphers) |
iv_len | IV length for ciphers with variable-size IV; discarded by ciphers with fixed-size IV. |
input | buffer holding the input data |
ilen | length of the input data |
output | buffer for the output data. Should be able to hold at least ilen + block_size. Cannot be the same buffer as input! |
olen | length of the output data, will be filled with the actual number of bytes written. |
int mbedtls_cipher_finish | ( | mbedtls_cipher_context_t * | ctx, |
unsigned char * | output, | ||
size_t * | olen | ||
) |
Generic cipher finalisation function. If data still needs to be flushed from an incomplete block, data contained within it will be padded with the size of the last block, and written to the output buffer.
ctx | Generic cipher context |
output | buffer to write data to. Needs block_size available. |
olen | length of the data written to the output buffer. |
void mbedtls_cipher_free | ( | mbedtls_cipher_context_t * | ctx | ) |
Free and clear the cipher-specific context of ctx. Freeing ctx itself remains the responsibility of the caller.
const mbedtls_cipher_info_t* mbedtls_cipher_info_from_string | ( | const char * | cipher_name | ) |
Returns the cipher information structure associated with the given cipher name.
cipher_name | Name of the cipher to search for. |
const mbedtls_cipher_info_t* mbedtls_cipher_info_from_type | ( | const mbedtls_cipher_type_t | cipher_type | ) |
Returns the cipher information structure associated with the given cipher type.
cipher_type | Type of the cipher to search for. |
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 | ||
) |
Returns the cipher information structure associated with the given cipher id, key size and mode.
cipher_id | Id of the cipher to search for (e.g. MBEDTLS_CIPHER_ID_AES) |
key_bitlen | Length of the key in bits |
mode | Cipher mode (e.g. MBEDTLS_MODE_CBC) |
void mbedtls_cipher_init | ( | mbedtls_cipher_context_t * | ctx | ) |
Initialize a cipher_context (as NONE)
Returns the list of ciphers supported by the generic cipher module.
int mbedtls_cipher_reset | ( | mbedtls_cipher_context_t * | ctx | ) |
Finish preparation of the given context.
ctx | generic cipher context |
int mbedtls_cipher_set_iv | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | iv, | ||
size_t | iv_len | ||
) |
Set the initialization vector (IV) or nonce.
ctx | generic cipher context |
iv | IV to use (or NONCE_COUNTER for CTR-mode ciphers) |
iv_len | IV length for ciphers with variable-size IV; discarded by ciphers with fixed-size IV. |
int mbedtls_cipher_set_padding_mode | ( | mbedtls_cipher_context_t * | ctx, |
mbedtls_cipher_padding_t | mode | ||
) |
Set padding mode, for cipher modes that use padding. (Default: PKCS7 padding.)
ctx | generic cipher context |
mode | padding mode |
int mbedtls_cipher_setkey | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | key, | ||
int | key_bitlen, | ||
const mbedtls_operation_t | operation | ||
) |
Set the key to use with the given context.
ctx | generic cipher context. May not be NULL. Must have been initialised using cipher_context_from_type or cipher_context_from_string. |
key | The key to use. |
key_bitlen | key length to use, in bits. |
operation | Operation that the key will be used for, either MBEDTLS_ENCRYPT or MBEDTLS_DECRYPT. |
int mbedtls_cipher_setup | ( | mbedtls_cipher_context_t * | ctx, |
const mbedtls_cipher_info_t * | cipher_info | ||
) |
Initialises and fills the cipher context structure with the appropriate values.
ctx | context to initialise. May not be NULL. |
cipher_info | cipher to use. |
int mbedtls_cipher_update | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | input, | ||
size_t | ilen, | ||
unsigned char * | output, | ||
size_t * | olen | ||
) |
Generic cipher update function. Encrypts/decrypts using the given cipher context. Writes as many block size'd blocks of data as possible to output. Any data that cannot be written immediately will either be added to the next block, or flushed when cipher_final is called. Exception: for MBEDTLS_MODE_ECB, expects single block in size (e.g. 16 bytes for AES)
ctx | generic cipher context |
input | buffer holding the input data |
ilen | length of the input data |
output | buffer for the output data. Should be able to hold at least ilen + block_size. Cannot be the same buffer as input! |
olen | length of the output data, will be filled with the actual number of bytes written. |
int mbedtls_cipher_update_ad | ( | mbedtls_cipher_context_t * | ctx, |
const unsigned char * | ad, | ||
size_t | ad_len | ||
) |
Add additional data (for AEAD ciphers). Currently only supported with GCM. Must be called exactly once, after mbedtls_cipher_reset().
ctx | generic cipher context |
ad | Additional data to use. |
ad_len | Length of ad. |
int mbedtls_cipher_write_tag | ( | mbedtls_cipher_context_t * | ctx, |
unsigned char * | tag, | ||
size_t | tag_len | ||
) |
Write tag for AEAD ciphers. Currently only supported with GCM. Must be called after mbedtls_cipher_finish().
ctx | Generic cipher context |
tag | buffer to write the tag |
tag_len | Length of the tag to write |
|
static |