// SPDX-License-Identifier: GPL-2.0+ OR BSD-2-Clause
/*
* Streebog hash function as specified by GOST R 34.11-2012 and
* described at https://tools.ietf.org/html/rfc6986
*
* Copyright (c) 2013 Alexey Degtyarev <alexey@renatasystems.org>
* Copyright (c) 2018 Vitaly Chikunov <vt@altlinux.org>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option)
* any later version.
*/
#include <crypto/internal/hash.h>
#include <crypto/streebog.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/string.h>
static const struct streebog_uint512 buffer0 = { {
0 ,
0 ,
0 ,
0 ,
0 ,
0 ,
0 ,
0
} };
static const struct streebog_uint512 buffer512 = { {
cpu_to_le64(
0 x200),
0 ,
0 ,
0 ,
0 ,
0 ,
0 ,
0
} };
static const struct streebog_uint512 C[
12 ] = {
{ {
cpu_to_le64(
0 xdd806559f2a64507ULL),
cpu_to_le64(
0 x05767436cc744d23ULL),
cpu_to_le64(
0 xa2422a08a460d315ULL),
cpu_to_le64(
0 x4b7ce09192676901ULL),
cpu_to_le64(
0 x714eb88d7585c4fcULL),
cpu_to_le64(
0 x2f6a76432e45d016ULL),
cpu_to_le64(
0 xebcb2f81c0657c1fULL),
cpu_to_le64(
0 xb1085bda1ecadae9ULL)
} },
{ {
cpu_to_le64(
0 xe679047021b19bb7ULL),
cpu_to_le64(
0 x55dda21bd7cbcd56ULL),
cpu_to_le64(
0 x5cb561c2db0aa7caULL),
cpu_to_le64(
0 x9ab5176b12d69958ULL),
cpu_to_le64(
0 x61d55e0f16b50131ULL),
cpu_to_le64(
0 xf3feea720a232b98ULL),
cpu_to_le64(
0 x4fe39d460f70b5d7ULL),
cpu_to_le64(
0 x6fa3b58aa99d2f1aULL)
} },
{ {
cpu_to_le64(
0 x991e96f50aba0ab2ULL),
cpu_to_le64(
0 xc2b6f443867adb31ULL),
cpu_to_le64(
0 xc1c93a376062db09ULL),
cpu_to_le64(
0 xd3e20fe490359eb1ULL),
cpu_to_le64(
0 xf2ea7514b1297b7bULL),
cpu_to_le64(
0 x06f15e5f529c1f8bULL),
cpu_to_le64(
0 x0a39fc286a3d8435ULL),
cpu_to_le64(
0 xf574dcac2bce2fc7ULL)
} },
{ {
cpu_to_le64(
0 x220cbebc84e3d12eULL),
cpu_to_le64(
0 x3453eaa193e837f1ULL),
cpu_to_le64(
0 xd8b71333935203beULL),
cpu_to_le64(
0 xa9d72c82ed03d675ULL),
cpu_to_le64(
0 x9d721cad685e353fULL),
cpu_to_le64(
0 x488e857e335c3c7dULL),
cpu_to_le64(
0 xf948e1a05d71e4ddULL),
cpu_to_le64(
0 xef1fdfb3e81566d2ULL)
} },
{ {
cpu_to_le64(
0 x601758fd7c6cfe57ULL),
cpu_to_le64(
0 x7a56a27ea9ea63f5ULL),
cpu_to_le64(
0 xdfff00b723271a16ULL),
cpu_to_le64(
0 xbfcd1747253af5a3ULL),
cpu_to_le64(
0 x359e35d7800fffbdULL),
cpu_to_le64(
0 x7f151c1f1686104aULL),
cpu_to_le64(
0 x9a3f410c6ca92363ULL),
cpu_to_le64(
0 x4bea6bacad474799ULL)
} },
{ {
cpu_to_le64(
0 xfa68407a46647d6eULL),
cpu_to_le64(
0 xbf71c57236904f35ULL),
cpu_to_le64(
0 x0af21f66c2bec6b6ULL),
cpu_to_le64(
0 xcffaa6b71c9ab7b4ULL),
cpu_to_le64(
0 x187f9ab49af08ec6ULL),
cpu_to_le64(
0 x2d66c4f95142a46cULL),
cpu_to_le64(
0 x6fa4c33b7a3039c0ULL),
cpu_to_le64(
0 xae4faeae1d3ad3d9ULL)
} },
{ {
cpu_to_le64(
0 x8886564d3a14d493ULL),
cpu_to_le64(
0 x3517454ca23c4af3ULL),
cpu_to_le64(
0 x06476983284a0504ULL),
cpu_to_le64(
0 x0992abc52d822c37ULL),
cpu_to_le64(
0 xd3473e33197a93c9ULL),
cpu_to_le64(
0 x399ec6c7e6bf87c9ULL),
cpu_to_le64(
0 x51ac86febf240954ULL),
cpu_to_le64(
0 xf4c70e16eeaac5ecULL)
} },
{ {
cpu_to_le64(
0 xa47f0dd4bf02e71eULL),
cpu_to_le64(
0 x36acc2355951a8d9ULL),
cpu_to_le64(
0 x69d18d2bd1a5c42fULL),
cpu_to_le64(
0 xf4892bcb929b0690ULL),
cpu_to_le64(
0 x89b4443b4ddbc49aULL),
cpu_to_le64(
0 x4eb7f8719c36de1eULL),
cpu_to_le64(
0 x03e7aa020c6e4141ULL),
cpu_to_le64(
0 x9b1f5b424d93c9a7ULL)
} },
{ {
cpu_to_le64(
0 x7261445183235adbULL),
cpu_to_le64(
0 x0e38dc92cb1f2a60ULL),
cpu_to_le64(
0 x7b2b8a9aa6079c54ULL),
cpu_to_le64(
0 x800a440bdbb2ceb1ULL),
cpu_to_le64(
0 x3cd955b7e00d0984ULL),
cpu_to_le64(
0 x3a7d3a1b25894224ULL),
cpu_to_le64(
0 x944c9ad8ec165fdeULL),
cpu_to_le64(
0 x378f5a541631229bULL)
} },
{ {
cpu_to_le64(
0 x74b4c7fb98459cedULL),
cpu_to_le64(
0 x3698fad1153bb6c3ULL),
cpu_to_le64(
0 x7a1e6c303b7652f4ULL),
cpu_to_le64(
0 x9fe76702af69334bULL),
cpu_to_le64(
0 x1fffe18a1b336103ULL),
cpu_to_le64(
0 x8941e71cff8a78dbULL),
cpu_to_le64(
0 x382ae548b2e4f3f3ULL),
cpu_to_le64(
0 xabbedea680056f52ULL)
} },
{ {
cpu_to_le64(
0 x6bcaa4cd81f32d1bULL),
cpu_to_le64(
0 xdea2594ac06fd85dULL),
cpu_to_le64(
0 xefbacd1d7d476e98ULL),
cpu_to_le64(
0 x8a1d71efea48b9caULL),
cpu_to_le64(
0 x2001802114846679ULL),
cpu_to_le64(
0 xd8fa6bbbebab0761ULL),
cpu_to_le64(
0 x3002c6cd635afe94ULL),
cpu_to_le64(
0 x7bcd9ed0efc889fbULL)
} },
{ {
cpu_to_le64(
0 x48bc924af11bd720ULL),
cpu_to_le64(
0 xfaf417d5d9b21b99ULL),
cpu_to_le64(
0 xe71da4aa88e12852ULL),
cpu_to_le64(
0 x5d80ef9d1891cc86ULL),
cpu_to_le64(
0 xf82012d430219f9bULL),
cpu_to_le64(
0 xcda43c32bcdf1d77ULL),
cpu_to_le64(
0 xd21380b00449b17aULL),
cpu_to_le64(
0 x378ee767f11631baULL)
} }
};
static const unsigned long long Ax[
8 ][
256 ] = {
{
0 xd01f715b5c7ef8e6ULL,
0 x16fa240980778325ULL,
0 xa8a42e857ee049c8ULL,
0 x6ac1068fa186465bULL,
0 x6e417bd7a2e9320bULL,
0 x665c8167a437daabULL,
0 x7666681aa89617f6ULL,
0 x4b959163700bdcf5ULL,
0 xf14be6b78df36248ULL,
0 xc585bd689a625cffULL,
0 x9557d7fca67d82cbULL,
0 x89f0b969af6dd366ULL,
0 xb0833d48749f6c35ULL,
0 xa1998c23b1ecbc7cULL,
0 x8d70c431ac02a736ULL,
0 xd6dfbc2fd0a8b69eULL,
0 x37aeb3e551fa198bULL,
0 x0b7d128a40b5cf9cULL,
0 x5a8f2008b5780cbcULL,
0 xedec882284e333e5ULL,
0 xd25fc177d3c7c2ceULL,
0 x5e0f5d50b61778ecULL,
0 x1d873683c0c24cb9ULL,
0 xad040bcbb45d208cULL,
0 x2f89a0285b853c76ULL,
0 x5732fff6791b8d58ULL,
0 x3e9311439ef6ec3fULL,
0 xc9183a809fd3c00fULL,
0 x83adf3f5260a01eeULL,
0 xa6791941f4e8ef10ULL,
0 x103ae97d0ca1cd5dULL,
0 x2ce948121dee1b4aULL,
0 x39738421dbf2bf53ULL,
0 x093da2a6cf0cf5b4ULL,
0 xcd9847d89cbcb45fULL,
0 xf9561c078b2d8ae8ULL,
0 x9c6a755a6971777fULL,
0 xbc1ebaa0712ef0c5ULL,
0 x72e61542abf963a6ULL,
0 x78bb5fde229eb12eULL,
0 x14ba94250fceb90dULL,
0 x844d6697630e5282ULL,
0 x98ea08026a1e032fULL,
0 xf06bbea144217f5cULL,
0 xdb6263d11ccb377aULL,
0 x641c314b2b8ee083ULL,
0 x320e96ab9b4770cfULL,
0 x1ee7deb986a96b85ULL,
0 xe96cf57a878c47b5ULL,
0 xfdd6615f8842feb8ULL,
0 xc83862965601dd1bULL,
0 x2ea9f83e92572162ULL,
0 xf876441142ff97fcULL,
0 xeb2c455608357d9dULL,
0 x5612a7e0b0c9904cULL,
0 x6c01cbfb2d500823ULL,
0 x4548a6a7fa037a2dULL,
0 xabc4c6bf388b6ef4ULL,
0 xbade77d4fdf8bebdULL,
0 x799b07c8eb4cac3aULL,
0 x0c9d87e805b19cf0ULL,
0 xcb588aac106afa27ULL,
0 xea0c1d40c1e76089ULL,
0 x2869354a1e816f1aULL,
0 xff96d17307fbc490ULL,
0 x9f0a9d602f1a5043ULL,
0 x96373fc6e016a5f7ULL,
0 x5292dab8b3a6e41cULL,
0 x9b8ae0382c752413ULL,
0 x4f15ec3b7364a8a5ULL,
0 x3fb349555724f12bULL,
0 xc7c50d4415db66d7ULL,
0 x92b7429ee379d1a7ULL,
0 xd37f99611a15dfdaULL,
0 x231427c05e34a086ULL,
0 xa439a96d7b51d538ULL,
0 xb403401077f01865ULL,
0 xdda2aea5901d7902ULL,
0 x0a5d4a9c8967d288ULL,
0 xc265280adf660f93ULL,
0 x8bb0094520d4e94eULL,
0 x2a29856691385532ULL,
0 x42a833c5bf072941ULL,
0 x73c64d54622b7eb2ULL,
0 x07e095624504536cULL,
0 x8a905153e906f45aULL,
0 x6f6123c16b3b2f1fULL,
0 xc6e55552dc097bc3ULL,
0 x4468feb133d16739ULL,
0 xe211e7f0c7398829ULL,
0 xa2f96419f7879b40ULL,
0 x19074bdbc3ad38e9ULL,
0 xf4ebc3f9474e0b0cULL,
0 x43886bd376d53455ULL,
0 xd8028beb5aa01046ULL,
0 x51f23282f5cdc320ULL,
0 xe7b1c2be0d84e16dULL,
0 x081dfab006dee8a0ULL,
0 x3b33340d544b857bULL,
0 x7f5bcabc679ae242ULL,
0 x0edd37c48a08a6d8ULL,
0 x81ed43d9a9b33bc6ULL,
0 xb1a3655ebd4d7121ULL,
0 x69a1eeb5e7ed6167ULL,
0 xf6ab73d5c8f73124ULL,
0 x1a67a3e185c61fd5ULL,
0 x2dc91004d43c065eULL,
0 x0240b02c8fb93a28ULL,
0 x90f7f2b26cc0eb8fULL,
0 x3cd3a16f114fd617ULL,
0 xaae49ea9f15973e0ULL,
0 x06c0cd748cd64e78ULL,
0 xda423bc7d5192a6eULL,
0 xc345701c16b41287ULL,
0 x6d2193ede4821537ULL,
0 xfcf639494190e3acULL,
0 x7c3b228621f1c57eULL,
0 xfb16ac2b0494b0c0ULL,
0 xbf7e529a3745d7f9ULL,
0 x6881b6a32e3f7c73ULL,
0 xca78d2bad9b8e733ULL,
0 xbbfe2fc2342aa3a9ULL,
0 x0dbddffecc6381e4ULL,
0 x70a6a56e2440598eULL,
0 xe4d12a844befc651ULL,
0 x8c509c2765d0ba22ULL,
0 xee8c6018c28814d9ULL,
0 x17da7c1f49a59e31ULL,
0 x609c4c1328e194d3ULL,
0 xb3e3d57232f44b09ULL,
0 x91d7aaa4a512f69bULL,
0 x0ffd6fd243dabbccULL,
0 x50d26a943c1fde34ULL,
0 x6be15e9968545b4fULL,
0 x94778fea6faf9fdfULL,
0 x2b09dd7058ea4826ULL,
0 x677cd9716de5c7bfULL,
0 x49d5214fffb2e6ddULL,
0 x0360e83a466b273cULL,
0 x1fc786af4f7b7691ULL,
0 xa0b9d435783ea168ULL,
0 xd49f0c035f118cb6ULL,
0 x01205816c9d21d14ULL,
0 xac2453dd7d8f3d98ULL,
0 x545217cc3f70aa64ULL,
0 x26b4028e9489c9c2ULL,
0 xdec2469fd6765e3eULL,
0 x04807d58036f7450ULL,
0 xe5f17292823ddb45ULL,
0 xf30b569b024a5860ULL,
0 x62dcfc3fa758aefbULL,
0 xe84cad6c4e5e5aa1ULL,
0 xccb81fce556ea94bULL,
0 x53b282ae7a74f908ULL,
0 x1b47fbf74c1402c1ULL,
0 x368eebf39828049fULL,
0 x7afbeff2ad278b06ULL,
0 xbe5e0a8cfe97caedULL,
0 xcfd8f7f413058e77ULL,
0 xf78b2bc301252c30ULL,
0 x4d555c17fcdd928dULL,
0 x5f2f05467fc565f8ULL,
0 x24f4b2a21b30f3eaULL,
0 x860dd6bbecb768aaULL,
0 x4c750401350f8f99ULL,
0 x0000000000000000ULL,
0 xecccd0344d312ef1ULL,
0 xb5231806be220571ULL,
0 xc105c030990d28afULL,
0 x653c695de25cfd97ULL,
0 x159acc33c61ca419ULL,
0 xb89ec7f872418495ULL,
0 xa9847693b73254dcULL,
0 x58cf90243ac13694ULL,
0 x59efc832f3132b80ULL,
0 x5c4fed7c39ae42c4ULL,
0 x828dabe3efd81cfaULL,
0 xd13f294d95ace5f2ULL,
0 x7d1b7a90e823d86aULL,
0 xb643f03cf849224dULL,
0 x3df3f979d89dcb03ULL,
0 x7426d836272f2ddeULL,
0 xdfe21e891fa4432aULL,
0 x3a136c1b9d99986fULL,
0 xfa36f43dcd46add4ULL,
0 xc025982650df35bbULL,
0 x856d3e81aadc4f96ULL,
0 xc4a5e57e53b041ebULL,
0 x4708168b75ba4005ULL,
0 xaf44bbe73be41aa4ULL,
0 x971767d029c4b8e3ULL,
0 xb9be9feebb939981ULL,
0 x215497ecd18d9aaeULL,
0 x316e7e91dd2c57f3ULL,
0 xcef8afe2dad79363ULL,
0 x3853dc371220a247ULL,
0 x35ee03c9de4323a3ULL,
0 xe6919aa8c456fc79ULL,
0 xe05157dc4880b201ULL,
0 x7bdbb7e464f59612ULL,
0 x127a59518318f775ULL,
0 x332ecebd52956ddbULL,
0 x8f30741d23bb9d1eULL,
0 xd922d3fd93720d52ULL,
0 x7746300c61440ae2ULL,
0 x25d4eab4d2e2eefeULL,
0 x75068020eefd30caULL,
0 x135a01474acaea61ULL,
0 x304e268714fe4ae7ULL,
0 xa519f17bb283c82cULL,
0 xdc82f6b359cf6416ULL,
0 x5baf781e7caa11a8ULL,
0 xb2c38d64fb26561dULL,
0 x34ce5bdf17913eb7ULL,
0 x5d6fb56af07c5fd0ULL,
0 x182713cd0a7f25fdULL,
0 x9e2ac576e6c84d57ULL,
0 x9aaab82ee5a73907ULL,
0 xa3d93c0f3e558654ULL,
0 x7e7b92aaae48ff56ULL,
0 x872d8ead256575beULL,
0 x41c8dbfff96c0e7dULL,
0 x99ca5014a3cc1e3bULL,
0 x40e883e930be1369ULL,
0 x1ca76e95091051adULL,
0 x4e35b42dbab6b5b1ULL,
0 x05a0254ecabd6944ULL,
0 xe1710fca8152af15ULL,
0 xf22b0e8dcb984574ULL,
0 xb763a82a319b3f59ULL,
0 x63fca4296e8ab3efULL,
0 x9d4a2d4ca0a36a6bULL,
0 xe331bfe60eeb953dULL,
0 xd5bf541596c391a2ULL,
0 xf5cb9bef8e9c1618ULL,
0 x46284e9dbc685d11ULL,
0 x2074cffa185f87baULL,
0 xbd3ee2b6b8fcedd1ULL,
0 xae64e3f1f23607b0ULL,
0 xfeb68965ce29d984ULL,
0 x55724fdaf6a2b770ULL,
0 x29496d5cd753720eULL,
0 xa75941573d3af204ULL,
0 x8e102c0bea69800aULL,
0 x111ab16bc573d049ULL,
0 xd7ffe439197aab8aULL,
0 xefac380e0b5a09cdULL,
0 x48f579593660fbc9ULL,
0 x22347fd697e6bd92ULL,
0 x61bc1405e13389c7ULL,
0 x4ab5c975b9d9c1e1ULL,
0 x80cd1bcf606126d2ULL,
0 x7186fd78ed92449aULL,
0 x93971a882aabccb3ULL,
0 x88d0e17f66bfce72ULL,
0 x27945a985d5bd4d6ULL
}, {
0 xde553f8c05a811c8ULL,
0 x1906b59631b4f565ULL,
0 x436e70d6b1964ff7ULL,
0 x36d343cb8b1e9d85ULL,
0 x843dfacc858aab5aULL,
0 xfdfc95c299bfc7f9ULL,
0 x0f634bdea1d51fa2ULL,
0 x6d458b3b76efb3cdULL,
0 x85c3f77cf8593f80ULL,
0 x3c91315fbe737cb2ULL,
0 x2148b03366ace398ULL,
0 x18f8b8264c6761bfULL,
0 xc830c1c495c9fb0fULL,
0 x981a76102086a0aaULL,
0 xaa16012142f35760ULL,
0 x35cc54060c763cf6ULL,
0 x42907d66cc45db2dULL,
0 x8203d44b965af4bcULL,
0 x3d6f3cefc3a0e868ULL,
0 xbc73ff69d292bda7ULL,
0 x8722ed0102e20a29ULL,
0 x8f8185e8cd34deb7ULL,
0 x9b0561dda7ee01d9ULL,
0 x5335a0193227fad6ULL,
0 xc9cecc74e81a6fd5ULL,
0 x54f5832e5c2431eaULL,
0 x99e47ba05d553470ULL,
0 xf7bee756acd226ceULL,
0 x384e05a5571816fdULL,
0 xd1367452a47d0e6aULL,
0 xf29fde1c386ad85bULL,
0 x320c77316275f7caULL,
0 xd0c879e2d9ae9ab0ULL,
0 xdb7406c69110ef5dULL,
0 x45505e51a2461011ULL,
0 xfc029872e46c5323ULL,
0 xfa3cb6f5f7bc0cc5ULL,
0 x031f17cd8768a173ULL,
0 xbd8df2d9af41297dULL,
0 x9d3b4f5ab43e5e3fULL,
0 x4071671b36feee84ULL,
0 x716207e7d3e3b83dULL,
0 x48d20ff2f9283a1aULL,
0 x27769eb4757cbc7eULL,
0 x5c56ebc793f2e574ULL,
0 xa48b474f9ef5dc18ULL,
0 x52cbada94ff46e0cULL,
0 x60c7da982d8199c6ULL,
0 x0e9d466edc068b78ULL,
0 x4eec2175eaf865fcULL,
0 x550b8e9e21f7a530ULL,
0 x6b7ba5bc653fec2bULL,
0 x5eb7f1ba6949d0ddULL,
0 x57ea94e3db4c9099ULL,
0 xf640eae6d101b214ULL,
0 xdd4a284182c0b0bbULL,
0 xff1d8fbf6304f250ULL,
0 xb8accb933bf9d7e8ULL,
0 xe8867c478eb68c4dULL,
0 x3f8e2692391bddc1ULL,
0 xcb2fd60912a15a7cULL,
0 xaec935dbab983d2fULL,
0 xf55ffd2b56691367ULL,
0 x80e2ce366ce1c115ULL,
0 x179bf3f8edb27e1dULL,
0 x01fe0db07dd394daULL,
0 xda8a0b76ecc37b87ULL,
0 x44ae53e1df9584cbULL,
0 xb310b4b77347a205ULL,
0 xdfab323c787b8512ULL,
0 x3b511268d070b78eULL,
0 x65e6e3d2b9396753ULL,
0 x6864b271e2574d58ULL,
0 x259784c98fc789d7ULL,
0 x02e11a7dfabb35a9ULL,
0 x8841a6dfa337158bULL,
0 x7ade78c39b5dcdd0ULL,
0 xb7cf804d9a2cc84aULL,
0 x20b6bd831b7f7742ULL,
0 x75bd331d3a88d272ULL,
0 x418f6aab4b2d7a5eULL,
0 xd9951cbb6babdaf4ULL,
0 xb6318dfde7ff5c90ULL,
0 x1f389b112264aa83ULL,
0 x492c024284fbaec0ULL,
0 xe33a0363c608f9a0ULL,
0 x2688930408af28a4ULL,
0 xc7538a1a341ce4adULL,
0 x5da8e677ee2171aeULL,
0 x8c9e92254a5c7fc4ULL,
0 x63d8cd55aae938b5ULL,
0 x29ebd8daa97a3706ULL,
0 x959827b37be88aa1ULL,
0 x1484e4356adadf6eULL,
0 xa7945082199d7d6bULL,
0 xbf6ce8a455fa1cd4ULL,
0 x9cc542eac9edcae5ULL,
0 x79c16f0e1c356ca3ULL,
0 x89bfab6fdee48151ULL,
0 xd4174d1830c5f0ffULL,
0 x9258048415eb419dULL,
0 x6139d72850520d1cULL,
0 x6a85a80c18ec78f1ULL,
0 xcd11f88e0171059aULL,
0 xcceff53e7ca29140ULL,
0 xd229639f2315af19ULL,
0 x90b91ef9ef507434ULL,
0 x5977d28d074a1be1ULL,
0 x311360fce51d56b9ULL,
0 xc093a92d5a1f2f91ULL,
0 x1a19a25bb6dc5416ULL,
0 xeb996b8a09de2d3eULL,
0 xfee3820f1ed7668aULL,
0 xd7085ad5b7ad518cULL,
0 x7fff41890fe53345ULL,
0 xec5948bd67dde602ULL,
0 x2fd5f65dbaaa68e0ULL,
0 xa5754affe32648c2ULL,
0 xf8ddac880d07396cULL,
0 x6fa491468c548664ULL,
0 x0c7c5c1326bdbed1ULL,
0 x4a33158f03930fb3ULL,
0 x699abfc19f84d982ULL,
0 xe4fa2054a80b329cULL,
0 x6707f9af438252faULL,
0 x08a368e9cfd6d49eULL,
0 x47b1442c58fd25b8ULL,
0 xbbb3dc5ebc91769bULL,
0 x1665fe489061eac7ULL,
0 x33f27a811fa66310ULL,
0 x93a609346838d547ULL,
0 x30ed6d4c98cec263ULL,
0 x1dd9816cd8df9f2aULL,
0 x94662a03063b1e7bULL,
0 x83fdd9fbeb896066ULL,
0 x7b207573e68e590aULL,
0 x5f49fc0a149a4407ULL,
0 x343259b671a5a82cULL,
0 xfbc2bb458a6f981fULL,
0 xc272b350a0a41a38ULL,
0 x3aaf1fd8ada32354ULL,
0 x6cbb868b0b3c2717ULL,
0 xa2b569c88d2583feULL,
0 xf180c9d1bf027928ULL,
0 xaf37386bd64ba9f5ULL,
0 x12bacab2790a8088ULL,
0 x4c0d3b0810435055ULL,
0 xb2eeb9070e9436dfULL,
0 xc5b29067cea7d104ULL,
0 xdcb425f1ff132461ULL,
0 x4f122cc5972bf126ULL,
0 xac282fa651230886ULL,
0 xe7e537992f6393efULL,
0 xe61b3a2952b00735ULL,
0 x709c0a57ae302ce7ULL,
0 xe02514ae416058d3ULL,
0 xc44c9dd7b37445deULL,
0 x5a68c5408022ba92ULL,
0 x1c278cdca50c0bf0ULL,
0 x6e5a9cf6f18712beULL,
0 x86dce0b17f319ef3ULL,
0 x2d34ec2040115d49ULL,
0 x4bcd183f7e409b69ULL,
0 x2815d56ad4a9a3dcULL,
0 x24698979f2141d0dULL,
0 x0000000000000000ULL,
0 x1ec696a15fb73e59ULL,
0 xd86b110b16784e2eULL,
0 x8e7f8858b0e74a6dULL,
0 x063e2e8713d05fe6ULL,
0 xe2c40ed3bbdb6d7aULL,
0 xb1f1aeca89fc97acULL,
0 xe1db191e3cb3cc09ULL,
0 x6418ee62c4eaf389ULL,
0 xc6ad87aa49cf7077ULL,
0 xd6f65765ca7ec556ULL,
0 x9afb6c6dda3d9503ULL,
0 x7ce05644888d9236ULL,
0 x8d609f95378feb1eULL,
0 x23a9aa4e9c17d631ULL,
0 x6226c0e5d73aac6fULL,
0 x56149953a69f0443ULL,
0 xeeb852c09d66d3abULL,
0 x2b0ac2a753c102afULL,
0 x07c023376e03cb3cULL,
0 x2ccae1903dc2c993ULL,
0 xd3d76e2f5ec63bc3ULL,
0 x9e2458973356ff4cULL,
0 xa66a5d32644ee9b1ULL,
0 x0a427294356de137ULL,
0 x783f62be61e6f879ULL,
0 x1344c70204d91452ULL,
0 x5b96c8f0fdf12e48ULL,
0 xa90916ecc59bf613ULL,
0 xbe92e5142829880eULL,
0 x727d102a548b194eULL,
0 x1be7afebcb0fc0ccULL,
0 x3e702b2244c8491bULL,
0 xd5e940a84d166425ULL,
0 x66f9f41f3e51c620ULL,
0 xabe80c913f20c3baULL,
0 xf07ec461c2d1edf2ULL,
0 xf361d3ac45b94c81ULL,
0 x0521394a94b8fe95ULL,
0 xadd622162cf09c5cULL,
0 xe97871f7f3651897ULL,
0 xf4a1f09b2bba87bdULL,
0 x095d6559b2054044ULL,
0 x0bbc7f2448be75edULL,
0 x2af4cf172e129675ULL,
0 x157ae98517094bb4ULL,
0 x9fda55274e856b96ULL,
0 x914713499283e0eeULL,
0 xb952c623462a4332ULL,
0 x74433ead475b46a8ULL,
0 x8b5eb112245fb4f8ULL,
0 xa34b6478f0f61724ULL,
0 x11a5dd7ffe6221fbULL,
0 xc16da49d27ccbb4bULL,
0 x76a224d0bde07301ULL,
0 x8aa0bca2598c2022ULL,
0 x4df336b86d90c48fULL,
0 xea67663a740db9e4ULL,
0 xef465f70e0b54771ULL,
0 x39b008152acb8227ULL,
0 x7d1e5bf4f55e06ecULL,
0 x105bd0cf83b1b521ULL,
0 x775c2960c033e7dbULL,
0 x7e014c397236a79fULL,
0 x811cc386113255cfULL,
0 xeda7450d1a0e72d8ULL,
0 x5889df3d7a998f3bULL,
0 x2e2bfbedc779fc3aULL,
0 xce0eef438619a4e9ULL,
0 x372d4e7bf6cd095fULL,
0 x04df34fae96b6a4fULL,
0 xf923a13870d4adb6ULL,
0 xa1aa7e050a4d228dULL,
0 xa8f71b5cb84862c9ULL,
0 xb52e9a306097fde3ULL,
0 x0d8251a35b6e2a0bULL,
0 x2257a7fee1c442ebULL,
0 x73831d9a29588d94ULL,
0 x51d4ba64c89ccf7fULL,
0 x502ab7d4b54f5ba5ULL,
0 x97793dce8153bf08ULL,
0 xe5042de4d5d8a646ULL,
0 x9687307efc802bd2ULL,
0 xa05473b5779eb657ULL,
0 xb4d097801d446939ULL,
0 xcff0e2f3fbca3033ULL,
0 xc38cbee0dd778ee2ULL,
0 x464f499c252eb162ULL,
0 xcad1dbb96f72cea6ULL,
0 xba4dd1eec142e241ULL,
0 xb00fa37af42f0376ULL
}, {
0 xcce4cd3aa968b245ULL,
0 x089d5484e80b7fafULL,
0 x638246c1b3548304ULL,
0 xd2fe0ec8c2355492ULL,
0 xa7fbdf7ff2374eeeULL,
0 x4df1600c92337a16ULL,
0 x84e503ea523b12fbULL,
0 x0790bbfd53ab0c4aULL,
0 x198a780f38f6ea9dULL,
0 x2ab30c8f55ec48cbULL,
0 xe0f7fed6b2c49db5ULL,
0 xb6ecf3f422cadbdcULL,
0 x409c9a541358df11ULL,
0 xd3ce8a56dfde3fe3ULL,
0 xc3e9224312c8c1a0ULL,
0 x0d6dfa58816ba507ULL,
0 xddf3e1b179952777ULL,
0 x04c02a42748bb1d9ULL,
0 x94c2abff9f2decb8ULL,
0 x4f91752da8f8acf4ULL,
0 x78682befb169bf7bULL,
0 xe1c77a48af2ff6c4ULL,
0 x0c5d7ec69c80ce76ULL,
0 x4cc1e4928fd81167ULL,
0 xfeed3d24d9997b62ULL,
0 x518bb6dfc3a54a23ULL,
0 x6dbf2d26151f9b90ULL,
0 xb5bc624b05ea664fULL,
0 xe86aaa525acfe21aULL,
0 x4801ced0fb53a0beULL,
0 xc91463e6c00868edULL,
0 x1027a815cd16fe43ULL,
0 xf67069a0319204cdULL,
0 xb04ccc976c8abce7ULL,
0 xc0b9b3fc35e87c33ULL,
0 xf380c77c58f2de65ULL,
0 x50bb3241de4e2152ULL,
0 xdf93f490435ef195ULL,
0 xf1e0d25d62390887ULL,
0 xaf668bfb1a3c3141ULL,
0 xbc11b251f00a7291ULL,
0 x73a5eed47e427d47ULL,
0 x25bee3f6ee4c3b2eULL,
0 x43cc0beb34786282ULL,
0 xc824e778dde3039cULL,
0 xf97d86d98a327728ULL,
0 xf2b043e24519b514ULL,
0 xe297ebf7880f4b57ULL,
0 x3a94a49a98fab688ULL,
0 x868516cb68f0c419ULL,
0 xeffa11af0964ee50ULL,
0 xa4ab4ec0d517f37dULL,
0 xa9c6b498547c567aULL,
0 x8e18424f80fbbbb6ULL,
0 x0bcdc53bcf2bc23cULL,
0 x137739aaea3643d0ULL,
0 x2c1333ec1bac2ff0ULL,
0 x8d48d3f0a7db0625ULL,
0 x1e1ac3f26b5de6d7ULL,
0 xf520f81f16b2b95eULL,
0 x9f0f6ec450062e84ULL,
0 x0130849e1deb6b71ULL,
0 xd45e31ab8c7533a9ULL,
0 x652279a2fd14e43fULL,
0 x3209f01e70f1c927ULL,
0 xbe71a770cac1a473ULL,
0 x0e3d6be7a64b1894ULL,
0 x7ec8148cff29d840ULL,
0 xcb7476c7fac3be0fULL,
0 x72956a4a63a91636ULL,
0 x37f95ec21991138fULL,
0 x9e3fea5a4ded45f5ULL,
0 x7b38ba50964902e8ULL,
0 x222e580bbde73764ULL,
0 x61e253e0899f55e6ULL,
0 xfc8d2805e352ad80ULL,
0 x35994be3235ac56dULL,
0 x09add01af5e014deULL,
0 x5e8659a6780539c6ULL,
0 xb17c48097161d796ULL,
0 x026015213acbd6e2ULL,
0 xd1ae9f77e515e901ULL,
0 xb7dc776a3f21b0adULL,
0 xaba6a1b96eb78098ULL,
0 x9bcf4486248d9f5dULL,
0 x582666c536455efdULL,
0 xfdbdac9bfeb9c6f1ULL,
0 xc47999be4163cdeaULL,
0 x765540081722a7efULL,
0 x3e548ed8ec710751ULL,
0 x3d041f67cb51bac2ULL,
0 x7958af71ac82d40aULL,
0 x36c9da5c047a78feULL,
0 xed9a048e33af38b2ULL,
0 x26ee7249c96c86bdULL,
0 x900281bdeba65d61ULL,
0 x11172c8bd0fd9532ULL,
0 xea0abf73600434f8ULL,
0 x42fc8f75299309f3ULL,
0 x34a9cf7d3eb1ae1cULL,
0 x2b838811480723baULL,
0 x5ce64c8742ceef24ULL,
0 x1adae9b01fd6570eULL,
0 x3c349bf9d6bad1b3ULL,
0 x82453c891c7b75c0ULL,
0 x97923a40b80d512bULL,
0 x4a61dbf1c198765cULL,
0 xb48ce6d518010d3eULL,
0 xcfb45c858e480fd6ULL,
0 xd933cbf30d1e96aeULL,
0 xd70ea014ab558e3aULL,
0 xc189376228031742ULL,
0 x9262949cd16d8b83ULL,
0 xeb3a3bed7def5f89ULL,
0 x49314a4ee6b8cbcfULL,
0 xdcc3652f647e4c06ULL,
0 xda635a4c2a3e2b3dULL,
0 x470c21a940f3d35bULL,
0 x315961a157d174b4ULL,
0 x6672e81dda3459acULL,
0 x5b76f77a1165e36eULL,
0 x445cb01667d36ec8ULL,
0 xc5491d205c88a69bULL,
0 x456c34887a3805b9ULL,
0 xffddb9bac4721013ULL,
0 x99af51a71e4649bfULL,
0 xa15be01cbc7729d5ULL,
0 x52db2760e485f7b0ULL,
0 x8c78576eba306d54ULL,
0 xae560f6507d75a30ULL,
0 x95f22f6182c687c9ULL,
0 x71c5fbf54489aba5ULL,
0 xca44f259e728d57eULL,
0 x88b87d2ccebbdc8dULL,
0 xbab18d32be4a15aaULL,
0 x8be8ec93e99b611eULL,
0 x17b713e89ebdf209ULL,
0 xb31c5d284baa0174ULL,
0 xeeca9531148f8521ULL,
0 xb8d198138481c348ULL,
0 x8988f9b2d350b7fcULL,
0 xb9e11c8d996aa839ULL,
0 x5a4673e40c8e881fULL,
0 x1687977683569978ULL,
0 xbf4123eed72acf02ULL,
0 x4ea1f1b3b513c785ULL,
0 xe767452be16f91ffULL,
0 x7505d1b730021a7cULL,
0 xa59bca5ec8fc980cULL,
0 xad069eda20f7e7a3ULL,
0 x38f4b1bba231606aULL,
0 x60d2d77e94743e97ULL,
0 x9affc0183966f42cULL,
0 x248e6768f3a7505fULL,
0 xcdd449a4b483d934ULL,
0 x87b59255751baf68ULL,
0 x1bea6d2e023d3c7fULL,
0 x6b1f12455b5ffcabULL,
0 x743555292de9710dULL,
0 xd8034f6d10f5fddfULL,
0 xc6198c9f7ba81b08ULL,
0 xbb8109aca3a17edbULL,
0 xfa2d1766ad12cabbULL,
0 xc729080166437079ULL,
0 x9c5fff7b77269317ULL,
0 x0000000000000000ULL,
0 x15d706c9a47624ebULL,
0 x6fdf38072fd44d72ULL,
0 x5fb6dd3865ee52b7ULL,
0 xa33bf53d86bcff37ULL,
0 xe657c1b5fc84fa8eULL,
0 xaa962527735cebe9ULL,
0 x39c43525bfda0b1bULL,
0 x204e4d2a872ce186ULL,
0 x7a083ece8ba26999ULL,
0 x554b9c9db72efbfaULL,
0 xb22cd9b656416a05ULL,
0 x96a2bedea5e63a5aULL,
0 x802529a826b0a322ULL,
0 x8115ad363b5bc853ULL,
0 x8375b81701901eb1ULL,
0 x3069e53f4a3a1fc5ULL,
0 xbd2136cfede119e0ULL,
0 x18bafc91251d81ecULL,
0 x1d4a524d4c7d5b44ULL,
0 x05f0aedc6960daa8ULL,
0 x29e39d3072ccf558ULL,
0 x70f57f6b5962c0d4ULL,
0 x989fd53903ad22ceULL,
0 xf84d024797d91c59ULL,
0 x547b1803aac5908bULL,
0 xf0d056c37fd263f6ULL,
0 xd56eb535919e58d8ULL,
0 x1c7ad6d351963035ULL,
0 x2e7326cd2167f912ULL,
0 xac361a443d1c8cd2ULL,
0 x697f076461942a49ULL,
0 x4b515f6fdc731d2dULL,
0 x8ad8680df4700a6fULL,
0 x41ac1eca0eb3b460ULL,
0 x7d988533d80965d3ULL,
0 xa8f6300649973d0bULL,
0 x7765c4960ac9cc9eULL,
0 x7ca801adc5e20ea2ULL,
0 xdea3700e5eb59ae4ULL,
0 xa06b6482a19c42a4ULL,
0 x6a2f96db46b497daULL,
0 x27def6d7d487edccULL,
0 x463ca5375d18b82aULL,
0 xa6cb5be1efdc259fULL,
0 x53eba3fef96e9cc1ULL,
0 xce84d81b93a364a7ULL,
0 xf4107c810b59d22fULL,
0 x333974806d1aa256ULL,
0 x0f0def79bba073e5ULL,
0 x231edc95a00c5c15ULL,
0 xe437d494c64f2c6cULL,
0 x91320523f64d3610ULL,
0 x67426c83c7df32ddULL,
0 x6eefbc99323f2603ULL,
0 x9d6f7be56acdf866ULL,
0 x5916e25b2bae358cULL,
0 x7ff89012e2c2b331ULL,
0 x035091bf2720bd93ULL,
0 x561b0d22900e4669ULL,
0 x28d319ae6f279e29ULL,
0 x2f43a2533c8c9263ULL,
0 xd09e1be9f8fe8270ULL,
0 xf740ed3e2c796fbcULL,
0 xdb53ded237d5404cULL,
0 x62b2c25faebfe875ULL,
0 x0afd41a5d2c0a94dULL,
0 x6412fd3ce0ff8f4eULL,
0 xe3a76f6995e42026ULL,
0 x6c8fa9b808f4f0e1ULL,
0 xc2d9a6dd0f23aad1ULL,
0 x8f28c6d19d10d0c7ULL,
0 x85d587744fd0798aULL,
0 xa20b71a39b579446ULL,
0 x684f83fa7c7f4138ULL,
0 xe507500adba4471dULL,
0 x3f640a46f19a6c20ULL,
0 x1247bd34f7dd28a1ULL,
0 x2d23b77206474481ULL,
0 x93521002cc86e0f2ULL,
0 x572b89bc8de52d18ULL,
0 xfb1d93f8b0f9a1caULL,
0 xe95a2ecc4724896bULL,
0 x3ba420048511ddf9ULL,
0 xd63e248ab6bee54bULL,
0 x5dd6c8195f258455ULL,
0 x06a03f634e40673bULL,
0 x1f2a476c76b68da6ULL,
0 x217ec9b49ac78af7ULL,
0 xecaa80102e4453c3ULL,
0 x14e78257b99d4f9aULL
}, {
0 x20329b2cc87bba05ULL,
0 x4f5eb6f86546a531ULL,
0 xd4f44775f751b6b1ULL,
0 x8266a47b850dfa8bULL,
0 xbb986aa15a6ca985ULL,
0 xc979eb08f9ae0f99ULL,
0 x2da6f447a2375ea1ULL,
0 x1e74275dcd7d8576ULL,
0 xbc20180a800bc5f8ULL,
0 xb4a2f701b2dc65beULL,
0 xe726946f981b6d66ULL,
0 x48e6c453bf21c94cULL,
0 x42cad9930f0a4195ULL,
0 xefa47b64aacccd20ULL,
0 x71180a8960409a42ULL,
0 x8bb3329bf6a44e0cULL,
0 xd34c35de2d36daccULL,
0 xa92f5b7cbc23dc96ULL,
0 xb31a85aa68bb09c3ULL,
0 x13e04836a73161d2ULL,
0 xb24dfc4129c51d02ULL,
0 x8ae44b70b7da5acdULL,
0 xe671ed84d96579a7ULL,
0 xa4bb3417d66f3832ULL,
0 x4572ab38d56d2de8ULL,
0 xb1b47761ea47215cULL,
0 xe81c09cf70aba15dULL,
0 xffbdb872ce7f90acULL,
0 xa8782297fd5dc857ULL,
0 x0d946f6b6a4ce4a4ULL,
0 xe4df1f4f5b995138ULL,
0 x9ebc71edca8c5762ULL,
0 x0a2c1dc0b02b88d9ULL,
0 x3b503c115d9d7b91ULL,
0 xc64376a8111ec3a2ULL,
0 xcec199a323c963e4ULL,
0 xdc76a87ec58616f7ULL,
0 x09d596e073a9b487ULL,
0 x14583a9d7d560dafULL,
0 xf4c6dc593f2a0cb4ULL,
0 xdd21d19584f80236ULL,
0 x4a4836983ddde1d3ULL,
0 xe58866a41ae745f9ULL,
0 xf591a5b27e541875ULL,
0 x891dc05074586693ULL,
0 x5b068c651810a89eULL,
0 xa30346bc0c08544fULL,
0 x3dbf3751c684032dULL,
0 x2a1e86ec785032dcULL,
0 xf73f5779fca830eaULL,
0 xb60c05ca30204d21ULL,
0 x0cc316802b32f065ULL,
0 x8770241bdd96be69ULL,
0 xb861e18199ee95dbULL,
0 xf805cad91418fcd1ULL,
0 x29e70dccbbd20e82ULL,
0 xc7140f435060d763ULL,
0 x0f3a9da0e8b0cc3bULL,
0 xa2543f574d76408eULL,
0 xbd7761e1c175d139ULL,
0 x4b1f4f737ca3f512ULL,
0 x6dc2df1f2fc137abULL,
0 xf1d05c3967b14856ULL,
0 xa742bf3715ed046cULL,
0 x654030141d1697edULL,
0 x07b872abda676c7dULL,
0 x3ce84eba87fa17ecULL,
0 xc1fb0403cb79afdfULL,
0 x3e46bc7105063f73ULL,
0 x278ae987121cd678ULL,
0 xa1adb4778ef47cd0ULL,
0 x26dd906c5362c2b9ULL,
0 x05168060589b44e2ULL,
0 xfbfc41f9d79ac08fULL,
0 x0e6de44ba9ced8faULL,
0 x9feb08068bf243a3ULL,
0 x7b341749d06b129bULL,
0 x229c69e74a87929aULL,
0 xe09ee6c4427c011bULL,
0 x5692e30e725c4c3aULL,
0 xda99a33e5e9f6e4bULL,
0 x353dd85af453a36bULL,
0 x25241b4c90e0fee7ULL,
0 x5de987258309d022ULL,
0 xe230140fc0802984ULL,
0 x93281e86a0c0b3c6ULL,
0 xf229d719a4337408ULL,
0 x6f6c2dd4ad3d1f34ULL,
0 x8ea5b2fbae3f0aeeULL,
0 x8331dd90c473ee4aULL,
0 x346aa1b1b52db7aaULL,
0 xdf8f235e06042aa9ULL,
0 xcc6f6b68a1354b7bULL,
0 x6c95a6f46ebf236aULL,
0 x52d31a856bb91c19ULL,
0 x1a35ded6d498d555ULL,
0 xf37eaef2e54d60c9ULL,
0 x72e181a9a3c2a61cULL,
0 x98537aad51952fdeULL,
0 x16f6c856ffaa2530ULL,
0 xd960281e9d1d5215ULL,
0 x3a0745fa1ce36f50ULL,
0 x0b7b642bf1559c18ULL,
0 x59a87eae9aec8001ULL,
0 x5e100c05408bec7cULL,
0 x0441f98b19e55023ULL,
0 xd70dcc5534d38aefULL,
0 x927f676de1bea707ULL,
0 x9769e70db925e3e5ULL,
0 x7a636ea29115065aULL,
0 x468b201816ef11b6ULL,
0 xab81a9b73edff409ULL,
0 xc0ac7de88a07bb1eULL,
0 x1f235eb68c0391b7ULL,
0 x6056b074458dd30fULL,
0 xbe8eeac102f7ed67ULL,
0 xcd381283e04b5fbaULL,
0 x5cbefecec277c4e3ULL,
0 xd21b4c356c48ce0dULL,
0 x1019c31664b35d8cULL,
0 x247362a7d19eea26ULL,
0 xebe582efb3299d03ULL,
0 x02aef2cb82fc289fULL,
0 x86275df09ce8aaa8ULL,
0 x28b07427faac1a43ULL,
0 x38a9b7319e1f47cfULL,
0 xc82e92e3b8d01b58ULL,
0 x06ef0b409b1978bcULL,
0 x62f842bfc771fb90ULL,
0 x9904034610eb3b1fULL,
0 xded85ab5477a3e68ULL,
0 x90d195a663428f98ULL,
0 x5384636e2ac708d8ULL,
0 xcbd719c37b522706ULL,
0 xae9729d76644b0ebULL,
0 x7c8c65e20a0c7ee6ULL,
0 x80c856b007f1d214ULL,
0 x8c0b40302cc32271ULL,
0 xdbcedad51fe17a8aULL,
0 x740e8ae938dbdea0ULL,
0 xa615c6dc549310adULL,
0 x19cc55f6171ae90bULL,
0 x49b1bdb8fe5fdd8dULL,
0 xed0a89af2830e5bfULL,
0 x6a7aadb4f5a65bd6ULL,
0 x7e22972988f05679ULL,
0 xf952b3325566e810ULL,
0 x39fecedadf61530eULL,
0 x6101c99f04f3c7ceULL,
0 x2e5f7f6761b562ffULL,
0 xf08725d226cf5c97ULL,
0 x63af3b54860fef51ULL,
0 x8ff2cb10ef411e2fULL,
0 x884ab9bb35267252ULL,
0 x4df04433e7ba8daeULL,
0 x9afd8866d3690741ULL,
0 x66b9bb34de94abb3ULL,
0 x9baaf18d92171380ULL,
0 x543c11c5f0a064a5ULL,
0 x17a1b1bdbed431f1ULL,
0 xb5f58eeaf3a2717fULL,
0 xc355f6c849858740ULL,
0 xec5df044694ef17eULL,
0 xd83751f5dc6346d4ULL,
0 xfc4433520dfdacf2ULL,
0 x0000000000000000ULL,
0 x5a51f58e596ebc5fULL,
0 x3285aaf12e34cf16ULL,
0 x8d5c39db6dbd36b0ULL,
0 x12b731dde64f7513ULL,
0 x94906c2d7aa7dfbbULL,
0 x302b583aacc8e789ULL,
0 x9d45facd090e6b3cULL,
0 x2165e2c78905aec4ULL,
0 x68d45f7f775a7349ULL,
0 x189b2c1d5664fdcaULL,
0 xe1c99f2f030215daULL,
0 x6983269436246788ULL,
0 x8489af3b1e148237ULL,
0 xe94b702431d5b59cULL,
0 x33d2d31a6f4adbd7ULL,
0 xbfd9932a4389f9a6ULL,
0 xb0e30e8aab39359dULL,
0 xd1e2c715afcaf253ULL,
0 x150f43763c28196eULL,
0 xc4ed846393e2eb3dULL,
0 x03f98b20c3823c5eULL,
0 xfd134ab94c83b833ULL,
0 x556b682eb1de7064ULL,
0 x36c4537a37d19f35ULL,
0 x7559f30279a5ca61ULL,
0 x799ae58252973a04ULL,
0 x9c12832648707ffdULL,
0 x78cd9c6913e92ec5ULL,
0 x1d8dac7d0effb928ULL,
0 x439da0784e745554ULL,
0 x413352b3cc887dcbULL,
0 xbacf134a1b12bd44ULL,
0 x114ebafd25cd494dULL,
0 x2f08068c20cb763eULL,
0 x76a07822ba27f63fULL,
0 xeab2fb04f25789c2ULL,
0 xe3676de481fe3d45ULL,
0 x1b62a73d95e6c194ULL,
0 x641749ff5c68832cULL,
0 xa5ec4dfc97112cf3ULL,
0 xf6682e92bdd6242bULL,
0 x3f11c59a44782bb2ULL,
0 x317c21d1edb6f348ULL,
0 xd65ab5be75ad9e2eULL,
0 x6b2dd45fb4d84f17ULL,
0 xfaab381296e4d44eULL,
0 xd0b5befeeeb4e692ULL,
0 x0882ef0b32d7a046ULL,
0 x512a91a5a83b2047ULL,
0 x963e9ee6f85bf724ULL,
0 x4e09cf132438b1f0ULL,
0 x77f701c9fb59e2feULL,
0 x7ddb1c094b726a27ULL,
0 x5f4775ee01f5f8bdULL,
0 x9186ec4d223c9b59ULL,
0 xfeeac1998f01846dULL,
0 xac39db1ce4b89874ULL,
0 xb75b7c21715e59e0ULL,
0 xafc0503c273aa42aULL,
0 x6e3b543fec430bf5ULL,
0 x704f7362213e8e83ULL,
0 x58ff0745db9294c0ULL,
0 x67eec2df9feabf72ULL,
0 xa0facd9ccf8a6811ULL,
0 xb936986ad890811aULL,
0 x95c715c63bd9cb7aULL,
0 xca8060283a2c33c7ULL,
0 x507de84ee9453486ULL,
0 x85ded6d05f6a96f6ULL,
0 x1cdad5964f81ade9ULL,
0 xd5a33e9eb62fa270ULL,
0 x40642b588df6690aULL,
0 x7f75eec2c98e42b8ULL,
0 x2cf18dace3494a60ULL,
0 x23cb100c0bf9865bULL,
0 xeef3028febb2d9e1ULL,
0 x4425d2d394133929ULL,
0 xaad6d05c7fa1e0c8ULL,
0 xad6ea2f7a5c68cb5ULL,
0 xc2028f2308fb9381ULL,
0 x819f2f5b468fc6d5ULL,
0 xc5bafd88d29cfffcULL,
0 x47dc59f357910577ULL,
0 x2b49ff07392e261dULL,
0 x57c59ae5332258fbULL,
0 x73b6f842e2bcb2ddULL,
0 xcf96e04862b77725ULL,
0 x4ca73dd8a6c4996fULL,
0 x015779eb417e14c1ULL,
0 x37932a9176af8bf4ULL
}, {
0 x190a2c9b249df23eULL,
0 x2f62f8b62263e1e9ULL,
0 x7a7f754740993655ULL,
0 x330b7ba4d5564d9fULL,
0 x4c17a16a46672582ULL,
0 xb22f08eb7d05f5b8ULL,
0 x535f47f40bc148ccULL,
0 x3aec5d27d4883037ULL,
0 x10ed0a1825438f96ULL,
0 x516101f72c233d17ULL,
0 x13cc6f949fd04eaeULL,
0 x739853c441474bfdULL,
0 x653793d90d3f5b1bULL,
0 x5240647b96b0fc2fULL,
0 x0c84890ad27623e0ULL,
0 xd7189b32703aaea3ULL,
0 x2685de3523bd9c41ULL,
0 x99317c5b11bffefaULL,
0 x0d9baa854f079703ULL,
0 x70b93648fbd48ac5ULL,
0 xa80441fce30bc6beULL,
0 x7287704bdc36ff1eULL,
0 xb65384ed33dc1f13ULL,
0 xd36417343ee34408ULL,
0 x39cd38ab6e1bf10fULL,
0 x5ab861770a1f3564ULL,
0 x0ebacf09f594563bULL,
0 xd04572b884708530ULL,
0 x3cae9722bdb3af47ULL,
0 x4a556b6f2f5cbaf2ULL,
0 xe1704f1f76c4bd74ULL,
0 x5ec4ed7144c6dfcfULL,
0 x16afc01d4c7810e6ULL,
0 x283f113cd629ca7aULL,
0 xaf59a8761741ed2dULL,
0 xeed5a3991e215facULL,
0 x3bf37ea849f984d4ULL,
0 xe413e096a56ce33cULL,
0 x2c439d3a98f020d1ULL,
0 x637559dc6404c46bULL,
0 x9e6c95d1e5f5d569ULL,
0 x24bb9836045fe99aULL,
0 x44efa466dac8ecc9ULL,
0 xc6eab2a5c80895d6ULL,
0 x803b50c035220cc4ULL,
0 x0321658cba93c138ULL,
0 x8f9ebc465dc7ee1cULL,
0 xd15a5137190131d3ULL,
0 x0fa5ec8668e5e2d8ULL,
0 x91c979578d1037b1ULL,
0 x0642ca05693b9f70ULL,
0 xefca80168350eb4fULL,
0 x38d21b24f36a45ecULL,
0 xbeab81e1af73d658ULL,
0 x8cbfd9cae7542f24ULL,
0 xfd19cc0d81f11102ULL,
0 x0ac6430fbb4dbc90ULL,
0 x1d76a09d6a441895ULL,
0 x2a01573ff1cbbfa1ULL,
0 xb572e161894fde2bULL,
0 x8124734fa853b827ULL,
0 x614b1fdf43e6b1b0ULL,
0 x68ac395c4238cc18ULL,
0 x21d837bfd7f7b7d2ULL,
0 x20c714304a860331ULL,
0 x5cfaab726324aa14ULL,
0 x74c5ba4eb50d606eULL,
0 xf3a3030474654739ULL,
0 x23e671bcf015c209ULL,
0 x45f087e947b9582aULL,
0 xd8bd77b418df4c7bULL,
0 xe06f6c90ebb50997ULL,
0 x0bd96080263c0873ULL,
0 x7e03f9410e40dcfeULL,
0 xb8e94be4c6484928ULL,
0 xfb5b0608e8ca8e72ULL,
0 x1a2b49179e0e3306ULL,
0 x4e29e76961855059ULL,
0 x4f36c4e6fcf4e4baULL,
0 x49740ee395cf7bcaULL,
0 xc2963ea386d17f7dULL,
0 x90d65ad810618352ULL,
0 x12d34c1b02a1fa4dULL,
0 xfa44258775bb3a91ULL,
0 x18150f14b9ec46ddULL,
0 x1491861e6b9a653dULL,
0 x9a1019d7ab2c3fc2ULL,
0 x3668d42d06fe13d7ULL,
0 xdcc1fbb25606a6d0ULL,
0 x969490dd795a1c22ULL,
0 x3549b1a1bc6dd2efULL,
0 xc94f5e23a0ed770eULL,
0 xb9f6686b5b39fdcbULL,
0 xc4d4f4a6efeae00dULL,
0 xe732851a1fff2204ULL,
0 x94aad6de5eb869f9ULL,
0 x3f8ff2ae07206e7fULL,
0 xfe38a9813b62d03aULL,
0 xa7a1ad7a8bee2466ULL,
0 x7b6056c8dde882b6ULL,
0 x302a1e286fc58ca7ULL,
0 x8da0fa457a259bc7ULL,
0 xb3302b64e074415bULL,
0 x5402ae7eff8b635fULL,
0 x08f8050c9cafc94bULL,
0 xae468bf98a3059ceULL,
0 x88c355cca98dc58fULL,
0 xb10e6d67c7963480ULL,
0 xbad70de7e1aa3cf3ULL,
0 xbfb4a26e320262bbULL,
0 xcb711820870f02d5ULL,
0 xce12b7a954a75c9dULL,
0 x563ce87dd8691684ULL,
0 x9f73b65e7884618aULL,
0 x2b1e74b06cba0b42ULL,
0 x47cec1ea605b2df1ULL,
0 x1c698312f735ac76ULL,
0 x5fdbcefed9b76b2cULL,
0 x831a354c8fb1cdfcULL,
0 x820516c312c0791fULL,
0 xb74ca762aeadabf0ULL,
0 xfc06ef821c80a5e1ULL,
0 x5723cbf24518a267ULL,
0 x9d4df05d5f661451ULL,
0 x588627742dfd40bfULL,
0 xda8331b73f3d39a0ULL,
0 x17b0e392d109a405ULL,
0 xf965400bcf28fba9ULL,
0 x7c3dbf4229a2a925ULL,
0 x023e460327e275dbULL,
0 x6cd0b55a0ce126b3ULL,
0 xe62da695828e96e7ULL,
0 x42ad6e63b3f373b9ULL,
0 xe50cc319381d57dfULL,
0 xc5cbd729729b54eeULL,
0 x46d1e265fd2a9912ULL,
0 x6428b056904eeff8ULL,
0 x8be23040131e04b7ULL,
0 x6709d5da2add2ec0ULL,
0 x075de98af44a2b93ULL,
0 x8447dcc67bfbe66fULL,
0 x6616f655b7ac9a23ULL,
0 xd607b8bded4b1a40ULL,
0 x0563af89d3a85e48ULL,
0 x3db1b4ad20c21ba4ULL,
0 x11f22997b8323b75ULL,
0 x292032b34b587e99ULL,
0 x7f1cdace9331681dULL,
0 x8e819fc9c0b65affULL,
0 xa1e3677fe2d5bb16ULL,
0 xcd33d225ee349da5ULL,
0 xd9a2543b85aef898ULL,
0 x795e10cbfa0af76dULL,
0 x25a4bbb9992e5d79ULL,
0 x78413344677b438eULL,
0 xf0826688cef68601ULL,
0 xd27b34bba392f0ebULL,
0 x551d8df162fad7bcULL,
0 x1e57c511d0d7d9adULL,
0 xdeffbdb171e4d30bULL,
0 xf4feea8e802f6caaULL,
0 xa480c8f6317de55eULL,
0 xa0fc44f07fa40ff5ULL,
0 x95b5f551c3c9dd1aULL,
0 x22f952336d6476eaULL,
0 x0000000000000000ULL,
0 xa6be8ef5169f9085ULL,
0 xcc2cf1aa73452946ULL,
0 x2e7ddb39bf12550aULL,
0 xd526dd3157d8db78ULL,
0 x486b2d6c08becf29ULL,
0 x9b0f3a58365d8b21ULL,
0 xac78cdfaadd22c15ULL,
0 xbc95c7e28891a383ULL,
0 x6a927f5f65dab9c3ULL,
0 xc3891d2c1ba0cb9eULL,
0 xeaa92f9f50f8b507ULL,
0 xcf0d9426c9d6e87eULL,
0 xca6e3baf1a7eb636ULL,
0 xab25247059980786ULL,
0 x69b31ad3df4978fbULL,
0 xe2512a93cc577c4cULL,
0 xff278a0ea61364d9ULL,
0 x71a615c766a53e26ULL,
0 x89dc764334fc716cULL,
0 xf87a638452594f4aULL,
0 xf2bc208be914f3daULL,
0 x8766b94ac1682757ULL,
0 xbbc82e687cdb8810ULL,
0 x626a7a53f9757088ULL,
0 xa2c202f358467a2eULL,
0 x4d0882e5db169161ULL,
0 x09e7268301de7da8ULL,
0 xe897699c771ac0dcULL,
0 xc8507dac3d9cc3edULL,
0 xc0a878a0a1330aa6ULL,
0 x978bb352e42ba8c1ULL,
0 xe9884a13ea6b743fULL,
0 x279afdbabecc28a2ULL,
0 x047c8c064ed9eaabULL,
0 x507e2278b15289f4ULL,
0 x599904fbb08cf45cULL,
0 xbd8ae46d15e01760ULL,
0 x31353da7f2b43844ULL,
0 x8558ff49e68a528cULL,
0 x76fbfc4d92ef15b5ULL,
0 x3456922e211c660cULL,
0 x86799ac55c1993b4ULL,
0 x3e90d1219a51da9cULL,
0 x2d5cbeb505819432ULL,
0 x982e5fd48cce4a19ULL,
0 xdb9c1238a24c8d43ULL,
0 xd439febecaa96f9bULL,
0 x418c0bef0960b281ULL,
0 x158ea591f6ebd1deULL,
0 x1f48e69e4da66d4eULL,
0 x8afd13cf8e6fb054ULL,
0 xf5e1c9011d5ed849ULL,
0 xe34e091c5126c8afULL,
0 xad67ee7530a398f6ULL,
0 x43b24dec2e82c75aULL,
0 x75da99c1287cd48dULL,
0 x92e81cdb3783f689ULL,
0 xa3dd217cc537cecdULL,
0 x60543c50de970553ULL,
0 x93f73f54aaf2426aULL,
0 xa91b62737e7a725dULL,
0 xf19d4507538732e2ULL,
0 x77e4dfc20f9ea156ULL,
0 x7d229ccdb4d31dc6ULL,
0 x1b346a98037f87e5ULL,
0 xedf4c615a4b29e94ULL,
0 x4093286094110662ULL,
0 xb0114ee85ae78063ULL,
0 x6ff1d0d6b672e78bULL,
0 x6dcf96d591909250ULL,
0 xdfe09e3eec9567e8ULL,
0 x3214582b4827f97cULL,
0 xb46dc2ee143e6ac8ULL,
0 xf6c0ac8da7cd1971ULL,
0 xebb60c10cd8901e4ULL,
0 xf7df8f023abcad92ULL,
0 x9c52d3d2c217a0b2ULL,
0 x6b8d5cd0f8ab0d20ULL,
0 x3777f7a29b8fa734ULL,
0 x011f238f9d71b4e3ULL,
0 xc1b75b2f3c42be45ULL,
0 x5de588fdfe551ef7ULL,
0 x6eeef3592b035368ULL,
0 xaa3a07ffc4e9b365ULL,
0 xecebe59a39c32a77ULL,
0 x5ba742f8976e8187ULL,
0 x4b4a48e0b22d0e11ULL,
0 xddded83dcb771233ULL,
0 xa59feb79ac0c51bdULL,
0 xc7f5912a55792135ULL
}, {
0 x6d6ae04668a9b08aULL,
0 x3ab3f04b0be8c743ULL,
0 xe51e166b54b3c908ULL,
0 xbe90a9eb35c2f139ULL,
0 xb2c7066637f2bec1ULL,
0 xaa6945613392202cULL,
0 x9a28c36f3b5201ebULL,
0 xddce5a93ab536994ULL,
0 x0e34133ef6382827ULL,
0 x52a02ba1ec55048bULL,
0 xa2f88f97c4b2a177ULL,
0 x8640e513ca2251a5ULL,
0 xcdf1d36258137622ULL,
0 xfe6cb708dedf8ddbULL,
0 x8a174a9ec8121e5dULL,
0 x679896036b81560eULL,
0 x59ed033395795feeULL,
0 x1dd778ab8b74edafULL,
0 xee533ef92d9f926dULL,
0 x2a8c79baf8a8d8f5ULL,
0 x6bcf398e69b119f6ULL,
0 xe20491742fafdd95ULL,
0 x276488e0809c2aecULL,
0 xea955b82d88f5cceULL,
0 x7102c63a99d9e0c4ULL,
0 xf9763017a5c39946ULL,
0 x429fa2501f151b3dULL,
0 x4659c72bea05d59eULL,
0 x984b7fdccf5a6634ULL,
0 xf742232953fbb161ULL,
0 x3041860e08c021c7ULL,
0 x747bfd9616cd9386ULL,
0 x4bb1367192312787ULL,
0 x1b72a1638a6c44d3ULL,
0 x4a0e68a6e8359a66ULL,
0 x169a5039f258b6caULL,
0 xb98a2ef44edee5a4ULL,
0 xd9083fe85e43a737ULL,
0 x967f6ce239624e13ULL,
0 x8874f62d3c1a7982ULL,
0 x3c1629830af06e3fULL,
0 x9165ebfd427e5a8eULL,
0 xb5dd81794ceeaa5cULL,
0 x0de8f15a7834f219ULL,
0 x70bd98ede3dd5d25ULL,
0 xaccc9ca9328a8950ULL,
0 x56664eda1945ca28ULL,
0 x221db34c0f8859aeULL,
0 x26dbd637fa98970dULL,
0 x1acdffb4f068f932ULL,
0 x4585254f64090fa0ULL,
0 x72de245e17d53afaULL,
0 x1546b25d7c546cf4ULL,
0 x207e0ffffb803e71ULL,
0 xfaaad2732bcf4378ULL,
0 xb462dfae36ea17bdULL,
0 xcf926fd1ac1b11fdULL,
0 xe0672dc7dba7ba4aULL,
0 xd3fa49ad5d6b41b3ULL,
0 x8ba81449b216a3bcULL,
0 x14f9ec8a0650d115ULL,
0 x40fc1ee3eb1d7ce2ULL,
0 x23a2ed9b758ce44fULL,
0 x782c521b14fddc7eULL,
0 x1c68267cf170504eULL,
0 xbcf31558c1ca96e6ULL,
0 xa781b43b4ba6d235ULL,
0 xf6fd7dfe29ff0c80ULL,
0 xb0a4bad5c3fad91eULL,
0 xd199f51ea963266cULL,
0 x414340349119c103ULL,
0 x5405f269ed4dadf7ULL,
0 xabd61bb649969dcdULL,
0 x6813dbeae7bdc3c8ULL,
0 x65fb2ab09f8931d1ULL,
0 xf1e7fae152e3181dULL,
0 xc1a67cef5a2339daULL,
0 x7a4feea8e0f5bba1ULL,
0 x1e0b9acf05783791ULL,
0 x5b8ebf8061713831ULL,
0 x80e53cdbcb3af8d9ULL,
0 x7e898bd315e57502ULL,
0 xc6bcfbf0213f2d47ULL,
0 x95a38e86b76e942dULL,
0 x092e94218d243cbaULL,
0 x8339debf453622e7ULL,
0 xb11be402b9fe64ffULL,
0 x57d9100d634177c9ULL,
0 xcc4e8db52217cbc3ULL,
0 x3b0cae9c71ec7aa2ULL,
0 xfb158ca451cbfe99ULL,
0 x2b33276d82ac6514ULL,
0 x01bf5ed77a04bde1ULL,
0 xc5601994af33f779ULL,
0 x75c4a3416cc92e67ULL,
0 xf3844652a6eb7fc2ULL,
0 x3487e375fdd0ef64ULL,
0 x18ae430704609eedULL,
0 x4d14efb993298efbULL,
0 x815a620cb13e4538ULL,
0 x125c354207487869ULL,
0 x9eeea614ce42cf48ULL,
0 xce2d3106d61fac1cULL,
0 xbbe99247bad6827bULL,
0 x071a871f7b1c149dULL,
0 x2e4a1cc10db81656ULL,
0 x77a71ff298c149b8ULL,
0 x06a5d9c80118a97cULL,
0 xad73c27e488e34b1ULL,
0 x443a7b981e0db241ULL,
0 xe3bbcfa355ab6074ULL,
0 x0af276450328e684ULL,
0 x73617a896dd1871bULL,
0 x58525de4ef7de20fULL,
0 xb7be3dcab8e6cd83ULL,
0 x19111dd07e64230cULL,
0 x842359a03e2a367aULL,
0 x103f89f1f3401fb6ULL,
0 xdc710444d157d475ULL,
0 xb835702334da5845ULL,
0 x4320fc876511a6dcULL,
0 xd026abc9d3679b8dULL,
0 x17250eee885c0b2bULL,
0 x90dab52a387ae76fULL,
0 x31fed8d972c49c26ULL,
0 x89cba8fa461ec463ULL,
0 x2ff5421677bcabb7ULL,
0 x396f122f85e41d7dULL,
0 xa09b332430bac6a8ULL,
0 xc888e8ced7070560ULL,
0 xaeaf201ac682ee8fULL,
0 x1180d7268944a257ULL,
0 xf058a43628e7a5fcULL,
0 xbd4c4b8fbbce2b07ULL,
0 xa1246df34abe7b49ULL,
0 x7d5569b79be9af3cULL,
0 xa9b5a705bd9efa12ULL,
0 xdb6b835baa4bc0e8ULL,
0 x05793bac8f147342ULL,
0 x21c1512881848390ULL,
0 xfdb0556c50d357e5ULL,
0 x613d4fcb6a99ff72ULL,
0 x03dce2648e0cda3eULL,
0 xe949b9e6568386f0ULL,
0 xfc0f0bbb2ad7ea04ULL,
0 x6a70675913b5a417ULL,
0 x7f36d5046fe1c8e3ULL,
0 x0c57af8d02304ff8ULL,
0 x32223abdfcc84618ULL,
0 x0891caf6f720815bULL,
0 xa63eeaec31a26fd4ULL,
0 x2507345374944d33ULL,
0 x49d28ac266394058ULL,
0 xf5219f9aa7f3d6beULL,
0 x2d96fea583b4cc68ULL,
0 x5a31e1571b7585d0ULL,
0 x8ed12fe53d02d0feULL,
0 xdfade6205f5b0e4bULL,
0 x4cabb16ee92d331aULL,
0 x04c6657bf510cea3ULL,
0 xd73c2cd6a87b8f10ULL,
0 xe1d87310a1a307abULL,
0 x6cd5be9112ad0d6bULL,
0 x97c032354366f3f2ULL,
0 xd4e0ceb22677552eULL,
0 x0000000000000000ULL,
0 x29509bde76a402cbULL,
0 xc27a9e8bd42fe3e4ULL,
0 x5ef7842cee654b73ULL,
0 xaf107ecdbc86536eULL,
0 x3fcacbe784fcb401ULL,
0 xd55f90655c73e8cfULL,
0 xe6c2f40fdabf1336ULL,
0 xe8f6e7312c873b11ULL,
0 xeb2a0555a28be12fULL,
0 xe4a148bc2eb774e9ULL,
0 x9b979db84156bc0aULL,
0 x6eb60222e6a56ab4ULL,
0 x87ffbbc4b026ec44ULL,
0 xc703a5275b3b90a6ULL,
0 x47e699fc9001687fULL,
0 x9c8d1aa73a4aa897ULL,
0 x7cea3760e1ed12ddULL,
0 x4ec80ddd1d2554c5ULL,
0 x13e36b957d4cc588ULL,
0 x5d2b66486069914dULL,
0 x92b90999cc7280b0ULL,
0 x517cc9c56259deb5ULL,
0 xc937b619ad03b881ULL,
0 xec30824ad997f5b2ULL,
0 xa45d565fc5aa080bULL,
0 xd6837201d27f32f1ULL,
0 x635ef3789e9198adULL,
0 x531f75769651b96aULL,
0 x4f77530a6721e924ULL,
0 x486dd4151c3dfdb9ULL,
0 x5f48dafb9461f692ULL,
0 x375b011173dc355aULL,
0 x3da9775470f4d3deULL,
0 x8d0dcd81b30e0ac0ULL,
0 x36e45fc609d888bbULL,
0 x55baacbe97491016ULL,
0 x8cb29356c90ab721ULL,
0 x76184125e2c5f459ULL,
0 x99f4210bb55edbd5ULL,
0 x6f095cf59ca1d755ULL,
0 x9f51f8c3b44672a9ULL,
0 x3538bda287d45285ULL,
0 x50c39712185d6354ULL,
0 xf23b1885dcefc223ULL,
0 x79930ccc6ef9619fULL,
0 xed8fdc9da3934853ULL,
0 xcb540aaa590bdf5eULL,
0 x5c94389f1a6d2cacULL,
0 xe77daad8a0bbaed7ULL,
0 x28efc5090ca0bf2aULL,
0 xbf2ff73c4fc64cd8ULL,
0 xb37858b14df60320ULL,
0 xf8c96ec0dfc724a7ULL,
0 x828680683f329f06ULL,
0 x941cd051cd6a29ccULL,
0 xc3c5c05cae2b5e05ULL,
0 xb601631dc2e27062ULL,
0 xc01922382027843bULL,
0 x24b86a840e90f0d2ULL,
0 xd245177a276ffc52ULL,
0 x0f8b4de98c3c95c6ULL,
0 x3e759530fef809e0ULL,
0 x0b4d2892792c5b65ULL,
0 xc4df4743d5374a98ULL,
0 xa5e20888bfaeb5eaULL,
0 xba56cc90c0d23f9aULL,
0 x38d04cf8ffe0a09cULL,
0 x62e1adafe495254cULL,
0 x0263bcb3f40867dfULL,
0 xcaeb547d230f62bfULL,
0 x6082111c109d4293ULL,
0 xdad4dd8cd04f7d09ULL,
0 xefec602e579b2f8cULL,
0 x1fb4c4187f7c8a70ULL,
0 xffd3e9dfa4db303aULL,
0 x7bf0b07f9af10640ULL,
0 xf49ec14dddf76b5fULL,
0 x8f6e713247066d1fULL,
0 x339d646a86ccfbf9ULL,
0 x64447467e58d8c30ULL,
0 x2c29a072f9b07189ULL,
0 xd8b7613f24471ad6ULL,
0 x6627c8d41185ebefULL,
0 xa347d140beb61c96ULL,
0 xde12b8f7255fb3aaULL,
0 x9d324470404e1576ULL,
0 x9306574eb6763d51ULL,
0 xa80af9d2c79a47f3ULL,
0 x859c0777442e8b9bULL,
0 x69ac853d9db97e29ULL
}, {
0 xc3407dfc2de6377eULL,
0 x5b9e93eea4256f77ULL,
0 xadb58fdd50c845e0ULL,
0 x5219ff11a75bed86ULL,
0 x356b61cfd90b1de9ULL,
0 xfb8f406e25abe037ULL,
0 x7a5a0231c0f60796ULL,
0 x9d3cd216e1f5020bULL,
0 x0c6550fb6b48d8f3ULL,
0 xf57508c427ff1c62ULL,
0 x4ad35ffa71cb407dULL,
0 x6290a2da1666aa6dULL,
0 xe284ec2349355f9fULL,
0 xb3c307c53d7c84ecULL,
0 x05e23c0468365a02ULL,
0 x190bac4d6c9ebfa8ULL,
0 x94bbbee9e28b80faULL,
0 xa34fc777529cb9b5ULL,
0 xcc7b39f095bcd978ULL,
0 x2426addb0ce532e3ULL,
0 x7e79329312ce4fc7ULL,
0 xab09a72eebec2917ULL,
0 xf8d15499f6b9d6c2ULL,
0 x1a55b8babf8c895dULL,
0 xdb8add17fb769a85ULL,
0 xb57f2f368658e81bULL,
0 x8acd36f18f3f41f6ULL,
0 x5ce3b7bba50f11d3ULL,
0 x114dcc14d5ee2f0aULL,
0 xb91a7fcded1030e8ULL,
0 x81d5425fe55de7a1ULL,
0 xb6213bc1554adeeeULL,
0 x80144ef95f53f5f2ULL,
0 x1e7688186db4c10cULL,
0 x3b912965db5fe1bcULL,
0 xc281715a97e8252dULL,
0 x54a5d7e21c7f8171ULL,
0 x4b12535ccbc5522eULL,
0 x1d289cefbea6f7f9ULL,
0 x6ef5f2217d2e729eULL,
0 xe6a7dc819b0d17ceULL,
0 x1b94b41c05829b0eULL,
0 x33d7493c622f711eULL,
0 xdcf7f942fa5ce421ULL,
0 x600fba8b7f7a8ecbULL,
0 x46b60f011a83988eULL,
0 x235b898e0dcf4c47ULL,
0 x957ab24f588592a9ULL,
0 x4354330572b5c28cULL,
0 xa5f3ef84e9b8d542ULL,
0 x8c711e02341b2d01ULL,
0 x0b1874ae6a62a657ULL,
0 x1213d8e306fc19ffULL,
0 xfe6d7c6a4d9dba35ULL,
0 x65ed868f174cd4c9ULL,
0 x88522ea0e6236550ULL,
0 x899322065c2d7703ULL,
0 xc01e690bfef4018bULL,
0 x915982ed8abddaf8ULL,
0 xbe675b98ec3a4e4cULL,
0 xa996bf7f82f00db1ULL,
0 xe1daf8d49a27696aULL,
0 x2effd5d3dc8986e7ULL,
0 xd153a51f2b1a2e81ULL,
0 x18caa0ebd690adfbULL,
0 x390e3134b243c51aULL,
0 x2778b92cdff70416ULL,
0 x029f1851691c24a6ULL,
0 x5e7cafeacc133575ULL,
0 xfa4e4cc89fa5f264ULL,
0 x5a5f9f481e2b7d24ULL,
0 x484c47ab18d764dbULL,
0 x400a27f2a1a7f479ULL,
0 xaeeb9b2a83da7315ULL,
0 x721c626879869734ULL,
0 x042330a2d2384851ULL,
0 x85f672fd3765aff0ULL,
0 xba446b3a3e02061dULL,
0 x73dd6ecec3888567ULL,
0 xffac70ccf793a866ULL,
0 xdfa9edb5294ed2d4ULL,
0 x6c6aea7014325638ULL,
0 x834a5a0e8c41c307ULL,
0 xcdba35562fb2cb2bULL,
0 x0ad97808d06cb404ULL,
0 x0f3b440cb85aee06ULL,
0 xe5f9c876481f213bULL,
0 x98deee1289c35809ULL,
0 x59018bbfcd394bd1ULL,
0 xe01bf47220297b39ULL,
0 xde68e1139340c087ULL,
0 x9fa3ca4788e926adULL,
0 xbb85679c840c144eULL,
0 x53d8f3b71d55ffd5ULL,
0 x0da45c5dd146caa0ULL,
0 x6f34fe87c72060cdULL,
0 x57fbc315cf6db784ULL,
0 xcee421a1fca0fddeULL,
0 x3d2d0196607b8d4bULL,
0 x642c8a29ad42c69aULL,
0 x14aff010bdd87508ULL,
0 xac74837beac657b3ULL,
0 x3216459ad821634dULL,
0 x3fb219c70967a9edULL,
0 x06bc28f3bb246cf7ULL,
0 xf2082c9126d562c6ULL,
0 x66b39278c45ee23cULL,
0 xbd394f6f3f2878b9ULL,
0 xfd33689d9e8f8cc0ULL,
0 x37f4799eb017394fULL,
0 x108cc0b26fe03d59ULL,
0 xda4bd1b1417888d6ULL,
0 xb09d1332ee6eb219ULL,
0 x2f3ed975668794b4ULL,
0 x58c0871977375982ULL,
0 x7561463d78ace990ULL,
0 x09876cff037e82f1ULL,
0 x7fb83e35a8c05d94ULL,
0 x26b9b58a65f91645ULL,
0 xef20b07e9873953fULL,
0 x3148516d0b3355b8ULL,
0 x41cb2b541ba9e62aULL,
0 x790416c613e43163ULL,
0 xa011d380818e8f40ULL,
0 x3a5025c36151f3efULL,
0 xd57095bdf92266d0ULL,
0 x498d4b0da2d97688ULL,
0 x8b0c3a57353153a5ULL,
0 x21c491df64d368e1ULL,
0 x8f2f0af5e7091bf4ULL,
0 x2da1c1240f9bb012ULL,
0 xc43d59a92ccc49daULL,
0 xbfa6573e56345c1fULL,
0 x828b56a8364fd154ULL,
0 x9a41f643e0df7cafULL,
0 xbcf843c985266aeaULL,
0 x2b1de9d7b4bfdce5ULL,
0 x20059d79dedd7ab2ULL,
0 x6dabe6d6ae3c446bULL,
0 x45e81bf6c991ae7bULL,
0 x6351ae7cac68b83eULL,
0 xa432e32253b6c711ULL,
0 xd092a9b991143cd2ULL,
0 xcac711032e98b58fULL,
0 xd8d4c9e02864ac70ULL,
0 xc5fc550f96c25b89ULL,
0 xd7ef8dec903e4276ULL,
0 x67729ede7e50f06fULL,
0 xeac28c7af045cf3dULL,
0 xb15c1f945460a04aULL,
0 x9cfddeb05bfb1058ULL,
0 x93c69abce3a1fe5eULL,
0 xeb0380dc4a4bdd6eULL,
0 xd20db1e8f8081874ULL,
0 x229a8528b7c15e14ULL,
0 x44291750739fbc28ULL,
0 xd3ccbd4e42060a27ULL,
0 xf62b1c33f4ed2a97ULL,
0 x86a8660ae4779905ULL,
0 xd62e814a2a305025ULL,
0 x477703a7a08d8addULL,
0 x7b9b0e977af815c5ULL,
0 x78c51a60a9ea2330ULL,
0 xa6adfb733aaae3b7ULL,
0 x97e5aa1e3199b60fULL,
0 x0000000000000000ULL,
0 xf4b404629df10e31ULL,
0 x5564db44a6719322ULL,
0 x9207961a59afec0dULL,
0 x9624a6b88b97a45cULL,
0 x363575380a192b1cULL,
0 x2c60cd82b595a241ULL,
0 x7d272664c1dc7932ULL,
0 x7142769faa94a1c1ULL,
0 xa1d0df263b809d13ULL,
0 x1630e841d4c451aeULL,
0 xc1df65ad44fa13d8ULL,
0 x13d2d445bcf20bacULL,
0 xd915c546926abe23ULL,
0 x38cf3d92084dd749ULL,
0 xe766d0272103059dULL,
0 xc7634d5effde7f2fULL,
0 x077d2455012a7ea4ULL,
0 xedbfa82ff16fb199ULL,
0 xaf2a978c39d46146ULL,
0 x42953fa3c8bbd0dfULL,
0 xcb061da59496a7dcULL,
0 x25e7a17db6eb20b0ULL,
0 x34aa6d6963050fbaULL,
0 xa76cf7d580a4f1e4ULL,
0 xf7ea10954ee338c4ULL,
0 xfcf2643b24819e93ULL,
0 xcf252d0746aeef8dULL,
0 x4ef06f58a3f3082cULL,
0 x563acfb37563a5d7ULL,
0 x5086e740ce47c920ULL,
0 x2982f186dda3f843ULL,
0 x87696aac5e798b56ULL,
0 x5d22bb1d1f010380ULL,
0 x035e14f7d31236f5ULL,
0 x3cec0d30da759f18ULL,
0 xf3c920379cdb7095ULL,
0 xb8db736b571e22bbULL,
0 xdd36f5e44052f672ULL,
0 xaac8ab8851e23b44ULL,
0 xa857b3d938fe1fe2ULL,
0 x17f1e4e76eca43fdULL,
0 xec7ea4894b61a3caULL,
0 x9e62c6e132e734feULL,
0 xd4b1991b432c7483ULL,
0 x6ad6c283af163acfULL,
0 x1ce9904904a8e5aaULL,
0 x5fbda34c761d2726ULL,
0 xf910583f4cb7c491ULL,
0 xc6a241f845d06d7cULL,
0 x4f3163fe19fd1a7fULL,
0 xe99c988d2357f9c8ULL,
0 x8eee06535d0709a7ULL,
0 x0efa48aa0254fc55ULL,
0 xb4be23903c56fa48ULL,
0 x763f52caabbedf65ULL,
0 xeee1bcd8227d876cULL,
0 xe345e085f33b4dccULL,
0 x3e731561b369bbbeULL,
0 x2843fd2067adea10ULL,
0 x2adce5710eb1ceb6ULL,
0 xb7e03767ef44ccbdULL,
0 x8db012a48e153f52ULL,
0 x61ceb62dc5749c98ULL,
0 xe85d942b9959eb9bULL,
0 x4c6f7709caef2c8aULL,
0 x84377e5b8d6bbda3ULL,
0 x30895dcbb13d47ebULL,
0 x74a04a9bc2a2fbc3ULL,
0 x6b17ce251518289cULL,
0 xe438c4d0f2113368ULL,
0 x1fb784bed7bad35fULL,
0 x9b80fae55ad16efcULL,
0 x77fe5e6c11b0cd36ULL,
0 xc858095247849129ULL,
0 x08466059b97090a2ULL,
0 x01c10ca6ba0e1253ULL,
0 x6988d6747c040c3aULL,
0 x6849dad2c60a1e69ULL,
0 x5147ebe67449db73ULL,
0 xc99905f4fd8a837aULL,
0 x991fe2b433cd4a5aULL,
0 xf09734c04fc94660ULL,
0 xa28ecbd1e892abe6ULL,
0 xf1563866f5c75433ULL,
0 x4dae7baf70e13ed9ULL,
0 x7ce62ac27bd26b61ULL,
0 x70837a39109ab392ULL,
0 x90988e4b30b3c8abULL,
0 xb2020b63877296bfULL,
0 x156efcb607d6675bULL
}, {
0 xe63f55ce97c331d0ULL,
0 x25b506b0015bba16ULL,
0 xc8706e29e6ad9ba8ULL,
0 x5b43d3775d521f6aULL,
0 x0bfa3d577035106eULL,
0 xab95fc172afb0e66ULL,
0 xf64b63979e7a3276ULL,
0 xf58b4562649dad4bULL,
0 x48f7c3dbae0c83f1ULL,
0 xff31916642f5c8c5ULL,
0 xcbb048dc1c4a0495ULL,
0 x66b8f83cdf622989ULL,
0 x35c130e908e2b9b0ULL,
0 x7c761a61f0b34fa1ULL,
0 x3601161cf205268dULL,
0 x9e54ccfe2219b7d6ULL,
0 x8b7d90a538940837ULL,
0 x9cd403588ea35d0bULL,
0 xbc3c6fea9ccc5b5aULL,
0 xe5ff733b6d24aeedULL,
0 xceed22de0f7eb8d2ULL,
0 xec8581cab1ab545eULL,
0 xb96105e88ff8e71dULL,
0 x8ca03501871a5eadULL,
0 x76ccce65d6db2a2fULL,
0 x5883f582a7b58057ULL,
0 x3f7be4ed2e8adc3eULL,
0 x0fe7be06355cd9c9ULL,
0 xee054e6c1d11be83ULL,
0 x1074365909b903a6ULL,
0 x5dde9f80b4813c10ULL,
0 x4a770c7d02b6692cULL,
0 x5379c8d5d7809039ULL,
0 xb4067448161ed409ULL,
0 x5f5e5026183bd6cdULL,
0 xe898029bf4c29df9ULL,
0 x7fb63c940a54d09cULL,
0 xc5171f897f4ba8bcULL,
0 xa6f28db7b31d3d72ULL,
0 x2e4f3be7716eaa78ULL,
0 x0d6771a099e63314ULL,
0 x82076254e41bf284ULL,
0 x2f0fd2b42733df98ULL,
0 x5c9e76d3e2dc49f0ULL,
0 x7aeb569619606cdbULL,
0 x83478b07b2468764ULL,
0 xcfadcb8d5923cd32ULL,
0 x85dac7f05b95a41eULL,
0 xb5469d1b4043a1e9ULL,
0 xb821ecbbd9a592fdULL,
0 x1b8e0b0e798c13c8ULL,
0 x62a57b6d9a0be02eULL,
0 xfcf1b793b81257f8ULL,
0 x9d94ea0bd8fe28ebULL,
0 x4cea408aeb654a56ULL,
0 x23284a47e888996cULL,
0 x2d8f1d128b893545ULL,
0 xf4cbac3132c0d8abULL,
0 xbd7c86b9ca912ebaULL,
0 x3a268eef3dbe6079ULL,
0 xf0d62f6077a9110cULL,
0 x2735c916ade150cbULL,
0 x89fd5f03942ee2eaULL,
0 x1acee25d2fd16628ULL,
0 x90f39bab41181bffULL,
0 x430dfe8cde39939fULL,
0 xf70b8ac4c8274796ULL,
0 x1c53aeaac6024552ULL,
0 x13b410acf35e9c9bULL,
0 xa532ab4249faa24fULL,
0 x2b1251e5625a163fULL,
0 xd7e3e676da4841c7ULL,
0 xa7b264e4e5404892ULL,
0 xda8497d643ae72d3ULL,
0 x861ae105a1723b23ULL,
0 x38a6414991048aa4ULL,
0 x6578dec92585b6b4ULL,
0 x0280cfa6acbaeaddULL,
0 x88bdb650c273970aULL,
0 x9333bd5ebbff84c2ULL,
0 x4e6a8f2c47dfa08bULL,
0 x321c954db76cef2aULL,
0 x418d312a72837942ULL,
0 xb29b38bfffcdf773ULL,
0 x6c022c38f90a4c07ULL,
0 x5a033a240b0f6a8aULL,
0 x1f93885f3ce5da6fULL,
0 xc38a537e96988bc6ULL,
0 x39e6a81ac759ff44ULL,
0 x29929e43cee0fce2ULL,
0 x40cdd87924de0ca2ULL,
0 xe9d8ebc8a29fe819ULL,
0 x0c2798f3cfbb46f4ULL,
0 x55e484223e53b343ULL,
0 x4650948ecd0d2fd8ULL,
0 x20e86cb2126f0651ULL,
0 x6d42c56baf5739e7ULL,
0 xa06fc1405ace1e08ULL,
0 x7babbfc54f3d193bULL,
0 x424d17df8864e67fULL,
0 xd8045870ef14980eULL,
0 xc6d7397c85ac3781ULL,
0 x21a885e1443273b1ULL,
0 x67f8116f893f5c69ULL,
0 x24f5efe35706cff6ULL,
0 xd56329d076f2ab1aULL,
0 x5e1eb9754e66a32dULL,
0 x28d2771098bd8902ULL,
0 x8f6013f47dfdc190ULL,
0 x17a993fdb637553cULL,
0 xe0a219397e1012aaULL,
0 x786b9930b5da8606ULL,
0 x6e82e39e55b0a6daULL,
0 x875a0856f72f4ec3ULL,
0 x3741ff4fa458536dULL,
0 xac4859b3957558fcULL,
0 x7ef6d5c75c09a57cULL,
0 xc04a758b6c7f14fbULL,
0 xf9acdd91ab26ebbfULL,
0 x7391a467c5ef9668ULL,
0 x335c7c1ee1319acaULL,
0 xa91533b18641e4bbULL,
0 xe4bf9a683b79db0dULL,
0 x8e20faa72ba0b470ULL,
0 x51f907737b3a7ae4ULL,
0 x2268a314bed5ec8cULL,
0 xd944b123b949edeeULL,
0 x31dcb3b84d8b7017ULL,
0 xd3fe65279f218860ULL,
0 x097af2f1dc8ffab3ULL,
0 x9b09a6fc312d0b91ULL,
0 xcc6ded78a3c4520fULL,
0 x3481d9ba5ebfcc50ULL,
0 x4f2a667f1182d56bULL,
0 xdfd9fdd4509ace94ULL,
0 x26752045fbbc252bULL,
0 xbffc491f662bc467ULL,
0 xdd593272fc202449ULL,
0 x3cbbc218d46d4303ULL,
0 x91b372f817456e1fULL,
0 x681faf69bc6385a0ULL,
0 xb686bbeebaa43ed4ULL,
0 x1469b5084cd0ca01ULL,
0 x98c98009cbca94acULL,
0 x6438379a73d8c354ULL,
0 xc2caba2dc0c5fe26ULL,
0 x3e3b0dbe78d7a9deULL,
0 x50b9ee202d670f04ULL,
0 x4590b27b37eab0e5ULL,
0 x6025b4cb36b10af3ULL,
0 xfb2c1237079c0162ULL,
0 xa12f28130c936be8ULL,
0 x4b37e52e54eb1cccULL,
0 x083a1ba28ad28f53ULL,
0 xc10a9cd83a22611bULL,
0 x9f1425ad7444c236ULL,
0 x069d4cf7e9d3237aULL,
0 xedc56899e7f621beULL,
0 x778c273680865fcfULL,
0 x309c5aeb1bd605f7ULL,
0 x8de0dc52d1472b4dULL,
0 xf8ec34c2fd7b9e5fULL,
0 xea18cd3d58787724ULL,
0 xaad515447ca67b86ULL,
0 x9989695a9d97e14cULL,
0 x0000000000000000ULL,
0 xf196c63321f464ecULL,
0 x71116bc169557cb5ULL,
0 xaf887f466f92c7c1ULL,
0 x972e3e0ffe964d65ULL,
0 x190ec4a8d536f915ULL,
0 x95aef1a9522ca7b8ULL,
0 xdc19db21aa7d51a9ULL,
0 x94ee18fa0471d258ULL,
0 x8087adf248a11859ULL,
0 xc457f6da2916dd5cULL,
0 xfa6cfb6451c17482ULL,
0 xf256e0c6db13fbd1ULL,
0 x6a9f60cf10d96f7dULL,
0 x4daaa9d9bd383fb6ULL,
0 x03c026f5fae79f3dULL,
0 xde99148706c7bb74ULL,
0 x2a52b8b6340763dfULL,
0 x6fc20acd03edd33aULL,
0 xd423c08320afdefaULL,
0 xbbe1ca4e23420dc0ULL,
0 x966ed75ca8cb3885ULL,
0 xeb58246e0e2502c4ULL,
0 x055d6a021334bc47ULL,
0 xa47242111fa7d7afULL,
0 xe3623fcc84f78d97ULL,
0 x81c744a11efc6db9ULL,
0 xaec8961539cfb221ULL,
0 xf31609958d4e8e31ULL,
0 x63e5923ecc5695ceULL,
0 x47107ddd9b505a38ULL,
0 xa3afe7b5a0298135ULL,
0 x792b7063e387f3e6ULL,
0 x0140e953565d75e0ULL,
0 x12f4f9ffa503e97bULL,
0 x750ce8902c3cb512ULL,
0 xdbc47e8515f30733ULL,
0 x1ed3610c6ab8af8fULL,
0 x5239218681dde5d9ULL,
0 xe222d69fd2aaf877ULL,
0 xfe71783514a8bd25ULL,
0 xcaf0a18f4a177175ULL,
0 x61655d9860ec7f13ULL,
0 xe77fbc9dc19e4430ULL,
0 x2ccff441ddd440a5ULL,
0 x16e97aaee06a20dcULL,
0 xa855dae2d01c915bULL,
0 x1d1347f9905f30b2ULL,
0 xb7c652bdecf94b34ULL,
0 xd03e43d265c6175dULL,
0 xfdb15ec0ee4f2218ULL,
0 x57644b8492e9599eULL,
0 x07dda5a4bf8e569aULL,
0 x54a46d71680ec6a3ULL,
0 x5624a2d7c4b42c7eULL,
0 xbebca04c3076b187ULL,
0 x7d36f332a6ee3a41ULL,
0 x3b6667bc6be31599ULL,
0 x695f463aea3ef040ULL,
0 xad08b0e0c3282d1cULL,
0 xb15b1e4a052a684eULL,
0 x44d05b2861b7c505ULL,
0 x15295c5b1a8dbfe1ULL,
0 x744c01c37a61c0f2ULL,
0 x59c31cd1f1e8f5b7ULL,
0 xef45a73f4b4ccb63ULL,
0 x6bdf899c46841a9dULL,
0 x3dfb2b4b823036e3ULL,
0 xa2ef0ee6f674f4d5ULL,
0 x184e2dfb836b8cf5ULL,
0 x1134df0a5fe47646ULL,
0 xbaa1231d751f7820ULL,
0 xd17eaa81339b62bdULL,
0 xb01bf71953771daeULL,
0 x849a2ea30dc8d1feULL,
0 x705182923f080955ULL,
0 x0ea757556301ac29ULL,
0 x041d83514569c9a7ULL,
0 x0abad4042668658eULL,
0 x49b72a88f851f611ULL,
0 x8a3d79f66ec97dd7ULL,
0 xcd2d042bf59927efULL,
0 xc930877ab0f0ee48ULL,
0 x9273540deda2f122ULL,
0 xc797d02fd3f14261ULL,
0 xe1e2f06a284d674aULL,
0 xd2be8c74c97cfd80ULL,
0 x9a494faf67707e71ULL,
0 xb3dbd1eca9908293ULL,
0 x72d14d3493b2e388ULL,
0 xd6a30f258c153427ULL
}
};
/* Ax */
static void streebog_xor(
const struct streebog_uint512 *x,
const struct streebog_uint512 *y,
struct streebog_uint512 *z)
{
z->qword[
0 ] = x->qword[
0 ] ^ y->qword[
0 ];
z->qword[
1 ] = x->qword[
1 ] ^ y->qword[
1 ];
z->qword[
2 ] = x->qword[
2 ] ^ y->qword[
2 ];
z->qword[
3 ] = x->qword[
3 ] ^ y->qword[
3 ];
z->qword[
4 ] = x->qword[
4 ] ^ y->qword[
4 ];
z->qword[
5 ] = x->qword[
5 ] ^ y->qword[
5 ];
z->qword[
6 ] = x->qword[
6 ] ^ y->qword[
6 ];
z->qword[
7 ] = x->qword[
7 ] ^ y->qword[
7 ];
}
static void streebog_xlps(
const struct streebog_uint512 *x,
const struct streebog_uint512 *y,
struct streebog_uint512 *data)
{
u64 r0, r1, r2, r3, r4, r5, r6, r7;
int i;
r0 = le64_to_cpu(x->qword[
0 ] ^ y->qword[
0 ]);
r1 = le64_to_cpu(x->qword[
1 ] ^ y->qword[
1 ]);
r2 = le64_to_cpu(x->qword[
2 ] ^ y->qword[
2 ]);
r3 = le64_to_cpu(x->qword[
3 ] ^ y->qword[
3 ]);
r4 = le64_to_cpu(x->qword[
4 ] ^ y->qword[
4 ]);
r5 = le64_to_cpu(x->qword[
5 ] ^ y->qword[
5 ]);
r6 = le64_to_cpu(x->qword[
6 ] ^ y->qword[
6 ]);
r7 = le64_to_cpu(x->qword[
7 ] ^ y->qword[
7 ]);
for (i =
0 ; i <=
7 ; i++) {
data->qword[i] = cpu_to_le64(Ax[
0 ][r0 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
1 ][r1 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
2 ][r2 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
3 ][r3 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
4 ][r4 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
5 ][r5 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
6 ][r6 &
0 xFF]);
data->qword[i] ^= cpu_to_le64(Ax[
7 ][r7 &
0 xFF]);
r0 >>=
8 ;
r1 >>=
8 ;
r2 >>=
8 ;
r3 >>=
8 ;
r4 >>=
8 ;
r5 >>=
8 ;
r6 >>=
8 ;
r7 >>=
8 ;
}
}
static void streebog_round(
int i,
struct streebog_uint512 *Ki,
struct streebog_uint512 *data)
{
streebog_xlps(Ki, &C[i], Ki);
streebog_xlps(Ki, data, data);
}
static int streebog_init(
struct shash_desc *desc)
{
struct streebog_state *ctx = shash_desc_ctx(desc);
unsigned int digest_size = crypto_shash_digestsize(desc->tfm);
unsigned int i;
memset(ctx,
0 ,
sizeof (
struct streebog_state));
for (i =
0 ; i <
8 ; i++) {
if (digest_size == STREEBOG256_DIGEST_SIZE)
ctx->h.qword[i] = cpu_to_le64(
0 x0101010101010101ULL);
}
return 0 ;
}
static void streebog_add512(
const struct streebog_uint512 *x,
const struct streebog_uint512 *y,
struct streebog_uint512 *r)
{
u64 carry =
0 ;
int i;
for (i =
0 ; i <
8 ; i++) {
const u64 left = le64_to_cpu(x->qword[i]);
u64 sum;
sum = left + le64_to_cpu(y->qword[i]) + carry;
if (sum != left)
carry = (sum < left);
r->qword[i] = cpu_to_le64(sum);
}
}
static void streebog_g(
struct streebog_uint512 *h,
const struct streebog_uint512 *N,
const struct streebog_uint512 *m)
{
struct streebog_uint512 Ki, data;
unsigned int i;
streebog_xlps(h, N, &data);
/* Starting E() */
Ki = data;
streebog_xlps(&Ki, m, &data);
for (i =
0 ; i <
11 ; i++)
streebog_round(i, &Ki, &data);
streebog_xlps(&Ki, &C[
11 ], &Ki);
streebog_xor(&Ki, &data, &data);
/* E() done */
streebog_xor(&data, h, &data);
streebog_xor(&data, m, h);
}
static void streebog_stage2(
struct streebog_state *ctx,
const u8 *data)
{
struct streebog_uint512 m;
memcpy(&m, data,
sizeof (m));
streebog_g(&ctx->h, &ctx->N, &m);
streebog_add512(&ctx->N, &buffer512, &ctx->N);
streebog_add512(&ctx->Sigma, &m, &ctx->Sigma);
}
static void streebog_stage3(
struct streebog_state *ctx,
const u8 *src,
unsigned int len)
{
struct streebog_uint512 buf = { {
0 } };
union {
u8 buffer[STREEBOG_BLOCK_SIZE];
struct streebog_uint512 m;
} u = {};
buf.qword[
0 ] = cpu_to_le64(len <<
3 );
memcpy(u.buffer, src, len);
u.buffer[len] =
1 ;
streebog_g(&ctx->h, &ctx->N, &u.m);
streebog_add512(&ctx->N, &buf, &ctx->N);
streebog_add512(&ctx->Sigma, &u.m, &ctx->Sigma);
memzero_explicit(&u,
sizeof (u));
streebog_g(&ctx->h, &buffer0, &ctx->N);
streebog_g(&ctx->h, &buffer0, &ctx->Sigma);
memcpy(&ctx->hash, &ctx->h,
sizeof (
struct streebog_uint512));
}
static int streebog_update(
struct shash_desc *desc,
const u8 *data,
unsigned int len)
{
struct streebog_state *ctx = shash_desc_ctx(desc);
do {
streebog_stage2(ctx, data);
data += STREEBOG_BLOCK_SIZE;
len -= STREEBOG_BLOCK_SIZE;
}
while (len >= STREEBOG_BLOCK_SIZE);
return len;
}
static int streebog_finup(
struct shash_desc *desc,
const u8 *src,
unsigned int len, u8 *digest)
{
struct streebog_state *ctx = shash_desc_ctx(desc);
streebog_stage3(ctx, src, len);
if (crypto_shash_digestsize(desc->tfm) == STREEBOG256_DIGEST_SIZE)
memcpy(digest, &ctx->hash.qword[
4 ], STREEBOG256_DIGEST_SIZE);
else
memcpy(digest, &ctx->hash.qword[
0 ], STREEBOG512_DIGEST_SIZE);
return 0 ;
}
static struct shash_alg algs[
2 ] = { {
.digestsize = STREEBOG256_DIGEST_SIZE,
.init = streebog_init,
.update = streebog_update,
.finup = streebog_finup,
.descsize =
sizeof (
struct streebog_state),
.base = {
.cra_name =
"streebog256" ,
.cra_driver_name =
"streebog256-generic" ,
.cra_flags = CRYPTO_AHASH_ALG_BLOCK_ONLY,
.cra_blocksize = STREEBOG_BLOCK_SIZE,
.cra_module = THIS_MODULE,
},
}, {
.digestsize = STREEBOG512_DIGEST_SIZE,
.init = streebog_init,
.update = streebog_update,
.finup = streebog_finup,
.descsize =
sizeof (
struct streebog_state),
.base = {
.cra_name =
"streebog512" ,
.cra_driver_name =
"streebog512-generic" ,
.cra_flags = CRYPTO_AHASH_ALG_BLOCK_ONLY,
.cra_blocksize = STREEBOG_BLOCK_SIZE,
.cra_module = THIS_MODULE,
}
} };
static int __init streebog_mod_init(
void )
{
return crypto_register_shashes(algs, ARRAY_SIZE(algs));
}
static void __
exit streebog_mod_fini(
void )
{
crypto_unregister_shashes(algs, ARRAY_SIZE(algs));
}
module_init(streebog_mod_init);
module_exit(streebog_mod_fini);
MODULE_LICENSE(
"GPL" );
MODULE_AUTHOR(
"Vitaly Chikunov <vt@altlinux.org>" );
MODULE_DESCRIPTION(
"Streebog Hash Function" );
MODULE_ALIAS_CRYPTO(
"streebog256" );
MODULE_ALIAS_CRYPTO(
"streebog256-generic" );
MODULE_ALIAS_CRYPTO(
"streebog512" );
MODULE_ALIAS_CRYPTO(
"streebog512-generic" );
Messung V0.5 in Prozent C=100 H=91 G=95
¤ Dauer der Verarbeitung: 0.28 Sekunden
(vorverarbeitet am 2026-06-06)
¤
*© Formatika GbR, Deutschland