bitcracker/src_OpenCL/kernel_attack.cl

2465 lines
147 KiB
Common Lisp
Executable File

/*
* BitCracker: BitLocker password cracking tool, OpenCL version.
* Copyright (C) 2013-2017 Elena Ago <elena dot ago at gmail dot com>
* Massimo Bernaschi <massimo dot bernaschi at gmail dot com>
*
* This file is part of the BitCracker project: https://github.com/e-ago/bitcracker
*
* BitCracker 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.
*
* BitCracker is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with BitCracker. If not, see <http://www.gnu.org/licenses/>.
*/
__constant unsigned int TS0[256] = {
0xC66363A5U, 0xF87C7C84U, 0xEE777799U, 0xF67B7B8DU, 0xFFF2F20DU, 0xD66B6BBDU, 0xDE6F6FB1U, 0x91C5C554U,
0x60303050U, 0x02010103U, 0xCE6767A9U, 0x562B2B7DU, 0xE7FEFE19U, 0xB5D7D762U, 0x4DABABE6U, 0xEC76769AU,
0x8FCACA45U, 0x1F82829DU, 0x89C9C940U, 0xFA7D7D87U, 0xEFFAFA15U, 0xB25959EBU, 0x8E4747C9U, 0xFBF0F00BU,
0x41ADADECU, 0xB3D4D467U, 0x5FA2A2FDU, 0x45AFAFEAU, 0x239C9CBFU, 0x53A4A4F7U, 0xE4727296U, 0x9BC0C05BU,
0x75B7B7C2U, 0xE1FDFD1CU, 0x3D9393AEU, 0x4C26266AU, 0x6C36365AU, 0x7E3F3F41U, 0xF5F7F702U, 0x83CCCC4FU,
0x6834345CU, 0x51A5A5F4U, 0xD1E5E534U, 0xF9F1F108U, 0xE2717193U, 0xABD8D873U, 0x62313153U, 0x2A15153FU,
0x0804040CU, 0x95C7C752U, 0x46232365U, 0x9DC3C35EU, 0x30181828U, 0x379696A1U, 0x0A05050FU, 0x2F9A9AB5U,
0x0E070709U, 0x24121236U, 0x1B80809BU, 0xDFE2E23DU, 0xCDEBEB26U, 0x4E272769U, 0x7FB2B2CDU, 0xEA75759FU,
0x1209091BU, 0x1D83839EU, 0x582C2C74U, 0x341A1A2EU, 0x361B1B2DU, 0xDC6E6EB2U, 0xB45A5AEEU, 0x5BA0A0FBU,
0xA45252F6U, 0x763B3B4DU, 0xB7D6D661U, 0x7DB3B3CEU, 0x5229297BU, 0xDDE3E33EU, 0x5E2F2F71U, 0x13848497U,
0xA65353F5U, 0xB9D1D168U, 0x00000000U, 0xC1EDED2CU, 0x40202060U, 0xE3FCFC1FU, 0x79B1B1C8U, 0xB65B5BEDU,
0xD46A6ABEU, 0x8DCBCB46U, 0x67BEBED9U, 0x7239394BU, 0x944A4ADEU, 0x984C4CD4U, 0xB05858E8U, 0x85CFCF4AU,
0xBBD0D06BU, 0xC5EFEF2AU, 0x4FAAAAE5U, 0xEDFBFB16U, 0x864343C5U, 0x9A4D4DD7U, 0x66333355U, 0x11858594U,
0x8A4545CFU, 0xE9F9F910U, 0x04020206U, 0xFE7F7F81U, 0xA05050F0U, 0x783C3C44U, 0x259F9FBAU, 0x4BA8A8E3U,
0xA25151F3U, 0x5DA3A3FEU, 0x804040C0U, 0x058F8F8AU, 0x3F9292ADU, 0x219D9DBCU, 0x70383848U, 0xF1F5F504U,
0x63BCBCDFU, 0x77B6B6C1U, 0xAFDADA75U, 0x42212163U, 0x20101030U, 0xE5FFFF1AU, 0xFDF3F30EU, 0xBFD2D26DU,
0x81CDCD4CU, 0x180C0C14U, 0x26131335U, 0xC3ECEC2FU, 0xBE5F5FE1U, 0x359797A2U, 0x884444CCU, 0x2E171739U,
0x93C4C457U, 0x55A7A7F2U, 0xFC7E7E82U, 0x7A3D3D47U, 0xC86464ACU, 0xBA5D5DE7U, 0x3219192BU, 0xE6737395U,
0xC06060A0U, 0x19818198U, 0x9E4F4FD1U, 0xA3DCDC7FU, 0x44222266U, 0x542A2A7EU, 0x3B9090ABU, 0x0B888883U,
0x8C4646CAU, 0xC7EEEE29U, 0x6BB8B8D3U, 0x2814143CU, 0xA7DEDE79U, 0xBC5E5EE2U, 0x160B0B1DU, 0xADDBDB76U,
0xDBE0E03BU, 0x64323256U, 0x743A3A4EU, 0x140A0A1EU, 0x924949DBU, 0x0C06060AU, 0x4824246CU, 0xB85C5CE4U,
0x9FC2C25DU, 0xBDD3D36EU, 0x43ACACEFU, 0xC46262A6U, 0x399191A8U, 0x319595A4U, 0xD3E4E437U, 0xF279798BU,
0xD5E7E732U, 0x8BC8C843U, 0x6E373759U, 0xDA6D6DB7U, 0x018D8D8CU, 0xB1D5D564U, 0x9C4E4ED2U, 0x49A9A9E0U,
0xD86C6CB4U, 0xAC5656FAU, 0xF3F4F407U, 0xCFEAEA25U, 0xCA6565AFU, 0xF47A7A8EU, 0x47AEAEE9U, 0x10080818U,
0x6FBABAD5U, 0xF0787888U, 0x4A25256FU, 0x5C2E2E72U, 0x381C1C24U, 0x57A6A6F1U, 0x73B4B4C7U, 0x97C6C651U,
0xCBE8E823U, 0xA1DDDD7CU, 0xE874749CU, 0x3E1F1F21U, 0x964B4BDDU, 0x61BDBDDCU, 0x0D8B8B86U, 0x0F8A8A85U,
0xE0707090U, 0x7C3E3E42U, 0x71B5B5C4U, 0xCC6666AAU, 0x904848D8U, 0x06030305U, 0xF7F6F601U, 0x1C0E0E12U,
0xC26161A3U, 0x6A35355FU, 0xAE5757F9U, 0x69B9B9D0U, 0x17868691U, 0x99C1C158U, 0x3A1D1D27U, 0x279E9EB9U,
0xD9E1E138U, 0xEBF8F813U, 0x2B9898B3U, 0x22111133U, 0xD26969BBU, 0xA9D9D970U, 0x078E8E89U, 0x339494A7U,
0x2D9B9BB6U, 0x3C1E1E22U, 0x15878792U, 0xC9E9E920U, 0x87CECE49U, 0xAA5555FFU, 0x50282878U, 0xA5DFDF7AU,
0x038C8C8FU, 0x59A1A1F8U, 0x09898980U, 0x1A0D0D17U, 0x65BFBFDAU, 0xD7E6E631U, 0x844242C6U, 0xD06868B8U,
0x824141C3U, 0x299999B0U, 0x5A2D2D77U, 0x1E0F0F11U, 0x7BB0B0CBU, 0xA85454FCU, 0x6DBBBBD6U, 0x2C16163AU
};
__constant unsigned int TS1[256] = {
0xA5C66363U, 0x84F87C7CU, 0x99EE7777U, 0x8DF67B7BU, 0x0DFFF2F2U, 0xBDD66B6BU, 0xB1DE6F6FU, 0x5491C5C5U,
0x50603030U, 0x03020101U, 0xA9CE6767U, 0x7D562B2BU, 0x19E7FEFEU, 0x62B5D7D7U, 0xE64DABABU, 0x9AEC7676U,
0x458FCACAU, 0x9D1F8282U, 0x4089C9C9U, 0x87FA7D7DU, 0x15EFFAFAU, 0xEBB25959U, 0xC98E4747U, 0x0BFBF0F0U,
0xEC41ADADU, 0x67B3D4D4U, 0xFD5FA2A2U, 0xEA45AFAFU, 0xBF239C9CU, 0xF753A4A4U, 0x96E47272U, 0x5B9BC0C0U,
0xC275B7B7U, 0x1CE1FDFDU, 0xAE3D9393U, 0x6A4C2626U, 0x5A6C3636U, 0x417E3F3FU, 0x02F5F7F7U, 0x4F83CCCCU,
0x5C683434U, 0xF451A5A5U, 0x34D1E5E5U, 0x08F9F1F1U, 0x93E27171U, 0x73ABD8D8U, 0x53623131U, 0x3F2A1515U,
0x0C080404U, 0x5295C7C7U, 0x65462323U, 0x5E9DC3C3U, 0x28301818U, 0xA1379696U, 0x0F0A0505U, 0xB52F9A9AU,
0x090E0707U, 0x36241212U, 0x9B1B8080U, 0x3DDFE2E2U, 0x26CDEBEBU, 0x694E2727U, 0xCD7FB2B2U, 0x9FEA7575U,
0x1B120909U, 0x9E1D8383U, 0x74582C2CU, 0x2E341A1AU, 0x2D361B1BU, 0xB2DC6E6EU, 0xEEB45A5AU, 0xFB5BA0A0U,
0xF6A45252U, 0x4D763B3BU, 0x61B7D6D6U, 0xCE7DB3B3U, 0x7B522929U, 0x3EDDE3E3U, 0x715E2F2FU, 0x97138484U,
0xF5A65353U, 0x68B9D1D1U, 0x00000000U, 0x2CC1EDEDU, 0x60402020U, 0x1FE3FCFCU, 0xC879B1B1U, 0xEDB65B5BU,
0xBED46A6AU, 0x468DCBCBU, 0xD967BEBEU, 0x4B723939U, 0xDE944A4AU, 0xD4984C4CU, 0xE8B05858U, 0x4A85CFCFU,
0x6BBBD0D0U, 0x2AC5EFEFU, 0xE54FAAAAU, 0x16EDFBFBU, 0xC5864343U, 0xD79A4D4DU, 0x55663333U, 0x94118585U,
0xCF8A4545U, 0x10E9F9F9U, 0x06040202U, 0x81FE7F7FU, 0xF0A05050U, 0x44783C3CU, 0xBA259F9FU, 0xE34BA8A8U,
0xF3A25151U, 0xFE5DA3A3U, 0xC0804040U, 0x8A058F8FU, 0xAD3F9292U, 0xBC219D9DU, 0x48703838U, 0x04F1F5F5U,
0xDF63BCBCU, 0xC177B6B6U, 0x75AFDADAU, 0x63422121U, 0x30201010U, 0x1AE5FFFFU, 0x0EFDF3F3U, 0x6DBFD2D2U,
0x4C81CDCDU, 0x14180C0CU, 0x35261313U, 0x2FC3ECECU, 0xE1BE5F5FU, 0xA2359797U, 0xCC884444U, 0x392E1717U,
0x5793C4C4U, 0xF255A7A7U, 0x82FC7E7EU, 0x477A3D3DU, 0xACC86464U, 0xE7BA5D5DU, 0x2B321919U, 0x95E67373U,
0xA0C06060U, 0x98198181U, 0xD19E4F4FU, 0x7FA3DCDCU, 0x66442222U, 0x7E542A2AU, 0xAB3B9090U, 0x830B8888U,
0xCA8C4646U, 0x29C7EEEEU, 0xD36BB8B8U, 0x3C281414U, 0x79A7DEDEU, 0xE2BC5E5EU, 0x1D160B0BU, 0x76ADDBDBU,
0x3BDBE0E0U, 0x56643232U, 0x4E743A3AU, 0x1E140A0AU, 0xDB924949U, 0x0A0C0606U, 0x6C482424U, 0xE4B85C5CU,
0x5D9FC2C2U, 0x6EBDD3D3U, 0xEF43ACACU, 0xA6C46262U, 0xA8399191U, 0xA4319595U, 0x37D3E4E4U, 0x8BF27979U,
0x32D5E7E7U, 0x438BC8C8U, 0x596E3737U, 0xB7DA6D6DU, 0x8C018D8DU, 0x64B1D5D5U, 0xD29C4E4EU, 0xE049A9A9U,
0xB4D86C6CU, 0xFAAC5656U, 0x07F3F4F4U, 0x25CFEAEAU, 0xAFCA6565U, 0x8EF47A7AU, 0xE947AEAEU, 0x18100808U,
0xD56FBABAU, 0x88F07878U, 0x6F4A2525U, 0x725C2E2EU, 0x24381C1CU, 0xF157A6A6U, 0xC773B4B4U, 0x5197C6C6U,
0x23CBE8E8U, 0x7CA1DDDDU, 0x9CE87474U, 0x213E1F1FU, 0xDD964B4BU, 0xDC61BDBDU, 0x860D8B8BU, 0x850F8A8AU,
0x90E07070U, 0x427C3E3EU, 0xC471B5B5U, 0xAACC6666U, 0xD8904848U, 0x05060303U, 0x01F7F6F6U, 0x121C0E0EU,
0xA3C26161U, 0x5F6A3535U, 0xF9AE5757U, 0xD069B9B9U, 0x91178686U, 0x5899C1C1U, 0x273A1D1DU, 0xB9279E9EU,
0x38D9E1E1U, 0x13EBF8F8U, 0xB32B9898U, 0x33221111U, 0xBBD26969U, 0x70A9D9D9U, 0x89078E8EU, 0xA7339494U,
0xB62D9B9BU, 0x223C1E1EU, 0x92158787U, 0x20C9E9E9U, 0x4987CECEU, 0xFFAA5555U, 0x78502828U, 0x7AA5DFDFU,
0x8F038C8CU, 0xF859A1A1U, 0x80098989U, 0x171A0D0DU, 0xDA65BFBFU, 0x31D7E6E6U, 0xC6844242U, 0xB8D06868U,
0xC3824141U, 0xB0299999U, 0x775A2D2DU, 0x111E0F0FU, 0xCB7BB0B0U, 0xFCA85454U, 0xD66DBBBBU, 0x3A2C1616U
};
__constant unsigned int TS2[256] = {
0x63A5C663U, 0x7C84F87CU, 0x7799EE77U, 0x7B8DF67BU, 0xF20DFFF2U, 0x6BBDD66BU, 0x6FB1DE6FU, 0xC55491C5U,
0x30506030U, 0x01030201U, 0x67A9CE67U, 0x2B7D562BU, 0xFE19E7FEU, 0xD762B5D7U, 0xABE64DABU, 0x769AEC76U,
0xCA458FCAU, 0x829D1F82U, 0xC94089C9U, 0x7D87FA7DU, 0xFA15EFFAU, 0x59EBB259U, 0x47C98E47U, 0xF00BFBF0U,
0xADEC41ADU, 0xD467B3D4U, 0xA2FD5FA2U, 0xAFEA45AFU, 0x9CBF239CU, 0xA4F753A4U, 0x7296E472U, 0xC05B9BC0U,
0xB7C275B7U, 0xFD1CE1FDU, 0x93AE3D93U, 0x266A4C26U, 0x365A6C36U, 0x3F417E3FU, 0xF702F5F7U, 0xCC4F83CCU,
0x345C6834U, 0xA5F451A5U, 0xE534D1E5U, 0xF108F9F1U, 0x7193E271U, 0xD873ABD8U, 0x31536231U, 0x153F2A15U,
0x040C0804U, 0xC75295C7U, 0x23654623U, 0xC35E9DC3U, 0x18283018U, 0x96A13796U, 0x050F0A05U, 0x9AB52F9AU,
0x07090E07U, 0x12362412U, 0x809B1B80U, 0xE23DDFE2U, 0xEB26CDEBU, 0x27694E27U, 0xB2CD7FB2U, 0x759FEA75U,
0x091B1209U, 0x839E1D83U, 0x2C74582CU, 0x1A2E341AU, 0x1B2D361BU, 0x6EB2DC6EU, 0x5AEEB45AU, 0xA0FB5BA0U,
0x52F6A452U, 0x3B4D763BU, 0xD661B7D6U, 0xB3CE7DB3U, 0x297B5229U, 0xE33EDDE3U, 0x2F715E2FU, 0x84971384U,
0x53F5A653U, 0xD168B9D1U, 0x00000000U, 0xED2CC1EDU, 0x20604020U, 0xFC1FE3FCU, 0xB1C879B1U, 0x5BEDB65BU,
0x6ABED46AU, 0xCB468DCBU, 0xBED967BEU, 0x394B7239U, 0x4ADE944AU, 0x4CD4984CU, 0x58E8B058U, 0xCF4A85CFU,
0xD06BBBD0U, 0xEF2AC5EFU, 0xAAE54FAAU, 0xFB16EDFBU, 0x43C58643U, 0x4DD79A4DU, 0x33556633U, 0x85941185U,
0x45CF8A45U, 0xF910E9F9U, 0x02060402U, 0x7F81FE7FU, 0x50F0A050U, 0x3C44783CU, 0x9FBA259FU, 0xA8E34BA8U,
0x51F3A251U, 0xA3FE5DA3U, 0x40C08040U, 0x8F8A058FU, 0x92AD3F92U, 0x9DBC219DU, 0x38487038U, 0xF504F1F5U,
0xBCDF63BCU, 0xB6C177B6U, 0xDA75AFDAU, 0x21634221U, 0x10302010U, 0xFF1AE5FFU, 0xF30EFDF3U, 0xD26DBFD2U,
0xCD4C81CDU, 0x0C14180CU, 0x13352613U, 0xEC2FC3ECU, 0x5FE1BE5FU, 0x97A23597U, 0x44CC8844U, 0x17392E17U,
0xC45793C4U, 0xA7F255A7U, 0x7E82FC7EU, 0x3D477A3DU, 0x64ACC864U, 0x5DE7BA5DU, 0x192B3219U, 0x7395E673U,
0x60A0C060U, 0x81981981U, 0x4FD19E4FU, 0xDC7FA3DCU, 0x22664422U, 0x2A7E542AU, 0x90AB3B90U, 0x88830B88U,
0x46CA8C46U, 0xEE29C7EEU, 0xB8D36BB8U, 0x143C2814U, 0xDE79A7DEU, 0x5EE2BC5EU, 0x0B1D160BU, 0xDB76ADDBU,
0xE03BDBE0U, 0x32566432U, 0x3A4E743AU, 0x0A1E140AU, 0x49DB9249U, 0x060A0C06U, 0x246C4824U, 0x5CE4B85CU,
0xC25D9FC2U, 0xD36EBDD3U, 0xACEF43ACU, 0x62A6C462U, 0x91A83991U, 0x95A43195U, 0xE437D3E4U, 0x798BF279U,
0xE732D5E7U, 0xC8438BC8U, 0x37596E37U, 0x6DB7DA6DU, 0x8D8C018DU, 0xD564B1D5U, 0x4ED29C4EU, 0xA9E049A9U,
0x6CB4D86CU, 0x56FAAC56U, 0xF407F3F4U, 0xEA25CFEAU, 0x65AFCA65U, 0x7A8EF47AU, 0xAEE947AEU, 0x08181008U,
0xBAD56FBAU, 0x7888F078U, 0x256F4A25U, 0x2E725C2EU, 0x1C24381CU, 0xA6F157A6U, 0xB4C773B4U, 0xC65197C6U,
0xE823CBE8U, 0xDD7CA1DDU, 0x749CE874U, 0x1F213E1FU, 0x4BDD964BU, 0xBDDC61BDU, 0x8B860D8BU, 0x8A850F8AU,
0x7090E070U, 0x3E427C3EU, 0xB5C471B5U, 0x66AACC66U, 0x48D89048U, 0x03050603U, 0xF601F7F6U, 0x0E121C0EU,
0x61A3C261U, 0x355F6A35U, 0x57F9AE57U, 0xB9D069B9U, 0x86911786U, 0xC15899C1U, 0x1D273A1DU, 0x9EB9279EU,
0xE138D9E1U, 0xF813EBF8U, 0x98B32B98U, 0x11332211U, 0x69BBD269U, 0xD970A9D9U, 0x8E89078EU, 0x94A73394U,
0x9BB62D9BU, 0x1E223C1EU, 0x87921587U, 0xE920C9E9U, 0xCE4987CEU, 0x55FFAA55U, 0x28785028U, 0xDF7AA5DFU,
0x8C8F038CU, 0xA1F859A1U, 0x89800989U, 0x0D171A0DU, 0xBFDA65BFU, 0xE631D7E6U, 0x42C68442U, 0x68B8D068U,
0x41C38241U, 0x99B02999U, 0x2D775A2DU, 0x0F111E0FU, 0xB0CB7BB0U, 0x54FCA854U, 0xBBD66DBBU, 0x163A2C16U
};
__constant unsigned int TS3[256] = {
0x6363A5C6U, 0x7C7C84F8U, 0x777799EEU, 0x7B7B8DF6U, 0xF2F20DFFU, 0x6B6BBDD6U, 0x6F6FB1DEU, 0xC5C55491U,
0x30305060U, 0x01010302U, 0x6767A9CEU, 0x2B2B7D56U, 0xFEFE19E7U, 0xD7D762B5U, 0xABABE64DU, 0x76769AECU,
0xCACA458FU, 0x82829D1FU, 0xC9C94089U, 0x7D7D87FAU, 0xFAFA15EFU, 0x5959EBB2U, 0x4747C98EU, 0xF0F00BFBU,
0xADADEC41U, 0xD4D467B3U, 0xA2A2FD5FU, 0xAFAFEA45U, 0x9C9CBF23U, 0xA4A4F753U, 0x727296E4U, 0xC0C05B9BU,
0xB7B7C275U, 0xFDFD1CE1U, 0x9393AE3DU, 0x26266A4CU, 0x36365A6CU, 0x3F3F417EU, 0xF7F702F5U, 0xCCCC4F83U,
0x34345C68U, 0xA5A5F451U, 0xE5E534D1U, 0xF1F108F9U, 0x717193E2U, 0xD8D873ABU, 0x31315362U, 0x15153F2AU,
0x04040C08U, 0xC7C75295U, 0x23236546U, 0xC3C35E9DU, 0x18182830U, 0x9696A137U, 0x05050F0AU, 0x9A9AB52FU,
0x0707090EU, 0x12123624U, 0x80809B1BU, 0xE2E23DDFU, 0xEBEB26CDU, 0x2727694EU, 0xB2B2CD7FU, 0x75759FEAU,
0x09091B12U, 0x83839E1DU, 0x2C2C7458U, 0x1A1A2E34U, 0x1B1B2D36U, 0x6E6EB2DCU, 0x5A5AEEB4U, 0xA0A0FB5BU,
0x5252F6A4U, 0x3B3B4D76U, 0xD6D661B7U, 0xB3B3CE7DU, 0x29297B52U, 0xE3E33EDDU, 0x2F2F715EU, 0x84849713U,
0x5353F5A6U, 0xD1D168B9U, 0x00000000U, 0xEDED2CC1U, 0x20206040U, 0xFCFC1FE3U, 0xB1B1C879U, 0x5B5BEDB6U,
0x6A6ABED4U, 0xCBCB468DU, 0xBEBED967U, 0x39394B72U, 0x4A4ADE94U, 0x4C4CD498U, 0x5858E8B0U, 0xCFCF4A85U,
0xD0D06BBBU, 0xEFEF2AC5U, 0xAAAAE54FU, 0xFBFB16EDU, 0x4343C586U, 0x4D4DD79AU, 0x33335566U, 0x85859411U,
0x4545CF8AU, 0xF9F910E9U, 0x02020604U, 0x7F7F81FEU, 0x5050F0A0U, 0x3C3C4478U, 0x9F9FBA25U, 0xA8A8E34BU,
0x5151F3A2U, 0xA3A3FE5DU, 0x4040C080U, 0x8F8F8A05U, 0x9292AD3FU, 0x9D9DBC21U, 0x38384870U, 0xF5F504F1U,
0xBCBCDF63U, 0xB6B6C177U, 0xDADA75AFU, 0x21216342U, 0x10103020U, 0xFFFF1AE5U, 0xF3F30EFDU, 0xD2D26DBFU,
0xCDCD4C81U, 0x0C0C1418U, 0x13133526U, 0xECEC2FC3U, 0x5F5FE1BEU, 0x9797A235U, 0x4444CC88U, 0x1717392EU,
0xC4C45793U, 0xA7A7F255U, 0x7E7E82FCU, 0x3D3D477AU, 0x6464ACC8U, 0x5D5DE7BAU, 0x19192B32U, 0x737395E6U,
0x6060A0C0U, 0x81819819U, 0x4F4FD19EU, 0xDCDC7FA3U, 0x22226644U, 0x2A2A7E54U, 0x9090AB3BU, 0x8888830BU,
0x4646CA8CU, 0xEEEE29C7U, 0xB8B8D36BU, 0x14143C28U, 0xDEDE79A7U, 0x5E5EE2BCU, 0x0B0B1D16U, 0xDBDB76ADU,
0xE0E03BDBU, 0x32325664U, 0x3A3A4E74U, 0x0A0A1E14U, 0x4949DB92U, 0x06060A0CU, 0x24246C48U, 0x5C5CE4B8U,
0xC2C25D9FU, 0xD3D36EBDU, 0xACACEF43U, 0x6262A6C4U, 0x9191A839U, 0x9595A431U, 0xE4E437D3U, 0x79798BF2U,
0xE7E732D5U, 0xC8C8438BU, 0x3737596EU, 0x6D6DB7DAU, 0x8D8D8C01U, 0xD5D564B1U, 0x4E4ED29CU, 0xA9A9E049U,
0x6C6CB4D8U, 0x5656FAACU, 0xF4F407F3U, 0xEAEA25CFU, 0x6565AFCAU, 0x7A7A8EF4U, 0xAEAEE947U, 0x08081810U,
0xBABAD56FU, 0x787888F0U, 0x25256F4AU, 0x2E2E725CU, 0x1C1C2438U, 0xA6A6F157U, 0xB4B4C773U, 0xC6C65197U,
0xE8E823CBU, 0xDDDD7CA1U, 0x74749CE8U, 0x1F1F213EU, 0x4B4BDD96U, 0xBDBDDC61U, 0x8B8B860DU, 0x8A8A850FU,
0x707090E0U, 0x3E3E427CU, 0xB5B5C471U, 0x6666AACCU, 0x4848D890U, 0x03030506U, 0xF6F601F7U, 0x0E0E121CU,
0x6161A3C2U, 0x35355F6AU, 0x5757F9AEU, 0xB9B9D069U, 0x86869117U, 0xC1C15899U, 0x1D1D273AU, 0x9E9EB927U,
0xE1E138D9U, 0xF8F813EBU, 0x9898B32BU, 0x11113322U, 0x6969BBD2U, 0xD9D970A9U, 0x8E8E8907U, 0x9494A733U,
0x9B9BB62DU, 0x1E1E223CU, 0x87879215U, 0xE9E920C9U, 0xCECE4987U, 0x5555FFAAU, 0x28287850U, 0xDFDF7AA5U,
0x8C8C8F03U, 0xA1A1F859U, 0x89898009U, 0x0D0D171AU, 0xBFBFDA65U, 0xE6E631D7U, 0x4242C684U, 0x6868B8D0U,
0x4141C382U, 0x9999B029U, 0x2D2D775AU, 0x0F0F111EU, 0xB0B0CB7BU, 0x5454FCA8U, 0xBBBBD66DU, 0x16163A2CU
};
unsigned int LOP3LUT_XOR(unsigned int a, unsigned int b, unsigned int c);
unsigned int LOP3LUT_XORAND(unsigned int a, unsigned int b, unsigned int c);
unsigned int LOP3LUT_ANDOR(unsigned int a, unsigned int b, unsigned int c);
void encrypt(
unsigned int k0, unsigned int k1, unsigned int k2, unsigned int k3, unsigned int k4, unsigned int k5, unsigned int k6, unsigned int k7,
unsigned int m0, unsigned int m1, unsigned int m2, unsigned int m3,
unsigned int * output0, unsigned int * output1, unsigned int * output2, unsigned int * output3);
#define MIN(a,b) (((a)<(b))?(a):(b))
#define AES_CTX_LENGTH 256
#define FALSE 0
#define TRUE 1
#define SALT_SIZE 16
#define MAC_SIZE 16
#define NONCE_SIZE 12
#define IV_SIZE 16
#define VMK_SIZE 60
#define VMK_HEADER_SIZE 12
#define VMK_BODY_SIZE 32
#define VMK_FULL_SIZE 44
#define DICT_BUFSIZE (50*1024*1024)
#define HASH_SIZE 8 //32
#define ROUND_SHA_NUM 64
#define SINGLE_BLOCK_SHA_SIZE 64
#define SINGLE_BLOCK_W_SIZE 64
#define PADDING_SIZE 40
#define ITERATION_NUMBER 0x100000
#define WORD_SIZE 4
#define INPUT_SIZE 2048
#define FIXED_PART_INPUT_CHAIN_HASH 88
#define MIN_INPUT_PASSWORD_LEN 8
#define MAX_INPUT_PASSWORD_LEN 27
#define RECOVERY_KEY_SIZE_CHAR 56
#define RECOVERY_PASS_BLOCKS 8
#define MODE_USER_PASS 1
#define MODE_RECV_PASS 2
#define PSW_CHAR_SIZE 64
#define PSW_INT_SIZE 16 //32 for double passwords
#define FIRST_LENGHT 27
#define SECOND_LENGHT 55
#define BLOCK_UNIT 32
#define HASH_SIZE_STRING 32
#define END_STRING 0x80
#define BLOCK_SIZE 64
#define ROR7(x) (((x) << 25) | ((x) >> 7))
#define ROR18(x) (((x) << 14) | ((x) >> 18))
#define ROR17(x) (((x) << 15) | ((x) >> 17))
#define ROR19(x) (((x) << 13) | ((x) >> 19))
#define SCHEDULE0() \
schedule0 = schedule16 + schedule25 \
+ LOP3LUT_XOR(ROR7(schedule17) , ROR18(schedule17) , (schedule17 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule30) , ROR19(schedule30) , (schedule30 >> 10));
#define SCHEDULE1() \
schedule1 = schedule17 + schedule26 \
+ LOP3LUT_XOR(ROR7(schedule18) , ROR18(schedule18) , (schedule18 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule31) , ROR19(schedule31) , (schedule31 >> 10));
#define SCHEDULE2() \
schedule2 = schedule18 + schedule27 \
+ LOP3LUT_XOR(ROR7(schedule19) , ROR18(schedule19) , (schedule19 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule0) , ROR19(schedule0) , (schedule0 >> 10));
#define SCHEDULE3() \
schedule3 = schedule19 + schedule28 \
+ LOP3LUT_XOR(ROR7(schedule20) , ROR18(schedule20) , (schedule20 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule1) , ROR19(schedule1) , (schedule1 >> 10));
#define SCHEDULE4() \
schedule4 = schedule20 + schedule29 \
+ LOP3LUT_XOR(ROR7(schedule21) , ROR18(schedule21) , (schedule21 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule2) , ROR19(schedule2) , (schedule2 >> 10));
#define SCHEDULE5() \
schedule5 = schedule21 + schedule30 \
+ LOP3LUT_XOR(ROR7(schedule22) , ROR18(schedule22) , (schedule22 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule3) , ROR19(schedule3) , (schedule3 >> 10));
#define SCHEDULE6() \
schedule6 = schedule22 + schedule31 \
+ LOP3LUT_XOR(ROR7(schedule23) , ROR18(schedule23) , (schedule23 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule4) , ROR19(schedule4) , (schedule4 >> 10));
#define SCHEDULE7() \
schedule7 = schedule23 + schedule0 \
+ LOP3LUT_XOR(ROR7(schedule24) , ROR18(schedule24) , (schedule24 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule5) , ROR19(schedule5) , (schedule5 >> 10));
#define SCHEDULE8() \
schedule8 = schedule24 + schedule1 \
+ LOP3LUT_XOR(ROR7(schedule25) , ROR18(schedule25) , (schedule25 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule6) , ROR19(schedule6) , (schedule6 >> 10));
#define SCHEDULE9() \
schedule9 = schedule25 + schedule2 \
+ LOP3LUT_XOR(ROR7(schedule26) , ROR18(schedule26) , (schedule26 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule7) , ROR19(schedule7) , (schedule7 >> 10));
#define SCHEDULE10() \
schedule10 = schedule26 + schedule3 \
+ LOP3LUT_XOR(ROR7(schedule27) , ROR18(schedule27) , (schedule27 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule8) , ROR19(schedule8) , (schedule8 >> 10));
#define SCHEDULE11() \
schedule11 = schedule27 + schedule4 \
+ LOP3LUT_XOR(ROR7(schedule28) , ROR18(schedule28) , (schedule28 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule9) , ROR19(schedule9) , (schedule9 >> 10));
#define SCHEDULE12() \
schedule12 = schedule28 + schedule5 \
+ LOP3LUT_XOR(ROR7(schedule29) , ROR18(schedule29) , (schedule29 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule10) , ROR19(schedule10) , (schedule10 >> 10));
#define SCHEDULE13() \
schedule13 = schedule29 + schedule6 \
+ LOP3LUT_XOR(ROR7(schedule30) , ROR18(schedule30) , (schedule30 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule11) , ROR19(schedule11) , (schedule11 >> 10));
#define SCHEDULE14() \
schedule14 = schedule30 + schedule7 \
+ LOP3LUT_XOR(ROR7(schedule31) , ROR18(schedule31) , (schedule31 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule12) , ROR19(schedule12) , (schedule12 >> 10));
#define SCHEDULE15() \
schedule15 = schedule31 + schedule8 \
+ LOP3LUT_XOR(ROR7(schedule0) , ROR18(schedule0) , (schedule0 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule13) , ROR19(schedule13) , (schedule13 >> 10));
#define SCHEDULE16() \
schedule16 = schedule0 + schedule9 \
+ LOP3LUT_XOR( ROR7(schedule1), ROR18(schedule1), (schedule1 >> 3)) \
+ LOP3LUT_XOR( ROR17(schedule14), ROR19(schedule14), (schedule14 >> 10));
#define SCHEDULE17() \
schedule17 = schedule1 + schedule10 \
+ LOP3LUT_XOR(ROR7(schedule2) , ROR18(schedule2) , (schedule2 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule15) , ROR19(schedule15) , (schedule15 >> 10));
#define SCHEDULE18() \
schedule18 = schedule2 + schedule11 \
+ LOP3LUT_XOR(ROR7(schedule3) ,ROR18(schedule3) ,(schedule3 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule16), ROR19(schedule16), (schedule16 >> 10));
#define SCHEDULE19() \
schedule19 = schedule3 + schedule12 \
+ LOP3LUT_XOR(ROR7(schedule4) , ROR18(schedule4) , (schedule4 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule17) , ROR19(schedule17) , (schedule17 >> 10));
#define SCHEDULE20() \
schedule20 = schedule4 + schedule13 \
+ LOP3LUT_XOR(ROR7(schedule5) , ROR18(schedule5) , (schedule5 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule18) , ROR19(schedule18) , (schedule18 >> 10));
#define SCHEDULE21() \
schedule21 = schedule5 + schedule14 \
+ LOP3LUT_XOR(ROR7(schedule6) , ROR18(schedule6) , (schedule6 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule19) , ROR19(schedule19) , (schedule19 >> 10));
#define SCHEDULE22() \
schedule22 = schedule6 + schedule15 \
+ LOP3LUT_XOR(ROR7(schedule7) , ROR18(schedule7) , (schedule7 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule20) , ROR19(schedule20) , (schedule20 >> 10));
#define SCHEDULE23() \
schedule23 = schedule7 + schedule16 \
+ LOP3LUT_XOR(ROR7(schedule8) , ROR18(schedule8) , (schedule8 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule21) , ROR19(schedule21) , (schedule21 >> 10));
#define SCHEDULE24() \
schedule24 = schedule8 + schedule17 \
+ LOP3LUT_XOR(ROR7(schedule9) , ROR18(schedule9) , (schedule9 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule22) , ROR19(schedule22) , (schedule22 >> 10));
#define SCHEDULE25() \
schedule25 = schedule9 + schedule18 \
+ LOP3LUT_XOR(ROR7(schedule10) , ROR18(schedule10) , (schedule10 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule23) , ROR19(schedule23) , (schedule23 >> 10));
#define SCHEDULE26() \
schedule26 = schedule10 + schedule19 \
+ LOP3LUT_XOR(ROR7(schedule11) , ROR18(schedule11) , (schedule11 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule24) , ROR19(schedule24) , (schedule24 >> 10));
#define SCHEDULE27() \
schedule27 = schedule11 + schedule20 \
+ LOP3LUT_XOR(ROR7(schedule12) , ROR18(schedule12) , (schedule12 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule25) , ROR19(schedule25) , (schedule25 >> 10));
#define SCHEDULE28() \
schedule28 = schedule12 + schedule21 \
+ LOP3LUT_XOR(ROR7(schedule13) , ROR18(schedule13) , (schedule13 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule26) , ROR19(schedule26) , (schedule26 >> 10));
#define SCHEDULE29() \
schedule29 = schedule13 + schedule22 \
+ LOP3LUT_XOR(ROR7(schedule14) , ROR18(schedule14) , (schedule14 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule27) , ROR19(schedule27) , (schedule27 >> 10));
#define SCHEDULE30() \
schedule30 = schedule14 + schedule23 \
+ LOP3LUT_XOR(ROR7(schedule15) , ROR18(schedule15) , (schedule15 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule28) , ROR19(schedule28) , (schedule28 >> 10));
#define SCHEDULE31() \
schedule31 = schedule15 + schedule24 \
+ LOP3LUT_XOR(ROR7(schedule16) , ROR18(schedule16) , (schedule16 >> 3)) \
+ LOP3LUT_XOR(ROR17(schedule29) , ROR19(schedule29) , (schedule29 >> 10));
#define ALL_SCHEDULE32() \
SCHEDULE0() \
SCHEDULE1() \
SCHEDULE2() \
SCHEDULE3() \
SCHEDULE4() \
SCHEDULE5() \
SCHEDULE6() \
SCHEDULE7() \
SCHEDULE8() \
SCHEDULE9() \
SCHEDULE10() \
SCHEDULE11() \
SCHEDULE12() \
SCHEDULE13() \
SCHEDULE14() \
SCHEDULE15() \
SCHEDULE16() \
SCHEDULE17() \
SCHEDULE18() \
SCHEDULE19() \
SCHEDULE20() \
SCHEDULE21() \
SCHEDULE22() \
SCHEDULE23() \
SCHEDULE24() \
SCHEDULE25() \
SCHEDULE26() \
SCHEDULE27() \
SCHEDULE28() \
SCHEDULE29() \
SCHEDULE30() \
SCHEDULE31()
#define ALL_SCHEDULE_LAST16() \
SCHEDULE16() \
SCHEDULE17() \
SCHEDULE18() \
SCHEDULE19() \
SCHEDULE20() \
SCHEDULE21() \
SCHEDULE22() \
SCHEDULE23() \
SCHEDULE24() \
SCHEDULE25() \
SCHEDULE26() \
SCHEDULE27() \
SCHEDULE28() \
SCHEDULE29() \
SCHEDULE30() \
SCHEDULE31()
#define ROR6(x) (((x) << 26) | ((x) >> 6))
#define ROR11(x) (((x) << 21) | ((x) >> 11))
#define ROR25(x) (((x) << 7) | ((x) >> 25))
#define ROR2(x) (((x) << 30) | ((x) >> 2))
#define ROR13(x) (((x) << 19) | ((x) >> 13))
#define ROR22(x) (((x) << 10) | ((x) >> 22))
#define ROUND(a, b, c, d, e, f, g, h, W, k) \
h += LOP3LUT_XOR(ROR6(e), ROR11(e), ROR25(e)) + LOP3LUT_XORAND(g,e,f) + k + W; \
d += h; \
h += LOP3LUT_XOR(ROR2(a), ROR13(a), ROR22(a)) + LOP3LUT_ANDOR(a,b,c); /*((a & (b | c)) | (b & c)); */
#define ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, i, k, indexW) \
h += LOP3LUT_XOR(ROR6(e), ROR11(e), ROR25(e)) + LOP3LUT_XORAND(g,e,f) + k + w_blocks_d[indexW+i]; \
d += h; \
h += LOP3LUT_XOR(ROR2(a), ROR13(a), ROR22(a)) + LOP3LUT_ANDOR(a,b,c);
unsigned int LOP3LUT_XOR(unsigned int a, unsigned int b, unsigned int c) {
#if DEV_NVIDIA_SM50 == 1
unsigned int d;
asm("lop3.b32 %0, %1, %2, %3, 0x96;" : "=r"(d) : "r"(a), "r"(b), "r"(c));
return d;
#else
return a^b^c;
#endif
}
unsigned int LOP3LUT_XORAND(unsigned int a, unsigned int b, unsigned int c) {
#if DEV_NVIDIA_SM50 == 1
unsigned int d;
asm("lop3.b32 %0, %1, %2, %3, 0xb8;" : "=r"(d) : "r"(a), "r"(b), "r"(c));
return d;
#else
return (a ^ (b & (c ^ a)));
#endif
}
unsigned int LOP3LUT_ANDOR(unsigned int a, unsigned int b, unsigned int c) {
#if DEV_NVIDIA_SM50 == 1
unsigned int d;
asm("lop3.b32 %0, %1, %2, %3, 0xe8;" : "=r"(d) : "r"(a), "r"(b), "r"(c));
return d;
#else
return ((a & (b | c)) | (b & c));
#endif
}
__kernel void opencl_bitcracker_attack(int numPassword, __global int *w_password,
__global int *found, __global unsigned char * vmkKey,
__global unsigned int *w_blocks_d,
unsigned int IV0, unsigned int IV4,
unsigned int IV8, unsigned int IV12)
{
unsigned int schedule0, schedule1, schedule2, schedule3, schedule4, schedule5, schedule6, schedule7, schedule8, schedule9;
unsigned int schedule10, schedule11, schedule12, schedule13, schedule14, schedule15, schedule16, schedule17, schedule18, schedule19;
unsigned int schedule20, schedule21, schedule22, schedule23, schedule24, schedule25, schedule26, schedule27, schedule28, schedule29;
unsigned int schedule30, schedule31;
unsigned int first_hash0, first_hash1, first_hash2, first_hash3, first_hash4, first_hash5, first_hash6, first_hash7;
unsigned int hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7;
unsigned int a, b, c, d, e, f, g, h;
int gIndex = (int)get_global_id(0);
int index_generic;
int indexW=(gIndex*PSW_INT_SIZE);
while(gIndex < numPassword)
{
first_hash0 = 0x6A09E667;
first_hash1 = 0xBB67AE85;
first_hash2 = 0x3C6EF372;
first_hash3 = 0xA54FF53A;
first_hash4 = 0x510E527F;
first_hash5 = 0x9B05688C;
first_hash6 = 0x1F83D9AB;
first_hash7 = 0x5BE0CD19;
//----------------------------------------------------- FIRST HASH ------------------------------------------------
a = 0x6A09E667;
b = 0xBB67AE85;
c = 0x3C6EF372;
d = 0xA54FF53A;
e = 0x510E527F;
f = 0x9B05688C;
g = 0x1F83D9AB;
h = 0x5BE0CD19;
indexW=(gIndex*PSW_INT_SIZE);
//--------------------- SCHEDULE -------------------
schedule0 = (unsigned int) (w_password[indexW+0]);
schedule1 = (unsigned int) (w_password[indexW+1]);
schedule2 = (unsigned int) (w_password[indexW+2]);
schedule3 = (unsigned int) (w_password[indexW+3]);
schedule4 = (unsigned int) (w_password[indexW+4]);
schedule5 = (unsigned int) (w_password[indexW+5]);
schedule6 = (unsigned int) (w_password[indexW+6]);
schedule7 = (unsigned int) (w_password[indexW+7]);
schedule8 = (unsigned int) (w_password[indexW+8]);
schedule9 = (unsigned int) (w_password[indexW+9]);
schedule10 = (unsigned int) (w_password[indexW+10]);
schedule11 = (unsigned int) (w_password[indexW+11]);
schedule12 = (unsigned int) (w_password[indexW+12]);
schedule13 = (unsigned int) (w_password[indexW+13]);
schedule14 = (unsigned int) (w_password[indexW+14]);
schedule15 = (unsigned int) (w_password[indexW+15]);
//-----------------------------------------------
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
first_hash0 += a;
first_hash1 += b;
first_hash2 += c;
first_hash3 += d;
first_hash4 += e;
first_hash5 += f;
first_hash6 += g;
first_hash7 += h;
//User password only
#if ATTACK_MODE < 2
//----------------------------------------------------- SECOND HASH ------------------------------------------------
schedule0 = first_hash0;
schedule1 = first_hash1;
schedule2 = first_hash2;
schedule3 = first_hash3;
schedule4 = first_hash4;
schedule5 = first_hash5;
schedule6 = first_hash6;
schedule7 = first_hash7;
schedule8 = 0x80000000;
schedule9 = 0;
schedule10 = 0;
schedule11 = 0;
schedule12 = 0;
schedule13 = 0;
schedule14 = 0;
schedule15 = 0x100;
first_hash0 = 0x6A09E667;
first_hash1 = 0xBB67AE85;
first_hash2 = 0x3C6EF372;
first_hash3 = 0xA54FF53A;
first_hash4 = 0x510E527F;
first_hash5 = 0x9B05688C;
first_hash6 = 0x1F83D9AB;
first_hash7 = 0x5BE0CD19;
a = first_hash0;
b = first_hash1;
c = first_hash2;
d = first_hash3;
e = first_hash4;
f = first_hash5;
g = first_hash6;
h = first_hash7;
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
first_hash0 += a;
first_hash1 += b;
first_hash2 += c;
first_hash3 += d;
first_hash4 += e;
first_hash5 += f;
first_hash6 += g;
first_hash7 += h;
#endif
//----------------------------------------------------- LOOP HASH ------------------------------------------------
hash0=0;
hash1=0;
hash2=0;
hash3=0;
hash4=0;
hash5=0;
hash6=0;
hash7=0;
indexW=0;
for(index_generic=0; index_generic < ITERATION_NUMBER/2; index_generic++)
{
a = 0x6A09E667;
b = 0xBB67AE85;
c = 0x3C6EF372;
d = 0xA54FF53A;
e = 0x510E527F;
f = 0x9B05688C;
g = 0x1F83D9AB;
h = 0x5BE0CD19;
schedule0 = hash0;
schedule1 = hash1;
schedule2 = hash2;
schedule3 = hash3;
schedule4 = hash4;
schedule5 = hash5;
schedule6 = hash6;
schedule7 = hash7;
schedule8 = first_hash0;
schedule9 = first_hash1;
schedule10 = first_hash2;
schedule11 = first_hash3;
schedule12 = first_hash4;
schedule13 = first_hash5;
schedule14 = first_hash6;
schedule15 = first_hash7;
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
hash0 = 0x6A09E667 + a;
hash1 = 0xBB67AE85 + b;
hash2 = 0x3C6EF372 + c;
hash3 = 0xA54FF53A + d;
hash4 = 0x510E527F + e;
hash5 = 0x9B05688C + f;
hash6 = 0x1F83D9AB + g;
hash7 = 0x5BE0CD19 + h;
a = hash0;
b = hash1;
c = hash2;
d = hash3;
e = hash4;
f = hash5;
g = hash6;
h = hash7;
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 0, 0x428A2F98, 0)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 1, 0x71374491, 0)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 2, 0xB5C0FBCF, 0)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 3, 0xE9B5DBA5, 0)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 4, 0x3956C25B, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 5, 0x59F111F1, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 6, 0x923F82A4, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 7, 0xAB1C5ED5, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 8, 0xD807AA98, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 9, 0x12835B01, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 10, 0x243185BE, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 11, 0x550C7DC3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 12, 0x72BE5D74, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 13, 0x80DEB1FE, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 14, 0x9BDC06A7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 15, 0xC19BF174, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 16, 0xE49B69C1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 17, 0xEFBE4786, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 18, 0x0FC19DC6, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 19, 0x240CA1CC, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 20, 0x2DE92C6F, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 21, 0x4A7484AA, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 22, 0x5CB0A9DC, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 23, 0x76F988DA, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 24, 0x983E5152, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 25, 0xA831C66D, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 26, 0xB00327C8, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 27, 0xBF597FC7, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 28, 0xC6E00BF3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 29, 0xD5A79147, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 30, 0x06CA6351, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 31, 0x14292967, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 32, 0x27B70A85, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 33, 0x2E1B2138, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 34, 0x4D2C6DFC, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 35, 0x53380D13, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 36, 0x650A7354, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 37, 0x766A0ABB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 38, 0x81C2C92E, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 39, 0x92722C85, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 40, 0xA2BFE8A1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 41, 0xA81A664B, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 42, 0xC24B8B70, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 43, 0xC76C51A3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 44, 0xD192E819, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 45, 0xD6990624, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 46, 0xF40E3585, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 47, 0x106AA070, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 48, 0x19A4C116, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 49, 0x1E376C08, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 50, 0x2748774C, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 51, 0x34B0BCB5, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 52, 0x391C0CB3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 53, 0x4ED8AA4A, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 54, 0x5B9CCA4F, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 55, 0x682E6FF3, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 56, 0x748F82EE, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 57, 0x78A5636F, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 58, 0x84C87814, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 59, 0x8CC70208, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 60, 0x90BEFFFA, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 61, 0xA4506CEB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 62, 0xBEF9A3F7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 63, 0xC67178F2, indexW)
hash0 += a;
hash1 += b;
hash2 += c;
hash3 += d;
hash4 += e;
hash5 += f;
hash6 += g;
hash7 += h;
indexW += SINGLE_BLOCK_W_SIZE;
}
for(index_generic=ITERATION_NUMBER/2; index_generic < ITERATION_NUMBER; index_generic++)
{
a = 0x6A09E667;
b = 0xBB67AE85;
c = 0x3C6EF372;
d = 0xA54FF53A;
e = 0x510E527F;
f = 0x9B05688C;
g = 0x1F83D9AB;
h = 0x5BE0CD19;
schedule0 = hash0;
schedule1 = hash1;
schedule2 = hash2;
schedule3 = hash3;
schedule4 = hash4;
schedule5 = hash5;
schedule6 = hash6;
schedule7 = hash7;
schedule8 = first_hash0;
schedule9 = first_hash1;
schedule10 = first_hash2;
schedule11 = first_hash3;
schedule12 = first_hash4;
schedule13 = first_hash5;
schedule14 = first_hash6;
schedule15 = first_hash7;
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
hash0 = 0x6A09E667 + a;
hash1 = 0xBB67AE85 + b;
hash2 = 0x3C6EF372 + c;
hash3 = 0xA54FF53A + d;
hash4 = 0x510E527F + e;
hash5 = 0x9B05688C + f;
hash6 = 0x1F83D9AB + g;
hash7 = 0x5BE0CD19 + h;
a = hash0;
b = hash1;
c = hash2;
d = hash3;
e = hash4;
f = hash5;
g = hash6;
h = hash7;
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 0, 0x428A2F98, 0)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 1, 0x71374491, 0)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 2, 0xB5C0FBCF, 0)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 3, 0xE9B5DBA5, 0)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 4, 0x3956C25B, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 5, 0x59F111F1, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 6, 0x923F82A4, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 7, 0xAB1C5ED5, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 8, 0xD807AA98, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 9, 0x12835B01, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 10, 0x243185BE, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 11, 0x550C7DC3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 12, 0x72BE5D74, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 13, 0x80DEB1FE, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 14, 0x9BDC06A7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 15, 0xC19BF174, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 16, 0xE49B69C1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 17, 0xEFBE4786, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 18, 0x0FC19DC6, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 19, 0x240CA1CC, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 20, 0x2DE92C6F, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 21, 0x4A7484AA, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 22, 0x5CB0A9DC, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 23, 0x76F988DA, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 24, 0x983E5152, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 25, 0xA831C66D, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 26, 0xB00327C8, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 27, 0xBF597FC7, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 28, 0xC6E00BF3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 29, 0xD5A79147, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 30, 0x06CA6351, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 31, 0x14292967, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 32, 0x27B70A85, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 33, 0x2E1B2138, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 34, 0x4D2C6DFC, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 35, 0x53380D13, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 36, 0x650A7354, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 37, 0x766A0ABB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 38, 0x81C2C92E, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 39, 0x92722C85, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 40, 0xA2BFE8A1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 41, 0xA81A664B, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 42, 0xC24B8B70, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 43, 0xC76C51A3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 44, 0xD192E819, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 45, 0xD6990624, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 46, 0xF40E3585, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 47, 0x106AA070, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 48, 0x19A4C116, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 49, 0x1E376C08, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 50, 0x2748774C, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 51, 0x34B0BCB5, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 52, 0x391C0CB3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 53, 0x4ED8AA4A, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 54, 0x5B9CCA4F, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 55, 0x682E6FF3, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 56, 0x748F82EE, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 57, 0x78A5636F, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 58, 0x84C87814, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 59, 0x8CC70208, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 60, 0x90BEFFFA, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 61, 0xA4506CEB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 62, 0xBEF9A3F7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 63, 0xC67178F2, indexW)
hash0 += a;
hash1 += b;
hash2 += c;
hash3 += d;
hash4 += e;
hash5 += f;
hash6 += g;
hash7 += h;
indexW += SINGLE_BLOCK_W_SIZE;
}
schedule0=
(
(unsigned int )(((unsigned int )(IV0 & 0xff000000)) >> 24) |
(unsigned int )((unsigned int )(IV0 & 0x00ff0000) >> 8) |
(unsigned int )((unsigned int )(IV0 & 0x0000ff00) << 8) |
(unsigned int )((unsigned int )(IV0 & 0x000000ff) << 24)
) ^ hash0;
schedule1=
(
(unsigned int )(((unsigned int )(IV4 & 0xff000000)) >> 24) |
(unsigned int )((unsigned int )(IV4 & 0x00ff0000) >> 8) |
(unsigned int )((unsigned int )(IV4 & 0x0000ff00) << 8) |
(unsigned int )((unsigned int )(IV4 & 0x000000ff) << 24)
) ^ hash1;
schedule2=
(
(unsigned int )(((unsigned int )(IV8 & 0xff000000)) >> 24) |
(unsigned int )((unsigned int )(IV8 & 0x00ff0000) >> 8) |
(unsigned int )((unsigned int )(IV8 & 0x0000ff00) << 8) |
(unsigned int )((unsigned int )(IV8 & 0x000000ff) << 24)
) ^ hash2;
schedule3=
(
(unsigned int )(((unsigned int )(IV12 & 0xff000000)) >> 24) |
(unsigned int )((unsigned int )(IV12 & 0x00ff0000) >> 8) |
(unsigned int )((unsigned int )(IV12 & 0x0000ff00) << 8) |
(unsigned int )((unsigned int )(IV12 & 0x000000ff) << 24)
) ^ hash3;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= LOP3LUT_XOR(LOP3LUT_XOR( (TS2[(hash7 >> 24) ] & 0x000000FF), (TS3[(hash7 >> 16) & 0xFF] & 0xFF000000), (TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000)),
(TS1[(hash7 ) & 0xFF] & 0x0000FF00), 0x01000000
); //RCON[0];
hash1 ^= hash0; hash2 ^= hash1; hash3 ^= hash2;
schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule4 >> 24], TS1[(schedule5 >> 16) & 0xFF], TS2[(schedule6 >> 8) & 0xFF]) , TS3[schedule7 & 0xFF] , hash0);
schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule5 >> 24], TS1[(schedule6 >> 16) & 0xFF], TS2[(schedule7 >> 8) & 0xFF]) , TS3[schedule4 & 0xFF] , hash1);
schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule6 >> 24], TS1[(schedule7 >> 16) & 0xFF], TS2[(schedule4 >> 8) & 0xFF]) , TS3[schedule5 & 0xFF] , hash2);
schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule7 >> 24], TS1[(schedule4 >> 16) & 0xFF], TS2[(schedule5 >> 8) & 0xFF]) , TS3[schedule6 & 0xFF] , hash3);
hash4 ^= (TS3[(hash3 >> 24) ] & 0xFF000000) ^
(TS0[(hash3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(hash3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(hash3 ) & 0xFF] & 0x000000FF);
hash5 ^= hash4;
hash6 ^= hash5;
hash7 ^= hash6;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= (TS2[(hash7 >> 24) ] & 0x000000FF) ^
(TS3[(hash7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(hash7 ) & 0xFF] & 0x0000FF00) ^ 0x02000000; //RCON[1];
hash1 ^= hash0; hash2 ^= hash1; hash3 ^= hash2;
schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule4 >> 24], TS1[(schedule5 >> 16) & 0xFF], TS2[(schedule6 >> 8) & 0xFF]) , TS3[schedule7 & 0xFF] , hash0);
schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule5 >> 24], TS1[(schedule6 >> 16) & 0xFF], TS2[(schedule7 >> 8) & 0xFF]) , TS3[schedule4 & 0xFF] , hash1);
schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule6 >> 24], TS1[(schedule7 >> 16) & 0xFF], TS2[(schedule4 >> 8) & 0xFF]) , TS3[schedule5 & 0xFF] , hash2);
schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule7 >> 24], TS1[(schedule4 >> 16) & 0xFF], TS2[(schedule5 >> 8) & 0xFF]) , TS3[schedule6 & 0xFF] , hash3);
hash4 ^= (TS3[(hash3 >> 24) ] & 0xFF000000) ^
(TS0[(hash3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(hash3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(hash3 ) & 0xFF] & 0x000000FF);
hash5 ^= hash4;
hash6 ^= hash5;
hash7 ^= hash6;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= (TS2[(hash7 >> 24) ] & 0x000000FF) ^
(TS3[(hash7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(hash7 ) & 0xFF] & 0x0000FF00) ^ 0x04000000; //RCON[2];
hash1 ^= hash0; hash2 ^= hash1; hash3 ^= hash2;
schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule4 >> 24], TS1[(schedule5 >> 16) & 0xFF], TS2[(schedule6 >> 8) & 0xFF]) , TS3[schedule7 & 0xFF] , hash0);
schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule5 >> 24], TS1[(schedule6 >> 16) & 0xFF], TS2[(schedule7 >> 8) & 0xFF]) , TS3[schedule4 & 0xFF] , hash1);
schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule6 >> 24], TS1[(schedule7 >> 16) & 0xFF], TS2[(schedule4 >> 8) & 0xFF]) , TS3[schedule5 & 0xFF] , hash2);
schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule7 >> 24], TS1[(schedule4 >> 16) & 0xFF], TS2[(schedule5 >> 8) & 0xFF]) , TS3[schedule6 & 0xFF] , hash3);
hash4 ^= (TS3[(hash3 >> 24) ] & 0xFF000000) ^
(TS0[(hash3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(hash3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(hash3 ) & 0xFF] & 0x000000FF);
hash5 ^= hash4;
hash6 ^= hash5;
hash7 ^= hash6;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= (TS2[(hash7 >> 24) ] & 0x000000FF) ^
(TS3[(hash7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(hash7 ) & 0xFF] & 0x0000FF00) ^ 0x08000000; //RCON[3];
hash1 ^= hash0; hash2 ^= hash1; hash3 ^= hash2;
schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule4 >> 24], TS1[(schedule5 >> 16) & 0xFF], TS2[(schedule6 >> 8) & 0xFF]) , TS3[schedule7 & 0xFF] , hash0);
schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule5 >> 24], TS1[(schedule6 >> 16) & 0xFF], TS2[(schedule7 >> 8) & 0xFF]) , TS3[schedule4 & 0xFF] , hash1);
schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule6 >> 24], TS1[(schedule7 >> 16) & 0xFF], TS2[(schedule4 >> 8) & 0xFF]) , TS3[schedule5 & 0xFF] , hash2);
schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule7 >> 24], TS1[(schedule4 >> 16) & 0xFF], TS2[(schedule5 >> 8) & 0xFF]) , TS3[schedule6 & 0xFF] , hash3);
hash4 ^= (TS3[(hash3 >> 24) ] & 0xFF000000) ^
(TS0[(hash3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(hash3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(hash3 ) & 0xFF] & 0x000000FF);
hash5 ^= hash4;
hash6 ^= hash5;
hash7 ^= hash6;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= (TS2[(hash7 >> 24) ] & 0x000000FF) ^
(TS3[(hash7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(hash7 ) & 0xFF] & 0x0000FF00) ^ 0x10000000; //RCON[4];
hash1 ^= hash0; hash2 ^= hash1; hash3 ^= hash2;
schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule4 >> 24], TS1[(schedule5 >> 16) & 0xFF], TS2[(schedule6 >> 8) & 0xFF]) , TS3[schedule7 & 0xFF] , hash0);
schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule5 >> 24], TS1[(schedule6 >> 16) & 0xFF], TS2[(schedule7 >> 8) & 0xFF]) , TS3[schedule4 & 0xFF] , hash1);
schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule6 >> 24], TS1[(schedule7 >> 16) & 0xFF], TS2[(schedule4 >> 8) & 0xFF]) , TS3[schedule5 & 0xFF] , hash2);
schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule7 >> 24], TS1[(schedule4 >> 16) & 0xFF], TS2[(schedule5 >> 8) & 0xFF]) , TS3[schedule6 & 0xFF] , hash3);
hash4 ^= (TS3[(hash3 >> 24) ] & 0xFF000000) ^
(TS0[(hash3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(hash3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(hash3 ) & 0xFF] & 0x000000FF);
hash5 ^= hash4;
hash6 ^= hash5;
hash7 ^= hash6;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= (TS2[(hash7 >> 24) ] & 0x000000FF) ^
(TS3[(hash7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(hash7 ) & 0xFF] & 0x0000FF00) ^ 0x20000000; //RCON[5];
hash1 ^= hash0; hash2 ^= hash1; hash3 ^= hash2;
schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule4 >> 24], TS1[(schedule5 >> 16) & 0xFF], TS2[(schedule6 >> 8) & 0xFF]) , TS3[schedule7 & 0xFF] , hash0);
schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule5 >> 24], TS1[(schedule6 >> 16) & 0xFF], TS2[(schedule7 >> 8) & 0xFF]) , TS3[schedule4 & 0xFF] , hash1);
schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule6 >> 24], TS1[(schedule7 >> 16) & 0xFF], TS2[(schedule4 >> 8) & 0xFF]) , TS3[schedule5 & 0xFF] , hash2);
schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule7 >> 24], TS1[(schedule4 >> 16) & 0xFF], TS2[(schedule5 >> 8) & 0xFF]) , TS3[schedule6 & 0xFF] , hash3);
hash4 ^= (TS3[(hash3 >> 24) ] & 0xFF000000) ^
(TS0[(hash3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(hash3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(hash3 ) & 0xFF] & 0x000000FF);
hash5 ^= hash4;
hash6 ^= hash5;
hash7 ^= hash6;
schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule0 >> 24], TS1[(schedule1 >> 16) & 0xFF], TS2[(schedule2 >> 8) & 0xFF]) , TS3[schedule3 & 0xFF] , hash4);
schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule1 >> 24], TS1[(schedule2 >> 16) & 0xFF], TS2[(schedule3 >> 8) & 0xFF]) , TS3[schedule0 & 0xFF] , hash5);
schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule2 >> 24], TS1[(schedule3 >> 16) & 0xFF], TS2[(schedule0 >> 8) & 0xFF]) , TS3[schedule1 & 0xFF] , hash6);
schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[schedule3 >> 24], TS1[(schedule0 >> 16) & 0xFF], TS2[(schedule1 >> 8) & 0xFF]) , TS3[schedule2 & 0xFF] , hash7);
hash0 ^= (TS2[(hash7 >> 24) ] & 0x000000FF) ^
(TS3[(hash7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(hash7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(hash7 ) & 0xFF] & 0x0000FF00) ^ 0x40000000; //RCON[6];
hash1 ^= hash0;
hash2 ^= hash1;
hash3 ^= hash2;
schedule0 = (TS2[(schedule4 >> 24) ] & 0xFF000000) ^
(TS3[(schedule5 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(schedule6 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(schedule7 ) & 0xFF] & 0x000000FF) ^ hash0;
schedule1 = (TS2[(schedule5 >> 24) ] & 0xFF000000) ^
(TS3[(schedule6 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(schedule7 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(schedule4 ) & 0xFF] & 0x000000FF) ^ hash1;
schedule2 = (TS2[(schedule6 >> 24) ] & 0xFF000000) ^
(TS3[(schedule7 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(schedule4 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(schedule5 ) & 0xFF] & 0x000000FF) ^ hash2;
schedule3 = (TS2[(schedule7 >> 24) ] & 0xFF000000) ^
(TS3[(schedule4 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(schedule5 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(schedule6 ) & 0xFF] & 0x000000FF) ^ hash3;
schedule4 =
(unsigned int)(((unsigned int)(schedule0 & 0xff000000)) >> 24) |
(unsigned int)((unsigned int)(schedule0 & 0x00ff0000) >> 8) |
(unsigned int)((unsigned int)(schedule0 & 0x0000ff00) << 8) |
(unsigned int)((unsigned int)(schedule0 & 0x000000ff) << 24);
schedule5 =
(unsigned int)(((unsigned int)(schedule1 & 0xff000000)) >> 24) |
(unsigned int)((unsigned int)(schedule1 & 0x00ff0000) >> 8) |
(unsigned int)((unsigned int)(schedule1 & 0x0000ff00) << 8) |
(unsigned int)((unsigned int)(schedule1 & 0x000000ff) << 24);
schedule6 =
(unsigned int)(((unsigned int)(schedule2 & 0xff000000)) >> 24) |
(unsigned int)((unsigned int)(schedule2 & 0x00ff0000) >> 8) |
(unsigned int)((unsigned int)(schedule2 & 0x0000ff00) << 8) |
(unsigned int)((unsigned int)(schedule2 & 0x000000ff) << 24);
if (
((vmkKey[0] ^ ((unsigned char)schedule4)) == 0x2c) &&
((vmkKey[1] ^ ((unsigned char)(schedule4 >> 8))) == 0x00) &&
((vmkKey[4] ^ ((unsigned char) schedule5)) == 0x01) &&
((vmkKey[5] ^ ((unsigned char) (schedule5 >> 8))) == 0x00) &&
#if STRICT_CHECK == 1
((vmkKey[8] ^ ((unsigned char) schedule6)) == 0x03) &&
#else
((vmkKey[8] ^ ((unsigned char)schedule6)) <= 0x05) &&
#endif
((vmkKey[9] ^ ((unsigned char)(schedule6 >> 8))) == 0x20)
)
{
found[0] = gIndex;
break;
}
gIndex += get_global_size(0);
}
return;
}
void encrypt(
unsigned int k0, unsigned int k1, unsigned int k2, unsigned int k3, unsigned int k4, unsigned int k5, unsigned int k6, unsigned int k7,
unsigned int m0, unsigned int m1, unsigned int m2, unsigned int m3,
unsigned int * output0, unsigned int * output1, unsigned int * output2, unsigned int * output3
)
{
unsigned int enc_schedule0, enc_schedule1, enc_schedule2, enc_schedule3, enc_schedule4, enc_schedule5, enc_schedule6, enc_schedule7;
unsigned int local_key0, local_key1, local_key2, local_key3, local_key4, local_key5, local_key6, local_key7;
local_key0=k0;
local_key1=k1;
local_key2=k2;
local_key3=k3;
local_key4=k4;
local_key5=k5;
local_key6=k6;
local_key7=k7;
enc_schedule0=(unsigned int )(((unsigned int )(m0 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(m0 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(m0 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(m0 & 0x000000ff) << 24);
enc_schedule0 = enc_schedule0 ^ local_key0;
enc_schedule1=(unsigned int )(((unsigned int )(m1 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(m1 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(m1 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(m1 & 0x000000ff) << 24);
enc_schedule1 = enc_schedule1 ^ local_key1;
enc_schedule2=(unsigned int )(((unsigned int )(m2 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(m2 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(m2 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(m2 & 0x000000ff) << 24);
enc_schedule2 = enc_schedule2 ^ local_key2;
enc_schedule3=(unsigned int )(((unsigned int )(m3 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(m3 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(m3 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(m3 & 0x000000ff) << 24);
enc_schedule3 = enc_schedule3 ^ local_key3;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= LOP3LUT_XOR(
LOP3LUT_XOR( (TS2[(local_key7 >> 24) ] & 0x000000FF), (TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000), (TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000)),
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00), 0x01000000
); //RCON[0];
local_key1 ^= local_key0; local_key2 ^= local_key1; local_key3 ^= local_key2;
enc_schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule4 >> 24], TS1[(enc_schedule5 >> 16) & 0xFF], TS2[(enc_schedule6 >> 8) & 0xFF]) , TS3[enc_schedule7 & 0xFF] , local_key0);
enc_schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule5 >> 24], TS1[(enc_schedule6 >> 16) & 0xFF], TS2[(enc_schedule7 >> 8) & 0xFF]) , TS3[enc_schedule4 & 0xFF] , local_key1);
enc_schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule6 >> 24], TS1[(enc_schedule7 >> 16) & 0xFF], TS2[(enc_schedule4 >> 8) & 0xFF]) , TS3[enc_schedule5 & 0xFF] , local_key2);
enc_schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule7 >> 24], TS1[(enc_schedule4 >> 16) & 0xFF], TS2[(enc_schedule5 >> 8) & 0xFF]) , TS3[enc_schedule6 & 0xFF] , local_key3);
local_key4 ^= (TS3[(local_key3 >> 24) ] & 0xFF000000) ^
(TS0[(local_key3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(local_key3 ) & 0xFF] & 0x000000FF);
local_key5 ^= local_key4;
local_key6 ^= local_key5;
local_key7 ^= local_key6;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= (TS2[(local_key7 >> 24) ] & 0x000000FF) ^
(TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00) ^ 0x02000000; //RCON[1];
local_key1 ^= local_key0; local_key2 ^= local_key1; local_key3 ^= local_key2;
enc_schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule4 >> 24], TS1[(enc_schedule5 >> 16) & 0xFF], TS2[(enc_schedule6 >> 8) & 0xFF]) , TS3[enc_schedule7 & 0xFF] , local_key0);
enc_schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule5 >> 24], TS1[(enc_schedule6 >> 16) & 0xFF], TS2[(enc_schedule7 >> 8) & 0xFF]) , TS3[enc_schedule4 & 0xFF] , local_key1);
enc_schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule6 >> 24], TS1[(enc_schedule7 >> 16) & 0xFF], TS2[(enc_schedule4 >> 8) & 0xFF]) , TS3[enc_schedule5 & 0xFF] , local_key2);
enc_schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule7 >> 24], TS1[(enc_schedule4 >> 16) & 0xFF], TS2[(enc_schedule5 >> 8) & 0xFF]) , TS3[enc_schedule6 & 0xFF] , local_key3);
local_key4 ^= (TS3[(local_key3 >> 24) ] & 0xFF000000) ^
(TS0[(local_key3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(local_key3 ) & 0xFF] & 0x000000FF);
local_key5 ^= local_key4;
local_key6 ^= local_key5;
local_key7 ^= local_key6;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= (TS2[(local_key7 >> 24) ] & 0x000000FF) ^
(TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00) ^ 0x04000000; //RCON[2];
local_key1 ^= local_key0; local_key2 ^= local_key1; local_key3 ^= local_key2;
enc_schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule4 >> 24], TS1[(enc_schedule5 >> 16) & 0xFF], TS2[(enc_schedule6 >> 8) & 0xFF]) , TS3[enc_schedule7 & 0xFF] , local_key0);
enc_schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule5 >> 24], TS1[(enc_schedule6 >> 16) & 0xFF], TS2[(enc_schedule7 >> 8) & 0xFF]) , TS3[enc_schedule4 & 0xFF] , local_key1);
enc_schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule6 >> 24], TS1[(enc_schedule7 >> 16) & 0xFF], TS2[(enc_schedule4 >> 8) & 0xFF]) , TS3[enc_schedule5 & 0xFF] , local_key2);
enc_schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule7 >> 24], TS1[(enc_schedule4 >> 16) & 0xFF], TS2[(enc_schedule5 >> 8) & 0xFF]) , TS3[enc_schedule6 & 0xFF] , local_key3);
local_key4 ^= (TS3[(local_key3 >> 24) ] & 0xFF000000) ^
(TS0[(local_key3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(local_key3 ) & 0xFF] & 0x000000FF);
local_key5 ^= local_key4;
local_key6 ^= local_key5;
local_key7 ^= local_key6;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= (TS2[(local_key7 >> 24) ] & 0x000000FF) ^
(TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00) ^ 0x08000000; //RCON[3];
local_key1 ^= local_key0; local_key2 ^= local_key1; local_key3 ^= local_key2;
enc_schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule4 >> 24], TS1[(enc_schedule5 >> 16) & 0xFF], TS2[(enc_schedule6 >> 8) & 0xFF]) , TS3[enc_schedule7 & 0xFF] , local_key0);
enc_schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule5 >> 24], TS1[(enc_schedule6 >> 16) & 0xFF], TS2[(enc_schedule7 >> 8) & 0xFF]) , TS3[enc_schedule4 & 0xFF] , local_key1);
enc_schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule6 >> 24], TS1[(enc_schedule7 >> 16) & 0xFF], TS2[(enc_schedule4 >> 8) & 0xFF]) , TS3[enc_schedule5 & 0xFF] , local_key2);
enc_schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule7 >> 24], TS1[(enc_schedule4 >> 16) & 0xFF], TS2[(enc_schedule5 >> 8) & 0xFF]) , TS3[enc_schedule6 & 0xFF] , local_key3);
local_key4 ^= (TS3[(local_key3 >> 24) ] & 0xFF000000) ^
(TS0[(local_key3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(local_key3 ) & 0xFF] & 0x000000FF);
local_key5 ^= local_key4;
local_key6 ^= local_key5;
local_key7 ^= local_key6;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= (TS2[(local_key7 >> 24) ] & 0x000000FF) ^
(TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00) ^ 0x10000000; //RCON[4];
local_key1 ^= local_key0; local_key2 ^= local_key1; local_key3 ^= local_key2;
enc_schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule4 >> 24], TS1[(enc_schedule5 >> 16) & 0xFF], TS2[(enc_schedule6 >> 8) & 0xFF]) , TS3[enc_schedule7 & 0xFF] , local_key0);
enc_schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule5 >> 24], TS1[(enc_schedule6 >> 16) & 0xFF], TS2[(enc_schedule7 >> 8) & 0xFF]) , TS3[enc_schedule4 & 0xFF] , local_key1);
enc_schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule6 >> 24], TS1[(enc_schedule7 >> 16) & 0xFF], TS2[(enc_schedule4 >> 8) & 0xFF]) , TS3[enc_schedule5 & 0xFF] , local_key2);
enc_schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule7 >> 24], TS1[(enc_schedule4 >> 16) & 0xFF], TS2[(enc_schedule5 >> 8) & 0xFF]) , TS3[enc_schedule6 & 0xFF] , local_key3);
local_key4 ^= (TS3[(local_key3 >> 24) ] & 0xFF000000) ^
(TS0[(local_key3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(local_key3 ) & 0xFF] & 0x000000FF);
local_key5 ^= local_key4;
local_key6 ^= local_key5;
local_key7 ^= local_key6;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= (TS2[(local_key7 >> 24) ] & 0x000000FF) ^
(TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00) ^ 0x20000000; //RCON[5];
local_key1 ^= local_key0; local_key2 ^= local_key1; local_key3 ^= local_key2;
enc_schedule0 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule4 >> 24], TS1[(enc_schedule5 >> 16) & 0xFF], TS2[(enc_schedule6 >> 8) & 0xFF]) , TS3[enc_schedule7 & 0xFF] , local_key0);
enc_schedule1 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule5 >> 24], TS1[(enc_schedule6 >> 16) & 0xFF], TS2[(enc_schedule7 >> 8) & 0xFF]) , TS3[enc_schedule4 & 0xFF] , local_key1);
enc_schedule2 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule6 >> 24], TS1[(enc_schedule7 >> 16) & 0xFF], TS2[(enc_schedule4 >> 8) & 0xFF]) , TS3[enc_schedule5 & 0xFF] , local_key2);
enc_schedule3 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule7 >> 24], TS1[(enc_schedule4 >> 16) & 0xFF], TS2[(enc_schedule5 >> 8) & 0xFF]) , TS3[enc_schedule6 & 0xFF] , local_key3);
local_key4 ^= (TS3[(local_key3 >> 24)] & 0xFF000000) ^
(TS0[(local_key3 >> 16) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key3 >> 8) & 0xFF] & 0x0000FF00) ^
(TS2[(local_key3 ) & 0xFF] & 0x000000FF);
local_key5 ^= local_key4;
local_key6 ^= local_key5;
local_key7 ^= local_key6;
enc_schedule4 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule0 >> 24], TS1[(enc_schedule1 >> 16) & 0xFF], TS2[(enc_schedule2 >> 8) & 0xFF]) , TS3[enc_schedule3 & 0xFF] , local_key4);
enc_schedule5 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule1 >> 24], TS1[(enc_schedule2 >> 16) & 0xFF], TS2[(enc_schedule3 >> 8) & 0xFF]) , TS3[enc_schedule0 & 0xFF] , local_key5);
enc_schedule6 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule2 >> 24], TS1[(enc_schedule3 >> 16) & 0xFF], TS2[(enc_schedule0 >> 8) & 0xFF]) , TS3[enc_schedule1 & 0xFF] , local_key6);
enc_schedule7 = LOP3LUT_XOR(LOP3LUT_XOR(TS0[enc_schedule3 >> 24], TS1[(enc_schedule0 >> 16) & 0xFF], TS2[(enc_schedule1 >> 8) & 0xFF]) , TS3[enc_schedule2 & 0xFF] , local_key7);
local_key0 ^= (TS2[(local_key7 >> 24)] & 0x000000FF) ^
(TS3[(local_key7 >> 16) & 0xFF] & 0xFF000000) ^
(TS0[(local_key7 >> 8) & 0xFF] & 0x00FF0000) ^
(TS1[(local_key7 ) & 0xFF] & 0x0000FF00) ^ 0x40000000; //RCON[6];
local_key1 ^= local_key0;
local_key2 ^= local_key1;
local_key3 ^= local_key2;
enc_schedule0 = (TS2[(enc_schedule4 >> 24) ] & 0xFF000000) ^
(TS3[(enc_schedule5 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(enc_schedule6 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(enc_schedule7 ) & 0xFF] & 0x000000FF) ^ local_key0;
enc_schedule1 = (TS2[(enc_schedule5 >> 24) ] & 0xFF000000) ^
(TS3[(enc_schedule6 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(enc_schedule7 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(enc_schedule4 ) & 0xFF] & 0x000000FF) ^ local_key1;
enc_schedule2 = (TS2[(enc_schedule6 >> 24) ] & 0xFF000000) ^
(TS3[(enc_schedule7 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(enc_schedule4 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(enc_schedule5 ) & 0xFF] & 0x000000FF) ^ local_key2;
enc_schedule3 = (TS2[(enc_schedule7 >> 24) ] & 0xFF000000) ^
(TS3[(enc_schedule4 >> 16) & 0xFF] & 0x00FF0000) ^
(TS0[(enc_schedule5 >> 8) & 0xFF] & 0x0000FF00) ^
(TS1[(enc_schedule6 ) & 0xFF] & 0x000000FF) ^ local_key3;
output0[0]=(unsigned int )(((unsigned int )(enc_schedule0 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(enc_schedule0 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(enc_schedule0 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(enc_schedule0 & 0x000000ff) << 24);
output1[0]=(unsigned int )(((unsigned int )(enc_schedule1 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(enc_schedule1 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(enc_schedule1 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(enc_schedule1 & 0x000000ff) << 24);
output2[0]=(unsigned int )(((unsigned int )(enc_schedule2 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(enc_schedule2 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(enc_schedule2 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(enc_schedule2 & 0x000000ff) << 24);
output3[0]=(unsigned int )(((unsigned int )(enc_schedule3 & 0xff000000)) >> 24) | (unsigned int )((unsigned int )(enc_schedule3 & 0x00ff0000) >> 8) | (unsigned int )((unsigned int )(enc_schedule3 & 0x0000ff00) << 8) | (unsigned int )((unsigned int )(enc_schedule3 & 0x000000ff) << 24);
}
__kernel void opencl_bitcracker_attack_mac(int numPassword, __global unsigned int *w_password,
__global int *found, __global unsigned char * vmkKey,
__global unsigned int *w_blocks_d,
unsigned int IV0, unsigned int IV4, unsigned int IV8, unsigned int IV12,
__global unsigned char * mac,
unsigned int macIV0, unsigned int macIV4, unsigned int macIV8, unsigned int macIV12,
unsigned int computeMacIV0, unsigned int computeMacIV4, unsigned int computeMacIV8, unsigned int computeMacIV12
)
{
unsigned int schedule0, schedule1, schedule2, schedule3, schedule4, schedule5, schedule6, schedule7, schedule8, schedule9;
unsigned int schedule10, schedule11, schedule12, schedule13, schedule14, schedule15, schedule16, schedule17, schedule18, schedule19;
unsigned int schedule20, schedule21, schedule22, schedule23, schedule24, schedule25, schedule26, schedule27, schedule28, schedule29;
unsigned int schedule30, schedule31;
unsigned int first_hash0, first_hash1, first_hash2, first_hash3, first_hash4, first_hash5, first_hash6, first_hash7;
unsigned int hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7;
unsigned int a, b, c, d, e, f, g, h;
int gIndex = (int)get_global_id(0);
int index_generic;
int indexW=(gIndex*PSW_INT_SIZE);
int curr_fetch=0;
while(gIndex < numPassword)
{
first_hash0 = 0x6A09E667;
first_hash1 = 0xBB67AE85;
first_hash2 = 0x3C6EF372;
first_hash3 = 0xA54FF53A;
first_hash4 = 0x510E527F;
first_hash5 = 0x9B05688C;
first_hash6 = 0x1F83D9AB;
first_hash7 = 0x5BE0CD19;
//----------------------------------------------------- FIRST HASH ------------------------------------------------
a = 0x6A09E667;
b = 0xBB67AE85;
c = 0x3C6EF372;
d = 0xA54FF53A;
e = 0x510E527F;
f = 0x9B05688C;
g = 0x1F83D9AB;
h = 0x5BE0CD19;
indexW=(gIndex*PSW_INT_SIZE);
//--------------------- SCHEDULE -------------------
schedule0 = (unsigned int) (w_password[indexW+0]);
schedule1 = (unsigned int) (w_password[indexW+1]);
schedule2 = (unsigned int) (w_password[indexW+2]);
schedule3 = (unsigned int) (w_password[indexW+3]);
schedule4 = (unsigned int) (w_password[indexW+4]);
schedule5 = (unsigned int) (w_password[indexW+5]);
schedule6 = (unsigned int) (w_password[indexW+6]);
schedule7 = (unsigned int) (w_password[indexW+7]);
schedule8 = (unsigned int) (w_password[indexW+8]);
schedule9 = (unsigned int) (w_password[indexW+9]);
schedule10 = (unsigned int) (w_password[indexW+10]);
schedule11 = (unsigned int) (w_password[indexW+11]);
schedule12 = (unsigned int) (w_password[indexW+12]);
schedule13 = (unsigned int) (w_password[indexW+13]);
schedule14 = (unsigned int) (w_password[indexW+14]);
schedule15 = (unsigned int) (w_password[indexW+15]);
//-----------------------------------------------
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
first_hash0 += a;
first_hash1 += b;
first_hash2 += c;
first_hash3 += d;
first_hash4 += e;
first_hash5 += f;
first_hash6 += g;
first_hash7 += h;
//User password only
#if ATTACK_MODE < 2
//----------------------------------------------------- SECOND HASH ------------------------------------------------
schedule0 = first_hash0;
schedule1 = first_hash1;
schedule2 = first_hash2;
schedule3 = first_hash3;
schedule4 = first_hash4;
schedule5 = first_hash5;
schedule6 = first_hash6;
schedule7 = first_hash7;
schedule8 = 0x80000000;
schedule9 = 0;
schedule10 = 0;
schedule11 = 0;
schedule12 = 0;
schedule13 = 0;
schedule14 = 0;
schedule15 = 0x100;
first_hash0 = 0x6A09E667;
first_hash1 = 0xBB67AE85;
first_hash2 = 0x3C6EF372;
first_hash3 = 0xA54FF53A;
first_hash4 = 0x510E527F;
first_hash5 = 0x9B05688C;
first_hash6 = 0x1F83D9AB;
first_hash7 = 0x5BE0CD19;
a = first_hash0;
b = first_hash1;
c = first_hash2;
d = first_hash3;
e = first_hash4;
f = first_hash5;
g = first_hash6;
h = first_hash7;
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
first_hash0 += a;
first_hash1 += b;
first_hash2 += c;
first_hash3 += d;
first_hash4 += e;
first_hash5 += f;
first_hash6 += g;
first_hash7 += h;
#endif
//----------------------------------------------------- LOOP HASH ------------------------------------------------
hash0=0;
hash1=0;
hash2=0;
hash3=0;
hash4=0;
hash5=0;
hash6=0;
hash7=0;
indexW=0;
for(index_generic=0; index_generic < ITERATION_NUMBER/2; index_generic++)
{
a = 0x6A09E667;
b = 0xBB67AE85;
c = 0x3C6EF372;
d = 0xA54FF53A;
e = 0x510E527F;
f = 0x9B05688C;
g = 0x1F83D9AB;
h = 0x5BE0CD19;
schedule0 = hash0;
schedule1 = hash1;
schedule2 = hash2;
schedule3 = hash3;
schedule4 = hash4;
schedule5 = hash5;
schedule6 = hash6;
schedule7 = hash7;
schedule8 = first_hash0;
schedule9 = first_hash1;
schedule10 = first_hash2;
schedule11 = first_hash3;
schedule12 = first_hash4;
schedule13 = first_hash5;
schedule14 = first_hash6;
schedule15 = first_hash7;
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
hash0 = 0x6A09E667 + a;
hash1 = 0xBB67AE85 + b;
hash2 = 0x3C6EF372 + c;
hash3 = 0xA54FF53A + d;
hash4 = 0x510E527F + e;
hash5 = 0x9B05688C + f;
hash6 = 0x1F83D9AB + g;
hash7 = 0x5BE0CD19 + h;
a = hash0;
b = hash1;
c = hash2;
d = hash3;
e = hash4;
f = hash5;
g = hash6;
h = hash7;
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 0, 0x428A2F98, 0)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 1, 0x71374491, 0)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 2, 0xB5C0FBCF, 0)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 3, 0xE9B5DBA5, 0)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 4, 0x3956C25B, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 5, 0x59F111F1, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 6, 0x923F82A4, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 7, 0xAB1C5ED5, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 8, 0xD807AA98, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 9, 0x12835B01, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 10, 0x243185BE, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 11, 0x550C7DC3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 12, 0x72BE5D74, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 13, 0x80DEB1FE, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 14, 0x9BDC06A7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 15, 0xC19BF174, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 16, 0xE49B69C1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 17, 0xEFBE4786, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 18, 0x0FC19DC6, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 19, 0x240CA1CC, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 20, 0x2DE92C6F, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 21, 0x4A7484AA, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 22, 0x5CB0A9DC, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 23, 0x76F988DA, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 24, 0x983E5152, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 25, 0xA831C66D, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 26, 0xB00327C8, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 27, 0xBF597FC7, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 28, 0xC6E00BF3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 29, 0xD5A79147, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 30, 0x06CA6351, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 31, 0x14292967, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 32, 0x27B70A85, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 33, 0x2E1B2138, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 34, 0x4D2C6DFC, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 35, 0x53380D13, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 36, 0x650A7354, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 37, 0x766A0ABB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 38, 0x81C2C92E, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 39, 0x92722C85, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 40, 0xA2BFE8A1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 41, 0xA81A664B, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 42, 0xC24B8B70, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 43, 0xC76C51A3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 44, 0xD192E819, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 45, 0xD6990624, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 46, 0xF40E3585, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 47, 0x106AA070, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 48, 0x19A4C116, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 49, 0x1E376C08, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 50, 0x2748774C, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 51, 0x34B0BCB5, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 52, 0x391C0CB3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 53, 0x4ED8AA4A, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 54, 0x5B9CCA4F, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 55, 0x682E6FF3, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 56, 0x748F82EE, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 57, 0x78A5636F, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 58, 0x84C87814, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 59, 0x8CC70208, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 60, 0x90BEFFFA, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 61, 0xA4506CEB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 62, 0xBEF9A3F7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 63, 0xC67178F2, indexW)
hash0 += a;
hash1 += b;
hash2 += c;
hash3 += d;
hash4 += e;
hash5 += f;
hash6 += g;
hash7 += h;
indexW += SINGLE_BLOCK_W_SIZE;
}
for(index_generic=ITERATION_NUMBER/2; index_generic < ITERATION_NUMBER; index_generic++)
{
a = 0x6A09E667;
b = 0xBB67AE85;
c = 0x3C6EF372;
d = 0xA54FF53A;
e = 0x510E527F;
f = 0x9B05688C;
g = 0x1F83D9AB;
h = 0x5BE0CD19;
schedule0 = hash0;
schedule1 = hash1;
schedule2 = hash2;
schedule3 = hash3;
schedule4 = hash4;
schedule5 = hash5;
schedule6 = hash6;
schedule7 = hash7;
schedule8 = first_hash0;
schedule9 = first_hash1;
schedule10 = first_hash2;
schedule11 = first_hash3;
schedule12 = first_hash4;
schedule13 = first_hash5;
schedule14 = first_hash6;
schedule15 = first_hash7;
ALL_SCHEDULE_LAST16()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x428A2F98)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x71374491)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0xB5C0FBCF)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0xE9B5DBA5)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x3956C25B)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x59F111F1)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x923F82A4)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0xAB1C5ED5)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xD807AA98)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0x12835B01)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0x243185BE)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0x550C7DC3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0x72BE5D74)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0x80DEB1FE)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0x9BDC06A7)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0xC19BF174)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0xE49B69C1)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0xEFBE4786)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x0FC19DC6)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x240CA1CC)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x2DE92C6F)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4A7484AA)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5CB0A9DC)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x76F988DA)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x983E5152)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0xA831C66D)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0xB00327C8)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0xBF597FC7)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0xC6E00BF3)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xD5A79147)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0x06CA6351)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0x14292967)
ALL_SCHEDULE32()
ROUND(a, b, c, d, e, f, g, h, schedule0, 0x27B70A85)
ROUND(h, a, b, c, d, e, f, g, schedule1, 0x2E1B2138)
ROUND(g, h, a, b, c, d, e, f, schedule2, 0x4D2C6DFC)
ROUND(f, g, h, a, b, c, d, e, schedule3, 0x53380D13)
ROUND(e, f, g, h, a, b, c, d, schedule4, 0x650A7354)
ROUND(d, e, f, g, h, a, b, c, schedule5, 0x766A0ABB)
ROUND(c, d, e, f, g, h, a, b, schedule6, 0x81C2C92E)
ROUND(b, c, d, e, f, g, h, a, schedule7, 0x92722C85)
ROUND(a, b, c, d, e, f, g, h, schedule8, 0xA2BFE8A1)
ROUND(h, a, b, c, d, e, f, g, schedule9, 0xA81A664B)
ROUND(g, h, a, b, c, d, e, f, schedule10, 0xC24B8B70)
ROUND(f, g, h, a, b, c, d, e, schedule11, 0xC76C51A3)
ROUND(e, f, g, h, a, b, c, d, schedule12, 0xD192E819)
ROUND(d, e, f, g, h, a, b, c, schedule13, 0xD6990624)
ROUND(c, d, e, f, g, h, a, b, schedule14, 0xF40E3585)
ROUND(b, c, d, e, f, g, h, a, schedule15, 0x106AA070)
ROUND(a, b, c, d, e, f, g, h, schedule16, 0x19A4C116)
ROUND(h, a, b, c, d, e, f, g, schedule17, 0x1E376C08)
ROUND(g, h, a, b, c, d, e, f, schedule18, 0x2748774C)
ROUND(f, g, h, a, b, c, d, e, schedule19, 0x34B0BCB5)
ROUND(e, f, g, h, a, b, c, d, schedule20, 0x391C0CB3)
ROUND(d, e, f, g, h, a, b, c, schedule21, 0x4ED8AA4A)
ROUND(c, d, e, f, g, h, a, b, schedule22, 0x5B9CCA4F)
ROUND(b, c, d, e, f, g, h, a, schedule23, 0x682E6FF3)
ROUND(a, b, c, d, e, f, g, h, schedule24, 0x748F82EE)
ROUND(h, a, b, c, d, e, f, g, schedule25, 0x78A5636F)
ROUND(g, h, a, b, c, d, e, f, schedule26, 0x84C87814)
ROUND(f, g, h, a, b, c, d, e, schedule27, 0x8CC70208)
ROUND(e, f, g, h, a, b, c, d, schedule28, 0x90BEFFFA)
ROUND(d, e, f, g, h, a, b, c, schedule29, 0xA4506CEB)
ROUND(c, d, e, f, g, h, a, b, schedule30, 0xBEF9A3F7)
ROUND(b, c, d, e, f, g, h, a, schedule31, 0xC67178F2)
hash0 = 0x6A09E667 + a;
hash1 = 0xBB67AE85 + b;
hash2 = 0x3C6EF372 + c;
hash3 = 0xA54FF53A + d;
hash4 = 0x510E527F + e;
hash5 = 0x9B05688C + f;
hash6 = 0x1F83D9AB + g;
hash7 = 0x5BE0CD19 + h;
a = hash0;
b = hash1;
c = hash2;
d = hash3;
e = hash4;
f = hash5;
g = hash6;
h = hash7;
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 0, 0x428A2F98, 0)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 1, 0x71374491, 0)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 2, 0xB5C0FBCF, 0)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 3, 0xE9B5DBA5, 0)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 4, 0x3956C25B, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 5, 0x59F111F1, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 6, 0x923F82A4, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 7, 0xAB1C5ED5, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 8, 0xD807AA98, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 9, 0x12835B01, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 10, 0x243185BE, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 11, 0x550C7DC3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 12, 0x72BE5D74, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 13, 0x80DEB1FE, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 14, 0x9BDC06A7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 15, 0xC19BF174, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 16, 0xE49B69C1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 17, 0xEFBE4786, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 18, 0x0FC19DC6, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 19, 0x240CA1CC, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 20, 0x2DE92C6F, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 21, 0x4A7484AA, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 22, 0x5CB0A9DC, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 23, 0x76F988DA, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 24, 0x983E5152, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 25, 0xA831C66D, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 26, 0xB00327C8, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 27, 0xBF597FC7, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 28, 0xC6E00BF3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 29, 0xD5A79147, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 30, 0x06CA6351, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 31, 0x14292967, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 32, 0x27B70A85, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 33, 0x2E1B2138, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 34, 0x4D2C6DFC, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 35, 0x53380D13, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 36, 0x650A7354, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 37, 0x766A0ABB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 38, 0x81C2C92E, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 39, 0x92722C85, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 40, 0xA2BFE8A1, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 41, 0xA81A664B, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 42, 0xC24B8B70, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 43, 0xC76C51A3, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 44, 0xD192E819, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 45, 0xD6990624, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 46, 0xF40E3585, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 47, 0x106AA070, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 48, 0x19A4C116, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 49, 0x1E376C08, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 50, 0x2748774C, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 51, 0x34B0BCB5, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 52, 0x391C0CB3, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 53, 0x4ED8AA4A, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 54, 0x5B9CCA4F, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 55, 0x682E6FF3, indexW)
ROUND_SECOND_BLOCK(a, b, c, d, e, f, g, h, 56, 0x748F82EE, indexW)
ROUND_SECOND_BLOCK(h, a, b, c, d, e, f, g, 57, 0x78A5636F, indexW)
ROUND_SECOND_BLOCK(g, h, a, b, c, d, e, f, 58, 0x84C87814, indexW)
ROUND_SECOND_BLOCK(f, g, h, a, b, c, d, e, 59, 0x8CC70208, indexW)
ROUND_SECOND_BLOCK(e, f, g, h, a, b, c, d, 60, 0x90BEFFFA, indexW)
ROUND_SECOND_BLOCK(d, e, f, g, h, a, b, c, 61, 0xA4506CEB, indexW)
ROUND_SECOND_BLOCK(c, d, e, f, g, h, a, b, 62, 0xBEF9A3F7, indexW)
ROUND_SECOND_BLOCK(b, c, d, e, f, g, h, a, 63, 0xC67178F2, indexW)
hash0 += a;
hash1 += b;
hash2 += c;
hash3 += d;
hash4 += e;
hash5 += f;
hash6 += g;
hash7 += h;
indexW += SINGLE_BLOCK_W_SIZE;
}
a = IV0;
b = IV4;
c = IV8;
d = IV12;
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
a, b, c, d,
&(schedule0), &(schedule1), &(schedule2), &(schedule3)
);
schedule0=
(((unsigned int)(vmkKey[3] ^ ((unsigned char) (schedule0 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[2] ^ ((unsigned char) (schedule0 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[1] ^ ((unsigned char) (schedule0 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[0] ^ ((unsigned char) (schedule0)))) << 0);
schedule1=
(((unsigned int)(vmkKey[7] ^ ((unsigned char) (schedule1 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[6] ^ ((unsigned char) (schedule1 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[5] ^ ((unsigned char) (schedule1 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[4] ^ ((unsigned char) (schedule1)))) << 0);
schedule2=
(((unsigned int)(vmkKey[11] ^ ((unsigned char) (schedule2 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[10] ^ ((unsigned char) (schedule2 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[9] ^ ((unsigned char) (schedule2 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[8] ^ ((unsigned char) (schedule2)))) << 0);
schedule3=
(((unsigned int)(vmkKey[15] ^ ((unsigned char) (schedule3 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[14] ^ ((unsigned char) (schedule3 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[13] ^ ((unsigned char) (schedule3 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[12] ^ ((unsigned char) (schedule3)))) << 0);
d += 0x01000000;
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
a, b, c, d,
&(schedule4), &(schedule5), &(schedule6), &(schedule7)
);
schedule4=
(((unsigned int)(vmkKey[19] ^ ((unsigned char) (schedule4 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[18] ^ ((unsigned char) (schedule4 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[17] ^ ((unsigned char) (schedule4 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[16] ^ ((unsigned char) (schedule4)))) << 0);
schedule5=
(((unsigned int)(vmkKey[23] ^ ((unsigned char) (schedule5 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[22] ^ ((unsigned char) (schedule5 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[21] ^ ((unsigned char) (schedule5 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[20] ^ ((unsigned char) (schedule5)))) << 0);
schedule6=
(((unsigned int)(vmkKey[27] ^ ((unsigned char) (schedule6 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[26] ^ ((unsigned char) (schedule6 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[25] ^ ((unsigned char) (schedule6 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[24] ^ ((unsigned char) (schedule6)))) << 0);
schedule7=
(((unsigned int)(vmkKey[31] ^ ((unsigned char) (schedule7 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[30] ^ ((unsigned char) (schedule7 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[29] ^ ((unsigned char) (schedule7 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[28] ^ ((unsigned char) (schedule7)))) << 0);
d += 0x01000000;
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
a, b, c, d,
&(schedule8), &(schedule9), &(schedule10), &(schedule11)
);
schedule8=
(((unsigned int)(vmkKey[35] ^ ((unsigned char) (schedule8 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[34] ^ ((unsigned char) (schedule8 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[33] ^ ((unsigned char) (schedule8 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[32] ^ ((unsigned char) (schedule8)))) << 0);
schedule9=
(((unsigned int)(vmkKey[39] ^ ((unsigned char) (schedule9 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[38] ^ ((unsigned char) (schedule9 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[37] ^ ((unsigned char) (schedule9 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[36] ^ ((unsigned char) (schedule9)))) << 0);
schedule10=
(((unsigned int)(vmkKey[43] ^ ((unsigned char) (schedule10 >> 24) ))) << 24) |
(((unsigned int)(vmkKey[42] ^ ((unsigned char) (schedule10 >> 16) ))) << 16) |
(((unsigned int)(vmkKey[41] ^ ((unsigned char) (schedule10 >> 8) ))) << 8) |
(((unsigned int)(vmkKey[40] ^ ((unsigned char) (schedule10)))) << 0);
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
macIV0, macIV4, macIV8, macIV12,
&(schedule16), &(schedule17), &(schedule18), &(schedule19)
);
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
computeMacIV0, computeMacIV4, computeMacIV8, computeMacIV12,
&(schedule12), &(schedule13), &(schedule14), &(schedule15)
);
schedule28 = schedule0 ^ schedule12;
schedule29 = schedule1 ^ schedule13;
schedule30 = schedule2 ^ schedule14;
schedule31 = schedule3 ^ schedule15;
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
schedule28, schedule29, schedule30, schedule31,
&(schedule12), &(schedule13), &(schedule14), &(schedule15)
);
schedule28 = schedule4 ^ schedule12;
schedule29 = schedule5 ^ schedule13;
schedule30 = schedule6 ^ schedule14;
schedule31 = schedule7 ^ schedule15;
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
schedule28, schedule29, schedule30, schedule31,
&(schedule12), &(schedule13), &(schedule14), &(schedule15)
);
schedule28 = schedule8 ^ schedule12;
schedule29 = schedule9 ^ schedule13;
schedule30 = schedule10 ^ schedule14;
schedule31 = schedule15;
encrypt(
hash0, hash1, hash2, hash3, hash4, hash5, hash6, hash7,
schedule28, schedule29, schedule30, schedule31,
&(schedule12), &(schedule13), &(schedule14), &(schedule15)
);
if (
(
schedule12 == ( (unsigned int)
(((unsigned int)(mac[3] ^ ((unsigned char) (schedule16 >> 24) ))) << 24) |
(((unsigned int)(mac[2] ^ ((unsigned char) (schedule16 >> 16) ))) << 16) |
(((unsigned int)(mac[1] ^ ((unsigned char) (schedule16 >> 8) ))) << 8) |
(((unsigned int)(mac[0] ^ ((unsigned char) (schedule16)))) << 0) )
)
&&
(
schedule13 == ( (unsigned int)
(((unsigned int)(mac[7] ^ ((unsigned char) (schedule17 >> 24) ))) << 24) |
(((unsigned int)(mac[6] ^ ((unsigned char) (schedule17 >> 16) ))) << 16) |
(((unsigned int)(mac[5] ^ ((unsigned char) (schedule17 >> 8) ))) << 8) |
(((unsigned int)(mac[4] ^ ((unsigned char) (schedule17)))) << 0) )
)
&&
(
schedule14 == ( (unsigned int)
(((unsigned int)(mac[11] ^ ((unsigned char) (schedule18 >> 24) ))) << 24) |
(((unsigned int)(mac[10] ^ ((unsigned char) (schedule18 >> 16) ))) << 16) |
(((unsigned int)(mac[9] ^ ((unsigned char) (schedule18 >> 8) ))) << 8) |
(((unsigned int)(mac[8] ^ ((unsigned char) (schedule18)))) << 0) )
)
&&
(
schedule15 == ( (unsigned int)
(((unsigned int)(mac[15] ^ ((unsigned char) (schedule19 >> 24) ))) << 24) |
(((unsigned int)(mac[14] ^ ((unsigned char) (schedule19 >> 16) ))) << 16) |
(((unsigned int)(mac[13] ^ ((unsigned char) (schedule19 >> 8) ))) << 8) |
(((unsigned int)(mac[12] ^ ((unsigned char) (schedule19)))) << 0) )
)
)
{
found[0] = gIndex;
break;
}
gIndex += get_global_size(0);
}
return;
}