Annotation of embedaddon/strongswan/src/libstrongswan/plugins/sha3/sha3_keccak.h, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * Copyright (C) 2016 Andreas Steffen
                      3:  * HSR Hochschule fuer Technik Rapperswil
                      4:  *
                      5:  * This program is free software; you can redistribute it and/or modify it
                      6:  * under the terms of the GNU General Public License as published by the
                      7:  * Free Software Foundation; either version 2 of the License, or (at your
                      8:  * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
                      9:  *
                     10:  * This program is distributed in the hope that it will be useful, but
                     11:  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
                     12:  * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
                     13:  * for more details.
                     14: n */
                     15: 
                     16: /**
                     17:  * @defgroup sha3_keccak sha3_keccak
                     18:  * @{ @ingroup sha3_p
                     19:  */
                     20: 
                     21: #ifndef SHA3_KECCAK_H_
                     22: #define SHA3_KECCAK_H_
                     23: 
                     24: typedef struct sha3_keccak_t sha3_keccak_t;
                     25: 
                     26: #include <crypto/hashers/hasher.h>
                     27: 
                     28: /**
                     29:  * Implements the Keccak-f[1600] sponge function as defined by FIPS-202.
                     30:  */
                     31: struct sha3_keccak_t {
                     32: 
                     33:        /**
                     34:         * Get the available rate in bytes
                     35:         *
                     36:         * @return                      rate in bytes
                     37:         */
                     38:        u_int (*get_rate)(sha3_keccak_t *this);
                     39: 
                     40:        /**
                     41:         * Resets the internal Keccak state
                     42:         */
                     43:        void (*reset)(sha3_keccak_t *this);
                     44: 
                     45:        /**
                     46:         * Absorbs data into the Keccak state
                     47:         *
                     48:         * @param data          data to be absorbed
                     49:         */
                     50:        void (*absorb)(sha3_keccak_t *this, chunk_t data);
                     51: 
                     52:        /**
                     53:         * Finalize the absorption phase and switch to the squeeze phase
                     54:         */
                     55:        void (*finalize)(sha3_keccak_t *this);
                     56: 
                     57:        /**
                     58:         * Squeeze the Keccak state to get output data
                     59:         * Can be called multiple times
                     60:         *
                     61:         * @param out_len       number of output bytes requested
                     62:         * @param out           output buffer, must comprise at least out_len bytes
                     63:         */
                     64:        void (*squeeze)(sha3_keccak_t *this, size_t out_len, uint8_t *out);
                     65: 
                     66:        /**
                     67:         * Destroy the sha3_keccak_t object
                     68:         */
                     69:        void (*destroy)(sha3_keccak_t *this);
                     70: 
                     71: };
                     72: 
                     73: /**
                     74:  * Creates a new sha3_keccak_t.
                     75:  *
                     76:  * @param      capacity                required capacity to achieve a given security level
                     77:  * @param delimited_suffix     bits delimiting the input message
                     78:  * @return                                     sha3_keccak_t object, NULL if capacity too big
                     79:  */
                     80: sha3_keccak_t *sha3_keccak_create(u_int capacity, uint8_t delimited_suffix);
                     81: 
                     82: #endif /** SHA3_KECCAK_H_ @}*/

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>