ReactOS 0.4.16-dev-1133-g947c03e
|
DES block cipher. More...
Go to the source code of this file.
Classes | |
struct | mbedtls_des_context |
DES context structure. More... | |
struct | mbedtls_des3_context |
Triple-DES context structure. More... | |
Macros | |
#define | MBEDTLS_DES_ENCRYPT 1 |
#define | MBEDTLS_DES_DECRYPT 0 |
#define | MBEDTLS_ERR_DES_INVALID_INPUT_LENGTH -0x0032 |
#define | MBEDTLS_ERR_DES_HW_ACCEL_FAILED -0x0033 |
#define | MBEDTLS_DES_KEY_SIZE 8 |
Typedefs | |
typedef struct mbedtls_des_context | mbedtls_des_context |
DES context structure. | |
typedef struct mbedtls_des3_context | mbedtls_des3_context |
Triple-DES context structure. | |
DES block cipher.
Definition in file des.h.
#define MBEDTLS_ERR_DES_HW_ACCEL_FAILED -0x0033 |
#define MBEDTLS_ERR_DES_INVALID_INPUT_LENGTH -0x0032 |
Triple-DES context structure.
DES context structure.
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 |
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 |
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 |
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 |
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 |
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 |
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 |
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 |
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 |
Check that key is not a weak or semi-weak DES key.
key | 8-byte secret key |
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 |
Internal function for key expansion. (Only exposed to allow overriding it, see MBEDTLS_DES_SETKEY_ALT)
SK | Round keys |
key | Base key |
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 |
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 |