123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- /**
- * @file ecb.c
- * @brief Electronic Codebook (ECB) mode
- *
- * @section License
- *
- * SPDX-License-Identifier: GPL-2.0-or-later
- *
- * Copyright (C) 2010-2023 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.
- *
- * @section Description
- *
- * The Electronic Codebook (ECB) mode is a confidentiality mode that features,
- * for a given key, the assignment of a fixed ciphertext block to each
- * plaintext block, analogous to the assignment of code words in a codebook.
- * Refer to SP 800-38A for more details
- *
- * @author Oryx Embedded SARL (www.oryx-embedded.com)
- * @version 2.2.4
- **/
- //Switch to the appropriate trace level
- #define TRACE_LEVEL CRYPTO_TRACE_LEVEL
- //Dependencies
- #include "core/crypto.h"
- #include "cipher_modes/ecb.h"
- #include "debug.h"
- //Check crypto library configuration
- #if (ECB_SUPPORT == ENABLED)
- /**
- * @brief ECB encryption
- * @param[in] cipher Cipher algorithm
- * @param[in] context Cipher algorithm context
- * @param[in] p Plaintext to be encrypted
- * @param[out] c Ciphertext resulting from the encryption
- * @param[in] length Total number of data bytes to be encrypted
- * @return Error code
- **/
- error_t ecbEncrypt(const CipherAlgo *cipher, void *context,
- const uint8_t *p, uint8_t *c, size_t length)
- {
- //ECB mode operates in a block-by-block fashion
- while(length >= cipher->blockSize)
- {
- //Encrypt current block
- cipher->encryptBlock(context, p, c);
- //Next block
- p += cipher->blockSize;
- c += cipher->blockSize;
- length -= cipher->blockSize;
- }
- //The plaintext must be a multiple of the block size
- if(length != 0)
- return ERROR_INVALID_LENGTH;
- //Successful encryption
- return WINDOWS_NO_ERROR;
- }
- /**
- * @brief ECB decryption
- * @param[in] cipher Cipher algorithm
- * @param[in] context Cipher algorithm context
- * @param[in] c Ciphertext to be decrypted
- * @param[out] p Plaintext resulting from the decryption
- * @param[in] length Total number of data bytes to be decrypted
- * @return Error code
- **/
- error_t ecbDecrypt(const CipherAlgo *cipher, void *context,
- const uint8_t *c, uint8_t *p, size_t length)
- {
- //ECB mode operates in a block-by-block fashion
- while(length >= cipher->blockSize)
- {
- //Decrypt current block
- cipher->decryptBlock(context, c, p);
- //Next block
- c += cipher->blockSize;
- p += cipher->blockSize;
- length -= cipher->blockSize;
- }
- //The ciphertext must be a multiple of the block size
- if(length != 0)
- return ERROR_INVALID_LENGTH;
- //Successful encryption
- return WINDOWS_NO_ERROR;
- }
- #endif
|