Xuyi Wang / wolfSSL

Dependents:   OS

Committer:
wolfSSL
Date:
Sat Aug 18 22:20:43 2018 +0000
Revision:
15:117db924cf7c
wolfSSL 3.15.3

Who changed what in which revision?

UserRevisionLine numberNew contents of line
wolfSSL 15:117db924cf7c 1 /* sha3.h
wolfSSL 15:117db924cf7c 2 *
wolfSSL 15:117db924cf7c 3 * Copyright (C) 2006-2017 wolfSSL Inc.
wolfSSL 15:117db924cf7c 4 *
wolfSSL 15:117db924cf7c 5 * This file is part of wolfSSL.
wolfSSL 15:117db924cf7c 6 *
wolfSSL 15:117db924cf7c 7 * wolfSSL is free software; you can redistribute it and/or modify
wolfSSL 15:117db924cf7c 8 * it under the terms of the GNU General Public License as published by
wolfSSL 15:117db924cf7c 9 * the Free Software Foundation; either version 2 of the License, or
wolfSSL 15:117db924cf7c 10 * (at your option) any later version.
wolfSSL 15:117db924cf7c 11 *
wolfSSL 15:117db924cf7c 12 * wolfSSL is distributed in the hope that it will be useful,
wolfSSL 15:117db924cf7c 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
wolfSSL 15:117db924cf7c 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
wolfSSL 15:117db924cf7c 15 * GNU General Public License for more details.
wolfSSL 15:117db924cf7c 16 *
wolfSSL 15:117db924cf7c 17 * You should have received a copy of the GNU General Public License
wolfSSL 15:117db924cf7c 18 * along with this program; if not, write to the Free Software
wolfSSL 15:117db924cf7c 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
wolfSSL 15:117db924cf7c 20 */
wolfSSL 15:117db924cf7c 21
wolfSSL 15:117db924cf7c 22
wolfSSL 15:117db924cf7c 23 #ifndef WOLF_CRYPT_SHA3_H
wolfSSL 15:117db924cf7c 24 #define WOLF_CRYPT_SHA3_H
wolfSSL 15:117db924cf7c 25
wolfSSL 15:117db924cf7c 26 #include <wolfssl/wolfcrypt/types.h>
wolfSSL 15:117db924cf7c 27
wolfSSL 15:117db924cf7c 28 #ifdef WOLFSSL_SHA3
wolfSSL 15:117db924cf7c 29
wolfSSL 15:117db924cf7c 30 #ifdef HAVE_FIPS
wolfSSL 15:117db924cf7c 31 /* for fips @wc_fips */
wolfSSL 15:117db924cf7c 32 #include <wolfssl/wolfcrypt/fips.h>
wolfSSL 15:117db924cf7c 33 #endif
wolfSSL 15:117db924cf7c 34
wolfSSL 15:117db924cf7c 35 #ifdef __cplusplus
wolfSSL 15:117db924cf7c 36 extern "C" {
wolfSSL 15:117db924cf7c 37 #endif
wolfSSL 15:117db924cf7c 38
wolfSSL 15:117db924cf7c 39 #ifdef WOLFSSL_ASYNC_CRYPT
wolfSSL 15:117db924cf7c 40 #include <wolfssl/wolfcrypt/async.h>
wolfSSL 15:117db924cf7c 41 #endif
wolfSSL 15:117db924cf7c 42
wolfSSL 15:117db924cf7c 43 /* in bytes */
wolfSSL 15:117db924cf7c 44 enum {
wolfSSL 15:117db924cf7c 45 WC_SHA3_224 = WC_HASH_TYPE_SHA3_224,
wolfSSL 15:117db924cf7c 46 WC_SHA3_224_DIGEST_SIZE = 28,
wolfSSL 15:117db924cf7c 47 WC_SHA3_224_COUNT = 18,
wolfSSL 15:117db924cf7c 48
wolfSSL 15:117db924cf7c 49 WC_SHA3_256 = WC_HASH_TYPE_SHA3_256,
wolfSSL 15:117db924cf7c 50 WC_SHA3_256_DIGEST_SIZE = 32,
wolfSSL 15:117db924cf7c 51 WC_SHA3_256_COUNT = 17,
wolfSSL 15:117db924cf7c 52
wolfSSL 15:117db924cf7c 53 WC_SHA3_384 = WC_HASH_TYPE_SHA3_384,
wolfSSL 15:117db924cf7c 54 WC_SHA3_384_DIGEST_SIZE = 48,
wolfSSL 15:117db924cf7c 55 WC_SHA3_384_COUNT = 13,
wolfSSL 15:117db924cf7c 56
wolfSSL 15:117db924cf7c 57 WC_SHA3_512 = WC_HASH_TYPE_SHA3_512,
wolfSSL 15:117db924cf7c 58 WC_SHA3_512_DIGEST_SIZE = 64,
wolfSSL 15:117db924cf7c 59 WC_SHA3_512_COUNT = 9,
wolfSSL 15:117db924cf7c 60
wolfSSL 15:117db924cf7c 61 #ifndef HAVE_SELFTEST
wolfSSL 15:117db924cf7c 62 /* These values are used for HMAC, not SHA-3 directly.
wolfSSL 15:117db924cf7c 63 * They come from from FIPS PUB 202. */
wolfSSL 15:117db924cf7c 64 WC_SHA3_224_BLOCK_SIZE = 144,
wolfSSL 15:117db924cf7c 65 WC_SHA3_256_BLOCK_SIZE = 136,
wolfSSL 15:117db924cf7c 66 WC_SHA3_384_BLOCK_SIZE = 104,
wolfSSL 15:117db924cf7c 67 WC_SHA3_512_BLOCK_SIZE = 72,
wolfSSL 15:117db924cf7c 68 #endif
wolfSSL 15:117db924cf7c 69 };
wolfSSL 15:117db924cf7c 70
wolfSSL 15:117db924cf7c 71 #ifndef NO_OLD_WC_NAMES
wolfSSL 15:117db924cf7c 72 #define SHA3_224 WC_SHA3_224
wolfSSL 15:117db924cf7c 73 #define SHA3_224_DIGEST_SIZE WC_SHA3_224_DIGEST_SIZE
wolfSSL 15:117db924cf7c 74 #define SHA3_256 WC_SHA3_256
wolfSSL 15:117db924cf7c 75 #define SHA3_256_DIGEST_SIZE WC_SHA3_256_DIGEST_SIZE
wolfSSL 15:117db924cf7c 76 #define SHA3_384 WC_SHA3_384
wolfSSL 15:117db924cf7c 77 #define SHA3_384_DIGEST_SIZE WC_SHA3_384_DIGEST_SIZE
wolfSSL 15:117db924cf7c 78 #define SHA3_512 WC_SHA3_512
wolfSSL 15:117db924cf7c 79 #define SHA3_512_DIGEST_SIZE WC_SHA3_512_DIGEST_SIZE
wolfSSL 15:117db924cf7c 80 #define Sha3 wc_Sha3
wolfSSL 15:117db924cf7c 81 #endif
wolfSSL 15:117db924cf7c 82
wolfSSL 15:117db924cf7c 83
wolfSSL 15:117db924cf7c 84 #ifdef WOLFSSL_XILINX_CRYPT
wolfSSL 15:117db924cf7c 85 #include "wolfssl/wolfcrypt/port/xilinx/xil-sha3.h"
wolfSSL 15:117db924cf7c 86 #else
wolfSSL 15:117db924cf7c 87 /* Sha3 digest */
wolfSSL 15:117db924cf7c 88 typedef struct Sha3 {
wolfSSL 15:117db924cf7c 89 /* State data that is processed for each block. */
wolfSSL 15:117db924cf7c 90 word64 s[25];
wolfSSL 15:117db924cf7c 91 /* Unprocessed message data. */
wolfSSL 15:117db924cf7c 92 byte t[200];
wolfSSL 15:117db924cf7c 93 /* Index into unprocessed data to place next message byte. */
wolfSSL 15:117db924cf7c 94 byte i;
wolfSSL 15:117db924cf7c 95
wolfSSL 15:117db924cf7c 96 void* heap;
wolfSSL 15:117db924cf7c 97
wolfSSL 15:117db924cf7c 98 #ifdef WOLFSSL_ASYNC_CRYPT
wolfSSL 15:117db924cf7c 99 WC_ASYNC_DEV asyncDev;
wolfSSL 15:117db924cf7c 100 #endif /* WOLFSSL_ASYNC_CRYPT */
wolfSSL 15:117db924cf7c 101 } wc_Sha3;
wolfSSL 15:117db924cf7c 102 #endif
wolfSSL 15:117db924cf7c 103
wolfSSL 15:117db924cf7c 104
wolfSSL 15:117db924cf7c 105 WOLFSSL_API int wc_InitSha3_224(wc_Sha3*, void*, int);
wolfSSL 15:117db924cf7c 106 WOLFSSL_API int wc_Sha3_224_Update(wc_Sha3*, const byte*, word32);
wolfSSL 15:117db924cf7c 107 WOLFSSL_API int wc_Sha3_224_Final(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 108 WOLFSSL_API void wc_Sha3_224_Free(wc_Sha3*);
wolfSSL 15:117db924cf7c 109 WOLFSSL_API int wc_Sha3_224_GetHash(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 110 WOLFSSL_API int wc_Sha3_224_Copy(wc_Sha3* src, wc_Sha3* dst);
wolfSSL 15:117db924cf7c 111
wolfSSL 15:117db924cf7c 112 WOLFSSL_API int wc_InitSha3_256(wc_Sha3*, void*, int);
wolfSSL 15:117db924cf7c 113 WOLFSSL_API int wc_Sha3_256_Update(wc_Sha3*, const byte*, word32);
wolfSSL 15:117db924cf7c 114 WOLFSSL_API int wc_Sha3_256_Final(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 115 WOLFSSL_API void wc_Sha3_256_Free(wc_Sha3*);
wolfSSL 15:117db924cf7c 116 WOLFSSL_API int wc_Sha3_256_GetHash(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 117 WOLFSSL_API int wc_Sha3_256_Copy(wc_Sha3* src, wc_Sha3* dst);
wolfSSL 15:117db924cf7c 118
wolfSSL 15:117db924cf7c 119 WOLFSSL_API int wc_InitSha3_384(wc_Sha3*, void*, int);
wolfSSL 15:117db924cf7c 120 WOLFSSL_API int wc_Sha3_384_Update(wc_Sha3*, const byte*, word32);
wolfSSL 15:117db924cf7c 121 WOLFSSL_API int wc_Sha3_384_Final(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 122 WOLFSSL_API void wc_Sha3_384_Free(wc_Sha3*);
wolfSSL 15:117db924cf7c 123 WOLFSSL_API int wc_Sha3_384_GetHash(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 124 WOLFSSL_API int wc_Sha3_384_Copy(wc_Sha3* src, wc_Sha3* dst);
wolfSSL 15:117db924cf7c 125
wolfSSL 15:117db924cf7c 126 WOLFSSL_API int wc_InitSha3_512(wc_Sha3*, void*, int);
wolfSSL 15:117db924cf7c 127 WOLFSSL_API int wc_Sha3_512_Update(wc_Sha3*, const byte*, word32);
wolfSSL 15:117db924cf7c 128 WOLFSSL_API int wc_Sha3_512_Final(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 129 WOLFSSL_API void wc_Sha3_512_Free(wc_Sha3*);
wolfSSL 15:117db924cf7c 130 WOLFSSL_API int wc_Sha3_512_GetHash(wc_Sha3*, byte*);
wolfSSL 15:117db924cf7c 131 WOLFSSL_API int wc_Sha3_512_Copy(wc_Sha3* src, wc_Sha3* dst);
wolfSSL 15:117db924cf7c 132
wolfSSL 15:117db924cf7c 133 #ifdef __cplusplus
wolfSSL 15:117db924cf7c 134 } /* extern "C" */
wolfSSL 15:117db924cf7c 135 #endif
wolfSSL 15:117db924cf7c 136
wolfSSL 15:117db924cf7c 137 #endif /* WOLFSSL_SHA3 */
wolfSSL 15:117db924cf7c 138 #endif /* WOLF_CRYPT_SHA3_H */
wolfSSL 15:117db924cf7c 139
wolfSSL 15:117db924cf7c 140