NimBLE-Arduino 2.2.0
Loading...
Searching...
No Matches
cbc_mode.h File Reference

Interface to a CBC mode implementation. More...

Go to the source code of this file.

Functions

int tc_cbc_mode_encrypt (uint8_t *out, unsigned int outlen, const uint8_t *in, unsigned int inlen, const uint8_t *iv, const TCAesKeySched_t sched)
 CBC encryption procedure CBC encrypts inlen bytes of the in buffer into the out buffer using the encryption key schedule provided, prepends iv to out.
 
int tc_cbc_mode_decrypt (uint8_t *out, unsigned int outlen, const uint8_t *in, unsigned int inlen, const uint8_t *iv, const TCAesKeySched_t sched)
 CBC decryption procedure CBC decrypts inlen bytes of the in buffer into the out buffer using the provided encryption key schedule.
 

Detailed Description

Interface to a CBC mode implementation.

Overview: CBC (for "cipher block chaining") mode is a NIST approved mode of operation defined in SP 800-38a. It can be used with any block cipher to provide confidentiality of strings whose lengths are multiples of the block_size of the underlying block cipher. TinyCrypt hard codes AES as the block cipher.

Security: CBC mode provides data confidentiality given that the maximum number q of blocks encrypted under a single key satisfies q < 2^63, which is not a practical constraint (it is considered a good practice to replace the encryption when q == 2^56). CBC mode provides NO data integrity.

CBC mode assumes that the IV value input into the tc_cbc_mode_encrypt is randomly generated. The TinyCrypt library provides HMAC-PRNG module, which generates suitable IVs. Other methods for generating IVs are acceptable, provided that the values of the IVs generated appear random to any adversary, including someone with complete knowledge of the system design.

The randomness property on which CBC mode's security depends is the unpredictability of the IV. Since it is unpredictable, this means in practice that CBC mode requires that the IV is stored somehow with the ciphertext in order to recover the plaintext.

TinyCrypt CBC encryption prepends the IV to the ciphertext, because this affords a more efficient (few buffers) decryption. Hence tc_cbc_mode_encrypt assumes the ciphertext buffer is always 16 bytes larger than the plaintext buffer.

Requires: AES-128

Usage: 1) call tc_cbc_mode_encrypt to encrypt data.

      2) call tc_cbc_mode_decrypt to decrypt data.

Function Documentation

◆ tc_cbc_mode_decrypt()

int tc_cbc_mode_decrypt ( uint8_t *  out,
unsigned int  outlen,
const uint8_t *  in,
unsigned int  inlen,
const uint8_t *  iv,
const TCAesKeySched_t  sched 
)

CBC decryption procedure CBC decrypts inlen bytes of the in buffer into the out buffer using the provided encryption key schedule.

Returns
returns TC_CRYPTO_SUCCESS (1) returns TC_CRYPTO_FAIL (0) if: out == NULL or in == NULL or sched == NULL or inlen == 0 or outlen == 0 or (inlen % TC_AES_BLOCK_SIZE) != 0 or (outlen % TC_AES_BLOCK_SIZE) != 0 or outlen != inlen + TC_AES_BLOCK_SIZE
Note
Assumes:- in == iv + ciphertext, i.e. the iv and the ciphertext are contiguous. This allows for a very efficient decryption algorithm that would not otherwise be possible
  • sched was configured by aes_set_decrypt_key
  • out buffer is large enough to hold the decrypted plaintext and is a contiguous buffer
  • inlen gives the number of bytes in the in buffer
Parameters
outIN/OUT – buffer to receive decrypted data
outlenIN – length of plaintext buffer in bytes
inIN – ciphertext to decrypt, including IV
inlenIN – length of ciphertext buffer in bytes
ivIN – the IV for the this encrypt/decrypt
schedIN – AES key schedule for this decrypt

◆ tc_cbc_mode_encrypt()

int tc_cbc_mode_encrypt ( uint8_t *  out,
unsigned int  outlen,
const uint8_t *  in,
unsigned int  inlen,
const uint8_t *  iv,
const TCAesKeySched_t  sched 
)

CBC encryption procedure CBC encrypts inlen bytes of the in buffer into the out buffer using the encryption key schedule provided, prepends iv to out.

Returns
returns TC_CRYPTO_SUCCESS (1) returns TC_CRYPTO_FAIL (0) if: out == NULL or in == NULL or ctr == NULL or sched == NULL or inlen == 0 or (inlen % TC_AES_BLOCK_SIZE) != 0 or (outlen % TC_AES_BLOCK_SIZE) != 0 or outlen != inlen + TC_AES_BLOCK_SIZE
Note
Assumes: - sched has been configured by aes_set_encrypt_key
  • iv contains a 16 byte random string
  • out buffer is large enough to hold the ciphertext + iv
  • out buffer is a contiguous buffer
  • in holds the plaintext and is a contiguous buffer
  • inlen gives the number of bytes in the in buffer
Parameters
outIN/OUT – buffer to receive the ciphertext
outlenIN – length of ciphertext buffer in bytes
inIN – plaintext to encrypt
inlenIN – length of plaintext buffer in bytes
ivIN – the IV for the this encrypt/decrypt
schedIN – AES key schedule for this encrypt