Cipher Feedback (CFB) mode. More...
Go to the source code of this file.
Macros | |
#define | TRACE_LEVEL CRYPTO_TRACE_LEVEL |
Functions | |
__weak_func error_t | cfbEncrypt (const CipherAlgo *cipher, void *context, uint_t s, uint8_t *iv, const uint8_t *p, uint8_t *c, size_t length) |
CFB encryption. More... | |
__weak_func error_t | cfbDecrypt (const CipherAlgo *cipher, void *context, uint_t s, uint8_t *iv, const uint8_t *c, uint8_t *p, size_t length) |
CFB decryption. More... | |
Detailed Description
Cipher Feedback (CFB) mode.
License
SPDX-License-Identifier: GPL-2.0-or-later
Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved.
This file is part of CycloneCRYPTO Open.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Description
The Cipher Feedback (CFB) mode is a confidentiality mode that features the feedback of successive ciphertext segments into the input blocks of the forward cipher to generate output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. The CFB mode requires an IV as the initial input block. The IV need not be secret, but it must be unpredictable. Refer to SP 800-38A for more details
- Version
- 2.4.4
Definition in file cfb.c.
Macro Definition Documentation
◆ TRACE_LEVEL
Function Documentation
◆ cfbDecrypt()
__weak_func error_t cfbDecrypt | ( | const CipherAlgo * | cipher, |
void * | context, | ||
uint_t | s, | ||
uint8_t * | iv, | ||
const uint8_t * | c, | ||
uint8_t * | p, | ||
size_t | length | ||
) |
CFB decryption.
- Parameters
-
[in] cipher Cipher algorithm [in] context Cipher algorithm context [in] s Size of the plaintext and ciphertext segments [in,out] iv Initialization vector [in] c Ciphertext to be decrypted [out] p Plaintext resulting from the decryption [in] length Total number of data bytes to be decrypted
- Returns
- Error code
◆ cfbEncrypt()
__weak_func error_t cfbEncrypt | ( | const CipherAlgo * | cipher, |
void * | context, | ||
uint_t | s, | ||
uint8_t * | iv, | ||
const uint8_t * | p, | ||
uint8_t * | c, | ||
size_t | length | ||
) |
CFB encryption.
- Parameters
-
[in] cipher Cipher algorithm [in] context Cipher algorithm context [in] s Size of the plaintext and ciphertext segments [in,out] iv Initialization vector [in] p Plaintext to be encrypted [out] c Ciphertext resulting from the encryption [in] length Total number of data bytes to be encrypted
- Returns
- Error code