mbed TLS v3.1.0
|
DES block cipher. More...
#include "mbedtls/private_access.h"
#include "mbedtls/build_info.h"
#include "mbedtls/platform_util.h"
#include <stddef.h>
#include <stdint.h>
#include "des_alt.h"
Go to the source code of this file.
Macros | |
#define | MBEDTLS_DES_ENCRYPT 1 |
#define | MBEDTLS_DES_DECRYPT 0 |
#define | MBEDTLS_ERR_DES_INVALID_INPUT_LENGTH -0x0032 |
#define | MBEDTLS_DES_KEY_SIZE 8 |
Functions | |
void | mbedtls_des_init (mbedtls_des_context *ctx) |
Initialize DES context. More... | |
void | mbedtls_des_free (mbedtls_des_context *ctx) |
Clear DES context. More... | |
void | mbedtls_des3_init (mbedtls_des3_context *ctx) |
Initialize Triple-DES context. More... | |
void | mbedtls_des3_free (mbedtls_des3_context *ctx) |
Clear Triple-DES context. More... | |
void | mbedtls_des_key_set_parity (unsigned char key[MBEDTLS_DES_KEY_SIZE]) |
Set key parity on the given key to odd. More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des_key_check_key_parity (const unsigned char key[MBEDTLS_DES_KEY_SIZE]) |
Check that key parity on the given key is odd. More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des_key_check_weak (const unsigned char key[MBEDTLS_DES_KEY_SIZE]) |
Check that key is not a weak or semi-weak DES key. More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des_setkey_enc (mbedtls_des_context *ctx, const unsigned char key[MBEDTLS_DES_KEY_SIZE]) |
DES key schedule (56-bit, encryption) More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des_setkey_dec (mbedtls_des_context *ctx, const unsigned char key[MBEDTLS_DES_KEY_SIZE]) |
DES key schedule (56-bit, decryption) More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des3_set2key_enc (mbedtls_des3_context *ctx, const unsigned char key[MBEDTLS_DES_KEY_SIZE *2]) |
Triple-DES key schedule (112-bit, encryption) More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des3_set2key_dec (mbedtls_des3_context *ctx, const unsigned char key[MBEDTLS_DES_KEY_SIZE *2]) |
Triple-DES key schedule (112-bit, decryption) More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des3_set3key_enc (mbedtls_des3_context *ctx, const unsigned char key[MBEDTLS_DES_KEY_SIZE *3]) |
Triple-DES key schedule (168-bit, encryption) More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des3_set3key_dec (mbedtls_des3_context *ctx, const unsigned char key[MBEDTLS_DES_KEY_SIZE *3]) |
Triple-DES key schedule (168-bit, decryption) More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des_crypt_ecb (mbedtls_des_context *ctx, const unsigned char input[8], unsigned char output[8]) |
DES-ECB block encryption/decryption. More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des_crypt_cbc (mbedtls_des_context *ctx, int mode, size_t length, unsigned char iv[8], const unsigned char *input, unsigned char *output) |
DES-CBC buffer encryption/decryption. More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des3_crypt_ecb (mbedtls_des3_context *ctx, const unsigned char input[8], unsigned char output[8]) |
3DES-ECB block encryption/decryption More... | |
MBEDTLS_CHECK_RETURN_TYPICAL int | mbedtls_des3_crypt_cbc (mbedtls_des3_context *ctx, int mode, size_t length, unsigned char iv[8], const unsigned char *input, unsigned char *output) |
3DES-CBC buffer encryption/decryption More... | |
void | mbedtls_des_setkey (uint32_t SK[32], const unsigned char key[MBEDTLS_DES_KEY_SIZE]) |
Internal function for key expansion. (Only exposed to allow overriding it, see MBEDTLS_DES_SETKEY_ALT) More... | |
MBEDTLS_CHECK_RETURN_CRITICAL int | mbedtls_des_self_test (int verbose) |
Checkup routine. More... | |
DES block cipher.
Definition in file des.h.
#define MBEDTLS_ERR_DES_INVALID_INPUT_LENGTH -0x0032 |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des3_crypt_cbc | ( | mbedtls_des3_context * | ctx, |
int | mode, | ||
size_t | length, | ||
unsigned char | iv[8], | ||
const unsigned char * | input, | ||
unsigned char * | output | ||
) |
3DES-CBC buffer encryption/decryption
ctx | 3DES context |
mode | MBEDTLS_DES_ENCRYPT or MBEDTLS_DES_DECRYPT |
length | length of the input data |
iv | initialization vector (updated after use) |
input | buffer holding the input data |
output | buffer holding the output data |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des3_crypt_ecb | ( | mbedtls_des3_context * | ctx, |
const unsigned char | input[8], | ||
unsigned char | output[8] | ||
) |
3DES-ECB block encryption/decryption
ctx | 3DES context |
input | 64-bit input block |
output | 64-bit output block |
void mbedtls_des3_free | ( | mbedtls_des3_context * | ctx | ) |
Clear Triple-DES context.
ctx | DES3 context to be cleared |
void mbedtls_des3_init | ( | mbedtls_des3_context * | ctx | ) |
Initialize Triple-DES context.
ctx | DES3 context to be initialized |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des3_set2key_dec | ( | mbedtls_des3_context * | ctx, |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE *2] | ||
) |
Triple-DES key schedule (112-bit, decryption)
ctx | 3DES context to be initialized |
key | 16-byte secret key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des3_set2key_enc | ( | mbedtls_des3_context * | ctx, |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE *2] | ||
) |
Triple-DES key schedule (112-bit, encryption)
ctx | 3DES context to be initialized |
key | 16-byte secret key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des3_set3key_dec | ( | mbedtls_des3_context * | ctx, |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE *3] | ||
) |
Triple-DES key schedule (168-bit, decryption)
ctx | 3DES context to be initialized |
key | 24-byte secret key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des3_set3key_enc | ( | mbedtls_des3_context * | ctx, |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE *3] | ||
) |
Triple-DES key schedule (168-bit, encryption)
ctx | 3DES context to be initialized |
key | 24-byte secret key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des_crypt_cbc | ( | mbedtls_des_context * | ctx, |
int | mode, | ||
size_t | length, | ||
unsigned char | iv[8], | ||
const unsigned char * | input, | ||
unsigned char * | output | ||
) |
DES-CBC buffer encryption/decryption.
ctx | DES context |
mode | MBEDTLS_DES_ENCRYPT or MBEDTLS_DES_DECRYPT |
length | length of the input data |
iv | initialization vector (updated after use) |
input | buffer holding the input data |
output | buffer holding the output data |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des_crypt_ecb | ( | mbedtls_des_context * | ctx, |
const unsigned char | input[8], | ||
unsigned char | output[8] | ||
) |
DES-ECB block encryption/decryption.
ctx | DES context |
input | 64-bit input block |
output | 64-bit output block |
void mbedtls_des_free | ( | mbedtls_des_context * | ctx | ) |
Clear DES context.
ctx | DES context to be cleared |
void mbedtls_des_init | ( | mbedtls_des_context * | ctx | ) |
Initialize DES context.
ctx | DES context to be initialized |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des_key_check_key_parity | ( | const unsigned char | key[MBEDTLS_DES_KEY_SIZE] | ) |
Check that key parity on the given key is odd.
DES keys are 56 bits long, but each byte is padded with a parity bit to allow verification.
key | 8-byte secret key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des_key_check_weak | ( | const unsigned char | key[MBEDTLS_DES_KEY_SIZE] | ) |
Check that key is not a weak or semi-weak DES key.
key | 8-byte secret key |
void mbedtls_des_key_set_parity | ( | unsigned char | key[MBEDTLS_DES_KEY_SIZE] | ) |
Set key parity on the given key to odd.
DES keys are 56 bits long, but each byte is padded with a parity bit to allow verification.
key | 8-byte secret key |
MBEDTLS_CHECK_RETURN_CRITICAL int mbedtls_des_self_test | ( | int | verbose | ) |
Checkup routine.
void mbedtls_des_setkey | ( | uint32_t | SK[32], |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE] | ||
) |
Internal function for key expansion. (Only exposed to allow overriding it, see MBEDTLS_DES_SETKEY_ALT)
SK | Round keys |
key | Base key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des_setkey_dec | ( | mbedtls_des_context * | ctx, |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE] | ||
) |
DES key schedule (56-bit, decryption)
ctx | DES context to be initialized |
key | 8-byte secret key |
MBEDTLS_CHECK_RETURN_TYPICAL int mbedtls_des_setkey_enc | ( | mbedtls_des_context * | ctx, |
const unsigned char | key[MBEDTLS_DES_KEY_SIZE] | ||
) |
DES key schedule (56-bit, encryption)
ctx | DES context to be initialized |
key | 8-byte secret key |