3 This file is part of the AVR-Crypto-Lib.
4 Copyright (C) 2010 Daniel Otte (daniel.otte@rub.de)
6 This program is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
20 * \file hfal_cubehash.c
21 * \email daniel.otte@rub.de
24 * \license GPLv3 or later
28 #include <avr/pgmspace.h>
30 #include "hashfunction_descriptor.h"
34 static const char cubehash224_str[] PROGMEM = "CubeHash-224";
35 static const char cubehash256_str[] PROGMEM = "CubeHash-256";
36 static const char cubehash384_str[] PROGMEM = "CubeHash-384";
37 static const char cubehash512_str[] PROGMEM = "CubeHash-512";
39 const hfdesc_t cubehash224_desc PROGMEM = {
40 HFDESC_TYPE_HASHFUNCTION,
43 sizeof(cubehash_ctx_t),
44 CUBEHASH224_BLOCKSIZE,
46 (hf_init_fpt)cubehash224_init,
47 (hf_nextBlock_fpt)cubehash_nextBlock,
48 (hf_lastBlock_fpt)cubehash_lastBlock,
49 (hf_ctx2hash_fpt)cubehash224_ctx2hash,
54 const hfdesc_t cubehash256_desc PROGMEM = {
55 HFDESC_TYPE_HASHFUNCTION,
58 sizeof(cubehash_ctx_t),
59 CUBEHASH256_BLOCKSIZE,
61 (hf_init_fpt)cubehash256_init,
62 (hf_nextBlock_fpt)cubehash_nextBlock,
63 (hf_lastBlock_fpt)cubehash_lastBlock,
64 (hf_ctx2hash_fpt)cubehash256_ctx2hash,
69 const hfdesc_t cubehash384_desc PROGMEM = {
70 HFDESC_TYPE_HASHFUNCTION,
73 sizeof(cubehash_ctx_t),
74 CUBEHASH384_BLOCKSIZE,
76 (hf_init_fpt)cubehash384_init,
77 (hf_nextBlock_fpt)cubehash_nextBlock,
78 (hf_lastBlock_fpt)cubehash_lastBlock,
79 (hf_ctx2hash_fpt)cubehash384_ctx2hash,
84 const hfdesc_t cubehash512_desc PROGMEM = {
85 HFDESC_TYPE_HASHFUNCTION,
88 sizeof(cubehash_ctx_t),
89 CUBEHASH512_BLOCKSIZE,
91 (hf_init_fpt)cubehash512_init,
92 (hf_nextBlock_fpt)cubehash_nextBlock,
93 (hf_lastBlock_fpt)cubehash_lastBlock,
94 (hf_ctx2hash_fpt)cubehash512_ctx2hash,