Path: blob/master/sha3/sph_groestl.c
1299 views
/* $Id: groestl.c 260 2011-07-21 01:02:38Z tp $ */1/*2* Groestl implementation.3*4* ==========================(LICENSE BEGIN)============================5*6* Copyright (c) 2007-2010 Projet RNRT SAPHIR7*8* Permission is hereby granted, free of charge, to any person obtaining9* a copy of this software and associated documentation files (the10* "Software"), to deal in the Software without restriction, including11* without limitation the rights to use, copy, modify, merge, publish,12* distribute, sublicense, and/or sell copies of the Software, and to13* permit persons to whom the Software is furnished to do so, subject to14* the following conditions:15*16* The above copyright notice and this permission notice shall be17* included in all copies or substantial portions of the Software.18*19* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,20* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF21* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.22* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY23* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,24* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE25* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.26*27* ===========================(LICENSE END)=============================28*29* @author Thomas Pornin <[email protected]>30*/3132#include <stddef.h>33#include <string.h>3435#include "sph_groestl.h"3637#ifdef __cplusplus38extern "C"{39#endif4041#if SPH_SMALL_FOOTPRINT && !defined SPH_SMALL_FOOTPRINT_GROESTL42#define SPH_SMALL_FOOTPRINT_GROESTL 143#endif4445/*46* Apparently, the 32-bit-only version is not faster than the 64-bit47* version unless using the "small footprint" code on a 32-bit machine.48*/49#if !defined SPH_GROESTL_6450#if SPH_SMALL_FOOTPRINT_GROESTL && !SPH_64_TRUE51#define SPH_GROESTL_64 052#else53#define SPH_GROESTL_64 154#endif55#endif5657#if !SPH_6458#undef SPH_GROESTL_6459#endif6061#ifdef _MSC_VER62#pragma warning (disable: 4146)63#endif6465/*66* The internal representation may use either big-endian or67* little-endian. Using the platform default representation speeds up68* encoding and decoding between bytes and the matrix columns.69*/7071#undef USE_LE72#if SPH_GROESTL_LITTLE_ENDIAN73#define USE_LE 174#elif SPH_GROESTL_BIG_ENDIAN75#define USE_LE 076#elif SPH_LITTLE_ENDIAN77#define USE_LE 178#endif7980#if USE_LE8182#define C32e(x) ((SPH_C32(x) >> 24) \83| ((SPH_C32(x) >> 8) & SPH_C32(0x0000FF00)) \84| ((SPH_C32(x) << 8) & SPH_C32(0x00FF0000)) \85| ((SPH_C32(x) << 24) & SPH_C32(0xFF000000)))86#define dec32e_aligned sph_dec32le_aligned87#define enc32e sph_enc32le88#define B32_0(x) ((x) & 0xFF)89#define B32_1(x) (((x) >> 8) & 0xFF)90#define B32_2(x) (((x) >> 16) & 0xFF)91#define B32_3(x) ((x) >> 24)9293#define R32u(u, d) SPH_T32(((u) << 16) | ((d) >> 16))94#define R32d(u, d) SPH_T32(((u) >> 16) | ((d) << 16))9596#define PC32up(j, r) ((sph_u32)((j) + (r)))97#define PC32dn(j, r) 098#define QC32up(j, r) SPH_C32(0xFFFFFFFF)99#define QC32dn(j, r) (((sph_u32)(r) << 24) ^ SPH_T32(~((sph_u32)(j) << 24)))100101#if SPH_64102#define C64e(x) ((SPH_C64(x) >> 56) \103| ((SPH_C64(x) >> 40) & SPH_C64(0x000000000000FF00)) \104| ((SPH_C64(x) >> 24) & SPH_C64(0x0000000000FF0000)) \105| ((SPH_C64(x) >> 8) & SPH_C64(0x00000000FF000000)) \106| ((SPH_C64(x) << 8) & SPH_C64(0x000000FF00000000)) \107| ((SPH_C64(x) << 24) & SPH_C64(0x0000FF0000000000)) \108| ((SPH_C64(x) << 40) & SPH_C64(0x00FF000000000000)) \109| ((SPH_C64(x) << 56) & SPH_C64(0xFF00000000000000)))110#define dec64e_aligned sph_dec64le_aligned111#define enc64e sph_enc64le112#define B64_0(x) ((x) & 0xFF)113#define B64_1(x) (((x) >> 8) & 0xFF)114#define B64_2(x) (((x) >> 16) & 0xFF)115#define B64_3(x) (((x) >> 24) & 0xFF)116#define B64_4(x) (((x) >> 32) & 0xFF)117#define B64_5(x) (((x) >> 40) & 0xFF)118#define B64_6(x) (((x) >> 48) & 0xFF)119#define B64_7(x) ((x) >> 56)120#define R64 SPH_ROTL64121#define PC64(j, r) ((sph_u64)((j) + (r)))122#define QC64(j, r) (((sph_u64)(r) << 56) ^ SPH_T64(~((sph_u64)(j) << 56)))123#endif124125#else126127#define C32e(x) SPH_C32(x)128#define dec32e_aligned sph_dec32be_aligned129#define enc32e sph_enc32be130#define B32_0(x) ((x) >> 24)131#define B32_1(x) (((x) >> 16) & 0xFF)132#define B32_2(x) (((x) >> 8) & 0xFF)133#define B32_3(x) ((x) & 0xFF)134135#define R32u(u, d) SPH_T32(((u) >> 16) | ((d) << 16))136#define R32d(u, d) SPH_T32(((u) << 16) | ((d) >> 16))137138#define PC32up(j, r) ((sph_u32)((j) + (r)) << 24)139#define PC32dn(j, r) 0140#define QC32up(j, r) SPH_C32(0xFFFFFFFF)141#define QC32dn(j, r) ((sph_u32)(r) ^ SPH_T32(~(sph_u32)(j)))142143#if SPH_64144#define C64e(x) SPH_C64(x)145#define dec64e_aligned sph_dec64be_aligned146#define enc64e sph_enc64be147#define B64_0(x) ((x) >> 56)148#define B64_1(x) (((x) >> 48) & 0xFF)149#define B64_2(x) (((x) >> 40) & 0xFF)150#define B64_3(x) (((x) >> 32) & 0xFF)151#define B64_4(x) (((x) >> 24) & 0xFF)152#define B64_5(x) (((x) >> 16) & 0xFF)153#define B64_6(x) (((x) >> 8) & 0xFF)154#define B64_7(x) ((x) & 0xFF)155#define R64 SPH_ROTR64156#define PC64(j, r) ((sph_u64)((j) + (r)) << 56)157#define QC64(j, r) ((sph_u64)(r) ^ SPH_T64(~(sph_u64)(j)))158#endif159160#endif161162#if SPH_GROESTL_64163164static const sph_u64 T0[] = {165C64e(0xc632f4a5f497a5c6), C64e(0xf86f978497eb84f8),166C64e(0xee5eb099b0c799ee), C64e(0xf67a8c8d8cf78df6),167C64e(0xffe8170d17e50dff), C64e(0xd60adcbddcb7bdd6),168C64e(0xde16c8b1c8a7b1de), C64e(0x916dfc54fc395491),169C64e(0x6090f050f0c05060), C64e(0x0207050305040302),170C64e(0xce2ee0a9e087a9ce), C64e(0x56d1877d87ac7d56),171C64e(0xe7cc2b192bd519e7), C64e(0xb513a662a67162b5),172C64e(0x4d7c31e6319ae64d), C64e(0xec59b59ab5c39aec),173C64e(0x8f40cf45cf05458f), C64e(0x1fa3bc9dbc3e9d1f),174C64e(0x8949c040c0094089), C64e(0xfa68928792ef87fa),175C64e(0xefd03f153fc515ef), C64e(0xb29426eb267febb2),176C64e(0x8ece40c94007c98e), C64e(0xfbe61d0b1ded0bfb),177C64e(0x416e2fec2f82ec41), C64e(0xb31aa967a97d67b3),178C64e(0x5f431cfd1cbefd5f), C64e(0x456025ea258aea45),179C64e(0x23f9dabfda46bf23), C64e(0x535102f702a6f753),180C64e(0xe445a196a1d396e4), C64e(0x9b76ed5bed2d5b9b),181C64e(0x75285dc25deac275), C64e(0xe1c5241c24d91ce1),182C64e(0x3dd4e9aee97aae3d), C64e(0x4cf2be6abe986a4c),183C64e(0x6c82ee5aeed85a6c), C64e(0x7ebdc341c3fc417e),184C64e(0xf5f3060206f102f5), C64e(0x8352d14fd11d4f83),185C64e(0x688ce45ce4d05c68), C64e(0x515607f407a2f451),186C64e(0xd18d5c345cb934d1), C64e(0xf9e1180818e908f9),187C64e(0xe24cae93aedf93e2), C64e(0xab3e9573954d73ab),188C64e(0x6297f553f5c45362), C64e(0x2a6b413f41543f2a),189C64e(0x081c140c14100c08), C64e(0x9563f652f6315295),190C64e(0x46e9af65af8c6546), C64e(0x9d7fe25ee2215e9d),191C64e(0x3048782878602830), C64e(0x37cff8a1f86ea137),192C64e(0x0a1b110f11140f0a), C64e(0x2febc4b5c45eb52f),193C64e(0x0e151b091b1c090e), C64e(0x247e5a365a483624),194C64e(0x1badb69bb6369b1b), C64e(0xdf98473d47a53ddf),195C64e(0xcda76a266a8126cd), C64e(0x4ef5bb69bb9c694e),196C64e(0x7f334ccd4cfecd7f), C64e(0xea50ba9fbacf9fea),197C64e(0x123f2d1b2d241b12), C64e(0x1da4b99eb93a9e1d),198C64e(0x58c49c749cb07458), C64e(0x3446722e72682e34),199C64e(0x3641772d776c2d36), C64e(0xdc11cdb2cda3b2dc),200C64e(0xb49d29ee2973eeb4), C64e(0x5b4d16fb16b6fb5b),201C64e(0xa4a501f60153f6a4), C64e(0x76a1d74dd7ec4d76),202C64e(0xb714a361a37561b7), C64e(0x7d3449ce49face7d),203C64e(0x52df8d7b8da47b52), C64e(0xdd9f423e42a13edd),204C64e(0x5ecd937193bc715e), C64e(0x13b1a297a2269713),205C64e(0xa6a204f50457f5a6), C64e(0xb901b868b86968b9),206C64e(0x0000000000000000), C64e(0xc1b5742c74992cc1),207C64e(0x40e0a060a0806040), C64e(0xe3c2211f21dd1fe3),208C64e(0x793a43c843f2c879), C64e(0xb69a2ced2c77edb6),209C64e(0xd40dd9bed9b3bed4), C64e(0x8d47ca46ca01468d),210C64e(0x671770d970ced967), C64e(0x72afdd4bdde44b72),211C64e(0x94ed79de7933de94), C64e(0x98ff67d4672bd498),212C64e(0xb09323e8237be8b0), C64e(0x855bde4ade114a85),213C64e(0xbb06bd6bbd6d6bbb), C64e(0xc5bb7e2a7e912ac5),214C64e(0x4f7b34e5349ee54f), C64e(0xedd73a163ac116ed),215C64e(0x86d254c55417c586), C64e(0x9af862d7622fd79a),216C64e(0x6699ff55ffcc5566), C64e(0x11b6a794a7229411),217C64e(0x8ac04acf4a0fcf8a), C64e(0xe9d9301030c910e9),218C64e(0x040e0a060a080604), C64e(0xfe66988198e781fe),219C64e(0xa0ab0bf00b5bf0a0), C64e(0x78b4cc44ccf04478),220C64e(0x25f0d5bad54aba25), C64e(0x4b753ee33e96e34b),221C64e(0xa2ac0ef30e5ff3a2), C64e(0x5d4419fe19bafe5d),222C64e(0x80db5bc05b1bc080), C64e(0x0580858a850a8a05),223C64e(0x3fd3ecadec7ead3f), C64e(0x21fedfbcdf42bc21),224C64e(0x70a8d848d8e04870), C64e(0xf1fd0c040cf904f1),225C64e(0x63197adf7ac6df63), C64e(0x772f58c158eec177),226C64e(0xaf309f759f4575af), C64e(0x42e7a563a5846342),227C64e(0x2070503050403020), C64e(0xe5cb2e1a2ed11ae5),228C64e(0xfdef120e12e10efd), C64e(0xbf08b76db7656dbf),229C64e(0x8155d44cd4194c81), C64e(0x18243c143c301418),230C64e(0x26795f355f4c3526), C64e(0xc3b2712f719d2fc3),231C64e(0xbe8638e13867e1be), C64e(0x35c8fda2fd6aa235),232C64e(0x88c74fcc4f0bcc88), C64e(0x2e654b394b5c392e),233C64e(0x936af957f93d5793), C64e(0x55580df20daaf255),234C64e(0xfc619d829de382fc), C64e(0x7ab3c947c9f4477a),235C64e(0xc827efacef8bacc8), C64e(0xba8832e7326fe7ba),236C64e(0x324f7d2b7d642b32), C64e(0xe642a495a4d795e6),237C64e(0xc03bfba0fb9ba0c0), C64e(0x19aab398b3329819),238C64e(0x9ef668d16827d19e), C64e(0xa322817f815d7fa3),239C64e(0x44eeaa66aa886644), C64e(0x54d6827e82a87e54),240C64e(0x3bdde6abe676ab3b), C64e(0x0b959e839e16830b),241C64e(0x8cc945ca4503ca8c), C64e(0xc7bc7b297b9529c7),242C64e(0x6b056ed36ed6d36b), C64e(0x286c443c44503c28),243C64e(0xa72c8b798b5579a7), C64e(0xbc813de23d63e2bc),244C64e(0x1631271d272c1d16), C64e(0xad379a769a4176ad),245C64e(0xdb964d3b4dad3bdb), C64e(0x649efa56fac85664),246C64e(0x74a6d24ed2e84e74), C64e(0x1436221e22281e14),247C64e(0x92e476db763fdb92), C64e(0x0c121e0a1e180a0c),248C64e(0x48fcb46cb4906c48), C64e(0xb88f37e4376be4b8),249C64e(0x9f78e75de7255d9f), C64e(0xbd0fb26eb2616ebd),250C64e(0x43692aef2a86ef43), C64e(0xc435f1a6f193a6c4),251C64e(0x39dae3a8e372a839), C64e(0x31c6f7a4f762a431),252C64e(0xd38a593759bd37d3), C64e(0xf274868b86ff8bf2),253C64e(0xd583563256b132d5), C64e(0x8b4ec543c50d438b),254C64e(0x6e85eb59ebdc596e), C64e(0xda18c2b7c2afb7da),255C64e(0x018e8f8c8f028c01), C64e(0xb11dac64ac7964b1),256C64e(0x9cf16dd26d23d29c), C64e(0x49723be03b92e049),257C64e(0xd81fc7b4c7abb4d8), C64e(0xacb915fa1543faac),258C64e(0xf3fa090709fd07f3), C64e(0xcfa06f256f8525cf),259C64e(0xca20eaafea8fafca), C64e(0xf47d898e89f38ef4),260C64e(0x476720e9208ee947), C64e(0x1038281828201810),261C64e(0x6f0b64d564ded56f), C64e(0xf073838883fb88f0),262C64e(0x4afbb16fb1946f4a), C64e(0x5cca967296b8725c),263C64e(0x38546c246c702438), C64e(0x575f08f108aef157),264C64e(0x732152c752e6c773), C64e(0x9764f351f3355197),265C64e(0xcbae6523658d23cb), C64e(0xa125847c84597ca1),266C64e(0xe857bf9cbfcb9ce8), C64e(0x3e5d6321637c213e),267C64e(0x96ea7cdd7c37dd96), C64e(0x611e7fdc7fc2dc61),268C64e(0x0d9c9186911a860d), C64e(0x0f9b9485941e850f),269C64e(0xe04bab90abdb90e0), C64e(0x7cbac642c6f8427c),270C64e(0x712657c457e2c471), C64e(0xcc29e5aae583aacc),271C64e(0x90e373d8733bd890), C64e(0x06090f050f0c0506),272C64e(0xf7f4030103f501f7), C64e(0x1c2a36123638121c),273C64e(0xc23cfea3fe9fa3c2), C64e(0x6a8be15fe1d45f6a),274C64e(0xaebe10f91047f9ae), C64e(0x69026bd06bd2d069),275C64e(0x17bfa891a82e9117), C64e(0x9971e858e8295899),276C64e(0x3a5369276974273a), C64e(0x27f7d0b9d04eb927),277C64e(0xd991483848a938d9), C64e(0xebde351335cd13eb),278C64e(0x2be5ceb3ce56b32b), C64e(0x2277553355443322),279C64e(0xd204d6bbd6bfbbd2), C64e(0xa9399070904970a9),280C64e(0x07878089800e8907), C64e(0x33c1f2a7f266a733),281C64e(0x2decc1b6c15ab62d), C64e(0x3c5a66226678223c),282C64e(0x15b8ad92ad2a9215), C64e(0xc9a96020608920c9),283C64e(0x875cdb49db154987), C64e(0xaab01aff1a4fffaa),284C64e(0x50d8887888a07850), C64e(0xa52b8e7a8e517aa5),285C64e(0x03898a8f8a068f03), C64e(0x594a13f813b2f859),286C64e(0x09929b809b128009), C64e(0x1a2339173934171a),287C64e(0x651075da75cada65), C64e(0xd784533153b531d7),288C64e(0x84d551c65113c684), C64e(0xd003d3b8d3bbb8d0),289C64e(0x82dc5ec35e1fc382), C64e(0x29e2cbb0cb52b029),290C64e(0x5ac3997799b4775a), C64e(0x1e2d3311333c111e),291C64e(0x7b3d46cb46f6cb7b), C64e(0xa8b71ffc1f4bfca8),292C64e(0x6d0c61d661dad66d), C64e(0x2c624e3a4e583a2c)293};294295#if !SPH_SMALL_FOOTPRINT_GROESTL296297static const sph_u64 T1[] = {298C64e(0xc6c632f4a5f497a5), C64e(0xf8f86f978497eb84),299C64e(0xeeee5eb099b0c799), C64e(0xf6f67a8c8d8cf78d),300C64e(0xffffe8170d17e50d), C64e(0xd6d60adcbddcb7bd),301C64e(0xdede16c8b1c8a7b1), C64e(0x91916dfc54fc3954),302C64e(0x606090f050f0c050), C64e(0x0202070503050403),303C64e(0xcece2ee0a9e087a9), C64e(0x5656d1877d87ac7d),304C64e(0xe7e7cc2b192bd519), C64e(0xb5b513a662a67162),305C64e(0x4d4d7c31e6319ae6), C64e(0xecec59b59ab5c39a),306C64e(0x8f8f40cf45cf0545), C64e(0x1f1fa3bc9dbc3e9d),307C64e(0x898949c040c00940), C64e(0xfafa68928792ef87),308C64e(0xefefd03f153fc515), C64e(0xb2b29426eb267feb),309C64e(0x8e8ece40c94007c9), C64e(0xfbfbe61d0b1ded0b),310C64e(0x41416e2fec2f82ec), C64e(0xb3b31aa967a97d67),311C64e(0x5f5f431cfd1cbefd), C64e(0x45456025ea258aea),312C64e(0x2323f9dabfda46bf), C64e(0x53535102f702a6f7),313C64e(0xe4e445a196a1d396), C64e(0x9b9b76ed5bed2d5b),314C64e(0x7575285dc25deac2), C64e(0xe1e1c5241c24d91c),315C64e(0x3d3dd4e9aee97aae), C64e(0x4c4cf2be6abe986a),316C64e(0x6c6c82ee5aeed85a), C64e(0x7e7ebdc341c3fc41),317C64e(0xf5f5f3060206f102), C64e(0x838352d14fd11d4f),318C64e(0x68688ce45ce4d05c), C64e(0x51515607f407a2f4),319C64e(0xd1d18d5c345cb934), C64e(0xf9f9e1180818e908),320C64e(0xe2e24cae93aedf93), C64e(0xabab3e9573954d73),321C64e(0x626297f553f5c453), C64e(0x2a2a6b413f41543f),322C64e(0x08081c140c14100c), C64e(0x959563f652f63152),323C64e(0x4646e9af65af8c65), C64e(0x9d9d7fe25ee2215e),324C64e(0x3030487828786028), C64e(0x3737cff8a1f86ea1),325C64e(0x0a0a1b110f11140f), C64e(0x2f2febc4b5c45eb5),326C64e(0x0e0e151b091b1c09), C64e(0x24247e5a365a4836),327C64e(0x1b1badb69bb6369b), C64e(0xdfdf98473d47a53d),328C64e(0xcdcda76a266a8126), C64e(0x4e4ef5bb69bb9c69),329C64e(0x7f7f334ccd4cfecd), C64e(0xeaea50ba9fbacf9f),330C64e(0x12123f2d1b2d241b), C64e(0x1d1da4b99eb93a9e),331C64e(0x5858c49c749cb074), C64e(0x343446722e72682e),332C64e(0x363641772d776c2d), C64e(0xdcdc11cdb2cda3b2),333C64e(0xb4b49d29ee2973ee), C64e(0x5b5b4d16fb16b6fb),334C64e(0xa4a4a501f60153f6), C64e(0x7676a1d74dd7ec4d),335C64e(0xb7b714a361a37561), C64e(0x7d7d3449ce49face),336C64e(0x5252df8d7b8da47b), C64e(0xdddd9f423e42a13e),337C64e(0x5e5ecd937193bc71), C64e(0x1313b1a297a22697),338C64e(0xa6a6a204f50457f5), C64e(0xb9b901b868b86968),339C64e(0x0000000000000000), C64e(0xc1c1b5742c74992c),340C64e(0x4040e0a060a08060), C64e(0xe3e3c2211f21dd1f),341C64e(0x79793a43c843f2c8), C64e(0xb6b69a2ced2c77ed),342C64e(0xd4d40dd9bed9b3be), C64e(0x8d8d47ca46ca0146),343C64e(0x67671770d970ced9), C64e(0x7272afdd4bdde44b),344C64e(0x9494ed79de7933de), C64e(0x9898ff67d4672bd4),345C64e(0xb0b09323e8237be8), C64e(0x85855bde4ade114a),346C64e(0xbbbb06bd6bbd6d6b), C64e(0xc5c5bb7e2a7e912a),347C64e(0x4f4f7b34e5349ee5), C64e(0xededd73a163ac116),348C64e(0x8686d254c55417c5), C64e(0x9a9af862d7622fd7),349C64e(0x666699ff55ffcc55), C64e(0x1111b6a794a72294),350C64e(0x8a8ac04acf4a0fcf), C64e(0xe9e9d9301030c910),351C64e(0x04040e0a060a0806), C64e(0xfefe66988198e781),352C64e(0xa0a0ab0bf00b5bf0), C64e(0x7878b4cc44ccf044),353C64e(0x2525f0d5bad54aba), C64e(0x4b4b753ee33e96e3),354C64e(0xa2a2ac0ef30e5ff3), C64e(0x5d5d4419fe19bafe),355C64e(0x8080db5bc05b1bc0), C64e(0x050580858a850a8a),356C64e(0x3f3fd3ecadec7ead), C64e(0x2121fedfbcdf42bc),357C64e(0x7070a8d848d8e048), C64e(0xf1f1fd0c040cf904),358C64e(0x6363197adf7ac6df), C64e(0x77772f58c158eec1),359C64e(0xafaf309f759f4575), C64e(0x4242e7a563a58463),360C64e(0x2020705030504030), C64e(0xe5e5cb2e1a2ed11a),361C64e(0xfdfdef120e12e10e), C64e(0xbfbf08b76db7656d),362C64e(0x818155d44cd4194c), C64e(0x1818243c143c3014),363C64e(0x2626795f355f4c35), C64e(0xc3c3b2712f719d2f),364C64e(0xbebe8638e13867e1), C64e(0x3535c8fda2fd6aa2),365C64e(0x8888c74fcc4f0bcc), C64e(0x2e2e654b394b5c39),366C64e(0x93936af957f93d57), C64e(0x5555580df20daaf2),367C64e(0xfcfc619d829de382), C64e(0x7a7ab3c947c9f447),368C64e(0xc8c827efacef8bac), C64e(0xbaba8832e7326fe7),369C64e(0x32324f7d2b7d642b), C64e(0xe6e642a495a4d795),370C64e(0xc0c03bfba0fb9ba0), C64e(0x1919aab398b33298),371C64e(0x9e9ef668d16827d1), C64e(0xa3a322817f815d7f),372C64e(0x4444eeaa66aa8866), C64e(0x5454d6827e82a87e),373C64e(0x3b3bdde6abe676ab), C64e(0x0b0b959e839e1683),374C64e(0x8c8cc945ca4503ca), C64e(0xc7c7bc7b297b9529),375C64e(0x6b6b056ed36ed6d3), C64e(0x28286c443c44503c),376C64e(0xa7a72c8b798b5579), C64e(0xbcbc813de23d63e2),377C64e(0x161631271d272c1d), C64e(0xadad379a769a4176),378C64e(0xdbdb964d3b4dad3b), C64e(0x64649efa56fac856),379C64e(0x7474a6d24ed2e84e), C64e(0x141436221e22281e),380C64e(0x9292e476db763fdb), C64e(0x0c0c121e0a1e180a),381C64e(0x4848fcb46cb4906c), C64e(0xb8b88f37e4376be4),382C64e(0x9f9f78e75de7255d), C64e(0xbdbd0fb26eb2616e),383C64e(0x4343692aef2a86ef), C64e(0xc4c435f1a6f193a6),384C64e(0x3939dae3a8e372a8), C64e(0x3131c6f7a4f762a4),385C64e(0xd3d38a593759bd37), C64e(0xf2f274868b86ff8b),386C64e(0xd5d583563256b132), C64e(0x8b8b4ec543c50d43),387C64e(0x6e6e85eb59ebdc59), C64e(0xdada18c2b7c2afb7),388C64e(0x01018e8f8c8f028c), C64e(0xb1b11dac64ac7964),389C64e(0x9c9cf16dd26d23d2), C64e(0x4949723be03b92e0),390C64e(0xd8d81fc7b4c7abb4), C64e(0xacacb915fa1543fa),391C64e(0xf3f3fa090709fd07), C64e(0xcfcfa06f256f8525),392C64e(0xcaca20eaafea8faf), C64e(0xf4f47d898e89f38e),393C64e(0x47476720e9208ee9), C64e(0x1010382818282018),394C64e(0x6f6f0b64d564ded5), C64e(0xf0f073838883fb88),395C64e(0x4a4afbb16fb1946f), C64e(0x5c5cca967296b872),396C64e(0x3838546c246c7024), C64e(0x57575f08f108aef1),397C64e(0x73732152c752e6c7), C64e(0x979764f351f33551),398C64e(0xcbcbae6523658d23), C64e(0xa1a125847c84597c),399C64e(0xe8e857bf9cbfcb9c), C64e(0x3e3e5d6321637c21),400C64e(0x9696ea7cdd7c37dd), C64e(0x61611e7fdc7fc2dc),401C64e(0x0d0d9c9186911a86), C64e(0x0f0f9b9485941e85),402C64e(0xe0e04bab90abdb90), C64e(0x7c7cbac642c6f842),403C64e(0x71712657c457e2c4), C64e(0xcccc29e5aae583aa),404C64e(0x9090e373d8733bd8), C64e(0x0606090f050f0c05),405C64e(0xf7f7f4030103f501), C64e(0x1c1c2a3612363812),406C64e(0xc2c23cfea3fe9fa3), C64e(0x6a6a8be15fe1d45f),407C64e(0xaeaebe10f91047f9), C64e(0x6969026bd06bd2d0),408C64e(0x1717bfa891a82e91), C64e(0x999971e858e82958),409C64e(0x3a3a536927697427), C64e(0x2727f7d0b9d04eb9),410C64e(0xd9d991483848a938), C64e(0xebebde351335cd13),411C64e(0x2b2be5ceb3ce56b3), C64e(0x2222775533554433),412C64e(0xd2d204d6bbd6bfbb), C64e(0xa9a9399070904970),413C64e(0x0707878089800e89), C64e(0x3333c1f2a7f266a7),414C64e(0x2d2decc1b6c15ab6), C64e(0x3c3c5a6622667822),415C64e(0x1515b8ad92ad2a92), C64e(0xc9c9a96020608920),416C64e(0x87875cdb49db1549), C64e(0xaaaab01aff1a4fff),417C64e(0x5050d8887888a078), C64e(0xa5a52b8e7a8e517a),418C64e(0x0303898a8f8a068f), C64e(0x59594a13f813b2f8),419C64e(0x0909929b809b1280), C64e(0x1a1a233917393417),420C64e(0x65651075da75cada), C64e(0xd7d784533153b531),421C64e(0x8484d551c65113c6), C64e(0xd0d003d3b8d3bbb8),422C64e(0x8282dc5ec35e1fc3), C64e(0x2929e2cbb0cb52b0),423C64e(0x5a5ac3997799b477), C64e(0x1e1e2d3311333c11),424C64e(0x7b7b3d46cb46f6cb), C64e(0xa8a8b71ffc1f4bfc),425C64e(0x6d6d0c61d661dad6), C64e(0x2c2c624e3a4e583a)426};427428static const sph_u64 T2[] = {429C64e(0xa5c6c632f4a5f497), C64e(0x84f8f86f978497eb),430C64e(0x99eeee5eb099b0c7), C64e(0x8df6f67a8c8d8cf7),431C64e(0x0dffffe8170d17e5), C64e(0xbdd6d60adcbddcb7),432C64e(0xb1dede16c8b1c8a7), C64e(0x5491916dfc54fc39),433C64e(0x50606090f050f0c0), C64e(0x0302020705030504),434C64e(0xa9cece2ee0a9e087), C64e(0x7d5656d1877d87ac),435C64e(0x19e7e7cc2b192bd5), C64e(0x62b5b513a662a671),436C64e(0xe64d4d7c31e6319a), C64e(0x9aecec59b59ab5c3),437C64e(0x458f8f40cf45cf05), C64e(0x9d1f1fa3bc9dbc3e),438C64e(0x40898949c040c009), C64e(0x87fafa68928792ef),439C64e(0x15efefd03f153fc5), C64e(0xebb2b29426eb267f),440C64e(0xc98e8ece40c94007), C64e(0x0bfbfbe61d0b1ded),441C64e(0xec41416e2fec2f82), C64e(0x67b3b31aa967a97d),442C64e(0xfd5f5f431cfd1cbe), C64e(0xea45456025ea258a),443C64e(0xbf2323f9dabfda46), C64e(0xf753535102f702a6),444C64e(0x96e4e445a196a1d3), C64e(0x5b9b9b76ed5bed2d),445C64e(0xc27575285dc25dea), C64e(0x1ce1e1c5241c24d9),446C64e(0xae3d3dd4e9aee97a), C64e(0x6a4c4cf2be6abe98),447C64e(0x5a6c6c82ee5aeed8), C64e(0x417e7ebdc341c3fc),448C64e(0x02f5f5f3060206f1), C64e(0x4f838352d14fd11d),449C64e(0x5c68688ce45ce4d0), C64e(0xf451515607f407a2),450C64e(0x34d1d18d5c345cb9), C64e(0x08f9f9e1180818e9),451C64e(0x93e2e24cae93aedf), C64e(0x73abab3e9573954d),452C64e(0x53626297f553f5c4), C64e(0x3f2a2a6b413f4154),453C64e(0x0c08081c140c1410), C64e(0x52959563f652f631),454C64e(0x654646e9af65af8c), C64e(0x5e9d9d7fe25ee221),455C64e(0x2830304878287860), C64e(0xa13737cff8a1f86e),456C64e(0x0f0a0a1b110f1114), C64e(0xb52f2febc4b5c45e),457C64e(0x090e0e151b091b1c), C64e(0x3624247e5a365a48),458C64e(0x9b1b1badb69bb636), C64e(0x3ddfdf98473d47a5),459C64e(0x26cdcda76a266a81), C64e(0x694e4ef5bb69bb9c),460C64e(0xcd7f7f334ccd4cfe), C64e(0x9feaea50ba9fbacf),461C64e(0x1b12123f2d1b2d24), C64e(0x9e1d1da4b99eb93a),462C64e(0x745858c49c749cb0), C64e(0x2e343446722e7268),463C64e(0x2d363641772d776c), C64e(0xb2dcdc11cdb2cda3),464C64e(0xeeb4b49d29ee2973), C64e(0xfb5b5b4d16fb16b6),465C64e(0xf6a4a4a501f60153), C64e(0x4d7676a1d74dd7ec),466C64e(0x61b7b714a361a375), C64e(0xce7d7d3449ce49fa),467C64e(0x7b5252df8d7b8da4), C64e(0x3edddd9f423e42a1),468C64e(0x715e5ecd937193bc), C64e(0x971313b1a297a226),469C64e(0xf5a6a6a204f50457), C64e(0x68b9b901b868b869),470C64e(0x0000000000000000), C64e(0x2cc1c1b5742c7499),471C64e(0x604040e0a060a080), C64e(0x1fe3e3c2211f21dd),472C64e(0xc879793a43c843f2), C64e(0xedb6b69a2ced2c77),473C64e(0xbed4d40dd9bed9b3), C64e(0x468d8d47ca46ca01),474C64e(0xd967671770d970ce), C64e(0x4b7272afdd4bdde4),475C64e(0xde9494ed79de7933), C64e(0xd49898ff67d4672b),476C64e(0xe8b0b09323e8237b), C64e(0x4a85855bde4ade11),477C64e(0x6bbbbb06bd6bbd6d), C64e(0x2ac5c5bb7e2a7e91),478C64e(0xe54f4f7b34e5349e), C64e(0x16ededd73a163ac1),479C64e(0xc58686d254c55417), C64e(0xd79a9af862d7622f),480C64e(0x55666699ff55ffcc), C64e(0x941111b6a794a722),481C64e(0xcf8a8ac04acf4a0f), C64e(0x10e9e9d9301030c9),482C64e(0x0604040e0a060a08), C64e(0x81fefe66988198e7),483C64e(0xf0a0a0ab0bf00b5b), C64e(0x447878b4cc44ccf0),484C64e(0xba2525f0d5bad54a), C64e(0xe34b4b753ee33e96),485C64e(0xf3a2a2ac0ef30e5f), C64e(0xfe5d5d4419fe19ba),486C64e(0xc08080db5bc05b1b), C64e(0x8a050580858a850a),487C64e(0xad3f3fd3ecadec7e), C64e(0xbc2121fedfbcdf42),488C64e(0x487070a8d848d8e0), C64e(0x04f1f1fd0c040cf9),489C64e(0xdf6363197adf7ac6), C64e(0xc177772f58c158ee),490C64e(0x75afaf309f759f45), C64e(0x634242e7a563a584),491C64e(0x3020207050305040), C64e(0x1ae5e5cb2e1a2ed1),492C64e(0x0efdfdef120e12e1), C64e(0x6dbfbf08b76db765),493C64e(0x4c818155d44cd419), C64e(0x141818243c143c30),494C64e(0x352626795f355f4c), C64e(0x2fc3c3b2712f719d),495C64e(0xe1bebe8638e13867), C64e(0xa23535c8fda2fd6a),496C64e(0xcc8888c74fcc4f0b), C64e(0x392e2e654b394b5c),497C64e(0x5793936af957f93d), C64e(0xf25555580df20daa),498C64e(0x82fcfc619d829de3), C64e(0x477a7ab3c947c9f4),499C64e(0xacc8c827efacef8b), C64e(0xe7baba8832e7326f),500C64e(0x2b32324f7d2b7d64), C64e(0x95e6e642a495a4d7),501C64e(0xa0c0c03bfba0fb9b), C64e(0x981919aab398b332),502C64e(0xd19e9ef668d16827), C64e(0x7fa3a322817f815d),503C64e(0x664444eeaa66aa88), C64e(0x7e5454d6827e82a8),504C64e(0xab3b3bdde6abe676), C64e(0x830b0b959e839e16),505C64e(0xca8c8cc945ca4503), C64e(0x29c7c7bc7b297b95),506C64e(0xd36b6b056ed36ed6), C64e(0x3c28286c443c4450),507C64e(0x79a7a72c8b798b55), C64e(0xe2bcbc813de23d63),508C64e(0x1d161631271d272c), C64e(0x76adad379a769a41),509C64e(0x3bdbdb964d3b4dad), C64e(0x5664649efa56fac8),510C64e(0x4e7474a6d24ed2e8), C64e(0x1e141436221e2228),511C64e(0xdb9292e476db763f), C64e(0x0a0c0c121e0a1e18),512C64e(0x6c4848fcb46cb490), C64e(0xe4b8b88f37e4376b),513C64e(0x5d9f9f78e75de725), C64e(0x6ebdbd0fb26eb261),514C64e(0xef4343692aef2a86), C64e(0xa6c4c435f1a6f193),515C64e(0xa83939dae3a8e372), C64e(0xa43131c6f7a4f762),516C64e(0x37d3d38a593759bd), C64e(0x8bf2f274868b86ff),517C64e(0x32d5d583563256b1), C64e(0x438b8b4ec543c50d),518C64e(0x596e6e85eb59ebdc), C64e(0xb7dada18c2b7c2af),519C64e(0x8c01018e8f8c8f02), C64e(0x64b1b11dac64ac79),520C64e(0xd29c9cf16dd26d23), C64e(0xe04949723be03b92),521C64e(0xb4d8d81fc7b4c7ab), C64e(0xfaacacb915fa1543),522C64e(0x07f3f3fa090709fd), C64e(0x25cfcfa06f256f85),523C64e(0xafcaca20eaafea8f), C64e(0x8ef4f47d898e89f3),524C64e(0xe947476720e9208e), C64e(0x1810103828182820),525C64e(0xd56f6f0b64d564de), C64e(0x88f0f073838883fb),526C64e(0x6f4a4afbb16fb194), C64e(0x725c5cca967296b8),527C64e(0x243838546c246c70), C64e(0xf157575f08f108ae),528C64e(0xc773732152c752e6), C64e(0x51979764f351f335),529C64e(0x23cbcbae6523658d), C64e(0x7ca1a125847c8459),530C64e(0x9ce8e857bf9cbfcb), C64e(0x213e3e5d6321637c),531C64e(0xdd9696ea7cdd7c37), C64e(0xdc61611e7fdc7fc2),532C64e(0x860d0d9c9186911a), C64e(0x850f0f9b9485941e),533C64e(0x90e0e04bab90abdb), C64e(0x427c7cbac642c6f8),534C64e(0xc471712657c457e2), C64e(0xaacccc29e5aae583),535C64e(0xd89090e373d8733b), C64e(0x050606090f050f0c),536C64e(0x01f7f7f4030103f5), C64e(0x121c1c2a36123638),537C64e(0xa3c2c23cfea3fe9f), C64e(0x5f6a6a8be15fe1d4),538C64e(0xf9aeaebe10f91047), C64e(0xd06969026bd06bd2),539C64e(0x911717bfa891a82e), C64e(0x58999971e858e829),540C64e(0x273a3a5369276974), C64e(0xb92727f7d0b9d04e),541C64e(0x38d9d991483848a9), C64e(0x13ebebde351335cd),542C64e(0xb32b2be5ceb3ce56), C64e(0x3322227755335544),543C64e(0xbbd2d204d6bbd6bf), C64e(0x70a9a93990709049),544C64e(0x890707878089800e), C64e(0xa73333c1f2a7f266),545C64e(0xb62d2decc1b6c15a), C64e(0x223c3c5a66226678),546C64e(0x921515b8ad92ad2a), C64e(0x20c9c9a960206089),547C64e(0x4987875cdb49db15), C64e(0xffaaaab01aff1a4f),548C64e(0x785050d8887888a0), C64e(0x7aa5a52b8e7a8e51),549C64e(0x8f0303898a8f8a06), C64e(0xf859594a13f813b2),550C64e(0x800909929b809b12), C64e(0x171a1a2339173934),551C64e(0xda65651075da75ca), C64e(0x31d7d784533153b5),552C64e(0xc68484d551c65113), C64e(0xb8d0d003d3b8d3bb),553C64e(0xc38282dc5ec35e1f), C64e(0xb02929e2cbb0cb52),554C64e(0x775a5ac3997799b4), C64e(0x111e1e2d3311333c),555C64e(0xcb7b7b3d46cb46f6), C64e(0xfca8a8b71ffc1f4b),556C64e(0xd66d6d0c61d661da), C64e(0x3a2c2c624e3a4e58)557};558559static const sph_u64 T3[] = {560C64e(0x97a5c6c632f4a5f4), C64e(0xeb84f8f86f978497),561C64e(0xc799eeee5eb099b0), C64e(0xf78df6f67a8c8d8c),562C64e(0xe50dffffe8170d17), C64e(0xb7bdd6d60adcbddc),563C64e(0xa7b1dede16c8b1c8), C64e(0x395491916dfc54fc),564C64e(0xc050606090f050f0), C64e(0x0403020207050305),565C64e(0x87a9cece2ee0a9e0), C64e(0xac7d5656d1877d87),566C64e(0xd519e7e7cc2b192b), C64e(0x7162b5b513a662a6),567C64e(0x9ae64d4d7c31e631), C64e(0xc39aecec59b59ab5),568C64e(0x05458f8f40cf45cf), C64e(0x3e9d1f1fa3bc9dbc),569C64e(0x0940898949c040c0), C64e(0xef87fafa68928792),570C64e(0xc515efefd03f153f), C64e(0x7febb2b29426eb26),571C64e(0x07c98e8ece40c940), C64e(0xed0bfbfbe61d0b1d),572C64e(0x82ec41416e2fec2f), C64e(0x7d67b3b31aa967a9),573C64e(0xbefd5f5f431cfd1c), C64e(0x8aea45456025ea25),574C64e(0x46bf2323f9dabfda), C64e(0xa6f753535102f702),575C64e(0xd396e4e445a196a1), C64e(0x2d5b9b9b76ed5bed),576C64e(0xeac27575285dc25d), C64e(0xd91ce1e1c5241c24),577C64e(0x7aae3d3dd4e9aee9), C64e(0x986a4c4cf2be6abe),578C64e(0xd85a6c6c82ee5aee), C64e(0xfc417e7ebdc341c3),579C64e(0xf102f5f5f3060206), C64e(0x1d4f838352d14fd1),580C64e(0xd05c68688ce45ce4), C64e(0xa2f451515607f407),581C64e(0xb934d1d18d5c345c), C64e(0xe908f9f9e1180818),582C64e(0xdf93e2e24cae93ae), C64e(0x4d73abab3e957395),583C64e(0xc453626297f553f5), C64e(0x543f2a2a6b413f41),584C64e(0x100c08081c140c14), C64e(0x3152959563f652f6),585C64e(0x8c654646e9af65af), C64e(0x215e9d9d7fe25ee2),586C64e(0x6028303048782878), C64e(0x6ea13737cff8a1f8),587C64e(0x140f0a0a1b110f11), C64e(0x5eb52f2febc4b5c4),588C64e(0x1c090e0e151b091b), C64e(0x483624247e5a365a),589C64e(0x369b1b1badb69bb6), C64e(0xa53ddfdf98473d47),590C64e(0x8126cdcda76a266a), C64e(0x9c694e4ef5bb69bb),591C64e(0xfecd7f7f334ccd4c), C64e(0xcf9feaea50ba9fba),592C64e(0x241b12123f2d1b2d), C64e(0x3a9e1d1da4b99eb9),593C64e(0xb0745858c49c749c), C64e(0x682e343446722e72),594C64e(0x6c2d363641772d77), C64e(0xa3b2dcdc11cdb2cd),595C64e(0x73eeb4b49d29ee29), C64e(0xb6fb5b5b4d16fb16),596C64e(0x53f6a4a4a501f601), C64e(0xec4d7676a1d74dd7),597C64e(0x7561b7b714a361a3), C64e(0xface7d7d3449ce49),598C64e(0xa47b5252df8d7b8d), C64e(0xa13edddd9f423e42),599C64e(0xbc715e5ecd937193), C64e(0x26971313b1a297a2),600C64e(0x57f5a6a6a204f504), C64e(0x6968b9b901b868b8),601C64e(0x0000000000000000), C64e(0x992cc1c1b5742c74),602C64e(0x80604040e0a060a0), C64e(0xdd1fe3e3c2211f21),603C64e(0xf2c879793a43c843), C64e(0x77edb6b69a2ced2c),604C64e(0xb3bed4d40dd9bed9), C64e(0x01468d8d47ca46ca),605C64e(0xced967671770d970), C64e(0xe44b7272afdd4bdd),606C64e(0x33de9494ed79de79), C64e(0x2bd49898ff67d467),607C64e(0x7be8b0b09323e823), C64e(0x114a85855bde4ade),608C64e(0x6d6bbbbb06bd6bbd), C64e(0x912ac5c5bb7e2a7e),609C64e(0x9ee54f4f7b34e534), C64e(0xc116ededd73a163a),610C64e(0x17c58686d254c554), C64e(0x2fd79a9af862d762),611C64e(0xcc55666699ff55ff), C64e(0x22941111b6a794a7),612C64e(0x0fcf8a8ac04acf4a), C64e(0xc910e9e9d9301030),613C64e(0x080604040e0a060a), C64e(0xe781fefe66988198),614C64e(0x5bf0a0a0ab0bf00b), C64e(0xf0447878b4cc44cc),615C64e(0x4aba2525f0d5bad5), C64e(0x96e34b4b753ee33e),616C64e(0x5ff3a2a2ac0ef30e), C64e(0xbafe5d5d4419fe19),617C64e(0x1bc08080db5bc05b), C64e(0x0a8a050580858a85),618C64e(0x7ead3f3fd3ecadec), C64e(0x42bc2121fedfbcdf),619C64e(0xe0487070a8d848d8), C64e(0xf904f1f1fd0c040c),620C64e(0xc6df6363197adf7a), C64e(0xeec177772f58c158),621C64e(0x4575afaf309f759f), C64e(0x84634242e7a563a5),622C64e(0x4030202070503050), C64e(0xd11ae5e5cb2e1a2e),623C64e(0xe10efdfdef120e12), C64e(0x656dbfbf08b76db7),624C64e(0x194c818155d44cd4), C64e(0x30141818243c143c),625C64e(0x4c352626795f355f), C64e(0x9d2fc3c3b2712f71),626C64e(0x67e1bebe8638e138), C64e(0x6aa23535c8fda2fd),627C64e(0x0bcc8888c74fcc4f), C64e(0x5c392e2e654b394b),628C64e(0x3d5793936af957f9), C64e(0xaaf25555580df20d),629C64e(0xe382fcfc619d829d), C64e(0xf4477a7ab3c947c9),630C64e(0x8bacc8c827efacef), C64e(0x6fe7baba8832e732),631C64e(0x642b32324f7d2b7d), C64e(0xd795e6e642a495a4),632C64e(0x9ba0c0c03bfba0fb), C64e(0x32981919aab398b3),633C64e(0x27d19e9ef668d168), C64e(0x5d7fa3a322817f81),634C64e(0x88664444eeaa66aa), C64e(0xa87e5454d6827e82),635C64e(0x76ab3b3bdde6abe6), C64e(0x16830b0b959e839e),636C64e(0x03ca8c8cc945ca45), C64e(0x9529c7c7bc7b297b),637C64e(0xd6d36b6b056ed36e), C64e(0x503c28286c443c44),638C64e(0x5579a7a72c8b798b), C64e(0x63e2bcbc813de23d),639C64e(0x2c1d161631271d27), C64e(0x4176adad379a769a),640C64e(0xad3bdbdb964d3b4d), C64e(0xc85664649efa56fa),641C64e(0xe84e7474a6d24ed2), C64e(0x281e141436221e22),642C64e(0x3fdb9292e476db76), C64e(0x180a0c0c121e0a1e),643C64e(0x906c4848fcb46cb4), C64e(0x6be4b8b88f37e437),644C64e(0x255d9f9f78e75de7), C64e(0x616ebdbd0fb26eb2),645C64e(0x86ef4343692aef2a), C64e(0x93a6c4c435f1a6f1),646C64e(0x72a83939dae3a8e3), C64e(0x62a43131c6f7a4f7),647C64e(0xbd37d3d38a593759), C64e(0xff8bf2f274868b86),648C64e(0xb132d5d583563256), C64e(0x0d438b8b4ec543c5),649C64e(0xdc596e6e85eb59eb), C64e(0xafb7dada18c2b7c2),650C64e(0x028c01018e8f8c8f), C64e(0x7964b1b11dac64ac),651C64e(0x23d29c9cf16dd26d), C64e(0x92e04949723be03b),652C64e(0xabb4d8d81fc7b4c7), C64e(0x43faacacb915fa15),653C64e(0xfd07f3f3fa090709), C64e(0x8525cfcfa06f256f),654C64e(0x8fafcaca20eaafea), C64e(0xf38ef4f47d898e89),655C64e(0x8ee947476720e920), C64e(0x2018101038281828),656C64e(0xded56f6f0b64d564), C64e(0xfb88f0f073838883),657C64e(0x946f4a4afbb16fb1), C64e(0xb8725c5cca967296),658C64e(0x70243838546c246c), C64e(0xaef157575f08f108),659C64e(0xe6c773732152c752), C64e(0x3551979764f351f3),660C64e(0x8d23cbcbae652365), C64e(0x597ca1a125847c84),661C64e(0xcb9ce8e857bf9cbf), C64e(0x7c213e3e5d632163),662C64e(0x37dd9696ea7cdd7c), C64e(0xc2dc61611e7fdc7f),663C64e(0x1a860d0d9c918691), C64e(0x1e850f0f9b948594),664C64e(0xdb90e0e04bab90ab), C64e(0xf8427c7cbac642c6),665C64e(0xe2c471712657c457), C64e(0x83aacccc29e5aae5),666C64e(0x3bd89090e373d873), C64e(0x0c050606090f050f),667C64e(0xf501f7f7f4030103), C64e(0x38121c1c2a361236),668C64e(0x9fa3c2c23cfea3fe), C64e(0xd45f6a6a8be15fe1),669C64e(0x47f9aeaebe10f910), C64e(0xd2d06969026bd06b),670C64e(0x2e911717bfa891a8), C64e(0x2958999971e858e8),671C64e(0x74273a3a53692769), C64e(0x4eb92727f7d0b9d0),672C64e(0xa938d9d991483848), C64e(0xcd13ebebde351335),673C64e(0x56b32b2be5ceb3ce), C64e(0x4433222277553355),674C64e(0xbfbbd2d204d6bbd6), C64e(0x4970a9a939907090),675C64e(0x0e89070787808980), C64e(0x66a73333c1f2a7f2),676C64e(0x5ab62d2decc1b6c1), C64e(0x78223c3c5a662266),677C64e(0x2a921515b8ad92ad), C64e(0x8920c9c9a9602060),678C64e(0x154987875cdb49db), C64e(0x4fffaaaab01aff1a),679C64e(0xa0785050d8887888), C64e(0x517aa5a52b8e7a8e),680C64e(0x068f0303898a8f8a), C64e(0xb2f859594a13f813),681C64e(0x12800909929b809b), C64e(0x34171a1a23391739),682C64e(0xcada65651075da75), C64e(0xb531d7d784533153),683C64e(0x13c68484d551c651), C64e(0xbbb8d0d003d3b8d3),684C64e(0x1fc38282dc5ec35e), C64e(0x52b02929e2cbb0cb),685C64e(0xb4775a5ac3997799), C64e(0x3c111e1e2d331133),686C64e(0xf6cb7b7b3d46cb46), C64e(0x4bfca8a8b71ffc1f),687C64e(0xdad66d6d0c61d661), C64e(0x583a2c2c624e3a4e)688};689690#endif691692static const sph_u64 T4[] = {693C64e(0xf497a5c6c632f4a5), C64e(0x97eb84f8f86f9784),694C64e(0xb0c799eeee5eb099), C64e(0x8cf78df6f67a8c8d),695C64e(0x17e50dffffe8170d), C64e(0xdcb7bdd6d60adcbd),696C64e(0xc8a7b1dede16c8b1), C64e(0xfc395491916dfc54),697C64e(0xf0c050606090f050), C64e(0x0504030202070503),698C64e(0xe087a9cece2ee0a9), C64e(0x87ac7d5656d1877d),699C64e(0x2bd519e7e7cc2b19), C64e(0xa67162b5b513a662),700C64e(0x319ae64d4d7c31e6), C64e(0xb5c39aecec59b59a),701C64e(0xcf05458f8f40cf45), C64e(0xbc3e9d1f1fa3bc9d),702C64e(0xc00940898949c040), C64e(0x92ef87fafa689287),703C64e(0x3fc515efefd03f15), C64e(0x267febb2b29426eb),704C64e(0x4007c98e8ece40c9), C64e(0x1ded0bfbfbe61d0b),705C64e(0x2f82ec41416e2fec), C64e(0xa97d67b3b31aa967),706C64e(0x1cbefd5f5f431cfd), C64e(0x258aea45456025ea),707C64e(0xda46bf2323f9dabf), C64e(0x02a6f753535102f7),708C64e(0xa1d396e4e445a196), C64e(0xed2d5b9b9b76ed5b),709C64e(0x5deac27575285dc2), C64e(0x24d91ce1e1c5241c),710C64e(0xe97aae3d3dd4e9ae), C64e(0xbe986a4c4cf2be6a),711C64e(0xeed85a6c6c82ee5a), C64e(0xc3fc417e7ebdc341),712C64e(0x06f102f5f5f30602), C64e(0xd11d4f838352d14f),713C64e(0xe4d05c68688ce45c), C64e(0x07a2f451515607f4),714C64e(0x5cb934d1d18d5c34), C64e(0x18e908f9f9e11808),715C64e(0xaedf93e2e24cae93), C64e(0x954d73abab3e9573),716C64e(0xf5c453626297f553), C64e(0x41543f2a2a6b413f),717C64e(0x14100c08081c140c), C64e(0xf63152959563f652),718C64e(0xaf8c654646e9af65), C64e(0xe2215e9d9d7fe25e),719C64e(0x7860283030487828), C64e(0xf86ea13737cff8a1),720C64e(0x11140f0a0a1b110f), C64e(0xc45eb52f2febc4b5),721C64e(0x1b1c090e0e151b09), C64e(0x5a483624247e5a36),722C64e(0xb6369b1b1badb69b), C64e(0x47a53ddfdf98473d),723C64e(0x6a8126cdcda76a26), C64e(0xbb9c694e4ef5bb69),724C64e(0x4cfecd7f7f334ccd), C64e(0xbacf9feaea50ba9f),725C64e(0x2d241b12123f2d1b), C64e(0xb93a9e1d1da4b99e),726C64e(0x9cb0745858c49c74), C64e(0x72682e343446722e),727C64e(0x776c2d363641772d), C64e(0xcda3b2dcdc11cdb2),728C64e(0x2973eeb4b49d29ee), C64e(0x16b6fb5b5b4d16fb),729C64e(0x0153f6a4a4a501f6), C64e(0xd7ec4d7676a1d74d),730C64e(0xa37561b7b714a361), C64e(0x49face7d7d3449ce),731C64e(0x8da47b5252df8d7b), C64e(0x42a13edddd9f423e),732C64e(0x93bc715e5ecd9371), C64e(0xa226971313b1a297),733C64e(0x0457f5a6a6a204f5), C64e(0xb86968b9b901b868),734C64e(0x0000000000000000), C64e(0x74992cc1c1b5742c),735C64e(0xa080604040e0a060), C64e(0x21dd1fe3e3c2211f),736C64e(0x43f2c879793a43c8), C64e(0x2c77edb6b69a2ced),737C64e(0xd9b3bed4d40dd9be), C64e(0xca01468d8d47ca46),738C64e(0x70ced967671770d9), C64e(0xdde44b7272afdd4b),739C64e(0x7933de9494ed79de), C64e(0x672bd49898ff67d4),740C64e(0x237be8b0b09323e8), C64e(0xde114a85855bde4a),741C64e(0xbd6d6bbbbb06bd6b), C64e(0x7e912ac5c5bb7e2a),742C64e(0x349ee54f4f7b34e5), C64e(0x3ac116ededd73a16),743C64e(0x5417c58686d254c5), C64e(0x622fd79a9af862d7),744C64e(0xffcc55666699ff55), C64e(0xa722941111b6a794),745C64e(0x4a0fcf8a8ac04acf), C64e(0x30c910e9e9d93010),746C64e(0x0a080604040e0a06), C64e(0x98e781fefe669881),747C64e(0x0b5bf0a0a0ab0bf0), C64e(0xccf0447878b4cc44),748C64e(0xd54aba2525f0d5ba), C64e(0x3e96e34b4b753ee3),749C64e(0x0e5ff3a2a2ac0ef3), C64e(0x19bafe5d5d4419fe),750C64e(0x5b1bc08080db5bc0), C64e(0x850a8a050580858a),751C64e(0xec7ead3f3fd3ecad), C64e(0xdf42bc2121fedfbc),752C64e(0xd8e0487070a8d848), C64e(0x0cf904f1f1fd0c04),753C64e(0x7ac6df6363197adf), C64e(0x58eec177772f58c1),754C64e(0x9f4575afaf309f75), C64e(0xa584634242e7a563),755C64e(0x5040302020705030), C64e(0x2ed11ae5e5cb2e1a),756C64e(0x12e10efdfdef120e), C64e(0xb7656dbfbf08b76d),757C64e(0xd4194c818155d44c), C64e(0x3c30141818243c14),758C64e(0x5f4c352626795f35), C64e(0x719d2fc3c3b2712f),759C64e(0x3867e1bebe8638e1), C64e(0xfd6aa23535c8fda2),760C64e(0x4f0bcc8888c74fcc), C64e(0x4b5c392e2e654b39),761C64e(0xf93d5793936af957), C64e(0x0daaf25555580df2),762C64e(0x9de382fcfc619d82), C64e(0xc9f4477a7ab3c947),763C64e(0xef8bacc8c827efac), C64e(0x326fe7baba8832e7),764C64e(0x7d642b32324f7d2b), C64e(0xa4d795e6e642a495),765C64e(0xfb9ba0c0c03bfba0), C64e(0xb332981919aab398),766C64e(0x6827d19e9ef668d1), C64e(0x815d7fa3a322817f),767C64e(0xaa88664444eeaa66), C64e(0x82a87e5454d6827e),768C64e(0xe676ab3b3bdde6ab), C64e(0x9e16830b0b959e83),769C64e(0x4503ca8c8cc945ca), C64e(0x7b9529c7c7bc7b29),770C64e(0x6ed6d36b6b056ed3), C64e(0x44503c28286c443c),771C64e(0x8b5579a7a72c8b79), C64e(0x3d63e2bcbc813de2),772C64e(0x272c1d161631271d), C64e(0x9a4176adad379a76),773C64e(0x4dad3bdbdb964d3b), C64e(0xfac85664649efa56),774C64e(0xd2e84e7474a6d24e), C64e(0x22281e141436221e),775C64e(0x763fdb9292e476db), C64e(0x1e180a0c0c121e0a),776C64e(0xb4906c4848fcb46c), C64e(0x376be4b8b88f37e4),777C64e(0xe7255d9f9f78e75d), C64e(0xb2616ebdbd0fb26e),778C64e(0x2a86ef4343692aef), C64e(0xf193a6c4c435f1a6),779C64e(0xe372a83939dae3a8), C64e(0xf762a43131c6f7a4),780C64e(0x59bd37d3d38a5937), C64e(0x86ff8bf2f274868b),781C64e(0x56b132d5d5835632), C64e(0xc50d438b8b4ec543),782C64e(0xebdc596e6e85eb59), C64e(0xc2afb7dada18c2b7),783C64e(0x8f028c01018e8f8c), C64e(0xac7964b1b11dac64),784C64e(0x6d23d29c9cf16dd2), C64e(0x3b92e04949723be0),785C64e(0xc7abb4d8d81fc7b4), C64e(0x1543faacacb915fa),786C64e(0x09fd07f3f3fa0907), C64e(0x6f8525cfcfa06f25),787C64e(0xea8fafcaca20eaaf), C64e(0x89f38ef4f47d898e),788C64e(0x208ee947476720e9), C64e(0x2820181010382818),789C64e(0x64ded56f6f0b64d5), C64e(0x83fb88f0f0738388),790C64e(0xb1946f4a4afbb16f), C64e(0x96b8725c5cca9672),791C64e(0x6c70243838546c24), C64e(0x08aef157575f08f1),792C64e(0x52e6c773732152c7), C64e(0xf33551979764f351),793C64e(0x658d23cbcbae6523), C64e(0x84597ca1a125847c),794C64e(0xbfcb9ce8e857bf9c), C64e(0x637c213e3e5d6321),795C64e(0x7c37dd9696ea7cdd), C64e(0x7fc2dc61611e7fdc),796C64e(0x911a860d0d9c9186), C64e(0x941e850f0f9b9485),797C64e(0xabdb90e0e04bab90), C64e(0xc6f8427c7cbac642),798C64e(0x57e2c471712657c4), C64e(0xe583aacccc29e5aa),799C64e(0x733bd89090e373d8), C64e(0x0f0c050606090f05),800C64e(0x03f501f7f7f40301), C64e(0x3638121c1c2a3612),801C64e(0xfe9fa3c2c23cfea3), C64e(0xe1d45f6a6a8be15f),802C64e(0x1047f9aeaebe10f9), C64e(0x6bd2d06969026bd0),803C64e(0xa82e911717bfa891), C64e(0xe82958999971e858),804C64e(0x6974273a3a536927), C64e(0xd04eb92727f7d0b9),805C64e(0x48a938d9d9914838), C64e(0x35cd13ebebde3513),806C64e(0xce56b32b2be5ceb3), C64e(0x5544332222775533),807C64e(0xd6bfbbd2d204d6bb), C64e(0x904970a9a9399070),808C64e(0x800e890707878089), C64e(0xf266a73333c1f2a7),809C64e(0xc15ab62d2decc1b6), C64e(0x6678223c3c5a6622),810C64e(0xad2a921515b8ad92), C64e(0x608920c9c9a96020),811C64e(0xdb154987875cdb49), C64e(0x1a4fffaaaab01aff),812C64e(0x88a0785050d88878), C64e(0x8e517aa5a52b8e7a),813C64e(0x8a068f0303898a8f), C64e(0x13b2f859594a13f8),814C64e(0x9b12800909929b80), C64e(0x3934171a1a233917),815C64e(0x75cada65651075da), C64e(0x53b531d7d7845331),816C64e(0x5113c68484d551c6), C64e(0xd3bbb8d0d003d3b8),817C64e(0x5e1fc38282dc5ec3), C64e(0xcb52b02929e2cbb0),818C64e(0x99b4775a5ac39977), C64e(0x333c111e1e2d3311),819C64e(0x46f6cb7b7b3d46cb), C64e(0x1f4bfca8a8b71ffc),820C64e(0x61dad66d6d0c61d6), C64e(0x4e583a2c2c624e3a)821};822823#if !SPH_SMALL_FOOTPRINT_GROESTL824825static const sph_u64 T5[] = {826C64e(0xa5f497a5c6c632f4), C64e(0x8497eb84f8f86f97),827C64e(0x99b0c799eeee5eb0), C64e(0x8d8cf78df6f67a8c),828C64e(0x0d17e50dffffe817), C64e(0xbddcb7bdd6d60adc),829C64e(0xb1c8a7b1dede16c8), C64e(0x54fc395491916dfc),830C64e(0x50f0c050606090f0), C64e(0x0305040302020705),831C64e(0xa9e087a9cece2ee0), C64e(0x7d87ac7d5656d187),832C64e(0x192bd519e7e7cc2b), C64e(0x62a67162b5b513a6),833C64e(0xe6319ae64d4d7c31), C64e(0x9ab5c39aecec59b5),834C64e(0x45cf05458f8f40cf), C64e(0x9dbc3e9d1f1fa3bc),835C64e(0x40c00940898949c0), C64e(0x8792ef87fafa6892),836C64e(0x153fc515efefd03f), C64e(0xeb267febb2b29426),837C64e(0xc94007c98e8ece40), C64e(0x0b1ded0bfbfbe61d),838C64e(0xec2f82ec41416e2f), C64e(0x67a97d67b3b31aa9),839C64e(0xfd1cbefd5f5f431c), C64e(0xea258aea45456025),840C64e(0xbfda46bf2323f9da), C64e(0xf702a6f753535102),841C64e(0x96a1d396e4e445a1), C64e(0x5bed2d5b9b9b76ed),842C64e(0xc25deac27575285d), C64e(0x1c24d91ce1e1c524),843C64e(0xaee97aae3d3dd4e9), C64e(0x6abe986a4c4cf2be),844C64e(0x5aeed85a6c6c82ee), C64e(0x41c3fc417e7ebdc3),845C64e(0x0206f102f5f5f306), C64e(0x4fd11d4f838352d1),846C64e(0x5ce4d05c68688ce4), C64e(0xf407a2f451515607),847C64e(0x345cb934d1d18d5c), C64e(0x0818e908f9f9e118),848C64e(0x93aedf93e2e24cae), C64e(0x73954d73abab3e95),849C64e(0x53f5c453626297f5), C64e(0x3f41543f2a2a6b41),850C64e(0x0c14100c08081c14), C64e(0x52f63152959563f6),851C64e(0x65af8c654646e9af), C64e(0x5ee2215e9d9d7fe2),852C64e(0x2878602830304878), C64e(0xa1f86ea13737cff8),853C64e(0x0f11140f0a0a1b11), C64e(0xb5c45eb52f2febc4),854C64e(0x091b1c090e0e151b), C64e(0x365a483624247e5a),855C64e(0x9bb6369b1b1badb6), C64e(0x3d47a53ddfdf9847),856C64e(0x266a8126cdcda76a), C64e(0x69bb9c694e4ef5bb),857C64e(0xcd4cfecd7f7f334c), C64e(0x9fbacf9feaea50ba),858C64e(0x1b2d241b12123f2d), C64e(0x9eb93a9e1d1da4b9),859C64e(0x749cb0745858c49c), C64e(0x2e72682e34344672),860C64e(0x2d776c2d36364177), C64e(0xb2cda3b2dcdc11cd),861C64e(0xee2973eeb4b49d29), C64e(0xfb16b6fb5b5b4d16),862C64e(0xf60153f6a4a4a501), C64e(0x4dd7ec4d7676a1d7),863C64e(0x61a37561b7b714a3), C64e(0xce49face7d7d3449),864C64e(0x7b8da47b5252df8d), C64e(0x3e42a13edddd9f42),865C64e(0x7193bc715e5ecd93), C64e(0x97a226971313b1a2),866C64e(0xf50457f5a6a6a204), C64e(0x68b86968b9b901b8),867C64e(0x0000000000000000), C64e(0x2c74992cc1c1b574),868C64e(0x60a080604040e0a0), C64e(0x1f21dd1fe3e3c221),869C64e(0xc843f2c879793a43), C64e(0xed2c77edb6b69a2c),870C64e(0xbed9b3bed4d40dd9), C64e(0x46ca01468d8d47ca),871C64e(0xd970ced967671770), C64e(0x4bdde44b7272afdd),872C64e(0xde7933de9494ed79), C64e(0xd4672bd49898ff67),873C64e(0xe8237be8b0b09323), C64e(0x4ade114a85855bde),874C64e(0x6bbd6d6bbbbb06bd), C64e(0x2a7e912ac5c5bb7e),875C64e(0xe5349ee54f4f7b34), C64e(0x163ac116ededd73a),876C64e(0xc55417c58686d254), C64e(0xd7622fd79a9af862),877C64e(0x55ffcc55666699ff), C64e(0x94a722941111b6a7),878C64e(0xcf4a0fcf8a8ac04a), C64e(0x1030c910e9e9d930),879C64e(0x060a080604040e0a), C64e(0x8198e781fefe6698),880C64e(0xf00b5bf0a0a0ab0b), C64e(0x44ccf0447878b4cc),881C64e(0xbad54aba2525f0d5), C64e(0xe33e96e34b4b753e),882C64e(0xf30e5ff3a2a2ac0e), C64e(0xfe19bafe5d5d4419),883C64e(0xc05b1bc08080db5b), C64e(0x8a850a8a05058085),884C64e(0xadec7ead3f3fd3ec), C64e(0xbcdf42bc2121fedf),885C64e(0x48d8e0487070a8d8), C64e(0x040cf904f1f1fd0c),886C64e(0xdf7ac6df6363197a), C64e(0xc158eec177772f58),887C64e(0x759f4575afaf309f), C64e(0x63a584634242e7a5),888C64e(0x3050403020207050), C64e(0x1a2ed11ae5e5cb2e),889C64e(0x0e12e10efdfdef12), C64e(0x6db7656dbfbf08b7),890C64e(0x4cd4194c818155d4), C64e(0x143c30141818243c),891C64e(0x355f4c352626795f), C64e(0x2f719d2fc3c3b271),892C64e(0xe13867e1bebe8638), C64e(0xa2fd6aa23535c8fd),893C64e(0xcc4f0bcc8888c74f), C64e(0x394b5c392e2e654b),894C64e(0x57f93d5793936af9), C64e(0xf20daaf25555580d),895C64e(0x829de382fcfc619d), C64e(0x47c9f4477a7ab3c9),896C64e(0xacef8bacc8c827ef), C64e(0xe7326fe7baba8832),897C64e(0x2b7d642b32324f7d), C64e(0x95a4d795e6e642a4),898C64e(0xa0fb9ba0c0c03bfb), C64e(0x98b332981919aab3),899C64e(0xd16827d19e9ef668), C64e(0x7f815d7fa3a32281),900C64e(0x66aa88664444eeaa), C64e(0x7e82a87e5454d682),901C64e(0xabe676ab3b3bdde6), C64e(0x839e16830b0b959e),902C64e(0xca4503ca8c8cc945), C64e(0x297b9529c7c7bc7b),903C64e(0xd36ed6d36b6b056e), C64e(0x3c44503c28286c44),904C64e(0x798b5579a7a72c8b), C64e(0xe23d63e2bcbc813d),905C64e(0x1d272c1d16163127), C64e(0x769a4176adad379a),906C64e(0x3b4dad3bdbdb964d), C64e(0x56fac85664649efa),907C64e(0x4ed2e84e7474a6d2), C64e(0x1e22281e14143622),908C64e(0xdb763fdb9292e476), C64e(0x0a1e180a0c0c121e),909C64e(0x6cb4906c4848fcb4), C64e(0xe4376be4b8b88f37),910C64e(0x5de7255d9f9f78e7), C64e(0x6eb2616ebdbd0fb2),911C64e(0xef2a86ef4343692a), C64e(0xa6f193a6c4c435f1),912C64e(0xa8e372a83939dae3), C64e(0xa4f762a43131c6f7),913C64e(0x3759bd37d3d38a59), C64e(0x8b86ff8bf2f27486),914C64e(0x3256b132d5d58356), C64e(0x43c50d438b8b4ec5),915C64e(0x59ebdc596e6e85eb), C64e(0xb7c2afb7dada18c2),916C64e(0x8c8f028c01018e8f), C64e(0x64ac7964b1b11dac),917C64e(0xd26d23d29c9cf16d), C64e(0xe03b92e04949723b),918C64e(0xb4c7abb4d8d81fc7), C64e(0xfa1543faacacb915),919C64e(0x0709fd07f3f3fa09), C64e(0x256f8525cfcfa06f),920C64e(0xafea8fafcaca20ea), C64e(0x8e89f38ef4f47d89),921C64e(0xe9208ee947476720), C64e(0x1828201810103828),922C64e(0xd564ded56f6f0b64), C64e(0x8883fb88f0f07383),923C64e(0x6fb1946f4a4afbb1), C64e(0x7296b8725c5cca96),924C64e(0x246c70243838546c), C64e(0xf108aef157575f08),925C64e(0xc752e6c773732152), C64e(0x51f33551979764f3),926C64e(0x23658d23cbcbae65), C64e(0x7c84597ca1a12584),927C64e(0x9cbfcb9ce8e857bf), C64e(0x21637c213e3e5d63),928C64e(0xdd7c37dd9696ea7c), C64e(0xdc7fc2dc61611e7f),929C64e(0x86911a860d0d9c91), C64e(0x85941e850f0f9b94),930C64e(0x90abdb90e0e04bab), C64e(0x42c6f8427c7cbac6),931C64e(0xc457e2c471712657), C64e(0xaae583aacccc29e5),932C64e(0xd8733bd89090e373), C64e(0x050f0c050606090f),933C64e(0x0103f501f7f7f403), C64e(0x123638121c1c2a36),934C64e(0xa3fe9fa3c2c23cfe), C64e(0x5fe1d45f6a6a8be1),935C64e(0xf91047f9aeaebe10), C64e(0xd06bd2d06969026b),936C64e(0x91a82e911717bfa8), C64e(0x58e82958999971e8),937C64e(0x276974273a3a5369), C64e(0xb9d04eb92727f7d0),938C64e(0x3848a938d9d99148), C64e(0x1335cd13ebebde35),939C64e(0xb3ce56b32b2be5ce), C64e(0x3355443322227755),940C64e(0xbbd6bfbbd2d204d6), C64e(0x70904970a9a93990),941C64e(0x89800e8907078780), C64e(0xa7f266a73333c1f2),942C64e(0xb6c15ab62d2decc1), C64e(0x226678223c3c5a66),943C64e(0x92ad2a921515b8ad), C64e(0x20608920c9c9a960),944C64e(0x49db154987875cdb), C64e(0xff1a4fffaaaab01a),945C64e(0x7888a0785050d888), C64e(0x7a8e517aa5a52b8e),946C64e(0x8f8a068f0303898a), C64e(0xf813b2f859594a13),947C64e(0x809b12800909929b), C64e(0x173934171a1a2339),948C64e(0xda75cada65651075), C64e(0x3153b531d7d78453),949C64e(0xc65113c68484d551), C64e(0xb8d3bbb8d0d003d3),950C64e(0xc35e1fc38282dc5e), C64e(0xb0cb52b02929e2cb),951C64e(0x7799b4775a5ac399), C64e(0x11333c111e1e2d33),952C64e(0xcb46f6cb7b7b3d46), C64e(0xfc1f4bfca8a8b71f),953C64e(0xd661dad66d6d0c61), C64e(0x3a4e583a2c2c624e)954};955956static const sph_u64 T6[] = {957C64e(0xf4a5f497a5c6c632), C64e(0x978497eb84f8f86f),958C64e(0xb099b0c799eeee5e), C64e(0x8c8d8cf78df6f67a),959C64e(0x170d17e50dffffe8), C64e(0xdcbddcb7bdd6d60a),960C64e(0xc8b1c8a7b1dede16), C64e(0xfc54fc395491916d),961C64e(0xf050f0c050606090), C64e(0x0503050403020207),962C64e(0xe0a9e087a9cece2e), C64e(0x877d87ac7d5656d1),963C64e(0x2b192bd519e7e7cc), C64e(0xa662a67162b5b513),964C64e(0x31e6319ae64d4d7c), C64e(0xb59ab5c39aecec59),965C64e(0xcf45cf05458f8f40), C64e(0xbc9dbc3e9d1f1fa3),966C64e(0xc040c00940898949), C64e(0x928792ef87fafa68),967C64e(0x3f153fc515efefd0), C64e(0x26eb267febb2b294),968C64e(0x40c94007c98e8ece), C64e(0x1d0b1ded0bfbfbe6),969C64e(0x2fec2f82ec41416e), C64e(0xa967a97d67b3b31a),970C64e(0x1cfd1cbefd5f5f43), C64e(0x25ea258aea454560),971C64e(0xdabfda46bf2323f9), C64e(0x02f702a6f7535351),972C64e(0xa196a1d396e4e445), C64e(0xed5bed2d5b9b9b76),973C64e(0x5dc25deac2757528), C64e(0x241c24d91ce1e1c5),974C64e(0xe9aee97aae3d3dd4), C64e(0xbe6abe986a4c4cf2),975C64e(0xee5aeed85a6c6c82), C64e(0xc341c3fc417e7ebd),976C64e(0x060206f102f5f5f3), C64e(0xd14fd11d4f838352),977C64e(0xe45ce4d05c68688c), C64e(0x07f407a2f4515156),978C64e(0x5c345cb934d1d18d), C64e(0x180818e908f9f9e1),979C64e(0xae93aedf93e2e24c), C64e(0x9573954d73abab3e),980C64e(0xf553f5c453626297), C64e(0x413f41543f2a2a6b),981C64e(0x140c14100c08081c), C64e(0xf652f63152959563),982C64e(0xaf65af8c654646e9), C64e(0xe25ee2215e9d9d7f),983C64e(0x7828786028303048), C64e(0xf8a1f86ea13737cf),984C64e(0x110f11140f0a0a1b), C64e(0xc4b5c45eb52f2feb),985C64e(0x1b091b1c090e0e15), C64e(0x5a365a483624247e),986C64e(0xb69bb6369b1b1bad), C64e(0x473d47a53ddfdf98),987C64e(0x6a266a8126cdcda7), C64e(0xbb69bb9c694e4ef5),988C64e(0x4ccd4cfecd7f7f33), C64e(0xba9fbacf9feaea50),989C64e(0x2d1b2d241b12123f), C64e(0xb99eb93a9e1d1da4),990C64e(0x9c749cb0745858c4), C64e(0x722e72682e343446),991C64e(0x772d776c2d363641), C64e(0xcdb2cda3b2dcdc11),992C64e(0x29ee2973eeb4b49d), C64e(0x16fb16b6fb5b5b4d),993C64e(0x01f60153f6a4a4a5), C64e(0xd74dd7ec4d7676a1),994C64e(0xa361a37561b7b714), C64e(0x49ce49face7d7d34),995C64e(0x8d7b8da47b5252df), C64e(0x423e42a13edddd9f),996C64e(0x937193bc715e5ecd), C64e(0xa297a226971313b1),997C64e(0x04f50457f5a6a6a2), C64e(0xb868b86968b9b901),998C64e(0x0000000000000000), C64e(0x742c74992cc1c1b5),999C64e(0xa060a080604040e0), C64e(0x211f21dd1fe3e3c2),1000C64e(0x43c843f2c879793a), C64e(0x2ced2c77edb6b69a),1001C64e(0xd9bed9b3bed4d40d), C64e(0xca46ca01468d8d47),1002C64e(0x70d970ced9676717), C64e(0xdd4bdde44b7272af),1003C64e(0x79de7933de9494ed), C64e(0x67d4672bd49898ff),1004C64e(0x23e8237be8b0b093), C64e(0xde4ade114a85855b),1005C64e(0xbd6bbd6d6bbbbb06), C64e(0x7e2a7e912ac5c5bb),1006C64e(0x34e5349ee54f4f7b), C64e(0x3a163ac116ededd7),1007C64e(0x54c55417c58686d2), C64e(0x62d7622fd79a9af8),1008C64e(0xff55ffcc55666699), C64e(0xa794a722941111b6),1009C64e(0x4acf4a0fcf8a8ac0), C64e(0x301030c910e9e9d9),1010C64e(0x0a060a080604040e), C64e(0x988198e781fefe66),1011C64e(0x0bf00b5bf0a0a0ab), C64e(0xcc44ccf0447878b4),1012C64e(0xd5bad54aba2525f0), C64e(0x3ee33e96e34b4b75),1013C64e(0x0ef30e5ff3a2a2ac), C64e(0x19fe19bafe5d5d44),1014C64e(0x5bc05b1bc08080db), C64e(0x858a850a8a050580),1015C64e(0xecadec7ead3f3fd3), C64e(0xdfbcdf42bc2121fe),1016C64e(0xd848d8e0487070a8), C64e(0x0c040cf904f1f1fd),1017C64e(0x7adf7ac6df636319), C64e(0x58c158eec177772f),1018C64e(0x9f759f4575afaf30), C64e(0xa563a584634242e7),1019C64e(0x5030504030202070), C64e(0x2e1a2ed11ae5e5cb),1020C64e(0x120e12e10efdfdef), C64e(0xb76db7656dbfbf08),1021C64e(0xd44cd4194c818155), C64e(0x3c143c3014181824),1022C64e(0x5f355f4c35262679), C64e(0x712f719d2fc3c3b2),1023C64e(0x38e13867e1bebe86), C64e(0xfda2fd6aa23535c8),1024C64e(0x4fcc4f0bcc8888c7), C64e(0x4b394b5c392e2e65),1025C64e(0xf957f93d5793936a), C64e(0x0df20daaf2555558),1026C64e(0x9d829de382fcfc61), C64e(0xc947c9f4477a7ab3),1027C64e(0xefacef8bacc8c827), C64e(0x32e7326fe7baba88),1028C64e(0x7d2b7d642b32324f), C64e(0xa495a4d795e6e642),1029C64e(0xfba0fb9ba0c0c03b), C64e(0xb398b332981919aa),1030C64e(0x68d16827d19e9ef6), C64e(0x817f815d7fa3a322),1031C64e(0xaa66aa88664444ee), C64e(0x827e82a87e5454d6),1032C64e(0xe6abe676ab3b3bdd), C64e(0x9e839e16830b0b95),1033C64e(0x45ca4503ca8c8cc9), C64e(0x7b297b9529c7c7bc),1034C64e(0x6ed36ed6d36b6b05), C64e(0x443c44503c28286c),1035C64e(0x8b798b5579a7a72c), C64e(0x3de23d63e2bcbc81),1036C64e(0x271d272c1d161631), C64e(0x9a769a4176adad37),1037C64e(0x4d3b4dad3bdbdb96), C64e(0xfa56fac85664649e),1038C64e(0xd24ed2e84e7474a6), C64e(0x221e22281e141436),1039C64e(0x76db763fdb9292e4), C64e(0x1e0a1e180a0c0c12),1040C64e(0xb46cb4906c4848fc), C64e(0x37e4376be4b8b88f),1041C64e(0xe75de7255d9f9f78), C64e(0xb26eb2616ebdbd0f),1042C64e(0x2aef2a86ef434369), C64e(0xf1a6f193a6c4c435),1043C64e(0xe3a8e372a83939da), C64e(0xf7a4f762a43131c6),1044C64e(0x593759bd37d3d38a), C64e(0x868b86ff8bf2f274),1045C64e(0x563256b132d5d583), C64e(0xc543c50d438b8b4e),1046C64e(0xeb59ebdc596e6e85), C64e(0xc2b7c2afb7dada18),1047C64e(0x8f8c8f028c01018e), C64e(0xac64ac7964b1b11d),1048C64e(0x6dd26d23d29c9cf1), C64e(0x3be03b92e0494972),1049C64e(0xc7b4c7abb4d8d81f), C64e(0x15fa1543faacacb9),1050C64e(0x090709fd07f3f3fa), C64e(0x6f256f8525cfcfa0),1051C64e(0xeaafea8fafcaca20), C64e(0x898e89f38ef4f47d),1052C64e(0x20e9208ee9474767), C64e(0x2818282018101038),1053C64e(0x64d564ded56f6f0b), C64e(0x838883fb88f0f073),1054C64e(0xb16fb1946f4a4afb), C64e(0x967296b8725c5cca),1055C64e(0x6c246c7024383854), C64e(0x08f108aef157575f),1056C64e(0x52c752e6c7737321), C64e(0xf351f33551979764),1057C64e(0x6523658d23cbcbae), C64e(0x847c84597ca1a125),1058C64e(0xbf9cbfcb9ce8e857), C64e(0x6321637c213e3e5d),1059C64e(0x7cdd7c37dd9696ea), C64e(0x7fdc7fc2dc61611e),1060C64e(0x9186911a860d0d9c), C64e(0x9485941e850f0f9b),1061C64e(0xab90abdb90e0e04b), C64e(0xc642c6f8427c7cba),1062C64e(0x57c457e2c4717126), C64e(0xe5aae583aacccc29),1063C64e(0x73d8733bd89090e3), C64e(0x0f050f0c05060609),1064C64e(0x030103f501f7f7f4), C64e(0x36123638121c1c2a),1065C64e(0xfea3fe9fa3c2c23c), C64e(0xe15fe1d45f6a6a8b),1066C64e(0x10f91047f9aeaebe), C64e(0x6bd06bd2d0696902),1067C64e(0xa891a82e911717bf), C64e(0xe858e82958999971),1068C64e(0x69276974273a3a53), C64e(0xd0b9d04eb92727f7),1069C64e(0x483848a938d9d991), C64e(0x351335cd13ebebde),1070C64e(0xceb3ce56b32b2be5), C64e(0x5533554433222277),1071C64e(0xd6bbd6bfbbd2d204), C64e(0x9070904970a9a939),1072C64e(0x8089800e89070787), C64e(0xf2a7f266a73333c1),1073C64e(0xc1b6c15ab62d2dec), C64e(0x66226678223c3c5a),1074C64e(0xad92ad2a921515b8), C64e(0x6020608920c9c9a9),1075C64e(0xdb49db154987875c), C64e(0x1aff1a4fffaaaab0),1076C64e(0x887888a0785050d8), C64e(0x8e7a8e517aa5a52b),1077C64e(0x8a8f8a068f030389), C64e(0x13f813b2f859594a),1078C64e(0x9b809b1280090992), C64e(0x39173934171a1a23),1079C64e(0x75da75cada656510), C64e(0x533153b531d7d784),1080C64e(0x51c65113c68484d5), C64e(0xd3b8d3bbb8d0d003),1081C64e(0x5ec35e1fc38282dc), C64e(0xcbb0cb52b02929e2),1082C64e(0x997799b4775a5ac3), C64e(0x3311333c111e1e2d),1083C64e(0x46cb46f6cb7b7b3d), C64e(0x1ffc1f4bfca8a8b7),1084C64e(0x61d661dad66d6d0c), C64e(0x4e3a4e583a2c2c62)1085};10861087static const sph_u64 T7[] = {1088C64e(0x32f4a5f497a5c6c6), C64e(0x6f978497eb84f8f8),1089C64e(0x5eb099b0c799eeee), C64e(0x7a8c8d8cf78df6f6),1090C64e(0xe8170d17e50dffff), C64e(0x0adcbddcb7bdd6d6),1091C64e(0x16c8b1c8a7b1dede), C64e(0x6dfc54fc39549191),1092C64e(0x90f050f0c0506060), C64e(0x0705030504030202),1093C64e(0x2ee0a9e087a9cece), C64e(0xd1877d87ac7d5656),1094C64e(0xcc2b192bd519e7e7), C64e(0x13a662a67162b5b5),1095C64e(0x7c31e6319ae64d4d), C64e(0x59b59ab5c39aecec),1096C64e(0x40cf45cf05458f8f), C64e(0xa3bc9dbc3e9d1f1f),1097C64e(0x49c040c009408989), C64e(0x68928792ef87fafa),1098C64e(0xd03f153fc515efef), C64e(0x9426eb267febb2b2),1099C64e(0xce40c94007c98e8e), C64e(0xe61d0b1ded0bfbfb),1100C64e(0x6e2fec2f82ec4141), C64e(0x1aa967a97d67b3b3),1101C64e(0x431cfd1cbefd5f5f), C64e(0x6025ea258aea4545),1102C64e(0xf9dabfda46bf2323), C64e(0x5102f702a6f75353),1103C64e(0x45a196a1d396e4e4), C64e(0x76ed5bed2d5b9b9b),1104C64e(0x285dc25deac27575), C64e(0xc5241c24d91ce1e1),1105C64e(0xd4e9aee97aae3d3d), C64e(0xf2be6abe986a4c4c),1106C64e(0x82ee5aeed85a6c6c), C64e(0xbdc341c3fc417e7e),1107C64e(0xf3060206f102f5f5), C64e(0x52d14fd11d4f8383),1108C64e(0x8ce45ce4d05c6868), C64e(0x5607f407a2f45151),1109C64e(0x8d5c345cb934d1d1), C64e(0xe1180818e908f9f9),1110C64e(0x4cae93aedf93e2e2), C64e(0x3e9573954d73abab),1111C64e(0x97f553f5c4536262), C64e(0x6b413f41543f2a2a),1112C64e(0x1c140c14100c0808), C64e(0x63f652f631529595),1113C64e(0xe9af65af8c654646), C64e(0x7fe25ee2215e9d9d),1114C64e(0x4878287860283030), C64e(0xcff8a1f86ea13737),1115C64e(0x1b110f11140f0a0a), C64e(0xebc4b5c45eb52f2f),1116C64e(0x151b091b1c090e0e), C64e(0x7e5a365a48362424),1117C64e(0xadb69bb6369b1b1b), C64e(0x98473d47a53ddfdf),1118C64e(0xa76a266a8126cdcd), C64e(0xf5bb69bb9c694e4e),1119C64e(0x334ccd4cfecd7f7f), C64e(0x50ba9fbacf9feaea),1120C64e(0x3f2d1b2d241b1212), C64e(0xa4b99eb93a9e1d1d),1121C64e(0xc49c749cb0745858), C64e(0x46722e72682e3434),1122C64e(0x41772d776c2d3636), C64e(0x11cdb2cda3b2dcdc),1123C64e(0x9d29ee2973eeb4b4), C64e(0x4d16fb16b6fb5b5b),1124C64e(0xa501f60153f6a4a4), C64e(0xa1d74dd7ec4d7676),1125C64e(0x14a361a37561b7b7), C64e(0x3449ce49face7d7d),1126C64e(0xdf8d7b8da47b5252), C64e(0x9f423e42a13edddd),1127C64e(0xcd937193bc715e5e), C64e(0xb1a297a226971313),1128C64e(0xa204f50457f5a6a6), C64e(0x01b868b86968b9b9),1129C64e(0x0000000000000000), C64e(0xb5742c74992cc1c1),1130C64e(0xe0a060a080604040), C64e(0xc2211f21dd1fe3e3),1131C64e(0x3a43c843f2c87979), C64e(0x9a2ced2c77edb6b6),1132C64e(0x0dd9bed9b3bed4d4), C64e(0x47ca46ca01468d8d),1133C64e(0x1770d970ced96767), C64e(0xafdd4bdde44b7272),1134C64e(0xed79de7933de9494), C64e(0xff67d4672bd49898),1135C64e(0x9323e8237be8b0b0), C64e(0x5bde4ade114a8585),1136C64e(0x06bd6bbd6d6bbbbb), C64e(0xbb7e2a7e912ac5c5),1137C64e(0x7b34e5349ee54f4f), C64e(0xd73a163ac116eded),1138C64e(0xd254c55417c58686), C64e(0xf862d7622fd79a9a),1139C64e(0x99ff55ffcc556666), C64e(0xb6a794a722941111),1140C64e(0xc04acf4a0fcf8a8a), C64e(0xd9301030c910e9e9),1141C64e(0x0e0a060a08060404), C64e(0x66988198e781fefe),1142C64e(0xab0bf00b5bf0a0a0), C64e(0xb4cc44ccf0447878),1143C64e(0xf0d5bad54aba2525), C64e(0x753ee33e96e34b4b),1144C64e(0xac0ef30e5ff3a2a2), C64e(0x4419fe19bafe5d5d),1145C64e(0xdb5bc05b1bc08080), C64e(0x80858a850a8a0505),1146C64e(0xd3ecadec7ead3f3f), C64e(0xfedfbcdf42bc2121),1147C64e(0xa8d848d8e0487070), C64e(0xfd0c040cf904f1f1),1148C64e(0x197adf7ac6df6363), C64e(0x2f58c158eec17777),1149C64e(0x309f759f4575afaf), C64e(0xe7a563a584634242),1150C64e(0x7050305040302020), C64e(0xcb2e1a2ed11ae5e5),1151C64e(0xef120e12e10efdfd), C64e(0x08b76db7656dbfbf),1152C64e(0x55d44cd4194c8181), C64e(0x243c143c30141818),1153C64e(0x795f355f4c352626), C64e(0xb2712f719d2fc3c3),1154C64e(0x8638e13867e1bebe), C64e(0xc8fda2fd6aa23535),1155C64e(0xc74fcc4f0bcc8888), C64e(0x654b394b5c392e2e),1156C64e(0x6af957f93d579393), C64e(0x580df20daaf25555),1157C64e(0x619d829de382fcfc), C64e(0xb3c947c9f4477a7a),1158C64e(0x27efacef8bacc8c8), C64e(0x8832e7326fe7baba),1159C64e(0x4f7d2b7d642b3232), C64e(0x42a495a4d795e6e6),1160C64e(0x3bfba0fb9ba0c0c0), C64e(0xaab398b332981919),1161C64e(0xf668d16827d19e9e), C64e(0x22817f815d7fa3a3),1162C64e(0xeeaa66aa88664444), C64e(0xd6827e82a87e5454),1163C64e(0xdde6abe676ab3b3b), C64e(0x959e839e16830b0b),1164C64e(0xc945ca4503ca8c8c), C64e(0xbc7b297b9529c7c7),1165C64e(0x056ed36ed6d36b6b), C64e(0x6c443c44503c2828),1166C64e(0x2c8b798b5579a7a7), C64e(0x813de23d63e2bcbc),1167C64e(0x31271d272c1d1616), C64e(0x379a769a4176adad),1168C64e(0x964d3b4dad3bdbdb), C64e(0x9efa56fac8566464),1169C64e(0xa6d24ed2e84e7474), C64e(0x36221e22281e1414),1170C64e(0xe476db763fdb9292), C64e(0x121e0a1e180a0c0c),1171C64e(0xfcb46cb4906c4848), C64e(0x8f37e4376be4b8b8),1172C64e(0x78e75de7255d9f9f), C64e(0x0fb26eb2616ebdbd),1173C64e(0x692aef2a86ef4343), C64e(0x35f1a6f193a6c4c4),1174C64e(0xdae3a8e372a83939), C64e(0xc6f7a4f762a43131),1175C64e(0x8a593759bd37d3d3), C64e(0x74868b86ff8bf2f2),1176C64e(0x83563256b132d5d5), C64e(0x4ec543c50d438b8b),1177C64e(0x85eb59ebdc596e6e), C64e(0x18c2b7c2afb7dada),1178C64e(0x8e8f8c8f028c0101), C64e(0x1dac64ac7964b1b1),1179C64e(0xf16dd26d23d29c9c), C64e(0x723be03b92e04949),1180C64e(0x1fc7b4c7abb4d8d8), C64e(0xb915fa1543faacac),1181C64e(0xfa090709fd07f3f3), C64e(0xa06f256f8525cfcf),1182C64e(0x20eaafea8fafcaca), C64e(0x7d898e89f38ef4f4),1183C64e(0x6720e9208ee94747), C64e(0x3828182820181010),1184C64e(0x0b64d564ded56f6f), C64e(0x73838883fb88f0f0),1185C64e(0xfbb16fb1946f4a4a), C64e(0xca967296b8725c5c),1186C64e(0x546c246c70243838), C64e(0x5f08f108aef15757),1187C64e(0x2152c752e6c77373), C64e(0x64f351f335519797),1188C64e(0xae6523658d23cbcb), C64e(0x25847c84597ca1a1),1189C64e(0x57bf9cbfcb9ce8e8), C64e(0x5d6321637c213e3e),1190C64e(0xea7cdd7c37dd9696), C64e(0x1e7fdc7fc2dc6161),1191C64e(0x9c9186911a860d0d), C64e(0x9b9485941e850f0f),1192C64e(0x4bab90abdb90e0e0), C64e(0xbac642c6f8427c7c),1193C64e(0x2657c457e2c47171), C64e(0x29e5aae583aacccc),1194C64e(0xe373d8733bd89090), C64e(0x090f050f0c050606),1195C64e(0xf4030103f501f7f7), C64e(0x2a36123638121c1c),1196C64e(0x3cfea3fe9fa3c2c2), C64e(0x8be15fe1d45f6a6a),1197C64e(0xbe10f91047f9aeae), C64e(0x026bd06bd2d06969),1198C64e(0xbfa891a82e911717), C64e(0x71e858e829589999),1199C64e(0x5369276974273a3a), C64e(0xf7d0b9d04eb92727),1200C64e(0x91483848a938d9d9), C64e(0xde351335cd13ebeb),1201C64e(0xe5ceb3ce56b32b2b), C64e(0x7755335544332222),1202C64e(0x04d6bbd6bfbbd2d2), C64e(0x399070904970a9a9),1203C64e(0x878089800e890707), C64e(0xc1f2a7f266a73333),1204C64e(0xecc1b6c15ab62d2d), C64e(0x5a66226678223c3c),1205C64e(0xb8ad92ad2a921515), C64e(0xa96020608920c9c9),1206C64e(0x5cdb49db15498787), C64e(0xb01aff1a4fffaaaa),1207C64e(0xd8887888a0785050), C64e(0x2b8e7a8e517aa5a5),1208C64e(0x898a8f8a068f0303), C64e(0x4a13f813b2f85959),1209C64e(0x929b809b12800909), C64e(0x2339173934171a1a),1210C64e(0x1075da75cada6565), C64e(0x84533153b531d7d7),1211C64e(0xd551c65113c68484), C64e(0x03d3b8d3bbb8d0d0),1212C64e(0xdc5ec35e1fc38282), C64e(0xe2cbb0cb52b02929),1213C64e(0xc3997799b4775a5a), C64e(0x2d3311333c111e1e),1214C64e(0x3d46cb46f6cb7b7b), C64e(0xb71ffc1f4bfca8a8),1215C64e(0x0c61d661dad66d6d), C64e(0x624e3a4e583a2c2c)1216};12171218#endif12191220#define DECL_STATE_SMALL \1221sph_u64 H[8];12221223#define READ_STATE_SMALL(sc) do { \1224memcpy(H, (sc)->state.wide, sizeof H); \1225} while (0)12261227#define WRITE_STATE_SMALL(sc) do { \1228memcpy((sc)->state.wide, H, sizeof H); \1229} while (0)12301231#if SPH_SMALL_FOOTPRINT_GROESTL12321233#define RSTT(d, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \1234t[d] = T0[B64_0(a[b0])] \1235^ R64(T0[B64_1(a[b1])], 8) \1236^ R64(T0[B64_2(a[b2])], 16) \1237^ R64(T0[B64_3(a[b3])], 24) \1238^ T4[B64_4(a[b4])] \1239^ R64(T4[B64_5(a[b5])], 8) \1240^ R64(T4[B64_6(a[b6])], 16) \1241^ R64(T4[B64_7(a[b7])], 24); \1242} while (0)12431244#else12451246#define RSTT(d, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \1247t[d] = T0[B64_0(a[b0])] \1248^ T1[B64_1(a[b1])] \1249^ T2[B64_2(a[b2])] \1250^ T3[B64_3(a[b3])] \1251^ T4[B64_4(a[b4])] \1252^ T5[B64_5(a[b5])] \1253^ T6[B64_6(a[b6])] \1254^ T7[B64_7(a[b7])]; \1255} while (0)12561257#endif12581259#define ROUND_SMALL_P(a, r) do { \1260sph_u64 t[8]; \1261a[0] ^= PC64(0x00, r); \1262a[1] ^= PC64(0x10, r); \1263a[2] ^= PC64(0x20, r); \1264a[3] ^= PC64(0x30, r); \1265a[4] ^= PC64(0x40, r); \1266a[5] ^= PC64(0x50, r); \1267a[6] ^= PC64(0x60, r); \1268a[7] ^= PC64(0x70, r); \1269RSTT(0, a, 0, 1, 2, 3, 4, 5, 6, 7); \1270RSTT(1, a, 1, 2, 3, 4, 5, 6, 7, 0); \1271RSTT(2, a, 2, 3, 4, 5, 6, 7, 0, 1); \1272RSTT(3, a, 3, 4, 5, 6, 7, 0, 1, 2); \1273RSTT(4, a, 4, 5, 6, 7, 0, 1, 2, 3); \1274RSTT(5, a, 5, 6, 7, 0, 1, 2, 3, 4); \1275RSTT(6, a, 6, 7, 0, 1, 2, 3, 4, 5); \1276RSTT(7, a, 7, 0, 1, 2, 3, 4, 5, 6); \1277a[0] = t[0]; \1278a[1] = t[1]; \1279a[2] = t[2]; \1280a[3] = t[3]; \1281a[4] = t[4]; \1282a[5] = t[5]; \1283a[6] = t[6]; \1284a[7] = t[7]; \1285} while (0)12861287#define ROUND_SMALL_Q(a, r) do { \1288sph_u64 t[8]; \1289a[0] ^= QC64(0x00, r); \1290a[1] ^= QC64(0x10, r); \1291a[2] ^= QC64(0x20, r); \1292a[3] ^= QC64(0x30, r); \1293a[4] ^= QC64(0x40, r); \1294a[5] ^= QC64(0x50, r); \1295a[6] ^= QC64(0x60, r); \1296a[7] ^= QC64(0x70, r); \1297RSTT(0, a, 1, 3, 5, 7, 0, 2, 4, 6); \1298RSTT(1, a, 2, 4, 6, 0, 1, 3, 5, 7); \1299RSTT(2, a, 3, 5, 7, 1, 2, 4, 6, 0); \1300RSTT(3, a, 4, 6, 0, 2, 3, 5, 7, 1); \1301RSTT(4, a, 5, 7, 1, 3, 4, 6, 0, 2); \1302RSTT(5, a, 6, 0, 2, 4, 5, 7, 1, 3); \1303RSTT(6, a, 7, 1, 3, 5, 6, 0, 2, 4); \1304RSTT(7, a, 0, 2, 4, 6, 7, 1, 3, 5); \1305a[0] = t[0]; \1306a[1] = t[1]; \1307a[2] = t[2]; \1308a[3] = t[3]; \1309a[4] = t[4]; \1310a[5] = t[5]; \1311a[6] = t[6]; \1312a[7] = t[7]; \1313} while (0)13141315#if SPH_SMALL_FOOTPRINT_GROESTL13161317#define PERM_SMALL_P(a) do { \1318int r; \1319for (r = 0; r < 10; r ++) \1320ROUND_SMALL_P(a, r); \1321} while (0)13221323#define PERM_SMALL_Q(a) do { \1324int r; \1325for (r = 0; r < 10; r ++) \1326ROUND_SMALL_Q(a, r); \1327} while (0)13281329#else13301331/*1332* Apparently, unrolling more than that confuses GCC, resulting in1333* lower performance, even though L1 cache would be no problem.1334*/1335#define PERM_SMALL_P(a) do { \1336int r; \1337for (r = 0; r < 10; r += 2) { \1338ROUND_SMALL_P(a, r + 0); \1339ROUND_SMALL_P(a, r + 1); \1340} \1341} while (0)13421343#define PERM_SMALL_Q(a) do { \1344int r; \1345for (r = 0; r < 10; r += 2) { \1346ROUND_SMALL_Q(a, r + 0); \1347ROUND_SMALL_Q(a, r + 1); \1348} \1349} while (0)13501351#endif13521353#define COMPRESS_SMALL do { \1354sph_u64 g[8], m[8]; \1355size_t u; \1356for (u = 0; u < 8; u ++) { \1357m[u] = dec64e_aligned(buf + (u << 3)); \1358g[u] = m[u] ^ H[u]; \1359} \1360PERM_SMALL_P(g); \1361PERM_SMALL_Q(m); \1362for (u = 0; u < 8; u ++) \1363H[u] ^= g[u] ^ m[u]; \1364} while (0)13651366#define FINAL_SMALL do { \1367sph_u64 x[8]; \1368size_t u; \1369memcpy(x, H, sizeof x); \1370PERM_SMALL_P(x); \1371for (u = 0; u < 8; u ++) \1372H[u] ^= x[u]; \1373} while (0)13741375#define DECL_STATE_BIG \1376sph_u64 H[16];13771378#define READ_STATE_BIG(sc) do { \1379memcpy(H, (sc)->state.wide, sizeof H); \1380} while (0)13811382#define WRITE_STATE_BIG(sc) do { \1383memcpy((sc)->state.wide, H, sizeof H); \1384} while (0)13851386#if SPH_SMALL_FOOTPRINT_GROESTL13871388#define RBTT(d, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \1389t[d] = T0[B64_0(a[b0])] \1390^ R64(T0[B64_1(a[b1])], 8) \1391^ R64(T0[B64_2(a[b2])], 16) \1392^ R64(T0[B64_3(a[b3])], 24) \1393^ T4[B64_4(a[b4])] \1394^ R64(T4[B64_5(a[b5])], 8) \1395^ R64(T4[B64_6(a[b6])], 16) \1396^ R64(T4[B64_7(a[b7])], 24); \1397} while (0)13981399#else14001401#define RBTT(d, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \1402t[d] = T0[B64_0(a[b0])] \1403^ T1[B64_1(a[b1])] \1404^ T2[B64_2(a[b2])] \1405^ T3[B64_3(a[b3])] \1406^ T4[B64_4(a[b4])] \1407^ T5[B64_5(a[b5])] \1408^ T6[B64_6(a[b6])] \1409^ T7[B64_7(a[b7])]; \1410} while (0)14111412#endif14131414#if SPH_SMALL_FOOTPRINT_GROESTL14151416#define ROUND_BIG_P(a, r) do { \1417sph_u64 t[16]; \1418size_t u; \1419a[0x0] ^= PC64(0x00, r); \1420a[0x1] ^= PC64(0x10, r); \1421a[0x2] ^= PC64(0x20, r); \1422a[0x3] ^= PC64(0x30, r); \1423a[0x4] ^= PC64(0x40, r); \1424a[0x5] ^= PC64(0x50, r); \1425a[0x6] ^= PC64(0x60, r); \1426a[0x7] ^= PC64(0x70, r); \1427a[0x8] ^= PC64(0x80, r); \1428a[0x9] ^= PC64(0x90, r); \1429a[0xA] ^= PC64(0xA0, r); \1430a[0xB] ^= PC64(0xB0, r); \1431a[0xC] ^= PC64(0xC0, r); \1432a[0xD] ^= PC64(0xD0, r); \1433a[0xE] ^= PC64(0xE0, r); \1434a[0xF] ^= PC64(0xF0, r); \1435for (u = 0; u < 16; u += 4) { \1436RBTT(u + 0, a, u + 0, (u + 1) & 0xF, \1437(u + 2) & 0xF, (u + 3) & 0xF, (u + 4) & 0xF, \1438(u + 5) & 0xF, (u + 6) & 0xF, (u + 11) & 0xF); \1439RBTT(u + 1, a, u + 1, (u + 2) & 0xF, \1440(u + 3) & 0xF, (u + 4) & 0xF, (u + 5) & 0xF, \1441(u + 6) & 0xF, (u + 7) & 0xF, (u + 12) & 0xF); \1442RBTT(u + 2, a, u + 2, (u + 3) & 0xF, \1443(u + 4) & 0xF, (u + 5) & 0xF, (u + 6) & 0xF, \1444(u + 7) & 0xF, (u + 8) & 0xF, (u + 13) & 0xF); \1445RBTT(u + 3, a, u + 3, (u + 4) & 0xF, \1446(u + 5) & 0xF, (u + 6) & 0xF, (u + 7) & 0xF, \1447(u + 8) & 0xF, (u + 9) & 0xF, (u + 14) & 0xF); \1448} \1449memcpy(a, t, sizeof t); \1450} while (0)14511452#define ROUND_BIG_Q(a, r) do { \1453sph_u64 t[16]; \1454size_t u; \1455a[0x0] ^= QC64(0x00, r); \1456a[0x1] ^= QC64(0x10, r); \1457a[0x2] ^= QC64(0x20, r); \1458a[0x3] ^= QC64(0x30, r); \1459a[0x4] ^= QC64(0x40, r); \1460a[0x5] ^= QC64(0x50, r); \1461a[0x6] ^= QC64(0x60, r); \1462a[0x7] ^= QC64(0x70, r); \1463a[0x8] ^= QC64(0x80, r); \1464a[0x9] ^= QC64(0x90, r); \1465a[0xA] ^= QC64(0xA0, r); \1466a[0xB] ^= QC64(0xB0, r); \1467a[0xC] ^= QC64(0xC0, r); \1468a[0xD] ^= QC64(0xD0, r); \1469a[0xE] ^= QC64(0xE0, r); \1470a[0xF] ^= QC64(0xF0, r); \1471for (u = 0; u < 16; u += 4) { \1472RBTT(u + 0, a, (u + 1) & 0xF, (u + 3) & 0xF, \1473(u + 5) & 0xF, (u + 11) & 0xF, (u + 0) & 0xF, \1474(u + 2) & 0xF, (u + 4) & 0xF, (u + 6) & 0xF); \1475RBTT(u + 1, a, (u + 2) & 0xF, (u + 4) & 0xF, \1476(u + 6) & 0xF, (u + 12) & 0xF, (u + 1) & 0xF, \1477(u + 3) & 0xF, (u + 5) & 0xF, (u + 7) & 0xF); \1478RBTT(u + 2, a, (u + 3) & 0xF, (u + 5) & 0xF, \1479(u + 7) & 0xF, (u + 13) & 0xF, (u + 2) & 0xF, \1480(u + 4) & 0xF, (u + 6) & 0xF, (u + 8) & 0xF); \1481RBTT(u + 3, a, (u + 4) & 0xF, (u + 6) & 0xF, \1482(u + 8) & 0xF, (u + 14) & 0xF, (u + 3) & 0xF, \1483(u + 5) & 0xF, (u + 7) & 0xF, (u + 9) & 0xF); \1484} \1485memcpy(a, t, sizeof t); \1486} while (0)14871488#else14891490#define ROUND_BIG_P(a, r) do { \1491sph_u64 t[16]; \1492a[0x0] ^= PC64(0x00, r); \1493a[0x1] ^= PC64(0x10, r); \1494a[0x2] ^= PC64(0x20, r); \1495a[0x3] ^= PC64(0x30, r); \1496a[0x4] ^= PC64(0x40, r); \1497a[0x5] ^= PC64(0x50, r); \1498a[0x6] ^= PC64(0x60, r); \1499a[0x7] ^= PC64(0x70, r); \1500a[0x8] ^= PC64(0x80, r); \1501a[0x9] ^= PC64(0x90, r); \1502a[0xA] ^= PC64(0xA0, r); \1503a[0xB] ^= PC64(0xB0, r); \1504a[0xC] ^= PC64(0xC0, r); \1505a[0xD] ^= PC64(0xD0, r); \1506a[0xE] ^= PC64(0xE0, r); \1507a[0xF] ^= PC64(0xF0, r); \1508RBTT(0x0, a, 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0xB); \1509RBTT(0x1, a, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0xC); \1510RBTT(0x2, a, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0xD); \1511RBTT(0x3, a, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xE); \1512RBTT(0x4, a, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xA, 0xF); \1513RBTT(0x5, a, 0x5, 0x6, 0x7, 0x8, 0x9, 0xA, 0xB, 0x0); \1514RBTT(0x6, a, 0x6, 0x7, 0x8, 0x9, 0xA, 0xB, 0xC, 0x1); \1515RBTT(0x7, a, 0x7, 0x8, 0x9, 0xA, 0xB, 0xC, 0xD, 0x2); \1516RBTT(0x8, a, 0x8, 0x9, 0xA, 0xB, 0xC, 0xD, 0xE, 0x3); \1517RBTT(0x9, a, 0x9, 0xA, 0xB, 0xC, 0xD, 0xE, 0xF, 0x4); \1518RBTT(0xA, a, 0xA, 0xB, 0xC, 0xD, 0xE, 0xF, 0x0, 0x5); \1519RBTT(0xB, a, 0xB, 0xC, 0xD, 0xE, 0xF, 0x0, 0x1, 0x6); \1520RBTT(0xC, a, 0xC, 0xD, 0xE, 0xF, 0x0, 0x1, 0x2, 0x7); \1521RBTT(0xD, a, 0xD, 0xE, 0xF, 0x0, 0x1, 0x2, 0x3, 0x8); \1522RBTT(0xE, a, 0xE, 0xF, 0x0, 0x1, 0x2, 0x3, 0x4, 0x9); \1523RBTT(0xF, a, 0xF, 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0xA); \1524a[0x0] = t[0x0]; \1525a[0x1] = t[0x1]; \1526a[0x2] = t[0x2]; \1527a[0x3] = t[0x3]; \1528a[0x4] = t[0x4]; \1529a[0x5] = t[0x5]; \1530a[0x6] = t[0x6]; \1531a[0x7] = t[0x7]; \1532a[0x8] = t[0x8]; \1533a[0x9] = t[0x9]; \1534a[0xA] = t[0xA]; \1535a[0xB] = t[0xB]; \1536a[0xC] = t[0xC]; \1537a[0xD] = t[0xD]; \1538a[0xE] = t[0xE]; \1539a[0xF] = t[0xF]; \1540} while (0)15411542#define ROUND_BIG_Q(a, r) do { \1543sph_u64 t[16]; \1544a[0x0] ^= QC64(0x00, r); \1545a[0x1] ^= QC64(0x10, r); \1546a[0x2] ^= QC64(0x20, r); \1547a[0x3] ^= QC64(0x30, r); \1548a[0x4] ^= QC64(0x40, r); \1549a[0x5] ^= QC64(0x50, r); \1550a[0x6] ^= QC64(0x60, r); \1551a[0x7] ^= QC64(0x70, r); \1552a[0x8] ^= QC64(0x80, r); \1553a[0x9] ^= QC64(0x90, r); \1554a[0xA] ^= QC64(0xA0, r); \1555a[0xB] ^= QC64(0xB0, r); \1556a[0xC] ^= QC64(0xC0, r); \1557a[0xD] ^= QC64(0xD0, r); \1558a[0xE] ^= QC64(0xE0, r); \1559a[0xF] ^= QC64(0xF0, r); \1560RBTT(0x0, a, 0x1, 0x3, 0x5, 0xB, 0x0, 0x2, 0x4, 0x6); \1561RBTT(0x1, a, 0x2, 0x4, 0x6, 0xC, 0x1, 0x3, 0x5, 0x7); \1562RBTT(0x2, a, 0x3, 0x5, 0x7, 0xD, 0x2, 0x4, 0x6, 0x8); \1563RBTT(0x3, a, 0x4, 0x6, 0x8, 0xE, 0x3, 0x5, 0x7, 0x9); \1564RBTT(0x4, a, 0x5, 0x7, 0x9, 0xF, 0x4, 0x6, 0x8, 0xA); \1565RBTT(0x5, a, 0x6, 0x8, 0xA, 0x0, 0x5, 0x7, 0x9, 0xB); \1566RBTT(0x6, a, 0x7, 0x9, 0xB, 0x1, 0x6, 0x8, 0xA, 0xC); \1567RBTT(0x7, a, 0x8, 0xA, 0xC, 0x2, 0x7, 0x9, 0xB, 0xD); \1568RBTT(0x8, a, 0x9, 0xB, 0xD, 0x3, 0x8, 0xA, 0xC, 0xE); \1569RBTT(0x9, a, 0xA, 0xC, 0xE, 0x4, 0x9, 0xB, 0xD, 0xF); \1570RBTT(0xA, a, 0xB, 0xD, 0xF, 0x5, 0xA, 0xC, 0xE, 0x0); \1571RBTT(0xB, a, 0xC, 0xE, 0x0, 0x6, 0xB, 0xD, 0xF, 0x1); \1572RBTT(0xC, a, 0xD, 0xF, 0x1, 0x7, 0xC, 0xE, 0x0, 0x2); \1573RBTT(0xD, a, 0xE, 0x0, 0x2, 0x8, 0xD, 0xF, 0x1, 0x3); \1574RBTT(0xE, a, 0xF, 0x1, 0x3, 0x9, 0xE, 0x0, 0x2, 0x4); \1575RBTT(0xF, a, 0x0, 0x2, 0x4, 0xA, 0xF, 0x1, 0x3, 0x5); \1576a[0x0] = t[0x0]; \1577a[0x1] = t[0x1]; \1578a[0x2] = t[0x2]; \1579a[0x3] = t[0x3]; \1580a[0x4] = t[0x4]; \1581a[0x5] = t[0x5]; \1582a[0x6] = t[0x6]; \1583a[0x7] = t[0x7]; \1584a[0x8] = t[0x8]; \1585a[0x9] = t[0x9]; \1586a[0xA] = t[0xA]; \1587a[0xB] = t[0xB]; \1588a[0xC] = t[0xC]; \1589a[0xD] = t[0xD]; \1590a[0xE] = t[0xE]; \1591a[0xF] = t[0xF]; \1592} while (0)15931594#endif15951596#define PERM_BIG_P(a) do { \1597int r; \1598for (r = 0; r < 14; r += 2) { \1599ROUND_BIG_P(a, r + 0); \1600ROUND_BIG_P(a, r + 1); \1601} \1602} while (0)16031604#define PERM_BIG_Q(a) do { \1605int r; \1606for (r = 0; r < 14; r += 2) { \1607ROUND_BIG_Q(a, r + 0); \1608ROUND_BIG_Q(a, r + 1); \1609} \1610} while (0)16111612/* obsolete1613#if SPH_SMALL_FOOTPRINT_GROESTL16141615#define COMPRESS_BIG do { \1616sph_u64 g[16], m[16], *ya; \1617const sph_u64 *yc; \1618size_t u; \1619int i; \1620for (u = 0; u < 16; u ++) { \1621m[u] = dec64e_aligned(buf + (u << 3)); \1622g[u] = m[u] ^ H[u]; \1623} \1624ya = g; \1625yc = CP; \1626for (i = 0; i < 2; i ++) { \1627PERM_BIG(ya, yc); \1628ya = m; \1629yc = CQ; \1630} \1631for (u = 0; u < 16; u ++) { \1632H[u] ^= g[u] ^ m[u]; \1633} \1634} while (0)16351636#else1637*/16381639#define COMPRESS_BIG do { \1640sph_u64 g[16], m[16]; \1641size_t u; \1642for (u = 0; u < 16; u ++) { \1643m[u] = dec64e_aligned(buf + (u << 3)); \1644g[u] = m[u] ^ H[u]; \1645} \1646PERM_BIG_P(g); \1647PERM_BIG_Q(m); \1648for (u = 0; u < 16; u ++) { \1649H[u] ^= g[u] ^ m[u]; \1650} \1651} while (0)16521653/* obsolete1654#endif1655*/16561657#define FINAL_BIG do { \1658sph_u64 x[16]; \1659size_t u; \1660memcpy(x, H, sizeof x); \1661PERM_BIG_P(x); \1662for (u = 0; u < 16; u ++) \1663H[u] ^= x[u]; \1664} while (0)16651666#else16671668static const sph_u32 T0up[] = {1669C32e(0xc632f4a5), C32e(0xf86f9784), C32e(0xee5eb099), C32e(0xf67a8c8d),1670C32e(0xffe8170d), C32e(0xd60adcbd), C32e(0xde16c8b1), C32e(0x916dfc54),1671C32e(0x6090f050), C32e(0x02070503), C32e(0xce2ee0a9), C32e(0x56d1877d),1672C32e(0xe7cc2b19), C32e(0xb513a662), C32e(0x4d7c31e6), C32e(0xec59b59a),1673C32e(0x8f40cf45), C32e(0x1fa3bc9d), C32e(0x8949c040), C32e(0xfa689287),1674C32e(0xefd03f15), C32e(0xb29426eb), C32e(0x8ece40c9), C32e(0xfbe61d0b),1675C32e(0x416e2fec), C32e(0xb31aa967), C32e(0x5f431cfd), C32e(0x456025ea),1676C32e(0x23f9dabf), C32e(0x535102f7), C32e(0xe445a196), C32e(0x9b76ed5b),1677C32e(0x75285dc2), C32e(0xe1c5241c), C32e(0x3dd4e9ae), C32e(0x4cf2be6a),1678C32e(0x6c82ee5a), C32e(0x7ebdc341), C32e(0xf5f30602), C32e(0x8352d14f),1679C32e(0x688ce45c), C32e(0x515607f4), C32e(0xd18d5c34), C32e(0xf9e11808),1680C32e(0xe24cae93), C32e(0xab3e9573), C32e(0x6297f553), C32e(0x2a6b413f),1681C32e(0x081c140c), C32e(0x9563f652), C32e(0x46e9af65), C32e(0x9d7fe25e),1682C32e(0x30487828), C32e(0x37cff8a1), C32e(0x0a1b110f), C32e(0x2febc4b5),1683C32e(0x0e151b09), C32e(0x247e5a36), C32e(0x1badb69b), C32e(0xdf98473d),1684C32e(0xcda76a26), C32e(0x4ef5bb69), C32e(0x7f334ccd), C32e(0xea50ba9f),1685C32e(0x123f2d1b), C32e(0x1da4b99e), C32e(0x58c49c74), C32e(0x3446722e),1686C32e(0x3641772d), C32e(0xdc11cdb2), C32e(0xb49d29ee), C32e(0x5b4d16fb),1687C32e(0xa4a501f6), C32e(0x76a1d74d), C32e(0xb714a361), C32e(0x7d3449ce),1688C32e(0x52df8d7b), C32e(0xdd9f423e), C32e(0x5ecd9371), C32e(0x13b1a297),1689C32e(0xa6a204f5), C32e(0xb901b868), C32e(0x00000000), C32e(0xc1b5742c),1690C32e(0x40e0a060), C32e(0xe3c2211f), C32e(0x793a43c8), C32e(0xb69a2ced),1691C32e(0xd40dd9be), C32e(0x8d47ca46), C32e(0x671770d9), C32e(0x72afdd4b),1692C32e(0x94ed79de), C32e(0x98ff67d4), C32e(0xb09323e8), C32e(0x855bde4a),1693C32e(0xbb06bd6b), C32e(0xc5bb7e2a), C32e(0x4f7b34e5), C32e(0xedd73a16),1694C32e(0x86d254c5), C32e(0x9af862d7), C32e(0x6699ff55), C32e(0x11b6a794),1695C32e(0x8ac04acf), C32e(0xe9d93010), C32e(0x040e0a06), C32e(0xfe669881),1696C32e(0xa0ab0bf0), C32e(0x78b4cc44), C32e(0x25f0d5ba), C32e(0x4b753ee3),1697C32e(0xa2ac0ef3), C32e(0x5d4419fe), C32e(0x80db5bc0), C32e(0x0580858a),1698C32e(0x3fd3ecad), C32e(0x21fedfbc), C32e(0x70a8d848), C32e(0xf1fd0c04),1699C32e(0x63197adf), C32e(0x772f58c1), C32e(0xaf309f75), C32e(0x42e7a563),1700C32e(0x20705030), C32e(0xe5cb2e1a), C32e(0xfdef120e), C32e(0xbf08b76d),1701C32e(0x8155d44c), C32e(0x18243c14), C32e(0x26795f35), C32e(0xc3b2712f),1702C32e(0xbe8638e1), C32e(0x35c8fda2), C32e(0x88c74fcc), C32e(0x2e654b39),1703C32e(0x936af957), C32e(0x55580df2), C32e(0xfc619d82), C32e(0x7ab3c947),1704C32e(0xc827efac), C32e(0xba8832e7), C32e(0x324f7d2b), C32e(0xe642a495),1705C32e(0xc03bfba0), C32e(0x19aab398), C32e(0x9ef668d1), C32e(0xa322817f),1706C32e(0x44eeaa66), C32e(0x54d6827e), C32e(0x3bdde6ab), C32e(0x0b959e83),1707C32e(0x8cc945ca), C32e(0xc7bc7b29), C32e(0x6b056ed3), C32e(0x286c443c),1708C32e(0xa72c8b79), C32e(0xbc813de2), C32e(0x1631271d), C32e(0xad379a76),1709C32e(0xdb964d3b), C32e(0x649efa56), C32e(0x74a6d24e), C32e(0x1436221e),1710C32e(0x92e476db), C32e(0x0c121e0a), C32e(0x48fcb46c), C32e(0xb88f37e4),1711C32e(0x9f78e75d), C32e(0xbd0fb26e), C32e(0x43692aef), C32e(0xc435f1a6),1712C32e(0x39dae3a8), C32e(0x31c6f7a4), C32e(0xd38a5937), C32e(0xf274868b),1713C32e(0xd5835632), C32e(0x8b4ec543), C32e(0x6e85eb59), C32e(0xda18c2b7),1714C32e(0x018e8f8c), C32e(0xb11dac64), C32e(0x9cf16dd2), C32e(0x49723be0),1715C32e(0xd81fc7b4), C32e(0xacb915fa), C32e(0xf3fa0907), C32e(0xcfa06f25),1716C32e(0xca20eaaf), C32e(0xf47d898e), C32e(0x476720e9), C32e(0x10382818),1717C32e(0x6f0b64d5), C32e(0xf0738388), C32e(0x4afbb16f), C32e(0x5cca9672),1718C32e(0x38546c24), C32e(0x575f08f1), C32e(0x732152c7), C32e(0x9764f351),1719C32e(0xcbae6523), C32e(0xa125847c), C32e(0xe857bf9c), C32e(0x3e5d6321),1720C32e(0x96ea7cdd), C32e(0x611e7fdc), C32e(0x0d9c9186), C32e(0x0f9b9485),1721C32e(0xe04bab90), C32e(0x7cbac642), C32e(0x712657c4), C32e(0xcc29e5aa),1722C32e(0x90e373d8), C32e(0x06090f05), C32e(0xf7f40301), C32e(0x1c2a3612),1723C32e(0xc23cfea3), C32e(0x6a8be15f), C32e(0xaebe10f9), C32e(0x69026bd0),1724C32e(0x17bfa891), C32e(0x9971e858), C32e(0x3a536927), C32e(0x27f7d0b9),1725C32e(0xd9914838), C32e(0xebde3513), C32e(0x2be5ceb3), C32e(0x22775533),1726C32e(0xd204d6bb), C32e(0xa9399070), C32e(0x07878089), C32e(0x33c1f2a7),1727C32e(0x2decc1b6), C32e(0x3c5a6622), C32e(0x15b8ad92), C32e(0xc9a96020),1728C32e(0x875cdb49), C32e(0xaab01aff), C32e(0x50d88878), C32e(0xa52b8e7a),1729C32e(0x03898a8f), C32e(0x594a13f8), C32e(0x09929b80), C32e(0x1a233917),1730C32e(0x651075da), C32e(0xd7845331), C32e(0x84d551c6), C32e(0xd003d3b8),1731C32e(0x82dc5ec3), C32e(0x29e2cbb0), C32e(0x5ac39977), C32e(0x1e2d3311),1732C32e(0x7b3d46cb), C32e(0xa8b71ffc), C32e(0x6d0c61d6), C32e(0x2c624e3a)1733};17341735static const sph_u32 T0dn[] = {1736C32e(0xf497a5c6), C32e(0x97eb84f8), C32e(0xb0c799ee), C32e(0x8cf78df6),1737C32e(0x17e50dff), C32e(0xdcb7bdd6), C32e(0xc8a7b1de), C32e(0xfc395491),1738C32e(0xf0c05060), C32e(0x05040302), C32e(0xe087a9ce), C32e(0x87ac7d56),1739C32e(0x2bd519e7), C32e(0xa67162b5), C32e(0x319ae64d), C32e(0xb5c39aec),1740C32e(0xcf05458f), C32e(0xbc3e9d1f), C32e(0xc0094089), C32e(0x92ef87fa),1741C32e(0x3fc515ef), C32e(0x267febb2), C32e(0x4007c98e), C32e(0x1ded0bfb),1742C32e(0x2f82ec41), C32e(0xa97d67b3), C32e(0x1cbefd5f), C32e(0x258aea45),1743C32e(0xda46bf23), C32e(0x02a6f753), C32e(0xa1d396e4), C32e(0xed2d5b9b),1744C32e(0x5deac275), C32e(0x24d91ce1), C32e(0xe97aae3d), C32e(0xbe986a4c),1745C32e(0xeed85a6c), C32e(0xc3fc417e), C32e(0x06f102f5), C32e(0xd11d4f83),1746C32e(0xe4d05c68), C32e(0x07a2f451), C32e(0x5cb934d1), C32e(0x18e908f9),1747C32e(0xaedf93e2), C32e(0x954d73ab), C32e(0xf5c45362), C32e(0x41543f2a),1748C32e(0x14100c08), C32e(0xf6315295), C32e(0xaf8c6546), C32e(0xe2215e9d),1749C32e(0x78602830), C32e(0xf86ea137), C32e(0x11140f0a), C32e(0xc45eb52f),1750C32e(0x1b1c090e), C32e(0x5a483624), C32e(0xb6369b1b), C32e(0x47a53ddf),1751C32e(0x6a8126cd), C32e(0xbb9c694e), C32e(0x4cfecd7f), C32e(0xbacf9fea),1752C32e(0x2d241b12), C32e(0xb93a9e1d), C32e(0x9cb07458), C32e(0x72682e34),1753C32e(0x776c2d36), C32e(0xcda3b2dc), C32e(0x2973eeb4), C32e(0x16b6fb5b),1754C32e(0x0153f6a4), C32e(0xd7ec4d76), C32e(0xa37561b7), C32e(0x49face7d),1755C32e(0x8da47b52), C32e(0x42a13edd), C32e(0x93bc715e), C32e(0xa2269713),1756C32e(0x0457f5a6), C32e(0xb86968b9), C32e(0x00000000), C32e(0x74992cc1),1757C32e(0xa0806040), C32e(0x21dd1fe3), C32e(0x43f2c879), C32e(0x2c77edb6),1758C32e(0xd9b3bed4), C32e(0xca01468d), C32e(0x70ced967), C32e(0xdde44b72),1759C32e(0x7933de94), C32e(0x672bd498), C32e(0x237be8b0), C32e(0xde114a85),1760C32e(0xbd6d6bbb), C32e(0x7e912ac5), C32e(0x349ee54f), C32e(0x3ac116ed),1761C32e(0x5417c586), C32e(0x622fd79a), C32e(0xffcc5566), C32e(0xa7229411),1762C32e(0x4a0fcf8a), C32e(0x30c910e9), C32e(0x0a080604), C32e(0x98e781fe),1763C32e(0x0b5bf0a0), C32e(0xccf04478), C32e(0xd54aba25), C32e(0x3e96e34b),1764C32e(0x0e5ff3a2), C32e(0x19bafe5d), C32e(0x5b1bc080), C32e(0x850a8a05),1765C32e(0xec7ead3f), C32e(0xdf42bc21), C32e(0xd8e04870), C32e(0x0cf904f1),1766C32e(0x7ac6df63), C32e(0x58eec177), C32e(0x9f4575af), C32e(0xa5846342),1767C32e(0x50403020), C32e(0x2ed11ae5), C32e(0x12e10efd), C32e(0xb7656dbf),1768C32e(0xd4194c81), C32e(0x3c301418), C32e(0x5f4c3526), C32e(0x719d2fc3),1769C32e(0x3867e1be), C32e(0xfd6aa235), C32e(0x4f0bcc88), C32e(0x4b5c392e),1770C32e(0xf93d5793), C32e(0x0daaf255), C32e(0x9de382fc), C32e(0xc9f4477a),1771C32e(0xef8bacc8), C32e(0x326fe7ba), C32e(0x7d642b32), C32e(0xa4d795e6),1772C32e(0xfb9ba0c0), C32e(0xb3329819), C32e(0x6827d19e), C32e(0x815d7fa3),1773C32e(0xaa886644), C32e(0x82a87e54), C32e(0xe676ab3b), C32e(0x9e16830b),1774C32e(0x4503ca8c), C32e(0x7b9529c7), C32e(0x6ed6d36b), C32e(0x44503c28),1775C32e(0x8b5579a7), C32e(0x3d63e2bc), C32e(0x272c1d16), C32e(0x9a4176ad),1776C32e(0x4dad3bdb), C32e(0xfac85664), C32e(0xd2e84e74), C32e(0x22281e14),1777C32e(0x763fdb92), C32e(0x1e180a0c), C32e(0xb4906c48), C32e(0x376be4b8),1778C32e(0xe7255d9f), C32e(0xb2616ebd), C32e(0x2a86ef43), C32e(0xf193a6c4),1779C32e(0xe372a839), C32e(0xf762a431), C32e(0x59bd37d3), C32e(0x86ff8bf2),1780C32e(0x56b132d5), C32e(0xc50d438b), C32e(0xebdc596e), C32e(0xc2afb7da),1781C32e(0x8f028c01), C32e(0xac7964b1), C32e(0x6d23d29c), C32e(0x3b92e049),1782C32e(0xc7abb4d8), C32e(0x1543faac), C32e(0x09fd07f3), C32e(0x6f8525cf),1783C32e(0xea8fafca), C32e(0x89f38ef4), C32e(0x208ee947), C32e(0x28201810),1784C32e(0x64ded56f), C32e(0x83fb88f0), C32e(0xb1946f4a), C32e(0x96b8725c),1785C32e(0x6c702438), C32e(0x08aef157), C32e(0x52e6c773), C32e(0xf3355197),1786C32e(0x658d23cb), C32e(0x84597ca1), C32e(0xbfcb9ce8), C32e(0x637c213e),1787C32e(0x7c37dd96), C32e(0x7fc2dc61), C32e(0x911a860d), C32e(0x941e850f),1788C32e(0xabdb90e0), C32e(0xc6f8427c), C32e(0x57e2c471), C32e(0xe583aacc),1789C32e(0x733bd890), C32e(0x0f0c0506), C32e(0x03f501f7), C32e(0x3638121c),1790C32e(0xfe9fa3c2), C32e(0xe1d45f6a), C32e(0x1047f9ae), C32e(0x6bd2d069),1791C32e(0xa82e9117), C32e(0xe8295899), C32e(0x6974273a), C32e(0xd04eb927),1792C32e(0x48a938d9), C32e(0x35cd13eb), C32e(0xce56b32b), C32e(0x55443322),1793C32e(0xd6bfbbd2), C32e(0x904970a9), C32e(0x800e8907), C32e(0xf266a733),1794C32e(0xc15ab62d), C32e(0x6678223c), C32e(0xad2a9215), C32e(0x608920c9),1795C32e(0xdb154987), C32e(0x1a4fffaa), C32e(0x88a07850), C32e(0x8e517aa5),1796C32e(0x8a068f03), C32e(0x13b2f859), C32e(0x9b128009), C32e(0x3934171a),1797C32e(0x75cada65), C32e(0x53b531d7), C32e(0x5113c684), C32e(0xd3bbb8d0),1798C32e(0x5e1fc382), C32e(0xcb52b029), C32e(0x99b4775a), C32e(0x333c111e),1799C32e(0x46f6cb7b), C32e(0x1f4bfca8), C32e(0x61dad66d), C32e(0x4e583a2c)1800};18011802static const sph_u32 T1up[] = {1803C32e(0xc6c632f4), C32e(0xf8f86f97), C32e(0xeeee5eb0), C32e(0xf6f67a8c),1804C32e(0xffffe817), C32e(0xd6d60adc), C32e(0xdede16c8), C32e(0x91916dfc),1805C32e(0x606090f0), C32e(0x02020705), C32e(0xcece2ee0), C32e(0x5656d187),1806C32e(0xe7e7cc2b), C32e(0xb5b513a6), C32e(0x4d4d7c31), C32e(0xecec59b5),1807C32e(0x8f8f40cf), C32e(0x1f1fa3bc), C32e(0x898949c0), C32e(0xfafa6892),1808C32e(0xefefd03f), C32e(0xb2b29426), C32e(0x8e8ece40), C32e(0xfbfbe61d),1809C32e(0x41416e2f), C32e(0xb3b31aa9), C32e(0x5f5f431c), C32e(0x45456025),1810C32e(0x2323f9da), C32e(0x53535102), C32e(0xe4e445a1), C32e(0x9b9b76ed),1811C32e(0x7575285d), C32e(0xe1e1c524), C32e(0x3d3dd4e9), C32e(0x4c4cf2be),1812C32e(0x6c6c82ee), C32e(0x7e7ebdc3), C32e(0xf5f5f306), C32e(0x838352d1),1813C32e(0x68688ce4), C32e(0x51515607), C32e(0xd1d18d5c), C32e(0xf9f9e118),1814C32e(0xe2e24cae), C32e(0xabab3e95), C32e(0x626297f5), C32e(0x2a2a6b41),1815C32e(0x08081c14), C32e(0x959563f6), C32e(0x4646e9af), C32e(0x9d9d7fe2),1816C32e(0x30304878), C32e(0x3737cff8), C32e(0x0a0a1b11), C32e(0x2f2febc4),1817C32e(0x0e0e151b), C32e(0x24247e5a), C32e(0x1b1badb6), C32e(0xdfdf9847),1818C32e(0xcdcda76a), C32e(0x4e4ef5bb), C32e(0x7f7f334c), C32e(0xeaea50ba),1819C32e(0x12123f2d), C32e(0x1d1da4b9), C32e(0x5858c49c), C32e(0x34344672),1820C32e(0x36364177), C32e(0xdcdc11cd), C32e(0xb4b49d29), C32e(0x5b5b4d16),1821C32e(0xa4a4a501), C32e(0x7676a1d7), C32e(0xb7b714a3), C32e(0x7d7d3449),1822C32e(0x5252df8d), C32e(0xdddd9f42), C32e(0x5e5ecd93), C32e(0x1313b1a2),1823C32e(0xa6a6a204), C32e(0xb9b901b8), C32e(0x00000000), C32e(0xc1c1b574),1824C32e(0x4040e0a0), C32e(0xe3e3c221), C32e(0x79793a43), C32e(0xb6b69a2c),1825C32e(0xd4d40dd9), C32e(0x8d8d47ca), C32e(0x67671770), C32e(0x7272afdd),1826C32e(0x9494ed79), C32e(0x9898ff67), C32e(0xb0b09323), C32e(0x85855bde),1827C32e(0xbbbb06bd), C32e(0xc5c5bb7e), C32e(0x4f4f7b34), C32e(0xededd73a),1828C32e(0x8686d254), C32e(0x9a9af862), C32e(0x666699ff), C32e(0x1111b6a7),1829C32e(0x8a8ac04a), C32e(0xe9e9d930), C32e(0x04040e0a), C32e(0xfefe6698),1830C32e(0xa0a0ab0b), C32e(0x7878b4cc), C32e(0x2525f0d5), C32e(0x4b4b753e),1831C32e(0xa2a2ac0e), C32e(0x5d5d4419), C32e(0x8080db5b), C32e(0x05058085),1832C32e(0x3f3fd3ec), C32e(0x2121fedf), C32e(0x7070a8d8), C32e(0xf1f1fd0c),1833C32e(0x6363197a), C32e(0x77772f58), C32e(0xafaf309f), C32e(0x4242e7a5),1834C32e(0x20207050), C32e(0xe5e5cb2e), C32e(0xfdfdef12), C32e(0xbfbf08b7),1835C32e(0x818155d4), C32e(0x1818243c), C32e(0x2626795f), C32e(0xc3c3b271),1836C32e(0xbebe8638), C32e(0x3535c8fd), C32e(0x8888c74f), C32e(0x2e2e654b),1837C32e(0x93936af9), C32e(0x5555580d), C32e(0xfcfc619d), C32e(0x7a7ab3c9),1838C32e(0xc8c827ef), C32e(0xbaba8832), C32e(0x32324f7d), C32e(0xe6e642a4),1839C32e(0xc0c03bfb), C32e(0x1919aab3), C32e(0x9e9ef668), C32e(0xa3a32281),1840C32e(0x4444eeaa), C32e(0x5454d682), C32e(0x3b3bdde6), C32e(0x0b0b959e),1841C32e(0x8c8cc945), C32e(0xc7c7bc7b), C32e(0x6b6b056e), C32e(0x28286c44),1842C32e(0xa7a72c8b), C32e(0xbcbc813d), C32e(0x16163127), C32e(0xadad379a),1843C32e(0xdbdb964d), C32e(0x64649efa), C32e(0x7474a6d2), C32e(0x14143622),1844C32e(0x9292e476), C32e(0x0c0c121e), C32e(0x4848fcb4), C32e(0xb8b88f37),1845C32e(0x9f9f78e7), C32e(0xbdbd0fb2), C32e(0x4343692a), C32e(0xc4c435f1),1846C32e(0x3939dae3), C32e(0x3131c6f7), C32e(0xd3d38a59), C32e(0xf2f27486),1847C32e(0xd5d58356), C32e(0x8b8b4ec5), C32e(0x6e6e85eb), C32e(0xdada18c2),1848C32e(0x01018e8f), C32e(0xb1b11dac), C32e(0x9c9cf16d), C32e(0x4949723b),1849C32e(0xd8d81fc7), C32e(0xacacb915), C32e(0xf3f3fa09), C32e(0xcfcfa06f),1850C32e(0xcaca20ea), C32e(0xf4f47d89), C32e(0x47476720), C32e(0x10103828),1851C32e(0x6f6f0b64), C32e(0xf0f07383), C32e(0x4a4afbb1), C32e(0x5c5cca96),1852C32e(0x3838546c), C32e(0x57575f08), C32e(0x73732152), C32e(0x979764f3),1853C32e(0xcbcbae65), C32e(0xa1a12584), C32e(0xe8e857bf), C32e(0x3e3e5d63),1854C32e(0x9696ea7c), C32e(0x61611e7f), C32e(0x0d0d9c91), C32e(0x0f0f9b94),1855C32e(0xe0e04bab), C32e(0x7c7cbac6), C32e(0x71712657), C32e(0xcccc29e5),1856C32e(0x9090e373), C32e(0x0606090f), C32e(0xf7f7f403), C32e(0x1c1c2a36),1857C32e(0xc2c23cfe), C32e(0x6a6a8be1), C32e(0xaeaebe10), C32e(0x6969026b),1858C32e(0x1717bfa8), C32e(0x999971e8), C32e(0x3a3a5369), C32e(0x2727f7d0),1859C32e(0xd9d99148), C32e(0xebebde35), C32e(0x2b2be5ce), C32e(0x22227755),1860C32e(0xd2d204d6), C32e(0xa9a93990), C32e(0x07078780), C32e(0x3333c1f2),1861C32e(0x2d2decc1), C32e(0x3c3c5a66), C32e(0x1515b8ad), C32e(0xc9c9a960),1862C32e(0x87875cdb), C32e(0xaaaab01a), C32e(0x5050d888), C32e(0xa5a52b8e),1863C32e(0x0303898a), C32e(0x59594a13), C32e(0x0909929b), C32e(0x1a1a2339),1864C32e(0x65651075), C32e(0xd7d78453), C32e(0x8484d551), C32e(0xd0d003d3),1865C32e(0x8282dc5e), C32e(0x2929e2cb), C32e(0x5a5ac399), C32e(0x1e1e2d33),1866C32e(0x7b7b3d46), C32e(0xa8a8b71f), C32e(0x6d6d0c61), C32e(0x2c2c624e)1867};18681869static const sph_u32 T1dn[] = {1870C32e(0xa5f497a5), C32e(0x8497eb84), C32e(0x99b0c799), C32e(0x8d8cf78d),1871C32e(0x0d17e50d), C32e(0xbddcb7bd), C32e(0xb1c8a7b1), C32e(0x54fc3954),1872C32e(0x50f0c050), C32e(0x03050403), C32e(0xa9e087a9), C32e(0x7d87ac7d),1873C32e(0x192bd519), C32e(0x62a67162), C32e(0xe6319ae6), C32e(0x9ab5c39a),1874C32e(0x45cf0545), C32e(0x9dbc3e9d), C32e(0x40c00940), C32e(0x8792ef87),1875C32e(0x153fc515), C32e(0xeb267feb), C32e(0xc94007c9), C32e(0x0b1ded0b),1876C32e(0xec2f82ec), C32e(0x67a97d67), C32e(0xfd1cbefd), C32e(0xea258aea),1877C32e(0xbfda46bf), C32e(0xf702a6f7), C32e(0x96a1d396), C32e(0x5bed2d5b),1878C32e(0xc25deac2), C32e(0x1c24d91c), C32e(0xaee97aae), C32e(0x6abe986a),1879C32e(0x5aeed85a), C32e(0x41c3fc41), C32e(0x0206f102), C32e(0x4fd11d4f),1880C32e(0x5ce4d05c), C32e(0xf407a2f4), C32e(0x345cb934), C32e(0x0818e908),1881C32e(0x93aedf93), C32e(0x73954d73), C32e(0x53f5c453), C32e(0x3f41543f),1882C32e(0x0c14100c), C32e(0x52f63152), C32e(0x65af8c65), C32e(0x5ee2215e),1883C32e(0x28786028), C32e(0xa1f86ea1), C32e(0x0f11140f), C32e(0xb5c45eb5),1884C32e(0x091b1c09), C32e(0x365a4836), C32e(0x9bb6369b), C32e(0x3d47a53d),1885C32e(0x266a8126), C32e(0x69bb9c69), C32e(0xcd4cfecd), C32e(0x9fbacf9f),1886C32e(0x1b2d241b), C32e(0x9eb93a9e), C32e(0x749cb074), C32e(0x2e72682e),1887C32e(0x2d776c2d), C32e(0xb2cda3b2), C32e(0xee2973ee), C32e(0xfb16b6fb),1888C32e(0xf60153f6), C32e(0x4dd7ec4d), C32e(0x61a37561), C32e(0xce49face),1889C32e(0x7b8da47b), C32e(0x3e42a13e), C32e(0x7193bc71), C32e(0x97a22697),1890C32e(0xf50457f5), C32e(0x68b86968), C32e(0x00000000), C32e(0x2c74992c),1891C32e(0x60a08060), C32e(0x1f21dd1f), C32e(0xc843f2c8), C32e(0xed2c77ed),1892C32e(0xbed9b3be), C32e(0x46ca0146), C32e(0xd970ced9), C32e(0x4bdde44b),1893C32e(0xde7933de), C32e(0xd4672bd4), C32e(0xe8237be8), C32e(0x4ade114a),1894C32e(0x6bbd6d6b), C32e(0x2a7e912a), C32e(0xe5349ee5), C32e(0x163ac116),1895C32e(0xc55417c5), C32e(0xd7622fd7), C32e(0x55ffcc55), C32e(0x94a72294),1896C32e(0xcf4a0fcf), C32e(0x1030c910), C32e(0x060a0806), C32e(0x8198e781),1897C32e(0xf00b5bf0), C32e(0x44ccf044), C32e(0xbad54aba), C32e(0xe33e96e3),1898C32e(0xf30e5ff3), C32e(0xfe19bafe), C32e(0xc05b1bc0), C32e(0x8a850a8a),1899C32e(0xadec7ead), C32e(0xbcdf42bc), C32e(0x48d8e048), C32e(0x040cf904),1900C32e(0xdf7ac6df), C32e(0xc158eec1), C32e(0x759f4575), C32e(0x63a58463),1901C32e(0x30504030), C32e(0x1a2ed11a), C32e(0x0e12e10e), C32e(0x6db7656d),1902C32e(0x4cd4194c), C32e(0x143c3014), C32e(0x355f4c35), C32e(0x2f719d2f),1903C32e(0xe13867e1), C32e(0xa2fd6aa2), C32e(0xcc4f0bcc), C32e(0x394b5c39),1904C32e(0x57f93d57), C32e(0xf20daaf2), C32e(0x829de382), C32e(0x47c9f447),1905C32e(0xacef8bac), C32e(0xe7326fe7), C32e(0x2b7d642b), C32e(0x95a4d795),1906C32e(0xa0fb9ba0), C32e(0x98b33298), C32e(0xd16827d1), C32e(0x7f815d7f),1907C32e(0x66aa8866), C32e(0x7e82a87e), C32e(0xabe676ab), C32e(0x839e1683),1908C32e(0xca4503ca), C32e(0x297b9529), C32e(0xd36ed6d3), C32e(0x3c44503c),1909C32e(0x798b5579), C32e(0xe23d63e2), C32e(0x1d272c1d), C32e(0x769a4176),1910C32e(0x3b4dad3b), C32e(0x56fac856), C32e(0x4ed2e84e), C32e(0x1e22281e),1911C32e(0xdb763fdb), C32e(0x0a1e180a), C32e(0x6cb4906c), C32e(0xe4376be4),1912C32e(0x5de7255d), C32e(0x6eb2616e), C32e(0xef2a86ef), C32e(0xa6f193a6),1913C32e(0xa8e372a8), C32e(0xa4f762a4), C32e(0x3759bd37), C32e(0x8b86ff8b),1914C32e(0x3256b132), C32e(0x43c50d43), C32e(0x59ebdc59), C32e(0xb7c2afb7),1915C32e(0x8c8f028c), C32e(0x64ac7964), C32e(0xd26d23d2), C32e(0xe03b92e0),1916C32e(0xb4c7abb4), C32e(0xfa1543fa), C32e(0x0709fd07), C32e(0x256f8525),1917C32e(0xafea8faf), C32e(0x8e89f38e), C32e(0xe9208ee9), C32e(0x18282018),1918C32e(0xd564ded5), C32e(0x8883fb88), C32e(0x6fb1946f), C32e(0x7296b872),1919C32e(0x246c7024), C32e(0xf108aef1), C32e(0xc752e6c7), C32e(0x51f33551),1920C32e(0x23658d23), C32e(0x7c84597c), C32e(0x9cbfcb9c), C32e(0x21637c21),1921C32e(0xdd7c37dd), C32e(0xdc7fc2dc), C32e(0x86911a86), C32e(0x85941e85),1922C32e(0x90abdb90), C32e(0x42c6f842), C32e(0xc457e2c4), C32e(0xaae583aa),1923C32e(0xd8733bd8), C32e(0x050f0c05), C32e(0x0103f501), C32e(0x12363812),1924C32e(0xa3fe9fa3), C32e(0x5fe1d45f), C32e(0xf91047f9), C32e(0xd06bd2d0),1925C32e(0x91a82e91), C32e(0x58e82958), C32e(0x27697427), C32e(0xb9d04eb9),1926C32e(0x3848a938), C32e(0x1335cd13), C32e(0xb3ce56b3), C32e(0x33554433),1927C32e(0xbbd6bfbb), C32e(0x70904970), C32e(0x89800e89), C32e(0xa7f266a7),1928C32e(0xb6c15ab6), C32e(0x22667822), C32e(0x92ad2a92), C32e(0x20608920),1929C32e(0x49db1549), C32e(0xff1a4fff), C32e(0x7888a078), C32e(0x7a8e517a),1930C32e(0x8f8a068f), C32e(0xf813b2f8), C32e(0x809b1280), C32e(0x17393417),1931C32e(0xda75cada), C32e(0x3153b531), C32e(0xc65113c6), C32e(0xb8d3bbb8),1932C32e(0xc35e1fc3), C32e(0xb0cb52b0), C32e(0x7799b477), C32e(0x11333c11),1933C32e(0xcb46f6cb), C32e(0xfc1f4bfc), C32e(0xd661dad6), C32e(0x3a4e583a)1934};19351936static const sph_u32 T2up[] = {1937C32e(0xa5c6c632), C32e(0x84f8f86f), C32e(0x99eeee5e), C32e(0x8df6f67a),1938C32e(0x0dffffe8), C32e(0xbdd6d60a), C32e(0xb1dede16), C32e(0x5491916d),1939C32e(0x50606090), C32e(0x03020207), C32e(0xa9cece2e), C32e(0x7d5656d1),1940C32e(0x19e7e7cc), C32e(0x62b5b513), C32e(0xe64d4d7c), C32e(0x9aecec59),1941C32e(0x458f8f40), C32e(0x9d1f1fa3), C32e(0x40898949), C32e(0x87fafa68),1942C32e(0x15efefd0), C32e(0xebb2b294), C32e(0xc98e8ece), C32e(0x0bfbfbe6),1943C32e(0xec41416e), C32e(0x67b3b31a), C32e(0xfd5f5f43), C32e(0xea454560),1944C32e(0xbf2323f9), C32e(0xf7535351), C32e(0x96e4e445), C32e(0x5b9b9b76),1945C32e(0xc2757528), C32e(0x1ce1e1c5), C32e(0xae3d3dd4), C32e(0x6a4c4cf2),1946C32e(0x5a6c6c82), C32e(0x417e7ebd), C32e(0x02f5f5f3), C32e(0x4f838352),1947C32e(0x5c68688c), C32e(0xf4515156), C32e(0x34d1d18d), C32e(0x08f9f9e1),1948C32e(0x93e2e24c), C32e(0x73abab3e), C32e(0x53626297), C32e(0x3f2a2a6b),1949C32e(0x0c08081c), C32e(0x52959563), C32e(0x654646e9), C32e(0x5e9d9d7f),1950C32e(0x28303048), C32e(0xa13737cf), C32e(0x0f0a0a1b), C32e(0xb52f2feb),1951C32e(0x090e0e15), C32e(0x3624247e), C32e(0x9b1b1bad), C32e(0x3ddfdf98),1952C32e(0x26cdcda7), C32e(0x694e4ef5), C32e(0xcd7f7f33), C32e(0x9feaea50),1953C32e(0x1b12123f), C32e(0x9e1d1da4), C32e(0x745858c4), C32e(0x2e343446),1954C32e(0x2d363641), C32e(0xb2dcdc11), C32e(0xeeb4b49d), C32e(0xfb5b5b4d),1955C32e(0xf6a4a4a5), C32e(0x4d7676a1), C32e(0x61b7b714), C32e(0xce7d7d34),1956C32e(0x7b5252df), C32e(0x3edddd9f), C32e(0x715e5ecd), C32e(0x971313b1),1957C32e(0xf5a6a6a2), C32e(0x68b9b901), C32e(0x00000000), C32e(0x2cc1c1b5),1958C32e(0x604040e0), C32e(0x1fe3e3c2), C32e(0xc879793a), C32e(0xedb6b69a),1959C32e(0xbed4d40d), C32e(0x468d8d47), C32e(0xd9676717), C32e(0x4b7272af),1960C32e(0xde9494ed), C32e(0xd49898ff), C32e(0xe8b0b093), C32e(0x4a85855b),1961C32e(0x6bbbbb06), C32e(0x2ac5c5bb), C32e(0xe54f4f7b), C32e(0x16ededd7),1962C32e(0xc58686d2), C32e(0xd79a9af8), C32e(0x55666699), C32e(0x941111b6),1963C32e(0xcf8a8ac0), C32e(0x10e9e9d9), C32e(0x0604040e), C32e(0x81fefe66),1964C32e(0xf0a0a0ab), C32e(0x447878b4), C32e(0xba2525f0), C32e(0xe34b4b75),1965C32e(0xf3a2a2ac), C32e(0xfe5d5d44), C32e(0xc08080db), C32e(0x8a050580),1966C32e(0xad3f3fd3), C32e(0xbc2121fe), C32e(0x487070a8), C32e(0x04f1f1fd),1967C32e(0xdf636319), C32e(0xc177772f), C32e(0x75afaf30), C32e(0x634242e7),1968C32e(0x30202070), C32e(0x1ae5e5cb), C32e(0x0efdfdef), C32e(0x6dbfbf08),1969C32e(0x4c818155), C32e(0x14181824), C32e(0x35262679), C32e(0x2fc3c3b2),1970C32e(0xe1bebe86), C32e(0xa23535c8), C32e(0xcc8888c7), C32e(0x392e2e65),1971C32e(0x5793936a), C32e(0xf2555558), C32e(0x82fcfc61), C32e(0x477a7ab3),1972C32e(0xacc8c827), C32e(0xe7baba88), C32e(0x2b32324f), C32e(0x95e6e642),1973C32e(0xa0c0c03b), C32e(0x981919aa), C32e(0xd19e9ef6), C32e(0x7fa3a322),1974C32e(0x664444ee), C32e(0x7e5454d6), C32e(0xab3b3bdd), C32e(0x830b0b95),1975C32e(0xca8c8cc9), C32e(0x29c7c7bc), C32e(0xd36b6b05), C32e(0x3c28286c),1976C32e(0x79a7a72c), C32e(0xe2bcbc81), C32e(0x1d161631), C32e(0x76adad37),1977C32e(0x3bdbdb96), C32e(0x5664649e), C32e(0x4e7474a6), C32e(0x1e141436),1978C32e(0xdb9292e4), C32e(0x0a0c0c12), C32e(0x6c4848fc), C32e(0xe4b8b88f),1979C32e(0x5d9f9f78), C32e(0x6ebdbd0f), C32e(0xef434369), C32e(0xa6c4c435),1980C32e(0xa83939da), C32e(0xa43131c6), C32e(0x37d3d38a), C32e(0x8bf2f274),1981C32e(0x32d5d583), C32e(0x438b8b4e), C32e(0x596e6e85), C32e(0xb7dada18),1982C32e(0x8c01018e), C32e(0x64b1b11d), C32e(0xd29c9cf1), C32e(0xe0494972),1983C32e(0xb4d8d81f), C32e(0xfaacacb9), C32e(0x07f3f3fa), C32e(0x25cfcfa0),1984C32e(0xafcaca20), C32e(0x8ef4f47d), C32e(0xe9474767), C32e(0x18101038),1985C32e(0xd56f6f0b), C32e(0x88f0f073), C32e(0x6f4a4afb), C32e(0x725c5cca),1986C32e(0x24383854), C32e(0xf157575f), C32e(0xc7737321), C32e(0x51979764),1987C32e(0x23cbcbae), C32e(0x7ca1a125), C32e(0x9ce8e857), C32e(0x213e3e5d),1988C32e(0xdd9696ea), C32e(0xdc61611e), C32e(0x860d0d9c), C32e(0x850f0f9b),1989C32e(0x90e0e04b), C32e(0x427c7cba), C32e(0xc4717126), C32e(0xaacccc29),1990C32e(0xd89090e3), C32e(0x05060609), C32e(0x01f7f7f4), C32e(0x121c1c2a),1991C32e(0xa3c2c23c), C32e(0x5f6a6a8b), C32e(0xf9aeaebe), C32e(0xd0696902),1992C32e(0x911717bf), C32e(0x58999971), C32e(0x273a3a53), C32e(0xb92727f7),1993C32e(0x38d9d991), C32e(0x13ebebde), C32e(0xb32b2be5), C32e(0x33222277),1994C32e(0xbbd2d204), C32e(0x70a9a939), C32e(0x89070787), C32e(0xa73333c1),1995C32e(0xb62d2dec), C32e(0x223c3c5a), C32e(0x921515b8), C32e(0x20c9c9a9),1996C32e(0x4987875c), C32e(0xffaaaab0), C32e(0x785050d8), C32e(0x7aa5a52b),1997C32e(0x8f030389), C32e(0xf859594a), C32e(0x80090992), C32e(0x171a1a23),1998C32e(0xda656510), C32e(0x31d7d784), C32e(0xc68484d5), C32e(0xb8d0d003),1999C32e(0xc38282dc), C32e(0xb02929e2), C32e(0x775a5ac3), C32e(0x111e1e2d),2000C32e(0xcb7b7b3d), C32e(0xfca8a8b7), C32e(0xd66d6d0c), C32e(0x3a2c2c62)2001};20022003static const sph_u32 T2dn[] = {2004C32e(0xf4a5f497), C32e(0x978497eb), C32e(0xb099b0c7), C32e(0x8c8d8cf7),2005C32e(0x170d17e5), C32e(0xdcbddcb7), C32e(0xc8b1c8a7), C32e(0xfc54fc39),2006C32e(0xf050f0c0), C32e(0x05030504), C32e(0xe0a9e087), C32e(0x877d87ac),2007C32e(0x2b192bd5), C32e(0xa662a671), C32e(0x31e6319a), C32e(0xb59ab5c3),2008C32e(0xcf45cf05), C32e(0xbc9dbc3e), C32e(0xc040c009), C32e(0x928792ef),2009C32e(0x3f153fc5), C32e(0x26eb267f), C32e(0x40c94007), C32e(0x1d0b1ded),2010C32e(0x2fec2f82), C32e(0xa967a97d), C32e(0x1cfd1cbe), C32e(0x25ea258a),2011C32e(0xdabfda46), C32e(0x02f702a6), C32e(0xa196a1d3), C32e(0xed5bed2d),2012C32e(0x5dc25dea), C32e(0x241c24d9), C32e(0xe9aee97a), C32e(0xbe6abe98),2013C32e(0xee5aeed8), C32e(0xc341c3fc), C32e(0x060206f1), C32e(0xd14fd11d),2014C32e(0xe45ce4d0), C32e(0x07f407a2), C32e(0x5c345cb9), C32e(0x180818e9),2015C32e(0xae93aedf), C32e(0x9573954d), C32e(0xf553f5c4), C32e(0x413f4154),2016C32e(0x140c1410), C32e(0xf652f631), C32e(0xaf65af8c), C32e(0xe25ee221),2017C32e(0x78287860), C32e(0xf8a1f86e), C32e(0x110f1114), C32e(0xc4b5c45e),2018C32e(0x1b091b1c), C32e(0x5a365a48), C32e(0xb69bb636), C32e(0x473d47a5),2019C32e(0x6a266a81), C32e(0xbb69bb9c), C32e(0x4ccd4cfe), C32e(0xba9fbacf),2020C32e(0x2d1b2d24), C32e(0xb99eb93a), C32e(0x9c749cb0), C32e(0x722e7268),2021C32e(0x772d776c), C32e(0xcdb2cda3), C32e(0x29ee2973), C32e(0x16fb16b6),2022C32e(0x01f60153), C32e(0xd74dd7ec), C32e(0xa361a375), C32e(0x49ce49fa),2023C32e(0x8d7b8da4), C32e(0x423e42a1), C32e(0x937193bc), C32e(0xa297a226),2024C32e(0x04f50457), C32e(0xb868b869), C32e(0x00000000), C32e(0x742c7499),2025C32e(0xa060a080), C32e(0x211f21dd), C32e(0x43c843f2), C32e(0x2ced2c77),2026C32e(0xd9bed9b3), C32e(0xca46ca01), C32e(0x70d970ce), C32e(0xdd4bdde4),2027C32e(0x79de7933), C32e(0x67d4672b), C32e(0x23e8237b), C32e(0xde4ade11),2028C32e(0xbd6bbd6d), C32e(0x7e2a7e91), C32e(0x34e5349e), C32e(0x3a163ac1),2029C32e(0x54c55417), C32e(0x62d7622f), C32e(0xff55ffcc), C32e(0xa794a722),2030C32e(0x4acf4a0f), C32e(0x301030c9), C32e(0x0a060a08), C32e(0x988198e7),2031C32e(0x0bf00b5b), C32e(0xcc44ccf0), C32e(0xd5bad54a), C32e(0x3ee33e96),2032C32e(0x0ef30e5f), C32e(0x19fe19ba), C32e(0x5bc05b1b), C32e(0x858a850a),2033C32e(0xecadec7e), C32e(0xdfbcdf42), C32e(0xd848d8e0), C32e(0x0c040cf9),2034C32e(0x7adf7ac6), C32e(0x58c158ee), C32e(0x9f759f45), C32e(0xa563a584),2035C32e(0x50305040), C32e(0x2e1a2ed1), C32e(0x120e12e1), C32e(0xb76db765),2036C32e(0xd44cd419), C32e(0x3c143c30), C32e(0x5f355f4c), C32e(0x712f719d),2037C32e(0x38e13867), C32e(0xfda2fd6a), C32e(0x4fcc4f0b), C32e(0x4b394b5c),2038C32e(0xf957f93d), C32e(0x0df20daa), C32e(0x9d829de3), C32e(0xc947c9f4),2039C32e(0xefacef8b), C32e(0x32e7326f), C32e(0x7d2b7d64), C32e(0xa495a4d7),2040C32e(0xfba0fb9b), C32e(0xb398b332), C32e(0x68d16827), C32e(0x817f815d),2041C32e(0xaa66aa88), C32e(0x827e82a8), C32e(0xe6abe676), C32e(0x9e839e16),2042C32e(0x45ca4503), C32e(0x7b297b95), C32e(0x6ed36ed6), C32e(0x443c4450),2043C32e(0x8b798b55), C32e(0x3de23d63), C32e(0x271d272c), C32e(0x9a769a41),2044C32e(0x4d3b4dad), C32e(0xfa56fac8), C32e(0xd24ed2e8), C32e(0x221e2228),2045C32e(0x76db763f), C32e(0x1e0a1e18), C32e(0xb46cb490), C32e(0x37e4376b),2046C32e(0xe75de725), C32e(0xb26eb261), C32e(0x2aef2a86), C32e(0xf1a6f193),2047C32e(0xe3a8e372), C32e(0xf7a4f762), C32e(0x593759bd), C32e(0x868b86ff),2048C32e(0x563256b1), C32e(0xc543c50d), C32e(0xeb59ebdc), C32e(0xc2b7c2af),2049C32e(0x8f8c8f02), C32e(0xac64ac79), C32e(0x6dd26d23), C32e(0x3be03b92),2050C32e(0xc7b4c7ab), C32e(0x15fa1543), C32e(0x090709fd), C32e(0x6f256f85),2051C32e(0xeaafea8f), C32e(0x898e89f3), C32e(0x20e9208e), C32e(0x28182820),2052C32e(0x64d564de), C32e(0x838883fb), C32e(0xb16fb194), C32e(0x967296b8),2053C32e(0x6c246c70), C32e(0x08f108ae), C32e(0x52c752e6), C32e(0xf351f335),2054C32e(0x6523658d), C32e(0x847c8459), C32e(0xbf9cbfcb), C32e(0x6321637c),2055C32e(0x7cdd7c37), C32e(0x7fdc7fc2), C32e(0x9186911a), C32e(0x9485941e),2056C32e(0xab90abdb), C32e(0xc642c6f8), C32e(0x57c457e2), C32e(0xe5aae583),2057C32e(0x73d8733b), C32e(0x0f050f0c), C32e(0x030103f5), C32e(0x36123638),2058C32e(0xfea3fe9f), C32e(0xe15fe1d4), C32e(0x10f91047), C32e(0x6bd06bd2),2059C32e(0xa891a82e), C32e(0xe858e829), C32e(0x69276974), C32e(0xd0b9d04e),2060C32e(0x483848a9), C32e(0x351335cd), C32e(0xceb3ce56), C32e(0x55335544),2061C32e(0xd6bbd6bf), C32e(0x90709049), C32e(0x8089800e), C32e(0xf2a7f266),2062C32e(0xc1b6c15a), C32e(0x66226678), C32e(0xad92ad2a), C32e(0x60206089),2063C32e(0xdb49db15), C32e(0x1aff1a4f), C32e(0x887888a0), C32e(0x8e7a8e51),2064C32e(0x8a8f8a06), C32e(0x13f813b2), C32e(0x9b809b12), C32e(0x39173934),2065C32e(0x75da75ca), C32e(0x533153b5), C32e(0x51c65113), C32e(0xd3b8d3bb),2066C32e(0x5ec35e1f), C32e(0xcbb0cb52), C32e(0x997799b4), C32e(0x3311333c),2067C32e(0x46cb46f6), C32e(0x1ffc1f4b), C32e(0x61d661da), C32e(0x4e3a4e58)2068};20692070static const sph_u32 T3up[] = {2071C32e(0x97a5c6c6), C32e(0xeb84f8f8), C32e(0xc799eeee), C32e(0xf78df6f6),2072C32e(0xe50dffff), C32e(0xb7bdd6d6), C32e(0xa7b1dede), C32e(0x39549191),2073C32e(0xc0506060), C32e(0x04030202), C32e(0x87a9cece), C32e(0xac7d5656),2074C32e(0xd519e7e7), C32e(0x7162b5b5), C32e(0x9ae64d4d), C32e(0xc39aecec),2075C32e(0x05458f8f), C32e(0x3e9d1f1f), C32e(0x09408989), C32e(0xef87fafa),2076C32e(0xc515efef), C32e(0x7febb2b2), C32e(0x07c98e8e), C32e(0xed0bfbfb),2077C32e(0x82ec4141), C32e(0x7d67b3b3), C32e(0xbefd5f5f), C32e(0x8aea4545),2078C32e(0x46bf2323), C32e(0xa6f75353), C32e(0xd396e4e4), C32e(0x2d5b9b9b),2079C32e(0xeac27575), C32e(0xd91ce1e1), C32e(0x7aae3d3d), C32e(0x986a4c4c),2080C32e(0xd85a6c6c), C32e(0xfc417e7e), C32e(0xf102f5f5), C32e(0x1d4f8383),2081C32e(0xd05c6868), C32e(0xa2f45151), C32e(0xb934d1d1), C32e(0xe908f9f9),2082C32e(0xdf93e2e2), C32e(0x4d73abab), C32e(0xc4536262), C32e(0x543f2a2a),2083C32e(0x100c0808), C32e(0x31529595), C32e(0x8c654646), C32e(0x215e9d9d),2084C32e(0x60283030), C32e(0x6ea13737), C32e(0x140f0a0a), C32e(0x5eb52f2f),2085C32e(0x1c090e0e), C32e(0x48362424), C32e(0x369b1b1b), C32e(0xa53ddfdf),2086C32e(0x8126cdcd), C32e(0x9c694e4e), C32e(0xfecd7f7f), C32e(0xcf9feaea),2087C32e(0x241b1212), C32e(0x3a9e1d1d), C32e(0xb0745858), C32e(0x682e3434),2088C32e(0x6c2d3636), C32e(0xa3b2dcdc), C32e(0x73eeb4b4), C32e(0xb6fb5b5b),2089C32e(0x53f6a4a4), C32e(0xec4d7676), C32e(0x7561b7b7), C32e(0xface7d7d),2090C32e(0xa47b5252), C32e(0xa13edddd), C32e(0xbc715e5e), C32e(0x26971313),2091C32e(0x57f5a6a6), C32e(0x6968b9b9), C32e(0x00000000), C32e(0x992cc1c1),2092C32e(0x80604040), C32e(0xdd1fe3e3), C32e(0xf2c87979), C32e(0x77edb6b6),2093C32e(0xb3bed4d4), C32e(0x01468d8d), C32e(0xced96767), C32e(0xe44b7272),2094C32e(0x33de9494), C32e(0x2bd49898), C32e(0x7be8b0b0), C32e(0x114a8585),2095C32e(0x6d6bbbbb), C32e(0x912ac5c5), C32e(0x9ee54f4f), C32e(0xc116eded),2096C32e(0x17c58686), C32e(0x2fd79a9a), C32e(0xcc556666), C32e(0x22941111),2097C32e(0x0fcf8a8a), C32e(0xc910e9e9), C32e(0x08060404), C32e(0xe781fefe),2098C32e(0x5bf0a0a0), C32e(0xf0447878), C32e(0x4aba2525), C32e(0x96e34b4b),2099C32e(0x5ff3a2a2), C32e(0xbafe5d5d), C32e(0x1bc08080), C32e(0x0a8a0505),2100C32e(0x7ead3f3f), C32e(0x42bc2121), C32e(0xe0487070), C32e(0xf904f1f1),2101C32e(0xc6df6363), C32e(0xeec17777), C32e(0x4575afaf), C32e(0x84634242),2102C32e(0x40302020), C32e(0xd11ae5e5), C32e(0xe10efdfd), C32e(0x656dbfbf),2103C32e(0x194c8181), C32e(0x30141818), C32e(0x4c352626), C32e(0x9d2fc3c3),2104C32e(0x67e1bebe), C32e(0x6aa23535), C32e(0x0bcc8888), C32e(0x5c392e2e),2105C32e(0x3d579393), C32e(0xaaf25555), C32e(0xe382fcfc), C32e(0xf4477a7a),2106C32e(0x8bacc8c8), C32e(0x6fe7baba), C32e(0x642b3232), C32e(0xd795e6e6),2107C32e(0x9ba0c0c0), C32e(0x32981919), C32e(0x27d19e9e), C32e(0x5d7fa3a3),2108C32e(0x88664444), C32e(0xa87e5454), C32e(0x76ab3b3b), C32e(0x16830b0b),2109C32e(0x03ca8c8c), C32e(0x9529c7c7), C32e(0xd6d36b6b), C32e(0x503c2828),2110C32e(0x5579a7a7), C32e(0x63e2bcbc), C32e(0x2c1d1616), C32e(0x4176adad),2111C32e(0xad3bdbdb), C32e(0xc8566464), C32e(0xe84e7474), C32e(0x281e1414),2112C32e(0x3fdb9292), C32e(0x180a0c0c), C32e(0x906c4848), C32e(0x6be4b8b8),2113C32e(0x255d9f9f), C32e(0x616ebdbd), C32e(0x86ef4343), C32e(0x93a6c4c4),2114C32e(0x72a83939), C32e(0x62a43131), C32e(0xbd37d3d3), C32e(0xff8bf2f2),2115C32e(0xb132d5d5), C32e(0x0d438b8b), C32e(0xdc596e6e), C32e(0xafb7dada),2116C32e(0x028c0101), C32e(0x7964b1b1), C32e(0x23d29c9c), C32e(0x92e04949),2117C32e(0xabb4d8d8), C32e(0x43faacac), C32e(0xfd07f3f3), C32e(0x8525cfcf),2118C32e(0x8fafcaca), C32e(0xf38ef4f4), C32e(0x8ee94747), C32e(0x20181010),2119C32e(0xded56f6f), C32e(0xfb88f0f0), C32e(0x946f4a4a), C32e(0xb8725c5c),2120C32e(0x70243838), C32e(0xaef15757), C32e(0xe6c77373), C32e(0x35519797),2121C32e(0x8d23cbcb), C32e(0x597ca1a1), C32e(0xcb9ce8e8), C32e(0x7c213e3e),2122C32e(0x37dd9696), C32e(0xc2dc6161), C32e(0x1a860d0d), C32e(0x1e850f0f),2123C32e(0xdb90e0e0), C32e(0xf8427c7c), C32e(0xe2c47171), C32e(0x83aacccc),2124C32e(0x3bd89090), C32e(0x0c050606), C32e(0xf501f7f7), C32e(0x38121c1c),2125C32e(0x9fa3c2c2), C32e(0xd45f6a6a), C32e(0x47f9aeae), C32e(0xd2d06969),2126C32e(0x2e911717), C32e(0x29589999), C32e(0x74273a3a), C32e(0x4eb92727),2127C32e(0xa938d9d9), C32e(0xcd13ebeb), C32e(0x56b32b2b), C32e(0x44332222),2128C32e(0xbfbbd2d2), C32e(0x4970a9a9), C32e(0x0e890707), C32e(0x66a73333),2129C32e(0x5ab62d2d), C32e(0x78223c3c), C32e(0x2a921515), C32e(0x8920c9c9),2130C32e(0x15498787), C32e(0x4fffaaaa), C32e(0xa0785050), C32e(0x517aa5a5),2131C32e(0x068f0303), C32e(0xb2f85959), C32e(0x12800909), C32e(0x34171a1a),2132C32e(0xcada6565), C32e(0xb531d7d7), C32e(0x13c68484), C32e(0xbbb8d0d0),2133C32e(0x1fc38282), C32e(0x52b02929), C32e(0xb4775a5a), C32e(0x3c111e1e),2134C32e(0xf6cb7b7b), C32e(0x4bfca8a8), C32e(0xdad66d6d), C32e(0x583a2c2c)2135};21362137static const sph_u32 T3dn[] = {2138C32e(0x32f4a5f4), C32e(0x6f978497), C32e(0x5eb099b0), C32e(0x7a8c8d8c),2139C32e(0xe8170d17), C32e(0x0adcbddc), C32e(0x16c8b1c8), C32e(0x6dfc54fc),2140C32e(0x90f050f0), C32e(0x07050305), C32e(0x2ee0a9e0), C32e(0xd1877d87),2141C32e(0xcc2b192b), C32e(0x13a662a6), C32e(0x7c31e631), C32e(0x59b59ab5),2142C32e(0x40cf45cf), C32e(0xa3bc9dbc), C32e(0x49c040c0), C32e(0x68928792),2143C32e(0xd03f153f), C32e(0x9426eb26), C32e(0xce40c940), C32e(0xe61d0b1d),2144C32e(0x6e2fec2f), C32e(0x1aa967a9), C32e(0x431cfd1c), C32e(0x6025ea25),2145C32e(0xf9dabfda), C32e(0x5102f702), C32e(0x45a196a1), C32e(0x76ed5bed),2146C32e(0x285dc25d), C32e(0xc5241c24), C32e(0xd4e9aee9), C32e(0xf2be6abe),2147C32e(0x82ee5aee), C32e(0xbdc341c3), C32e(0xf3060206), C32e(0x52d14fd1),2148C32e(0x8ce45ce4), C32e(0x5607f407), C32e(0x8d5c345c), C32e(0xe1180818),2149C32e(0x4cae93ae), C32e(0x3e957395), C32e(0x97f553f5), C32e(0x6b413f41),2150C32e(0x1c140c14), C32e(0x63f652f6), C32e(0xe9af65af), C32e(0x7fe25ee2),2151C32e(0x48782878), C32e(0xcff8a1f8), C32e(0x1b110f11), C32e(0xebc4b5c4),2152C32e(0x151b091b), C32e(0x7e5a365a), C32e(0xadb69bb6), C32e(0x98473d47),2153C32e(0xa76a266a), C32e(0xf5bb69bb), C32e(0x334ccd4c), C32e(0x50ba9fba),2154C32e(0x3f2d1b2d), C32e(0xa4b99eb9), C32e(0xc49c749c), C32e(0x46722e72),2155C32e(0x41772d77), C32e(0x11cdb2cd), C32e(0x9d29ee29), C32e(0x4d16fb16),2156C32e(0xa501f601), C32e(0xa1d74dd7), C32e(0x14a361a3), C32e(0x3449ce49),2157C32e(0xdf8d7b8d), C32e(0x9f423e42), C32e(0xcd937193), C32e(0xb1a297a2),2158C32e(0xa204f504), C32e(0x01b868b8), C32e(0x00000000), C32e(0xb5742c74),2159C32e(0xe0a060a0), C32e(0xc2211f21), C32e(0x3a43c843), C32e(0x9a2ced2c),2160C32e(0x0dd9bed9), C32e(0x47ca46ca), C32e(0x1770d970), C32e(0xafdd4bdd),2161C32e(0xed79de79), C32e(0xff67d467), C32e(0x9323e823), C32e(0x5bde4ade),2162C32e(0x06bd6bbd), C32e(0xbb7e2a7e), C32e(0x7b34e534), C32e(0xd73a163a),2163C32e(0xd254c554), C32e(0xf862d762), C32e(0x99ff55ff), C32e(0xb6a794a7),2164C32e(0xc04acf4a), C32e(0xd9301030), C32e(0x0e0a060a), C32e(0x66988198),2165C32e(0xab0bf00b), C32e(0xb4cc44cc), C32e(0xf0d5bad5), C32e(0x753ee33e),2166C32e(0xac0ef30e), C32e(0x4419fe19), C32e(0xdb5bc05b), C32e(0x80858a85),2167C32e(0xd3ecadec), C32e(0xfedfbcdf), C32e(0xa8d848d8), C32e(0xfd0c040c),2168C32e(0x197adf7a), C32e(0x2f58c158), C32e(0x309f759f), C32e(0xe7a563a5),2169C32e(0x70503050), C32e(0xcb2e1a2e), C32e(0xef120e12), C32e(0x08b76db7),2170C32e(0x55d44cd4), C32e(0x243c143c), C32e(0x795f355f), C32e(0xb2712f71),2171C32e(0x8638e138), C32e(0xc8fda2fd), C32e(0xc74fcc4f), C32e(0x654b394b),2172C32e(0x6af957f9), C32e(0x580df20d), C32e(0x619d829d), C32e(0xb3c947c9),2173C32e(0x27efacef), C32e(0x8832e732), C32e(0x4f7d2b7d), C32e(0x42a495a4),2174C32e(0x3bfba0fb), C32e(0xaab398b3), C32e(0xf668d168), C32e(0x22817f81),2175C32e(0xeeaa66aa), C32e(0xd6827e82), C32e(0xdde6abe6), C32e(0x959e839e),2176C32e(0xc945ca45), C32e(0xbc7b297b), C32e(0x056ed36e), C32e(0x6c443c44),2177C32e(0x2c8b798b), C32e(0x813de23d), C32e(0x31271d27), C32e(0x379a769a),2178C32e(0x964d3b4d), C32e(0x9efa56fa), C32e(0xa6d24ed2), C32e(0x36221e22),2179C32e(0xe476db76), C32e(0x121e0a1e), C32e(0xfcb46cb4), C32e(0x8f37e437),2180C32e(0x78e75de7), C32e(0x0fb26eb2), C32e(0x692aef2a), C32e(0x35f1a6f1),2181C32e(0xdae3a8e3), C32e(0xc6f7a4f7), C32e(0x8a593759), C32e(0x74868b86),2182C32e(0x83563256), C32e(0x4ec543c5), C32e(0x85eb59eb), C32e(0x18c2b7c2),2183C32e(0x8e8f8c8f), C32e(0x1dac64ac), C32e(0xf16dd26d), C32e(0x723be03b),2184C32e(0x1fc7b4c7), C32e(0xb915fa15), C32e(0xfa090709), C32e(0xa06f256f),2185C32e(0x20eaafea), C32e(0x7d898e89), C32e(0x6720e920), C32e(0x38281828),2186C32e(0x0b64d564), C32e(0x73838883), C32e(0xfbb16fb1), C32e(0xca967296),2187C32e(0x546c246c), C32e(0x5f08f108), C32e(0x2152c752), C32e(0x64f351f3),2188C32e(0xae652365), C32e(0x25847c84), C32e(0x57bf9cbf), C32e(0x5d632163),2189C32e(0xea7cdd7c), C32e(0x1e7fdc7f), C32e(0x9c918691), C32e(0x9b948594),2190C32e(0x4bab90ab), C32e(0xbac642c6), C32e(0x2657c457), C32e(0x29e5aae5),2191C32e(0xe373d873), C32e(0x090f050f), C32e(0xf4030103), C32e(0x2a361236),2192C32e(0x3cfea3fe), C32e(0x8be15fe1), C32e(0xbe10f910), C32e(0x026bd06b),2193C32e(0xbfa891a8), C32e(0x71e858e8), C32e(0x53692769), C32e(0xf7d0b9d0),2194C32e(0x91483848), C32e(0xde351335), C32e(0xe5ceb3ce), C32e(0x77553355),2195C32e(0x04d6bbd6), C32e(0x39907090), C32e(0x87808980), C32e(0xc1f2a7f2),2196C32e(0xecc1b6c1), C32e(0x5a662266), C32e(0xb8ad92ad), C32e(0xa9602060),2197C32e(0x5cdb49db), C32e(0xb01aff1a), C32e(0xd8887888), C32e(0x2b8e7a8e),2198C32e(0x898a8f8a), C32e(0x4a13f813), C32e(0x929b809b), C32e(0x23391739),2199C32e(0x1075da75), C32e(0x84533153), C32e(0xd551c651), C32e(0x03d3b8d3),2200C32e(0xdc5ec35e), C32e(0xe2cbb0cb), C32e(0xc3997799), C32e(0x2d331133),2201C32e(0x3d46cb46), C32e(0xb71ffc1f), C32e(0x0c61d661), C32e(0x624e3a4e)2202};22032204#define DECL_STATE_SMALL \2205sph_u32 H[16];22062207#define READ_STATE_SMALL(sc) do { \2208memcpy(H, (sc)->state.narrow, sizeof H); \2209} while (0)22102211#define WRITE_STATE_SMALL(sc) do { \2212memcpy((sc)->state.narrow, H, sizeof H); \2213} while (0)22142215#define XCAT(x, y) XCAT_(x, y)2216#define XCAT_(x, y) x ## y22172218#define RSTT(d0, d1, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \2219t[d0] = T0up[B32_0(a[b0])] \2220^ T1up[B32_1(a[b1])] \2221^ T2up[B32_2(a[b2])] \2222^ T3up[B32_3(a[b3])] \2223^ T0dn[B32_0(a[b4])] \2224^ T1dn[B32_1(a[b5])] \2225^ T2dn[B32_2(a[b6])] \2226^ T3dn[B32_3(a[b7])]; \2227t[d1] = T0dn[B32_0(a[b0])] \2228^ T1dn[B32_1(a[b1])] \2229^ T2dn[B32_2(a[b2])] \2230^ T3dn[B32_3(a[b3])] \2231^ T0up[B32_0(a[b4])] \2232^ T1up[B32_1(a[b5])] \2233^ T2up[B32_2(a[b6])] \2234^ T3up[B32_3(a[b7])]; \2235} while (0)22362237#define ROUND_SMALL_P(a, r) do { \2238sph_u32 t[16]; \2239a[0x0] ^= PC32up(0x00, r); \2240a[0x1] ^= PC32dn(0x00, r); \2241a[0x2] ^= PC32up(0x10, r); \2242a[0x3] ^= PC32dn(0x10, r); \2243a[0x4] ^= PC32up(0x20, r); \2244a[0x5] ^= PC32dn(0x20, r); \2245a[0x6] ^= PC32up(0x30, r); \2246a[0x7] ^= PC32dn(0x30, r); \2247a[0x8] ^= PC32up(0x40, r); \2248a[0x9] ^= PC32dn(0x40, r); \2249a[0xA] ^= PC32up(0x50, r); \2250a[0xB] ^= PC32dn(0x50, r); \2251a[0xC] ^= PC32up(0x60, r); \2252a[0xD] ^= PC32dn(0x60, r); \2253a[0xE] ^= PC32up(0x70, r); \2254a[0xF] ^= PC32dn(0x70, r); \2255RSTT(0x0, 0x1, a, 0x0, 0x2, 0x4, 0x6, 0x9, 0xB, 0xD, 0xF); \2256RSTT(0x2, 0x3, a, 0x2, 0x4, 0x6, 0x8, 0xB, 0xD, 0xF, 0x1); \2257RSTT(0x4, 0x5, a, 0x4, 0x6, 0x8, 0xA, 0xD, 0xF, 0x1, 0x3); \2258RSTT(0x6, 0x7, a, 0x6, 0x8, 0xA, 0xC, 0xF, 0x1, 0x3, 0x5); \2259RSTT(0x8, 0x9, a, 0x8, 0xA, 0xC, 0xE, 0x1, 0x3, 0x5, 0x7); \2260RSTT(0xA, 0xB, a, 0xA, 0xC, 0xE, 0x0, 0x3, 0x5, 0x7, 0x9); \2261RSTT(0xC, 0xD, a, 0xC, 0xE, 0x0, 0x2, 0x5, 0x7, 0x9, 0xB); \2262RSTT(0xE, 0xF, a, 0xE, 0x0, 0x2, 0x4, 0x7, 0x9, 0xB, 0xD); \2263memcpy(a, t, sizeof t); \2264} while (0)22652266#define ROUND_SMALL_Q(a, r) do { \2267sph_u32 t[16]; \2268a[0x0] ^= QC32up(0x00, r); \2269a[0x1] ^= QC32dn(0x00, r); \2270a[0x2] ^= QC32up(0x10, r); \2271a[0x3] ^= QC32dn(0x10, r); \2272a[0x4] ^= QC32up(0x20, r); \2273a[0x5] ^= QC32dn(0x20, r); \2274a[0x6] ^= QC32up(0x30, r); \2275a[0x7] ^= QC32dn(0x30, r); \2276a[0x8] ^= QC32up(0x40, r); \2277a[0x9] ^= QC32dn(0x40, r); \2278a[0xA] ^= QC32up(0x50, r); \2279a[0xB] ^= QC32dn(0x50, r); \2280a[0xC] ^= QC32up(0x60, r); \2281a[0xD] ^= QC32dn(0x60, r); \2282a[0xE] ^= QC32up(0x70, r); \2283a[0xF] ^= QC32dn(0x70, r); \2284RSTT(0x0, 0x1, a, 0x2, 0x6, 0xA, 0xE, 0x1, 0x5, 0x9, 0xD); \2285RSTT(0x2, 0x3, a, 0x4, 0x8, 0xC, 0x0, 0x3, 0x7, 0xB, 0xF); \2286RSTT(0x4, 0x5, a, 0x6, 0xA, 0xE, 0x2, 0x5, 0x9, 0xD, 0x1); \2287RSTT(0x6, 0x7, a, 0x8, 0xC, 0x0, 0x4, 0x7, 0xB, 0xF, 0x3); \2288RSTT(0x8, 0x9, a, 0xA, 0xE, 0x2, 0x6, 0x9, 0xD, 0x1, 0x5); \2289RSTT(0xA, 0xB, a, 0xC, 0x0, 0x4, 0x8, 0xB, 0xF, 0x3, 0x7); \2290RSTT(0xC, 0xD, a, 0xE, 0x2, 0x6, 0xA, 0xD, 0x1, 0x5, 0x9); \2291RSTT(0xE, 0xF, a, 0x0, 0x4, 0x8, 0xC, 0xF, 0x3, 0x7, 0xB); \2292memcpy(a, t, sizeof t); \2293} while (0)22942295#if SPH_SMALL_FOOTPRINT_GROESTL22962297#define PERM_SMALL_P(a) do { \2298int r; \2299for (r = 0; r < 10; r ++) \2300ROUND_SMALL_P(a, r); \2301} while (0)23022303#define PERM_SMALL_Q(a) do { \2304int r; \2305for (r = 0; r < 10; r ++) \2306ROUND_SMALL_Q(a, r); \2307} while (0)23082309#else23102311#define PERM_SMALL_P(a) do { \2312int r; \2313for (r = 0; r < 10; r += 2) { \2314ROUND_SMALL_P(a, r + 0); \2315ROUND_SMALL_P(a, r + 1); \2316} \2317} while (0)23182319#define PERM_SMALL_Q(a) do { \2320int r; \2321for (r = 0; r < 10; r += 2) { \2322ROUND_SMALL_Q(a, r + 0); \2323ROUND_SMALL_Q(a, r + 1); \2324} \2325} while (0)23262327#endif23282329#define COMPRESS_SMALL do { \2330sph_u32 g[16], m[16]; \2331size_t u; \2332for (u = 0; u < 16; u ++) { \2333m[u] = dec32e_aligned(buf + (u << 2)); \2334g[u] = m[u] ^ H[u]; \2335} \2336PERM_SMALL_P(g); \2337PERM_SMALL_Q(m); \2338for (u = 0; u < 16; u ++) \2339H[u] ^= g[u] ^ m[u]; \2340} while (0)23412342#define FINAL_SMALL do { \2343sph_u32 x[16]; \2344size_t u; \2345memcpy(x, H, sizeof x); \2346PERM_SMALL_P(x); \2347for (u = 0; u < 16; u ++) \2348H[u] ^= x[u]; \2349} while (0)23502351#define DECL_STATE_BIG \2352sph_u32 H[32];23532354#define READ_STATE_BIG(sc) do { \2355memcpy(H, (sc)->state.narrow, sizeof H); \2356} while (0)23572358#define WRITE_STATE_BIG(sc) do { \2359memcpy((sc)->state.narrow, H, sizeof H); \2360} while (0)23612362#if SPH_SMALL_FOOTPRINT_GROESTL23632364#define RBTT(d0, d1, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \2365sph_u32 fu2 = T0up[B32_2(a[b2])]; \2366sph_u32 fd2 = T0dn[B32_2(a[b2])]; \2367sph_u32 fu3 = T1up[B32_3(a[b3])]; \2368sph_u32 fd3 = T1dn[B32_3(a[b3])]; \2369sph_u32 fu6 = T0up[B32_2(a[b6])]; \2370sph_u32 fd6 = T0dn[B32_2(a[b6])]; \2371sph_u32 fu7 = T1up[B32_3(a[b7])]; \2372sph_u32 fd7 = T1dn[B32_3(a[b7])]; \2373t[d0] = T0up[B32_0(a[b0])] \2374^ T1up[B32_1(a[b1])] \2375^ R32u(fu2, fd2) \2376^ R32u(fu3, fd3) \2377^ T0dn[B32_0(a[b4])] \2378^ T1dn[B32_1(a[b5])] \2379^ R32d(fu6, fd6) \2380^ R32d(fu7, fd7); \2381t[d1] = T0dn[B32_0(a[b0])] \2382^ T1dn[B32_1(a[b1])] \2383^ R32d(fu2, fd2) \2384^ R32d(fu3, fd3) \2385^ T0up[B32_0(a[b4])] \2386^ T1up[B32_1(a[b5])] \2387^ R32u(fu6, fd6) \2388^ R32u(fu7, fd7); \2389} while (0)23902391#else23922393#define RBTT(d0, d1, a, b0, b1, b2, b3, b4, b5, b6, b7) do { \2394t[d0] = T0up[B32_0(a[b0])] \2395^ T1up[B32_1(a[b1])] \2396^ T2up[B32_2(a[b2])] \2397^ T3up[B32_3(a[b3])] \2398^ T0dn[B32_0(a[b4])] \2399^ T1dn[B32_1(a[b5])] \2400^ T2dn[B32_2(a[b6])] \2401^ T3dn[B32_3(a[b7])]; \2402t[d1] = T0dn[B32_0(a[b0])] \2403^ T1dn[B32_1(a[b1])] \2404^ T2dn[B32_2(a[b2])] \2405^ T3dn[B32_3(a[b3])] \2406^ T0up[B32_0(a[b4])] \2407^ T1up[B32_1(a[b5])] \2408^ T2up[B32_2(a[b6])] \2409^ T3up[B32_3(a[b7])]; \2410} while (0)24112412#endif24132414#if SPH_SMALL_FOOTPRINT_GROESTL24152416#define ROUND_BIG_P(a, r) do { \2417sph_u32 t[32]; \2418size_t u; \2419a[0x00] ^= PC32up(0x00, r); \2420a[0x01] ^= PC32dn(0x00, r); \2421a[0x02] ^= PC32up(0x10, r); \2422a[0x03] ^= PC32dn(0x10, r); \2423a[0x04] ^= PC32up(0x20, r); \2424a[0x05] ^= PC32dn(0x20, r); \2425a[0x06] ^= PC32up(0x30, r); \2426a[0x07] ^= PC32dn(0x30, r); \2427a[0x08] ^= PC32up(0x40, r); \2428a[0x09] ^= PC32dn(0x40, r); \2429a[0x0A] ^= PC32up(0x50, r); \2430a[0x0B] ^= PC32dn(0x50, r); \2431a[0x0C] ^= PC32up(0x60, r); \2432a[0x0D] ^= PC32dn(0x60, r); \2433a[0x0E] ^= PC32up(0x70, r); \2434a[0x0F] ^= PC32dn(0x70, r); \2435a[0x10] ^= PC32up(0x80, r); \2436a[0x11] ^= PC32dn(0x80, r); \2437a[0x12] ^= PC32up(0x90, r); \2438a[0x13] ^= PC32dn(0x90, r); \2439a[0x14] ^= PC32up(0xA0, r); \2440a[0x15] ^= PC32dn(0xA0, r); \2441a[0x16] ^= PC32up(0xB0, r); \2442a[0x17] ^= PC32dn(0xB0, r); \2443a[0x18] ^= PC32up(0xC0, r); \2444a[0x19] ^= PC32dn(0xC0, r); \2445a[0x1A] ^= PC32up(0xD0, r); \2446a[0x1B] ^= PC32dn(0xD0, r); \2447a[0x1C] ^= PC32up(0xE0, r); \2448a[0x1D] ^= PC32dn(0xE0, r); \2449a[0x1E] ^= PC32up(0xF0, r); \2450a[0x1F] ^= PC32dn(0xF0, r); \2451for (u = 0; u < 32; u += 8) { \2452RBTT(u + 0x00, (u + 0x01) & 0x1F, a, \2453u + 0x00, (u + 0x02) & 0x1F, \2454(u + 0x04) & 0x1F, (u + 0x06) & 0x1F, \2455(u + 0x09) & 0x1F, (u + 0x0B) & 0x1F, \2456(u + 0x0D) & 0x1F, (u + 0x17) & 0x1F); \2457RBTT(u + 0x02, (u + 0x03) & 0x1F, a, \2458u + 0x02, (u + 0x04) & 0x1F, \2459(u + 0x06) & 0x1F, (u + 0x08) & 0x1F, \2460(u + 0x0B) & 0x1F, (u + 0x0D) & 0x1F, \2461(u + 0x0F) & 0x1F, (u + 0x19) & 0x1F); \2462RBTT(u + 0x04, (u + 0x05) & 0x1F, a, \2463u + 0x04, (u + 0x06) & 0x1F, \2464(u + 0x08) & 0x1F, (u + 0x0A) & 0x1F, \2465(u + 0x0D) & 0x1F, (u + 0x0F) & 0x1F, \2466(u + 0x11) & 0x1F, (u + 0x1B) & 0x1F); \2467RBTT(u + 0x06, (u + 0x07) & 0x1F, a, \2468u + 0x06, (u + 0x08) & 0x1F, \2469(u + 0x0A) & 0x1F, (u + 0x0C) & 0x1F, \2470(u + 0x0F) & 0x1F, (u + 0x11) & 0x1F, \2471(u + 0x13) & 0x1F, (u + 0x1D) & 0x1F); \2472} \2473memcpy(a, t, sizeof t); \2474} while (0)24752476#define ROUND_BIG_Q(a, r) do { \2477sph_u32 t[32]; \2478size_t u; \2479a[0x00] ^= QC32up(0x00, r); \2480a[0x01] ^= QC32dn(0x00, r); \2481a[0x02] ^= QC32up(0x10, r); \2482a[0x03] ^= QC32dn(0x10, r); \2483a[0x04] ^= QC32up(0x20, r); \2484a[0x05] ^= QC32dn(0x20, r); \2485a[0x06] ^= QC32up(0x30, r); \2486a[0x07] ^= QC32dn(0x30, r); \2487a[0x08] ^= QC32up(0x40, r); \2488a[0x09] ^= QC32dn(0x40, r); \2489a[0x0A] ^= QC32up(0x50, r); \2490a[0x0B] ^= QC32dn(0x50, r); \2491a[0x0C] ^= QC32up(0x60, r); \2492a[0x0D] ^= QC32dn(0x60, r); \2493a[0x0E] ^= QC32up(0x70, r); \2494a[0x0F] ^= QC32dn(0x70, r); \2495a[0x10] ^= QC32up(0x80, r); \2496a[0x11] ^= QC32dn(0x80, r); \2497a[0x12] ^= QC32up(0x90, r); \2498a[0x13] ^= QC32dn(0x90, r); \2499a[0x14] ^= QC32up(0xA0, r); \2500a[0x15] ^= QC32dn(0xA0, r); \2501a[0x16] ^= QC32up(0xB0, r); \2502a[0x17] ^= QC32dn(0xB0, r); \2503a[0x18] ^= QC32up(0xC0, r); \2504a[0x19] ^= QC32dn(0xC0, r); \2505a[0x1A] ^= QC32up(0xD0, r); \2506a[0x1B] ^= QC32dn(0xD0, r); \2507a[0x1C] ^= QC32up(0xE0, r); \2508a[0x1D] ^= QC32dn(0xE0, r); \2509a[0x1E] ^= QC32up(0xF0, r); \2510a[0x1F] ^= QC32dn(0xF0, r); \2511for (u = 0; u < 32; u += 8) { \2512RBTT(u + 0x00, (u + 0x01) & 0x1F, a, \2513(u + 0x02) & 0x1F, (u + 0x06) & 0x1F, \2514(u + 0x0A) & 0x1F, (u + 0x16) & 0x1F, \2515(u + 0x01) & 0x1F, (u + 0x05) & 0x1F, \2516(u + 0x09) & 0x1F, (u + 0x0D) & 0x1F); \2517RBTT(u + 0x02, (u + 0x03) & 0x1F, a, \2518(u + 0x04) & 0x1F, (u + 0x08) & 0x1F, \2519(u + 0x0C) & 0x1F, (u + 0x18) & 0x1F, \2520(u + 0x03) & 0x1F, (u + 0x07) & 0x1F, \2521(u + 0x0B) & 0x1F, (u + 0x0F) & 0x1F); \2522RBTT(u + 0x04, (u + 0x05) & 0x1F, a, \2523(u + 0x06) & 0x1F, (u + 0x0A) & 0x1F, \2524(u + 0x0E) & 0x1F, (u + 0x1A) & 0x1F, \2525(u + 0x05) & 0x1F, (u + 0x09) & 0x1F, \2526(u + 0x0D) & 0x1F, (u + 0x11) & 0x1F); \2527RBTT(u + 0x06, (u + 0x07) & 0x1F, a, \2528(u + 0x08) & 0x1F, (u + 0x0C) & 0x1F, \2529(u + 0x10) & 0x1F, (u + 0x1C) & 0x1F, \2530(u + 0x07) & 0x1F, (u + 0x0B) & 0x1F, \2531(u + 0x0F) & 0x1F, (u + 0x13) & 0x1F); \2532} \2533memcpy(a, t, sizeof t); \2534} while (0)25352536#else25372538#define ROUND_BIG_P(a, r) do { \2539sph_u32 t[32]; \2540a[0x00] ^= PC32up(0x00, r); \2541a[0x01] ^= PC32dn(0x00, r); \2542a[0x02] ^= PC32up(0x10, r); \2543a[0x03] ^= PC32dn(0x10, r); \2544a[0x04] ^= PC32up(0x20, r); \2545a[0x05] ^= PC32dn(0x20, r); \2546a[0x06] ^= PC32up(0x30, r); \2547a[0x07] ^= PC32dn(0x30, r); \2548a[0x08] ^= PC32up(0x40, r); \2549a[0x09] ^= PC32dn(0x40, r); \2550a[0x0A] ^= PC32up(0x50, r); \2551a[0x0B] ^= PC32dn(0x50, r); \2552a[0x0C] ^= PC32up(0x60, r); \2553a[0x0D] ^= PC32dn(0x60, r); \2554a[0x0E] ^= PC32up(0x70, r); \2555a[0x0F] ^= PC32dn(0x70, r); \2556a[0x10] ^= PC32up(0x80, r); \2557a[0x11] ^= PC32dn(0x80, r); \2558a[0x12] ^= PC32up(0x90, r); \2559a[0x13] ^= PC32dn(0x90, r); \2560a[0x14] ^= PC32up(0xA0, r); \2561a[0x15] ^= PC32dn(0xA0, r); \2562a[0x16] ^= PC32up(0xB0, r); \2563a[0x17] ^= PC32dn(0xB0, r); \2564a[0x18] ^= PC32up(0xC0, r); \2565a[0x19] ^= PC32dn(0xC0, r); \2566a[0x1A] ^= PC32up(0xD0, r); \2567a[0x1B] ^= PC32dn(0xD0, r); \2568a[0x1C] ^= PC32up(0xE0, r); \2569a[0x1D] ^= PC32dn(0xE0, r); \2570a[0x1E] ^= PC32up(0xF0, r); \2571a[0x1F] ^= PC32dn(0xF0, r); \2572RBTT(0x00, 0x01, a, \25730x00, 0x02, 0x04, 0x06, 0x09, 0x0B, 0x0D, 0x17); \2574RBTT(0x02, 0x03, a, \25750x02, 0x04, 0x06, 0x08, 0x0B, 0x0D, 0x0F, 0x19); \2576RBTT(0x04, 0x05, a, \25770x04, 0x06, 0x08, 0x0A, 0x0D, 0x0F, 0x11, 0x1B); \2578RBTT(0x06, 0x07, a, \25790x06, 0x08, 0x0A, 0x0C, 0x0F, 0x11, 0x13, 0x1D); \2580RBTT(0x08, 0x09, a, \25810x08, 0x0A, 0x0C, 0x0E, 0x11, 0x13, 0x15, 0x1F); \2582RBTT(0x0A, 0x0B, a, \25830x0A, 0x0C, 0x0E, 0x10, 0x13, 0x15, 0x17, 0x01); \2584RBTT(0x0C, 0x0D, a, \25850x0C, 0x0E, 0x10, 0x12, 0x15, 0x17, 0x19, 0x03); \2586RBTT(0x0E, 0x0F, a, \25870x0E, 0x10, 0x12, 0x14, 0x17, 0x19, 0x1B, 0x05); \2588RBTT(0x10, 0x11, a, \25890x10, 0x12, 0x14, 0x16, 0x19, 0x1B, 0x1D, 0x07); \2590RBTT(0x12, 0x13, a, \25910x12, 0x14, 0x16, 0x18, 0x1B, 0x1D, 0x1F, 0x09); \2592RBTT(0x14, 0x15, a, \25930x14, 0x16, 0x18, 0x1A, 0x1D, 0x1F, 0x01, 0x0B); \2594RBTT(0x16, 0x17, a, \25950x16, 0x18, 0x1A, 0x1C, 0x1F, 0x01, 0x03, 0x0D); \2596RBTT(0x18, 0x19, a, \25970x18, 0x1A, 0x1C, 0x1E, 0x01, 0x03, 0x05, 0x0F); \2598RBTT(0x1A, 0x1B, a, \25990x1A, 0x1C, 0x1E, 0x00, 0x03, 0x05, 0x07, 0x11); \2600RBTT(0x1C, 0x1D, a, \26010x1C, 0x1E, 0x00, 0x02, 0x05, 0x07, 0x09, 0x13); \2602RBTT(0x1E, 0x1F, a, \26030x1E, 0x00, 0x02, 0x04, 0x07, 0x09, 0x0B, 0x15); \2604memcpy(a, t, sizeof t); \2605} while (0)26062607#define ROUND_BIG_Q(a, r) do { \2608sph_u32 t[32]; \2609a[0x00] ^= QC32up(0x00, r); \2610a[0x01] ^= QC32dn(0x00, r); \2611a[0x02] ^= QC32up(0x10, r); \2612a[0x03] ^= QC32dn(0x10, r); \2613a[0x04] ^= QC32up(0x20, r); \2614a[0x05] ^= QC32dn(0x20, r); \2615a[0x06] ^= QC32up(0x30, r); \2616a[0x07] ^= QC32dn(0x30, r); \2617a[0x08] ^= QC32up(0x40, r); \2618a[0x09] ^= QC32dn(0x40, r); \2619a[0x0A] ^= QC32up(0x50, r); \2620a[0x0B] ^= QC32dn(0x50, r); \2621a[0x0C] ^= QC32up(0x60, r); \2622a[0x0D] ^= QC32dn(0x60, r); \2623a[0x0E] ^= QC32up(0x70, r); \2624a[0x0F] ^= QC32dn(0x70, r); \2625a[0x10] ^= QC32up(0x80, r); \2626a[0x11] ^= QC32dn(0x80, r); \2627a[0x12] ^= QC32up(0x90, r); \2628a[0x13] ^= QC32dn(0x90, r); \2629a[0x14] ^= QC32up(0xA0, r); \2630a[0x15] ^= QC32dn(0xA0, r); \2631a[0x16] ^= QC32up(0xB0, r); \2632a[0x17] ^= QC32dn(0xB0, r); \2633a[0x18] ^= QC32up(0xC0, r); \2634a[0x19] ^= QC32dn(0xC0, r); \2635a[0x1A] ^= QC32up(0xD0, r); \2636a[0x1B] ^= QC32dn(0xD0, r); \2637a[0x1C] ^= QC32up(0xE0, r); \2638a[0x1D] ^= QC32dn(0xE0, r); \2639a[0x1E] ^= QC32up(0xF0, r); \2640a[0x1F] ^= QC32dn(0xF0, r); \2641RBTT(0x00, 0x01, a, \26420x02, 0x06, 0x0A, 0x16, 0x01, 0x05, 0x09, 0x0D); \2643RBTT(0x02, 0x03, a, \26440x04, 0x08, 0x0C, 0x18, 0x03, 0x07, 0x0B, 0x0F); \2645RBTT(0x04, 0x05, a, \26460x06, 0x0A, 0x0E, 0x1A, 0x05, 0x09, 0x0D, 0x11); \2647RBTT(0x06, 0x07, a, \26480x08, 0x0C, 0x10, 0x1C, 0x07, 0x0B, 0x0F, 0x13); \2649RBTT(0x08, 0x09, a, \26500x0A, 0x0E, 0x12, 0x1E, 0x09, 0x0D, 0x11, 0x15); \2651RBTT(0x0A, 0x0B, a, \26520x0C, 0x10, 0x14, 0x00, 0x0B, 0x0F, 0x13, 0x17); \2653RBTT(0x0C, 0x0D, a, \26540x0E, 0x12, 0x16, 0x02, 0x0D, 0x11, 0x15, 0x19); \2655RBTT(0x0E, 0x0F, a, \26560x10, 0x14, 0x18, 0x04, 0x0F, 0x13, 0x17, 0x1B); \2657RBTT(0x10, 0x11, a, \26580x12, 0x16, 0x1A, 0x06, 0x11, 0x15, 0x19, 0x1D); \2659RBTT(0x12, 0x13, a, \26600x14, 0x18, 0x1C, 0x08, 0x13, 0x17, 0x1B, 0x1F); \2661RBTT(0x14, 0x15, a, \26620x16, 0x1A, 0x1E, 0x0A, 0x15, 0x19, 0x1D, 0x01); \2663RBTT(0x16, 0x17, a, \26640x18, 0x1C, 0x00, 0x0C, 0x17, 0x1B, 0x1F, 0x03); \2665RBTT(0x18, 0x19, a, \26660x1A, 0x1E, 0x02, 0x0E, 0x19, 0x1D, 0x01, 0x05); \2667RBTT(0x1A, 0x1B, a, \26680x1C, 0x00, 0x04, 0x10, 0x1B, 0x1F, 0x03, 0x07); \2669RBTT(0x1C, 0x1D, a, \26700x1E, 0x02, 0x06, 0x12, 0x1D, 0x01, 0x05, 0x09); \2671RBTT(0x1E, 0x1F, a, \26720x00, 0x04, 0x08, 0x14, 0x1F, 0x03, 0x07, 0x0B); \2673memcpy(a, t, sizeof t); \2674} while (0)26752676#endif26772678#if SPH_SMALL_FOOTPRINT_GROESTL26792680#define PERM_BIG_P(a) do { \2681int r; \2682for (r = 0; r < 14; r ++) \2683ROUND_BIG_P(a, r); \2684} while (0)26852686#define PERM_BIG_Q(a) do { \2687int r; \2688for (r = 0; r < 14; r ++) \2689ROUND_BIG_Q(a, r); \2690} while (0)26912692#else26932694#define PERM_BIG_P(a) do { \2695int r; \2696for (r = 0; r < 14; r += 2) { \2697ROUND_BIG_P(a, r + 0); \2698ROUND_BIG_P(a, r + 1); \2699} \2700} while (0)27012702#define PERM_BIG_Q(a) do { \2703int r; \2704for (r = 0; r < 14; r += 2) { \2705ROUND_BIG_Q(a, r + 0); \2706ROUND_BIG_Q(a, r + 1); \2707} \2708} while (0)27092710#endif27112712#define COMPRESS_BIG do { \2713sph_u32 g[32], m[32]; \2714size_t u; \2715for (u = 0; u < 32; u ++) { \2716m[u] = dec32e_aligned(buf + (u << 2)); \2717g[u] = m[u] ^ H[u]; \2718} \2719PERM_BIG_P(g); \2720PERM_BIG_Q(m); \2721for (u = 0; u < 32; u ++) \2722H[u] ^= g[u] ^ m[u]; \2723} while (0)27242725#define FINAL_BIG do { \2726sph_u32 x[32]; \2727size_t u; \2728memcpy(x, H, sizeof x); \2729PERM_BIG_P(x); \2730for (u = 0; u < 32; u ++) \2731H[u] ^= x[u]; \2732} while (0)27332734#endif27352736static void2737groestl_small_init(sph_groestl_small_context *sc, unsigned out_size)2738{2739size_t u;27402741sc->ptr = 0;2742#if SPH_GROESTL_642743for (u = 0; u < 7; u ++)2744sc->state.wide[u] = 0;2745#if USE_LE2746sc->state.wide[7] = ((sph_u64)(out_size & 0xFF) << 56)2747| ((sph_u64)(out_size & 0xFF00) << 40);2748#else2749sc->state.wide[7] = (sph_u64)out_size;2750#endif2751#else2752for (u = 0; u < 15; u ++)2753sc->state.narrow[u] = 0;2754#if USE_LE2755sc->state.narrow[15] = ((sph_u32)(out_size & 0xFF) << 24)2756| ((sph_u32)(out_size & 0xFF00) << 8);2757#else2758sc->state.narrow[15] = (sph_u32)out_size;2759#endif2760#endif2761#if SPH_642762sc->count = 0;2763#else2764sc->count_high = 0;2765sc->count_low = 0;2766#endif2767}27682769static void2770groestl_small_core(sph_groestl_small_context *sc, const void *data, size_t len)2771{2772unsigned char *buf;2773size_t ptr;2774DECL_STATE_SMALL27752776buf = sc->buf;2777ptr = sc->ptr;2778if (len < (sizeof sc->buf) - ptr) {2779memcpy(buf + ptr, data, len);2780ptr += len;2781sc->ptr = ptr;2782return;2783}27842785READ_STATE_SMALL(sc);2786while (len > 0) {2787size_t clen;27882789clen = (sizeof sc->buf) - ptr;2790if (clen > len)2791clen = len;2792memcpy(buf + ptr, data, clen);2793ptr += clen;2794data = (const unsigned char *)data + clen;2795len -= clen;2796if (ptr == sizeof sc->buf) {2797COMPRESS_SMALL;2798#if SPH_642799sc->count ++;2800#else2801if ((sc->count_low = SPH_T32(sc->count_low + 1)) == 0)2802sc->count_high = SPH_T32(sc->count_high + 1);2803#endif2804ptr = 0;2805}2806}2807WRITE_STATE_SMALL(sc);2808sc->ptr = ptr;2809}28102811static void2812groestl_small_close(sph_groestl_small_context *sc,2813unsigned ub, unsigned n, void *dst, size_t out_len)2814{2815unsigned char pad[72];2816size_t u, ptr, pad_len;2817#if SPH_642818sph_u64 count;2819#else2820sph_u32 count_high, count_low;2821#endif2822unsigned z;2823DECL_STATE_SMALL28242825ptr = sc->ptr;2826z = 0x80 >> n;2827pad[0] = ((ub & -z) | z) & 0xFF;2828if (ptr < 56) {2829pad_len = 64 - ptr;2830#if SPH_642831count = SPH_T64(sc->count + 1);2832#else2833count_low = SPH_T32(sc->count_low + 1);2834count_high = SPH_T32(sc->count_high);2835if (count_low == 0)2836count_high = SPH_T32(count_high + 1);2837#endif2838} else {2839pad_len = 128 - ptr;2840#if SPH_642841count = SPH_T64(sc->count + 2);2842#else2843count_low = SPH_T32(sc->count_low + 2);2844count_high = SPH_T32(sc->count_high);2845if (count_low <= 1)2846count_high = SPH_T32(count_high + 1);2847#endif2848}2849memset(pad + 1, 0, pad_len - 9);2850#if SPH_642851sph_enc64be(pad + pad_len - 8, count);2852#else2853sph_enc64be(pad + pad_len - 8, count_high);2854sph_enc64be(pad + pad_len - 4, count_low);2855#endif2856groestl_small_core(sc, pad, pad_len);2857READ_STATE_SMALL(sc);2858FINAL_SMALL;2859#if SPH_GROESTL_642860for (u = 0; u < 4; u ++)2861enc64e(pad + (u << 3), H[u + 4]);2862#else2863for (u = 0; u < 8; u ++)2864enc32e(pad + (u << 2), H[u + 8]);2865#endif2866memcpy(dst, pad + 32 - out_len, out_len);2867groestl_small_init(sc, (unsigned)out_len << 3);2868}28692870static void2871groestl_big_init(sph_groestl_big_context *sc, unsigned out_size)2872{2873size_t u;28742875sc->ptr = 0;2876#if SPH_GROESTL_642877for (u = 0; u < 15; u ++)2878sc->state.wide[u] = 0;2879#if USE_LE2880sc->state.wide[15] = ((sph_u64)(out_size & 0xFF) << 56)2881| ((sph_u64)(out_size & 0xFF00) << 40);2882#else2883sc->state.wide[15] = (sph_u64)out_size;2884#endif2885#else2886for (u = 0; u < 31; u ++)2887sc->state.narrow[u] = 0;2888#if USE_LE2889sc->state.narrow[31] = ((sph_u32)(out_size & 0xFF) << 24)2890| ((sph_u32)(out_size & 0xFF00) << 8);2891#else2892sc->state.narrow[31] = (sph_u32)out_size;2893#endif2894#endif2895#if SPH_642896sc->count = 0;2897#else2898sc->count_high = 0;2899sc->count_low = 0;2900#endif2901}29022903static void2904groestl_big_core(sph_groestl_big_context *sc, const void *data, size_t len)2905{2906unsigned char *buf;2907size_t ptr;2908DECL_STATE_BIG29092910buf = sc->buf;2911ptr = sc->ptr;2912if (len < (sizeof sc->buf) - ptr) {2913memcpy(buf + ptr, data, len);2914ptr += len;2915sc->ptr = ptr;2916return;2917}29182919READ_STATE_BIG(sc);2920while (len > 0) {2921size_t clen;29222923clen = (sizeof sc->buf) - ptr;2924if (clen > len)2925clen = len;2926memcpy(buf + ptr, data, clen);2927ptr += clen;2928data = (const unsigned char *)data + clen;2929len -= clen;2930if (ptr == sizeof sc->buf) {2931COMPRESS_BIG;2932#if SPH_642933sc->count ++;2934#else2935if ((sc->count_low = SPH_T32(sc->count_low + 1)) == 0)2936sc->count_high = SPH_T32(sc->count_high + 1);2937#endif2938ptr = 0;2939}2940}2941WRITE_STATE_BIG(sc);2942sc->ptr = ptr;2943}29442945static void2946groestl_big_close(sph_groestl_big_context *sc,2947unsigned ub, unsigned n, void *dst, size_t out_len)2948{2949unsigned char pad[136];2950size_t ptr, pad_len, u;2951#if SPH_642952sph_u64 count;2953#else2954sph_u32 count_high, count_low;2955#endif2956unsigned z;2957DECL_STATE_BIG29582959ptr = sc->ptr;2960z = 0x80 >> n;2961pad[0] = ((ub & -z) | z) & 0xFF;2962if (ptr < 120) {2963pad_len = 128 - ptr;2964#if SPH_642965count = SPH_T64(sc->count + 1);2966#else2967count_low = SPH_T32(sc->count_low + 1);2968count_high = SPH_T32(sc->count_high);2969if (count_low == 0)2970count_high = SPH_T32(count_high + 1);2971#endif2972} else {2973pad_len = 256 - ptr;2974#if SPH_642975count = SPH_T64(sc->count + 2);2976#else2977count_low = SPH_T32(sc->count_low + 2);2978count_high = SPH_T32(sc->count_high);2979if (count_low <= 1)2980count_high = SPH_T32(count_high + 1);2981#endif2982}2983memset(pad + 1, 0, pad_len - 9);2984#if SPH_642985sph_enc64be(pad + pad_len - 8, count);2986#else2987sph_enc64be(pad + pad_len - 8, count_high);2988sph_enc64be(pad + pad_len - 4, count_low);2989#endif2990groestl_big_core(sc, pad, pad_len);2991READ_STATE_BIG(sc);2992FINAL_BIG;2993#if SPH_GROESTL_642994for (u = 0; u < 8; u ++)2995enc64e(pad + (u << 3), H[u + 8]);2996#else2997for (u = 0; u < 16; u ++)2998enc32e(pad + (u << 2), H[u + 16]);2999#endif3000memcpy(dst, pad + 64 - out_len, out_len);3001groestl_big_init(sc, (unsigned)out_len << 3);3002}30033004/* see sph_groestl.h */3005void3006sph_groestl224_init(void *cc)3007{3008groestl_small_init(cc, 224);3009}30103011/* see sph_groestl.h */3012void3013sph_groestl224(void *cc, const void *data, size_t len)3014{3015groestl_small_core(cc, data, len);3016}30173018/* see sph_groestl.h */3019void3020sph_groestl224_close(void *cc, void *dst)3021{3022groestl_small_close(cc, 0, 0, dst, 28);3023}30243025/* see sph_groestl.h */3026void3027sph_groestl224_addbits_and_close(void *cc, unsigned ub, unsigned n, void *dst)3028{3029groestl_small_close(cc, ub, n, dst, 28);3030}30313032/* see sph_groestl.h */3033void3034sph_groestl256_init(void *cc)3035{3036groestl_small_init(cc, 256);3037}30383039/* see sph_groestl.h */3040void3041sph_groestl256(void *cc, const void *data, size_t len)3042{3043groestl_small_core(cc, data, len);3044}30453046/* see sph_groestl.h */3047void3048sph_groestl256_close(void *cc, void *dst)3049{3050groestl_small_close(cc, 0, 0, dst, 32);3051}30523053/* see sph_groestl.h */3054void3055sph_groestl256_addbits_and_close(void *cc, unsigned ub, unsigned n, void *dst)3056{3057groestl_small_close(cc, ub, n, dst, 32);3058}30593060/* see sph_groestl.h */3061void3062sph_groestl384_init(void *cc)3063{3064groestl_big_init(cc, 384);3065}30663067/* see sph_groestl.h */3068void3069sph_groestl384(void *cc, const void *data, size_t len)3070{3071groestl_big_core(cc, data, len);3072}30733074/* see sph_groestl.h */3075void3076sph_groestl384_close(void *cc, void *dst)3077{3078groestl_big_close(cc, 0, 0, dst, 48);3079}30803081/* see sph_groestl.h */3082void3083sph_groestl384_addbits_and_close(void *cc, unsigned ub, unsigned n, void *dst)3084{3085groestl_big_close(cc, ub, n, dst, 48);3086}30873088/* see sph_groestl.h */3089void3090sph_groestl512_init(void *cc)3091{3092groestl_big_init(cc, 512);3093}30943095/* see sph_groestl.h */3096void3097sph_groestl512(void *cc, const void *data, size_t len)3098{3099groestl_big_core(cc, data, len);3100}31013102/* see sph_groestl.h */3103void3104sph_groestl512_close(void *cc, void *dst)3105{3106groestl_big_close(cc, 0, 0, dst, 64);3107}31083109/* see sph_groestl.h */3110void3111sph_groestl512_addbits_and_close(void *cc, unsigned ub, unsigned n, void *dst)3112{3113groestl_big_close(cc, ub, n, dst, 64);3114}31153116#ifdef __cplusplus3117}3118#endif311931203121