mbedtls_cipher_update() function
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.
Arguments
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 \p 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 \p input.
olen
The length of the output data, to be updated with the actual number of Bytes written. This must not be \c NULL.
Return value
\c 0 on success. #MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA on parameter-verification failure. #MBEDTLS_ERR_CIPHER_FEATURE_UNAVAILABLE on an unsupported mode for a cipher. A cipher-specific error code on failure.
Notes
If the underlying cipher is used in GCM mode, all calls to this function, except for the last one before mbedtls_cipher_finish(), must have \p ilen as a multiple of the block size of the cipher.