/* bcal_aes256.c */ /* This file is part of the AVR-Crypto-Lib. Copyright (C) 2006-2015 Daniel Otte (bg@nerilex.org) 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 3 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, see . */ /** * \file bcal_aes256.c * \email bg@nerilex.org * \author Daniel Otte * \date 2009-01-08 * \license GPLv3 or later * */ #include #include #include "blockcipher_descriptor.h" #include "aes.h" #include "aes256_enc.h" #include "aes_keyschedule.h" #include "keysize_descriptor.h" const char aes256_str[] PROGMEM = "AES-256"; const uint8_t aes256_keysize_desc[] PROGMEM = { KS_TYPE_LIST, 1, KS_INT(256), KS_TYPE_TERMINATOR }; const bcdesc_t aes256_desc PROGMEM = { BCDESC_TYPE_BLOCKCIPHER, BC_INIT_TYPE_1, aes256_str, sizeof(aes256_ctx_t), 128, { (void_fpt) aes256_init }, { (void_fpt) aes256_enc }, { (void_fpt) NULL }, (bc_free_fpt) NULL, aes256_keysize_desc };