mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-22 21:51:07 +00:00
2441 lines
28 KiB
Common Lisp
2441 lines
28 KiB
Common Lisp
/**
|
|
* Author......: See docs/credits.txt
|
|
* License.....: MIT
|
|
*/
|
|
|
|
#ifdef KERNEL_STATIC
|
|
#include M2S(INCLUDE_PATH/inc_vendor.h)
|
|
#include M2S(INCLUDE_PATH/inc_types.h)
|
|
#include M2S(INCLUDE_PATH/inc_platform.cl)
|
|
#include M2S(INCLUDE_PATH/inc_common.cl)
|
|
#include M2S(INCLUDE_PATH/inc_hash_sha1.cl)
|
|
#endif
|
|
|
|
#define COMPARE_S M2S(INCLUDE_PATH/inc_comp_single.cl)
|
|
#define COMPARE_M M2S(INCLUDE_PATH/inc_comp_multi.cl)
|
|
|
|
typedef struct androidpin_tmp
|
|
{
|
|
u32 digest_buf[5];
|
|
|
|
} androidpin_tmp_t;
|
|
|
|
CONSTANT_VK u32a c_pc_dec[1024] =
|
|
{
|
|
0x00000030,
|
|
0x00000031,
|
|
0x00000032,
|
|
0x00000033,
|
|
0x00000034,
|
|
0x00000035,
|
|
0x00000036,
|
|
0x00000037,
|
|
0x00000038,
|
|
0x00000039,
|
|
0x00003031,
|
|
0x00003131,
|
|
0x00003231,
|
|
0x00003331,
|
|
0x00003431,
|
|
0x00003531,
|
|
0x00003631,
|
|
0x00003731,
|
|
0x00003831,
|
|
0x00003931,
|
|
0x00003032,
|
|
0x00003132,
|
|
0x00003232,
|
|
0x00003332,
|
|
0x00003432,
|
|
0x00003532,
|
|
0x00003632,
|
|
0x00003732,
|
|
0x00003832,
|
|
0x00003932,
|
|
0x00003033,
|
|
0x00003133,
|
|
0x00003233,
|
|
0x00003333,
|
|
0x00003433,
|
|
0x00003533,
|
|
0x00003633,
|
|
0x00003733,
|
|
0x00003833,
|
|
0x00003933,
|
|
0x00003034,
|
|
0x00003134,
|
|
0x00003234,
|
|
0x00003334,
|
|
0x00003434,
|
|
0x00003534,
|
|
0x00003634,
|
|
0x00003734,
|
|
0x00003834,
|
|
0x00003934,
|
|
0x00003035,
|
|
0x00003135,
|
|
0x00003235,
|
|
0x00003335,
|
|
0x00003435,
|
|
0x00003535,
|
|
0x00003635,
|
|
0x00003735,
|
|
0x00003835,
|
|
0x00003935,
|
|
0x00003036,
|
|
0x00003136,
|
|
0x00003236,
|
|
0x00003336,
|
|
0x00003436,
|
|
0x00003536,
|
|
0x00003636,
|
|
0x00003736,
|
|
0x00003836,
|
|
0x00003936,
|
|
0x00003037,
|
|
0x00003137,
|
|
0x00003237,
|
|
0x00003337,
|
|
0x00003437,
|
|
0x00003537,
|
|
0x00003637,
|
|
0x00003737,
|
|
0x00003837,
|
|
0x00003937,
|
|
0x00003038,
|
|
0x00003138,
|
|
0x00003238,
|
|
0x00003338,
|
|
0x00003438,
|
|
0x00003538,
|
|
0x00003638,
|
|
0x00003738,
|
|
0x00003838,
|
|
0x00003938,
|
|
0x00003039,
|
|
0x00003139,
|
|
0x00003239,
|
|
0x00003339,
|
|
0x00003439,
|
|
0x00003539,
|
|
0x00003639,
|
|
0x00003739,
|
|
0x00003839,
|
|
0x00003939,
|
|
0x00303031,
|
|
0x00313031,
|
|
0x00323031,
|
|
0x00333031,
|
|
0x00343031,
|
|
0x00353031,
|
|
0x00363031,
|
|
0x00373031,
|
|
0x00383031,
|
|
0x00393031,
|
|
0x00303131,
|
|
0x00313131,
|
|
0x00323131,
|
|
0x00333131,
|
|
0x00343131,
|
|
0x00353131,
|
|
0x00363131,
|
|
0x00373131,
|
|
0x00383131,
|
|
0x00393131,
|
|
0x00303231,
|
|
0x00313231,
|
|
0x00323231,
|
|
0x00333231,
|
|
0x00343231,
|
|
0x00353231,
|
|
0x00363231,
|
|
0x00373231,
|
|
0x00383231,
|
|
0x00393231,
|
|
0x00303331,
|
|
0x00313331,
|
|
0x00323331,
|
|
0x00333331,
|
|
0x00343331,
|
|
0x00353331,
|
|
0x00363331,
|
|
0x00373331,
|
|
0x00383331,
|
|
0x00393331,
|
|
0x00303431,
|
|
0x00313431,
|
|
0x00323431,
|
|
0x00333431,
|
|
0x00343431,
|
|
0x00353431,
|
|
0x00363431,
|
|
0x00373431,
|
|
0x00383431,
|
|
0x00393431,
|
|
0x00303531,
|
|
0x00313531,
|
|
0x00323531,
|
|
0x00333531,
|
|
0x00343531,
|
|
0x00353531,
|
|
0x00363531,
|
|
0x00373531,
|
|
0x00383531,
|
|
0x00393531,
|
|
0x00303631,
|
|
0x00313631,
|
|
0x00323631,
|
|
0x00333631,
|
|
0x00343631,
|
|
0x00353631,
|
|
0x00363631,
|
|
0x00373631,
|
|
0x00383631,
|
|
0x00393631,
|
|
0x00303731,
|
|
0x00313731,
|
|
0x00323731,
|
|
0x00333731,
|
|
0x00343731,
|
|
0x00353731,
|
|
0x00363731,
|
|
0x00373731,
|
|
0x00383731,
|
|
0x00393731,
|
|
0x00303831,
|
|
0x00313831,
|
|
0x00323831,
|
|
0x00333831,
|
|
0x00343831,
|
|
0x00353831,
|
|
0x00363831,
|
|
0x00373831,
|
|
0x00383831,
|
|
0x00393831,
|
|
0x00303931,
|
|
0x00313931,
|
|
0x00323931,
|
|
0x00333931,
|
|
0x00343931,
|
|
0x00353931,
|
|
0x00363931,
|
|
0x00373931,
|
|
0x00383931,
|
|
0x00393931,
|
|
0x00303032,
|
|
0x00313032,
|
|
0x00323032,
|
|
0x00333032,
|
|
0x00343032,
|
|
0x00353032,
|
|
0x00363032,
|
|
0x00373032,
|
|
0x00383032,
|
|
0x00393032,
|
|
0x00303132,
|
|
0x00313132,
|
|
0x00323132,
|
|
0x00333132,
|
|
0x00343132,
|
|
0x00353132,
|
|
0x00363132,
|
|
0x00373132,
|
|
0x00383132,
|
|
0x00393132,
|
|
0x00303232,
|
|
0x00313232,
|
|
0x00323232,
|
|
0x00333232,
|
|
0x00343232,
|
|
0x00353232,
|
|
0x00363232,
|
|
0x00373232,
|
|
0x00383232,
|
|
0x00393232,
|
|
0x00303332,
|
|
0x00313332,
|
|
0x00323332,
|
|
0x00333332,
|
|
0x00343332,
|
|
0x00353332,
|
|
0x00363332,
|
|
0x00373332,
|
|
0x00383332,
|
|
0x00393332,
|
|
0x00303432,
|
|
0x00313432,
|
|
0x00323432,
|
|
0x00333432,
|
|
0x00343432,
|
|
0x00353432,
|
|
0x00363432,
|
|
0x00373432,
|
|
0x00383432,
|
|
0x00393432,
|
|
0x00303532,
|
|
0x00313532,
|
|
0x00323532,
|
|
0x00333532,
|
|
0x00343532,
|
|
0x00353532,
|
|
0x00363532,
|
|
0x00373532,
|
|
0x00383532,
|
|
0x00393532,
|
|
0x00303632,
|
|
0x00313632,
|
|
0x00323632,
|
|
0x00333632,
|
|
0x00343632,
|
|
0x00353632,
|
|
0x00363632,
|
|
0x00373632,
|
|
0x00383632,
|
|
0x00393632,
|
|
0x00303732,
|
|
0x00313732,
|
|
0x00323732,
|
|
0x00333732,
|
|
0x00343732,
|
|
0x00353732,
|
|
0x00363732,
|
|
0x00373732,
|
|
0x00383732,
|
|
0x00393732,
|
|
0x00303832,
|
|
0x00313832,
|
|
0x00323832,
|
|
0x00333832,
|
|
0x00343832,
|
|
0x00353832,
|
|
0x00363832,
|
|
0x00373832,
|
|
0x00383832,
|
|
0x00393832,
|
|
0x00303932,
|
|
0x00313932,
|
|
0x00323932,
|
|
0x00333932,
|
|
0x00343932,
|
|
0x00353932,
|
|
0x00363932,
|
|
0x00373932,
|
|
0x00383932,
|
|
0x00393932,
|
|
0x00303033,
|
|
0x00313033,
|
|
0x00323033,
|
|
0x00333033,
|
|
0x00343033,
|
|
0x00353033,
|
|
0x00363033,
|
|
0x00373033,
|
|
0x00383033,
|
|
0x00393033,
|
|
0x00303133,
|
|
0x00313133,
|
|
0x00323133,
|
|
0x00333133,
|
|
0x00343133,
|
|
0x00353133,
|
|
0x00363133,
|
|
0x00373133,
|
|
0x00383133,
|
|
0x00393133,
|
|
0x00303233,
|
|
0x00313233,
|
|
0x00323233,
|
|
0x00333233,
|
|
0x00343233,
|
|
0x00353233,
|
|
0x00363233,
|
|
0x00373233,
|
|
0x00383233,
|
|
0x00393233,
|
|
0x00303333,
|
|
0x00313333,
|
|
0x00323333,
|
|
0x00333333,
|
|
0x00343333,
|
|
0x00353333,
|
|
0x00363333,
|
|
0x00373333,
|
|
0x00383333,
|
|
0x00393333,
|
|
0x00303433,
|
|
0x00313433,
|
|
0x00323433,
|
|
0x00333433,
|
|
0x00343433,
|
|
0x00353433,
|
|
0x00363433,
|
|
0x00373433,
|
|
0x00383433,
|
|
0x00393433,
|
|
0x00303533,
|
|
0x00313533,
|
|
0x00323533,
|
|
0x00333533,
|
|
0x00343533,
|
|
0x00353533,
|
|
0x00363533,
|
|
0x00373533,
|
|
0x00383533,
|
|
0x00393533,
|
|
0x00303633,
|
|
0x00313633,
|
|
0x00323633,
|
|
0x00333633,
|
|
0x00343633,
|
|
0x00353633,
|
|
0x00363633,
|
|
0x00373633,
|
|
0x00383633,
|
|
0x00393633,
|
|
0x00303733,
|
|
0x00313733,
|
|
0x00323733,
|
|
0x00333733,
|
|
0x00343733,
|
|
0x00353733,
|
|
0x00363733,
|
|
0x00373733,
|
|
0x00383733,
|
|
0x00393733,
|
|
0x00303833,
|
|
0x00313833,
|
|
0x00323833,
|
|
0x00333833,
|
|
0x00343833,
|
|
0x00353833,
|
|
0x00363833,
|
|
0x00373833,
|
|
0x00383833,
|
|
0x00393833,
|
|
0x00303933,
|
|
0x00313933,
|
|
0x00323933,
|
|
0x00333933,
|
|
0x00343933,
|
|
0x00353933,
|
|
0x00363933,
|
|
0x00373933,
|
|
0x00383933,
|
|
0x00393933,
|
|
0x00303034,
|
|
0x00313034,
|
|
0x00323034,
|
|
0x00333034,
|
|
0x00343034,
|
|
0x00353034,
|
|
0x00363034,
|
|
0x00373034,
|
|
0x00383034,
|
|
0x00393034,
|
|
0x00303134,
|
|
0x00313134,
|
|
0x00323134,
|
|
0x00333134,
|
|
0x00343134,
|
|
0x00353134,
|
|
0x00363134,
|
|
0x00373134,
|
|
0x00383134,
|
|
0x00393134,
|
|
0x00303234,
|
|
0x00313234,
|
|
0x00323234,
|
|
0x00333234,
|
|
0x00343234,
|
|
0x00353234,
|
|
0x00363234,
|
|
0x00373234,
|
|
0x00383234,
|
|
0x00393234,
|
|
0x00303334,
|
|
0x00313334,
|
|
0x00323334,
|
|
0x00333334,
|
|
0x00343334,
|
|
0x00353334,
|
|
0x00363334,
|
|
0x00373334,
|
|
0x00383334,
|
|
0x00393334,
|
|
0x00303434,
|
|
0x00313434,
|
|
0x00323434,
|
|
0x00333434,
|
|
0x00343434,
|
|
0x00353434,
|
|
0x00363434,
|
|
0x00373434,
|
|
0x00383434,
|
|
0x00393434,
|
|
0x00303534,
|
|
0x00313534,
|
|
0x00323534,
|
|
0x00333534,
|
|
0x00343534,
|
|
0x00353534,
|
|
0x00363534,
|
|
0x00373534,
|
|
0x00383534,
|
|
0x00393534,
|
|
0x00303634,
|
|
0x00313634,
|
|
0x00323634,
|
|
0x00333634,
|
|
0x00343634,
|
|
0x00353634,
|
|
0x00363634,
|
|
0x00373634,
|
|
0x00383634,
|
|
0x00393634,
|
|
0x00303734,
|
|
0x00313734,
|
|
0x00323734,
|
|
0x00333734,
|
|
0x00343734,
|
|
0x00353734,
|
|
0x00363734,
|
|
0x00373734,
|
|
0x00383734,
|
|
0x00393734,
|
|
0x00303834,
|
|
0x00313834,
|
|
0x00323834,
|
|
0x00333834,
|
|
0x00343834,
|
|
0x00353834,
|
|
0x00363834,
|
|
0x00373834,
|
|
0x00383834,
|
|
0x00393834,
|
|
0x00303934,
|
|
0x00313934,
|
|
0x00323934,
|
|
0x00333934,
|
|
0x00343934,
|
|
0x00353934,
|
|
0x00363934,
|
|
0x00373934,
|
|
0x00383934,
|
|
0x00393934,
|
|
0x00303035,
|
|
0x00313035,
|
|
0x00323035,
|
|
0x00333035,
|
|
0x00343035,
|
|
0x00353035,
|
|
0x00363035,
|
|
0x00373035,
|
|
0x00383035,
|
|
0x00393035,
|
|
0x00303135,
|
|
0x00313135,
|
|
0x00323135,
|
|
0x00333135,
|
|
0x00343135,
|
|
0x00353135,
|
|
0x00363135,
|
|
0x00373135,
|
|
0x00383135,
|
|
0x00393135,
|
|
0x00303235,
|
|
0x00313235,
|
|
0x00323235,
|
|
0x00333235,
|
|
0x00343235,
|
|
0x00353235,
|
|
0x00363235,
|
|
0x00373235,
|
|
0x00383235,
|
|
0x00393235,
|
|
0x00303335,
|
|
0x00313335,
|
|
0x00323335,
|
|
0x00333335,
|
|
0x00343335,
|
|
0x00353335,
|
|
0x00363335,
|
|
0x00373335,
|
|
0x00383335,
|
|
0x00393335,
|
|
0x00303435,
|
|
0x00313435,
|
|
0x00323435,
|
|
0x00333435,
|
|
0x00343435,
|
|
0x00353435,
|
|
0x00363435,
|
|
0x00373435,
|
|
0x00383435,
|
|
0x00393435,
|
|
0x00303535,
|
|
0x00313535,
|
|
0x00323535,
|
|
0x00333535,
|
|
0x00343535,
|
|
0x00353535,
|
|
0x00363535,
|
|
0x00373535,
|
|
0x00383535,
|
|
0x00393535,
|
|
0x00303635,
|
|
0x00313635,
|
|
0x00323635,
|
|
0x00333635,
|
|
0x00343635,
|
|
0x00353635,
|
|
0x00363635,
|
|
0x00373635,
|
|
0x00383635,
|
|
0x00393635,
|
|
0x00303735,
|
|
0x00313735,
|
|
0x00323735,
|
|
0x00333735,
|
|
0x00343735,
|
|
0x00353735,
|
|
0x00363735,
|
|
0x00373735,
|
|
0x00383735,
|
|
0x00393735,
|
|
0x00303835,
|
|
0x00313835,
|
|
0x00323835,
|
|
0x00333835,
|
|
0x00343835,
|
|
0x00353835,
|
|
0x00363835,
|
|
0x00373835,
|
|
0x00383835,
|
|
0x00393835,
|
|
0x00303935,
|
|
0x00313935,
|
|
0x00323935,
|
|
0x00333935,
|
|
0x00343935,
|
|
0x00353935,
|
|
0x00363935,
|
|
0x00373935,
|
|
0x00383935,
|
|
0x00393935,
|
|
0x00303036,
|
|
0x00313036,
|
|
0x00323036,
|
|
0x00333036,
|
|
0x00343036,
|
|
0x00353036,
|
|
0x00363036,
|
|
0x00373036,
|
|
0x00383036,
|
|
0x00393036,
|
|
0x00303136,
|
|
0x00313136,
|
|
0x00323136,
|
|
0x00333136,
|
|
0x00343136,
|
|
0x00353136,
|
|
0x00363136,
|
|
0x00373136,
|
|
0x00383136,
|
|
0x00393136,
|
|
0x00303236,
|
|
0x00313236,
|
|
0x00323236,
|
|
0x00333236,
|
|
0x00343236,
|
|
0x00353236,
|
|
0x00363236,
|
|
0x00373236,
|
|
0x00383236,
|
|
0x00393236,
|
|
0x00303336,
|
|
0x00313336,
|
|
0x00323336,
|
|
0x00333336,
|
|
0x00343336,
|
|
0x00353336,
|
|
0x00363336,
|
|
0x00373336,
|
|
0x00383336,
|
|
0x00393336,
|
|
0x00303436,
|
|
0x00313436,
|
|
0x00323436,
|
|
0x00333436,
|
|
0x00343436,
|
|
0x00353436,
|
|
0x00363436,
|
|
0x00373436,
|
|
0x00383436,
|
|
0x00393436,
|
|
0x00303536,
|
|
0x00313536,
|
|
0x00323536,
|
|
0x00333536,
|
|
0x00343536,
|
|
0x00353536,
|
|
0x00363536,
|
|
0x00373536,
|
|
0x00383536,
|
|
0x00393536,
|
|
0x00303636,
|
|
0x00313636,
|
|
0x00323636,
|
|
0x00333636,
|
|
0x00343636,
|
|
0x00353636,
|
|
0x00363636,
|
|
0x00373636,
|
|
0x00383636,
|
|
0x00393636,
|
|
0x00303736,
|
|
0x00313736,
|
|
0x00323736,
|
|
0x00333736,
|
|
0x00343736,
|
|
0x00353736,
|
|
0x00363736,
|
|
0x00373736,
|
|
0x00383736,
|
|
0x00393736,
|
|
0x00303836,
|
|
0x00313836,
|
|
0x00323836,
|
|
0x00333836,
|
|
0x00343836,
|
|
0x00353836,
|
|
0x00363836,
|
|
0x00373836,
|
|
0x00383836,
|
|
0x00393836,
|
|
0x00303936,
|
|
0x00313936,
|
|
0x00323936,
|
|
0x00333936,
|
|
0x00343936,
|
|
0x00353936,
|
|
0x00363936,
|
|
0x00373936,
|
|
0x00383936,
|
|
0x00393936,
|
|
0x00303037,
|
|
0x00313037,
|
|
0x00323037,
|
|
0x00333037,
|
|
0x00343037,
|
|
0x00353037,
|
|
0x00363037,
|
|
0x00373037,
|
|
0x00383037,
|
|
0x00393037,
|
|
0x00303137,
|
|
0x00313137,
|
|
0x00323137,
|
|
0x00333137,
|
|
0x00343137,
|
|
0x00353137,
|
|
0x00363137,
|
|
0x00373137,
|
|
0x00383137,
|
|
0x00393137,
|
|
0x00303237,
|
|
0x00313237,
|
|
0x00323237,
|
|
0x00333237,
|
|
0x00343237,
|
|
0x00353237,
|
|
0x00363237,
|
|
0x00373237,
|
|
0x00383237,
|
|
0x00393237,
|
|
0x00303337,
|
|
0x00313337,
|
|
0x00323337,
|
|
0x00333337,
|
|
0x00343337,
|
|
0x00353337,
|
|
0x00363337,
|
|
0x00373337,
|
|
0x00383337,
|
|
0x00393337,
|
|
0x00303437,
|
|
0x00313437,
|
|
0x00323437,
|
|
0x00333437,
|
|
0x00343437,
|
|
0x00353437,
|
|
0x00363437,
|
|
0x00373437,
|
|
0x00383437,
|
|
0x00393437,
|
|
0x00303537,
|
|
0x00313537,
|
|
0x00323537,
|
|
0x00333537,
|
|
0x00343537,
|
|
0x00353537,
|
|
0x00363537,
|
|
0x00373537,
|
|
0x00383537,
|
|
0x00393537,
|
|
0x00303637,
|
|
0x00313637,
|
|
0x00323637,
|
|
0x00333637,
|
|
0x00343637,
|
|
0x00353637,
|
|
0x00363637,
|
|
0x00373637,
|
|
0x00383637,
|
|
0x00393637,
|
|
0x00303737,
|
|
0x00313737,
|
|
0x00323737,
|
|
0x00333737,
|
|
0x00343737,
|
|
0x00353737,
|
|
0x00363737,
|
|
0x00373737,
|
|
0x00383737,
|
|
0x00393737,
|
|
0x00303837,
|
|
0x00313837,
|
|
0x00323837,
|
|
0x00333837,
|
|
0x00343837,
|
|
0x00353837,
|
|
0x00363837,
|
|
0x00373837,
|
|
0x00383837,
|
|
0x00393837,
|
|
0x00303937,
|
|
0x00313937,
|
|
0x00323937,
|
|
0x00333937,
|
|
0x00343937,
|
|
0x00353937,
|
|
0x00363937,
|
|
0x00373937,
|
|
0x00383937,
|
|
0x00393937,
|
|
0x00303038,
|
|
0x00313038,
|
|
0x00323038,
|
|
0x00333038,
|
|
0x00343038,
|
|
0x00353038,
|
|
0x00363038,
|
|
0x00373038,
|
|
0x00383038,
|
|
0x00393038,
|
|
0x00303138,
|
|
0x00313138,
|
|
0x00323138,
|
|
0x00333138,
|
|
0x00343138,
|
|
0x00353138,
|
|
0x00363138,
|
|
0x00373138,
|
|
0x00383138,
|
|
0x00393138,
|
|
0x00303238,
|
|
0x00313238,
|
|
0x00323238,
|
|
0x00333238,
|
|
0x00343238,
|
|
0x00353238,
|
|
0x00363238,
|
|
0x00373238,
|
|
0x00383238,
|
|
0x00393238,
|
|
0x00303338,
|
|
0x00313338,
|
|
0x00323338,
|
|
0x00333338,
|
|
0x00343338,
|
|
0x00353338,
|
|
0x00363338,
|
|
0x00373338,
|
|
0x00383338,
|
|
0x00393338,
|
|
0x00303438,
|
|
0x00313438,
|
|
0x00323438,
|
|
0x00333438,
|
|
0x00343438,
|
|
0x00353438,
|
|
0x00363438,
|
|
0x00373438,
|
|
0x00383438,
|
|
0x00393438,
|
|
0x00303538,
|
|
0x00313538,
|
|
0x00323538,
|
|
0x00333538,
|
|
0x00343538,
|
|
0x00353538,
|
|
0x00363538,
|
|
0x00373538,
|
|
0x00383538,
|
|
0x00393538,
|
|
0x00303638,
|
|
0x00313638,
|
|
0x00323638,
|
|
0x00333638,
|
|
0x00343638,
|
|
0x00353638,
|
|
0x00363638,
|
|
0x00373638,
|
|
0x00383638,
|
|
0x00393638,
|
|
0x00303738,
|
|
0x00313738,
|
|
0x00323738,
|
|
0x00333738,
|
|
0x00343738,
|
|
0x00353738,
|
|
0x00363738,
|
|
0x00373738,
|
|
0x00383738,
|
|
0x00393738,
|
|
0x00303838,
|
|
0x00313838,
|
|
0x00323838,
|
|
0x00333838,
|
|
0x00343838,
|
|
0x00353838,
|
|
0x00363838,
|
|
0x00373838,
|
|
0x00383838,
|
|
0x00393838,
|
|
0x00303938,
|
|
0x00313938,
|
|
0x00323938,
|
|
0x00333938,
|
|
0x00343938,
|
|
0x00353938,
|
|
0x00363938,
|
|
0x00373938,
|
|
0x00383938,
|
|
0x00393938,
|
|
0x00303039,
|
|
0x00313039,
|
|
0x00323039,
|
|
0x00333039,
|
|
0x00343039,
|
|
0x00353039,
|
|
0x00363039,
|
|
0x00373039,
|
|
0x00383039,
|
|
0x00393039,
|
|
0x00303139,
|
|
0x00313139,
|
|
0x00323139,
|
|
0x00333139,
|
|
0x00343139,
|
|
0x00353139,
|
|
0x00363139,
|
|
0x00373139,
|
|
0x00383139,
|
|
0x00393139,
|
|
0x00303239,
|
|
0x00313239,
|
|
0x00323239,
|
|
0x00333239,
|
|
0x00343239,
|
|
0x00353239,
|
|
0x00363239,
|
|
0x00373239,
|
|
0x00383239,
|
|
0x00393239,
|
|
0x00303339,
|
|
0x00313339,
|
|
0x00323339,
|
|
0x00333339,
|
|
0x00343339,
|
|
0x00353339,
|
|
0x00363339,
|
|
0x00373339,
|
|
0x00383339,
|
|
0x00393339,
|
|
0x00303439,
|
|
0x00313439,
|
|
0x00323439,
|
|
0x00333439,
|
|
0x00343439,
|
|
0x00353439,
|
|
0x00363439,
|
|
0x00373439,
|
|
0x00383439,
|
|
0x00393439,
|
|
0x00303539,
|
|
0x00313539,
|
|
0x00323539,
|
|
0x00333539,
|
|
0x00343539,
|
|
0x00353539,
|
|
0x00363539,
|
|
0x00373539,
|
|
0x00383539,
|
|
0x00393539,
|
|
0x00303639,
|
|
0x00313639,
|
|
0x00323639,
|
|
0x00333639,
|
|
0x00343639,
|
|
0x00353639,
|
|
0x00363639,
|
|
0x00373639,
|
|
0x00383639,
|
|
0x00393639,
|
|
0x00303739,
|
|
0x00313739,
|
|
0x00323739,
|
|
0x00333739,
|
|
0x00343739,
|
|
0x00353739,
|
|
0x00363739,
|
|
0x00373739,
|
|
0x00383739,
|
|
0x00393739,
|
|
0x00303839,
|
|
0x00313839,
|
|
0x00323839,
|
|
0x00333839,
|
|
0x00343839,
|
|
0x00353839,
|
|
0x00363839,
|
|
0x00373839,
|
|
0x00383839,
|
|
0x00393839,
|
|
0x00303939,
|
|
0x00313939,
|
|
0x00323939,
|
|
0x00333939,
|
|
0x00343939,
|
|
0x00353939,
|
|
0x00363939,
|
|
0x00373939,
|
|
0x00383939,
|
|
0x00393939,
|
|
0x30303031,
|
|
0x31303031,
|
|
0x32303031,
|
|
0x33303031,
|
|
0x34303031,
|
|
0x35303031,
|
|
0x36303031,
|
|
0x37303031,
|
|
0x38303031,
|
|
0x39303031,
|
|
0x30313031,
|
|
0x31313031,
|
|
0x32313031,
|
|
0x33313031,
|
|
0x34313031,
|
|
0x35313031,
|
|
0x36313031,
|
|
0x37313031,
|
|
0x38313031,
|
|
0x39313031,
|
|
0x30323031,
|
|
0x31323031,
|
|
0x32323031,
|
|
0x33323031,
|
|
};
|
|
|
|
CONSTANT_VK u32a c_pc_len[1024] =
|
|
{
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
1,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
2,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
3,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4,
|
|
4
|
|
};
|
|
|
|
DECLSPEC void append_word (PRIVATE_AS u32 *w0, PRIVATE_AS u32 *w1, PRIVATE_AS const u32 *append, const u32 offset)
|
|
{
|
|
switch (offset)
|
|
{
|
|
case 1:
|
|
w0[0] = w0[0] | append[0] << 8;
|
|
w0[1] = append[0] >> 24 | append[1] << 8;
|
|
w0[2] = append[1] >> 24 | append[2] << 8;
|
|
w0[3] = append[2] >> 24 | append[3] << 8;
|
|
break;
|
|
|
|
case 2:
|
|
w0[0] = w0[0] | append[0] << 16;
|
|
w0[1] = append[0] >> 16 | append[1] << 16;
|
|
w0[2] = append[1] >> 16 | append[2] << 16;
|
|
w0[3] = append[2] >> 16 | append[3] << 16;
|
|
break;
|
|
|
|
case 3:
|
|
w0[0] = w0[0] | append[0] << 24;
|
|
w0[1] = append[0] >> 8 | append[1] << 24;
|
|
w0[2] = append[1] >> 8 | append[2] << 24;
|
|
w0[3] = append[2] >> 8 | append[3] << 24;
|
|
break;
|
|
|
|
case 4:
|
|
w0[1] = append[0];
|
|
w0[2] = append[1];
|
|
w0[3] = append[2];
|
|
w1[0] = append[3];
|
|
break;
|
|
}
|
|
}
|
|
|
|
DECLSPEC void append_salt (PRIVATE_AS u32 *w0, PRIVATE_AS u32 *w1, PRIVATE_AS u32 *w2, PRIVATE_AS const u32 *append, const u32 offset)
|
|
{
|
|
u32 tmp0;
|
|
u32 tmp1;
|
|
u32 tmp2;
|
|
u32 tmp3;
|
|
u32 tmp4;
|
|
u32 tmp5;
|
|
|
|
#if ((defined IS_AMD || defined IS_HIP) && HAS_VPERM == 0) || defined IS_GENERIC
|
|
u32 in0 = append[0];
|
|
u32 in1 = append[1];
|
|
u32 in2 = append[2];
|
|
u32 in3 = append[3];
|
|
u32 in4 = append[4];
|
|
|
|
tmp0 = hc_bytealign ( 0, in0, offset);
|
|
tmp1 = hc_bytealign (in0, in1, offset);
|
|
tmp2 = hc_bytealign (in1, in2, offset);
|
|
tmp3 = hc_bytealign (in2, in3, offset);
|
|
tmp4 = hc_bytealign (in3, in4, offset);
|
|
tmp5 = hc_bytealign (in4, 0, offset);
|
|
#endif
|
|
|
|
#if ((defined IS_AMD || defined IS_HIP) && HAS_VPERM == 1) || defined IS_NV
|
|
const int offset_mod_4 = offset & 3;
|
|
|
|
const int offset_minus_4 = 4 - offset_mod_4;
|
|
|
|
#if defined IS_NV
|
|
const int selector = (0x76543210 >> (offset_minus_4 * 4)) & 0xffff;
|
|
#endif
|
|
|
|
#if (defined IS_AMD || defined IS_HIP)
|
|
const int selector = l32_from_64_S (0x0706050403020100UL >> (offset_minus_4 * 8));
|
|
#endif
|
|
|
|
u32 in0 = append[0];
|
|
u32 in1 = append[1];
|
|
u32 in2 = append[2];
|
|
u32 in3 = append[3];
|
|
u32 in4 = append[4];
|
|
|
|
tmp0 = hc_byte_perm ( 0, in0, selector);
|
|
tmp1 = hc_byte_perm (in0, in1, selector);
|
|
tmp2 = hc_byte_perm (in1, in2, selector);
|
|
tmp3 = hc_byte_perm (in2, in3, selector);
|
|
tmp4 = hc_byte_perm (in3, in4, selector);
|
|
tmp5 = hc_byte_perm (in4, 0, selector);
|
|
#endif
|
|
|
|
const u32 div = offset / 4;
|
|
|
|
switch (div)
|
|
{
|
|
case 0: w0[0] |= tmp0;
|
|
w0[1] = tmp1;
|
|
w0[2] = tmp2;
|
|
w0[3] = tmp3;
|
|
w1[0] = tmp4;
|
|
w1[1] = tmp5;
|
|
break;
|
|
case 1: w0[1] |= tmp0;
|
|
w0[2] = tmp1;
|
|
w0[3] = tmp2;
|
|
w1[0] = tmp3;
|
|
w1[1] = tmp4;
|
|
w1[2] = tmp5;
|
|
break;
|
|
case 2: w0[2] |= tmp0;
|
|
w0[3] = tmp1;
|
|
w1[0] = tmp2;
|
|
w1[1] = tmp3;
|
|
w1[2] = tmp4;
|
|
w1[3] = tmp5;
|
|
break;
|
|
case 3: w0[3] |= tmp0;
|
|
w1[0] = tmp1;
|
|
w1[1] = tmp2;
|
|
w1[2] = tmp3;
|
|
w1[3] = tmp4;
|
|
w2[0] = tmp5;
|
|
break;
|
|
case 4: w1[0] |= tmp0;
|
|
w1[1] = tmp1;
|
|
w1[2] = tmp2;
|
|
w1[3] = tmp3;
|
|
w2[0] = tmp4;
|
|
w2[1] = tmp5;
|
|
break;
|
|
}
|
|
}
|
|
|
|
KERNEL_FQ void m05800_init (KERN_ATTR_TMPS (androidpin_tmp_t))
|
|
{
|
|
/**
|
|
* base
|
|
*/
|
|
|
|
const u64 gid = get_global_id (0);
|
|
|
|
if (gid >= GID_CNT) return;
|
|
|
|
u32 word_buf[4];
|
|
|
|
word_buf[0] = pws[gid].i[ 0];
|
|
word_buf[1] = pws[gid].i[ 1];
|
|
word_buf[2] = pws[gid].i[ 2];
|
|
word_buf[3] = pws[gid].i[ 3];
|
|
|
|
const u32 pw_len = pws[gid].pw_len & 63;
|
|
|
|
/**
|
|
* salt
|
|
*/
|
|
|
|
u32 salt_len = salt_bufs[SALT_POS_HOST].salt_len;
|
|
|
|
u32 salt_buf[5];
|
|
|
|
salt_buf[0] = salt_bufs[SALT_POS_HOST].salt_buf[0];
|
|
salt_buf[1] = salt_bufs[SALT_POS_HOST].salt_buf[1];
|
|
salt_buf[2] = salt_bufs[SALT_POS_HOST].salt_buf[2];
|
|
salt_buf[3] = salt_bufs[SALT_POS_HOST].salt_buf[3];
|
|
salt_buf[4] = salt_bufs[SALT_POS_HOST].salt_buf[4];
|
|
|
|
/**
|
|
* init
|
|
*/
|
|
|
|
const u32 pc_len = 1;
|
|
const u32 pc_dec = 0x30;
|
|
|
|
u32 data0[4] = { 0, 0, 0, 0 };
|
|
u32 data1[4] = { 0, 0, 0, 0 };
|
|
u32 data2[4] = { 0, 0, 0, 0 };
|
|
|
|
data0[0] = pc_dec;
|
|
|
|
append_word (data0, data1, word_buf, pc_len);
|
|
|
|
append_salt (data0, data1, data2, salt_buf, pc_len + pw_len);
|
|
|
|
u32 w0[4];
|
|
u32 w1[4];
|
|
u32 w2[4];
|
|
u32 w3[4];
|
|
|
|
w0[0] = hc_swap32_S (data0[0]);
|
|
w0[1] = hc_swap32_S (data0[1]);
|
|
w0[2] = hc_swap32_S (data0[2]);
|
|
w0[3] = hc_swap32_S (data0[3]);
|
|
w1[0] = hc_swap32_S (data1[0]);
|
|
w1[1] = hc_swap32_S (data1[1]);
|
|
w1[2] = hc_swap32_S (data1[2]);
|
|
w1[3] = hc_swap32_S (data1[3]);
|
|
w2[0] = hc_swap32_S (data2[0]);
|
|
w2[1] = hc_swap32_S (data2[1]);
|
|
w2[2] = 0;
|
|
w2[3] = 0;
|
|
w3[0] = 0;
|
|
w3[1] = 0;
|
|
w3[2] = 0;
|
|
w3[3] = (pc_len + pw_len + salt_len) * 8;
|
|
|
|
u32 digest[5];
|
|
|
|
digest[0] = SHA1M_A;
|
|
digest[1] = SHA1M_B;
|
|
digest[2] = SHA1M_C;
|
|
digest[3] = SHA1M_D;
|
|
digest[4] = SHA1M_E;
|
|
|
|
sha1_transform (w0, w1, w2, w3, digest);
|
|
|
|
tmps[gid].digest_buf[0] = digest[0];
|
|
tmps[gid].digest_buf[1] = digest[1];
|
|
tmps[gid].digest_buf[2] = digest[2];
|
|
tmps[gid].digest_buf[3] = digest[3];
|
|
tmps[gid].digest_buf[4] = digest[4];
|
|
}
|
|
|
|
KERNEL_FQ void m05800_loop (KERN_ATTR_TMPS (androidpin_tmp_t))
|
|
{
|
|
/**
|
|
* base
|
|
*/
|
|
|
|
const u64 gid = get_global_id (0);
|
|
const u64 lid = get_local_id (0);
|
|
const u64 lsz = get_local_size (0);
|
|
|
|
/**
|
|
* cache precomputed conversion table in shared memory
|
|
*/
|
|
|
|
LOCAL_VK u32 s_pc_dec[1024];
|
|
LOCAL_VK u32 s_pc_len[1024];
|
|
|
|
for (u32 i = lid; i < 1024; i += lsz)
|
|
{
|
|
s_pc_dec[i] = c_pc_dec[i];
|
|
s_pc_len[i] = c_pc_len[i];
|
|
}
|
|
|
|
SYNC_THREADS ();
|
|
|
|
if (gid >= GID_CNT) return;
|
|
|
|
/**
|
|
* base
|
|
*/
|
|
|
|
u32 word_buf[4];
|
|
|
|
word_buf[0] = pws[gid].i[ 0];
|
|
word_buf[1] = pws[gid].i[ 1];
|
|
word_buf[2] = pws[gid].i[ 2];
|
|
word_buf[3] = pws[gid].i[ 3];
|
|
|
|
const u32 pw_len = pws[gid].pw_len & 63;
|
|
|
|
u32 digest[5];
|
|
|
|
digest[0] = tmps[gid].digest_buf[0];
|
|
digest[1] = tmps[gid].digest_buf[1];
|
|
digest[2] = tmps[gid].digest_buf[2];
|
|
digest[3] = tmps[gid].digest_buf[3];
|
|
digest[4] = tmps[gid].digest_buf[4];
|
|
|
|
/**
|
|
* salt
|
|
*/
|
|
|
|
u32 salt_len = salt_bufs[SALT_POS_HOST].salt_len;
|
|
|
|
u32 salt_buf[5];
|
|
|
|
salt_buf[0] = salt_bufs[SALT_POS_HOST].salt_buf[0];
|
|
salt_buf[1] = salt_bufs[SALT_POS_HOST].salt_buf[1];
|
|
salt_buf[2] = salt_bufs[SALT_POS_HOST].salt_buf[2];
|
|
salt_buf[3] = salt_bufs[SALT_POS_HOST].salt_buf[3];
|
|
salt_buf[4] = salt_bufs[SALT_POS_HOST].salt_buf[4];
|
|
|
|
/**
|
|
* loop
|
|
*/
|
|
|
|
for (u32 i = 0, j = LOOP_POS + 1; i < LOOP_CNT; i++, j++)
|
|
{
|
|
const u32 pc_dec = s_pc_dec[j];
|
|
const u32 pc_len = s_pc_len[j];
|
|
|
|
u32 data0[4] = { 0, 0, 0, 0 };
|
|
u32 data1[4] = { 0, 0, 0, 0 };
|
|
u32 data2[4] = { 0, 0, 0, 0 };
|
|
|
|
data0[0] = pc_dec;
|
|
|
|
append_word (data0, data1, word_buf, pc_len);
|
|
|
|
append_salt (data0, data1, data2, salt_buf, pc_len + pw_len);
|
|
|
|
u32 w0[4];
|
|
u32 w1[4];
|
|
u32 w2[4];
|
|
u32 w3[4];
|
|
|
|
w0[0] = digest[0];
|
|
w0[1] = digest[1];
|
|
w0[2] = digest[2];
|
|
w0[3] = digest[3];
|
|
w1[0] = digest[4];
|
|
w1[1] = hc_swap32_S (data0[0]);
|
|
w1[2] = hc_swap32_S (data0[1]);
|
|
w1[3] = hc_swap32_S (data0[2]);
|
|
w2[0] = hc_swap32_S (data0[3]);
|
|
w2[1] = hc_swap32_S (data1[0]);
|
|
w2[2] = hc_swap32_S (data1[1]);
|
|
w2[3] = hc_swap32_S (data1[2]);
|
|
w3[0] = hc_swap32_S (data1[3]);
|
|
w3[1] = hc_swap32_S (data2[0]);
|
|
w3[2] = 0;
|
|
w3[3] = (20 + pc_len + pw_len + salt_len) * 8;
|
|
|
|
digest[0] = SHA1M_A;
|
|
digest[1] = SHA1M_B;
|
|
digest[2] = SHA1M_C;
|
|
digest[3] = SHA1M_D;
|
|
digest[4] = SHA1M_E;
|
|
|
|
sha1_transform (w0, w1, w2, w3, digest);
|
|
}
|
|
|
|
tmps[gid].digest_buf[0] = digest[0];
|
|
tmps[gid].digest_buf[1] = digest[1];
|
|
tmps[gid].digest_buf[2] = digest[2];
|
|
tmps[gid].digest_buf[3] = digest[3];
|
|
tmps[gid].digest_buf[4] = digest[4];
|
|
}
|
|
|
|
KERNEL_FQ void m05800_comp (KERN_ATTR_TMPS (androidpin_tmp_t))
|
|
{
|
|
/**
|
|
* modifier
|
|
*/
|
|
|
|
const u64 gid = get_global_id (0);
|
|
|
|
if (gid >= GID_CNT) return;
|
|
|
|
const u64 lid = get_local_id (0);
|
|
|
|
/**
|
|
* digest
|
|
*/
|
|
|
|
const u32 r0 = tmps[gid].digest_buf[DGST_R0];
|
|
const u32 r1 = tmps[gid].digest_buf[DGST_R1];
|
|
const u32 r2 = tmps[gid].digest_buf[DGST_R2];
|
|
const u32 r3 = tmps[gid].digest_buf[DGST_R3];
|
|
|
|
#define il_pos 0
|
|
|
|
#ifdef KERNEL_STATIC
|
|
#include COMPARE_M
|
|
#endif
|
|
}
|