+++ /dev/null
-/**
- * Authors.....: Jens Steube <jens.steube@gmail.com>
- * Gabriele Gristina <matrix@hashcat.net>
- * magnum <john.magnum@hushmail.com>
- *
- * License.....: MIT
- */
-
-#ifdef OSX
-#include <stdio.h>
-#endif
-
-#include <common.h>
-#include <shared.h>
-#include <rp_kernel_on_cpu.h>
-#include <getopt.h>
-
-const char *PROGNAME = "oclHashcat";
-const uint VERSION_BIN = 210;
-const uint RESTORE_MIN = 210;
-
-double TARGET_MS_PROFILE[3] = { 8, 16, 96 };
-
-#define INCR_RULES 10000
-#define INCR_SALTS 100000
-#define INCR_MASKS 1000
-#define INCR_POT 1000
-
-#define USAGE 0
-#define VERSION 0
-#define QUIET 0
-#define MARKOV_THRESHOLD 0
-#define MARKOV_DISABLE 0
-#define MARKOV_CLASSIC 0
-#define BENCHMARK 0
-#define RESTORE 0
-#define RESTORE_TIMER 60
-#define RESTORE_DISABLE 0
-#define STATUS 0
-#define STATUS_TIMER 10
-#define STATUS_AUTOMAT 0
-#define LOOPBACK 0
-#define WEAK_HASH_THRESHOLD 100
-#define SHOW 0
-#define LEFT 0
-#define USERNAME 0
-#define REMOVE 0
-#define REMOVE_TIMER 60
-#define SKIP 0
-#define LIMIT 0
-#define KEYSPACE 0
-#define POTFILE_DISABLE 0
-#define DEBUG_MODE 0
-#define RP_GEN 0
-#define RP_GEN_FUNC_MIN 1
-#define RP_GEN_FUNC_MAX 4
-#define RP_GEN_SEED 0
-#define RULE_BUF_L ":"
-#define RULE_BUF_R ":"
-#define FORCE 0
-#define RUNTIME 0
-#define HEX_CHARSET 0
-#define HEX_SALT 0
-#define HEX_WORDLIST 0
-#define OUTFILE_FORMAT 3
-#define OUTFILE_AUTOHEX 1
-#define OUTFILE_CHECK_TIMER 5
-#define ATTACK_MODE 0
-#define HASH_MODE 0
-#define SEGMENT_SIZE 32
-#define INCREMENT 0
-#define INCREMENT_MIN 1
-#define INCREMENT_MAX PW_MAX
-#define SEPARATOR ':'
-#define BITMAP_MIN 16
-#define BITMAP_MAX 24
-#define GPU_TEMP_DISABLE 0
-#define GPU_TEMP_ABORT 90
-#define GPU_TEMP_RETAIN 80
-#define WORKLOAD_PROFILE 2
-#define KERNEL_ACCEL 0
-#define KERNEL_LOOPS 0
-#define KERNEL_RULES 1024
-#define KERNEL_COMBS 1024
-#define KERNEL_BFS 1024
-#define KERNEL_THREADS_MAX 256
-#define KERNEL_THREADS_MAX_CPU 16
-#define POWERTUNE_ENABLE 0
-#define LOGFILE_DISABLE 0
-#define SCRYPT_TMTO 0
-#define OPENCL_VECTOR_WIDTH 0
-
-#define WL_MODE_STDIN 1
-#define WL_MODE_FILE 2
-#define WL_MODE_MASK 3
-
-#define HL_MODE_FILE 4
-#define HL_MODE_ARG 5
-
-#define HLFMTS_CNT 11
-#define HLFMT_HASHCAT 0
-#define HLFMT_PWDUMP 1
-#define HLFMT_PASSWD 2
-#define HLFMT_SHADOW 3
-#define HLFMT_DCC 4
-#define HLFMT_DCC2 5
-#define HLFMT_NETNTLM1 7
-#define HLFMT_NETNTLM2 8
-#define HLFMT_NSLDAP 9
-#define HLFMT_NSLDAPS 10
-
-#define HLFMT_TEXT_HASHCAT "native hashcat"
-#define HLFMT_TEXT_PWDUMP "pwdump"
-#define HLFMT_TEXT_PASSWD "passwd"
-#define HLFMT_TEXT_SHADOW "shadow"
-#define HLFMT_TEXT_DCC "DCC"
-#define HLFMT_TEXT_DCC2 "DCC 2"
-#define HLFMT_TEXT_NETNTLM1 "NetNTLMv1"
-#define HLFMT_TEXT_NETNTLM2 "NetNTLMv2"
-#define HLFMT_TEXT_NSLDAP "nsldap"
-#define HLFMT_TEXT_NSLDAPS "nsldaps"
-
-#define ATTACK_MODE_STRAIGHT 0
-#define ATTACK_MODE_COMBI 1
-#define ATTACK_MODE_TOGGLE 2
-#define ATTACK_MODE_BF 3
-#define ATTACK_MODE_PERM 4
-#define ATTACK_MODE_TABLE 5
-#define ATTACK_MODE_HYBRID1 6
-#define ATTACK_MODE_HYBRID2 7
-#define ATTACK_MODE_NONE 100
-
-#define ATTACK_KERN_STRAIGHT 0
-#define ATTACK_KERN_COMBI 1
-#define ATTACK_KERN_BF 3
-#define ATTACK_KERN_NONE 100
-
-#define ATTACK_EXEC_OUTSIDE_KERNEL 10
-#define ATTACK_EXEC_INSIDE_KERNEL 11
-
-#define COMBINATOR_MODE_BASE_LEFT 10001
-#define COMBINATOR_MODE_BASE_RIGHT 10002
-
-#define MIN(a,b) (((a) < (b)) ? (a) : (b))
-#define MAX(a,b) (((a) > (b)) ? (a) : (b))
-
-#define MAX_CUT_TRIES 4
-
-#define MAX_DICTSTAT 10000
-
-#define NUM_DEFAULT_BENCHMARK_ALGORITHMS 136
-
-#define global_free(attr) \
-{ \
- myfree ((void *) data.attr); \
- \
- data.attr = NULL; \
-}
-
-#define local_free(attr) \
-{ \
- myfree ((void *) attr); \
- \
- attr = NULL; \
-}
-
-static uint default_benchmark_algorithms[NUM_DEFAULT_BENCHMARK_ALGORITHMS] =
-{
- 900,
- 0,
- 5100,
- 100,
- 1400,
- 10800,
- 1700,
- 5000,
- 10100,
- 6000,
- 6100,
- 6900,
- 11700,
- 11800,
- 400,
- 8900,
- 11900,
- 12000,
- 10900,
- 12100,
- 23,
- 2500,
- 5300,
- 5400,
- 5500,
- 5600,
- 7300,
- 7500,
- 13100,
- 8300,
- 11100,
- 11200,
- 11400,
- 121,
- 2611,
- 2711,
- 2811,
- 8400,
- 11,
- 2612,
- 7900,
- 21,
- 11000,
- 124,
- 10000,
- 3711,
- 7600,
- 12,
- 131,
- 132,
- 1731,
- 200,
- 300,
- 3100,
- 112,
- 12300,
- 8000,
- 141,
- 1441,
- 1600,
- 12600,
- 1421,
- 101,
- 111,
- 1711,
- 3000,
- 1000,
- 1100,
- 2100,
- 12800,
- 1500,
- 12400,
- 500,
- 3200,
- 7400,
- 1800,
- 122,
- 1722,
- 7100,
- 6300,
- 6700,
- 6400,
- 6500,
- 2400,
- 2410,
- 5700,
- 9200,
- 9300,
- 22,
- 501,
- 5800,
- 8100,
- 8500,
- 7200,
- 9900,
- 7700,
- 7800,
- 10300,
- 8600,
- 8700,
- 9100,
- 133,
- 13500,
- 11600,
- 12500,
- 13000,
- 13200,
- 13300,
- 6211,
- 6221,
- 6231,
- 6241,
- 8800,
- 12900,
- 12200,
- 9700,
- 9710,
- 9800,
- 9810,
- 9400,
- 9500,
- 9600,
- 10400,
- 10410,
- 10500,
- 10600,
- 10700,
- 9000,
- 5200,
- 6800,
- 6600,
- 8200,
- 11300,
- 12700,
- 13400,
- 125
-};
-
-/**
- * types
- */
-
-static void (*get_next_word_func) (char *, u32, u32 *, u32 *);
-
-/**
- * globals
- */
-
-static unsigned int full01 = 0x01010101;
-static unsigned int full80 = 0x80808080;
-
-int SUPPRESS_OUTPUT = 0;
-
-hc_thread_mutex_t mux_adl;
-hc_thread_mutex_t mux_counter;
-hc_thread_mutex_t mux_dispatcher;
-hc_thread_mutex_t mux_display;
-
-hc_global_data_t data;
-
-const char *PROMPT = "[s]tatus [p]ause [r]esume [b]ypass [c]heckpoint [q]uit => ";
-
-const char *USAGE_MINI[] =
-{
- "Usage: %s [options]... hash|hashfile|hccapfile [dictionary|mask|directory]...",
- "",
- "Try --help for more help.",
- NULL
-};
-
-const char *USAGE_BIG[] =
-{
- "%s, advanced password recovery",
- "",
- "Usage: %s [options]... hash|hashfile|hccapfile [dictionary|mask|directory]...",
- "",
- "=======",
- "Options",
- "=======",
- "",
- "* General:",
- "",
- " -m, --hash-type=NUM Hash-type, see references below",
- " -a, --attack-mode=NUM Attack-mode, see references below",
- " -V, --version Print version",
- " -h, --help Print help",
- " --quiet Suppress output",
- "",
- "* Misc:",
- "",
- " --hex-charset Assume charset is given in hex",
- " --hex-salt Assume salt is given in hex",
- " --hex-wordlist Assume words in wordlist is given in hex",
- " --force Ignore warnings",
- " --status Enable automatic update of the status-screen",
- " --status-timer=NUM Seconds between status-screen update",
- " --status-automat Display the status view in a machine readable format",
- " --loopback Add new plains to induct directory",
- " --weak-hash-threshold=NUM Threshold when to stop checking for weak hashes, default is 100 salts",
- "",
- "* Markov:",
- "",
- " --markov-hcstat=FILE Specify hcstat file to use, default is hashcat.hcstat",
- " --markov-disable Disables markov-chains, emulates classic brute-force",
- " --markov-classic Enables classic markov-chains, no per-position enhancement",
- " -t, --markov-threshold=NUM Threshold when to stop accepting new markov-chains",
- "",
- "* Session:",
- "",
- " --runtime=NUM Abort session after NUM seconds of runtime",
- " --session=STR Define specific session name",
- " --restore Restore session from --session",
- " --restore-disable Do not write restore file",
- "",
- "* Files:",
- "",
- " -o, --outfile=FILE Define outfile for recovered hash",
- " --outfile-format=NUM Define outfile-format for recovered hash, see references below",
- " --outfile-autohex-disable Disable the use of $HEX[] in output plains",
- " --outfile-check-timer=NUM Seconds between outfile checks",
- " -p, --separator=CHAR Separator char for hashlists and outfile",
- " --show Show cracked passwords only",
- " --left Show un-cracked passwords only",
- " --username Enable ignoring of usernames in hashfile (recommended: also use --show)",
- " --remove Enable remove of hash once it is cracked",
- " --remove-timer=NUM Update input hash file each NUM seconds",
- " --potfile-disable Do not write potfile",
- " --potfile-path Specific path to potfile",
- " --debug-mode=NUM Defines the debug mode (hybrid only by using rules), see references below",
- " --debug-file=FILE Output file for debugging rules (see also --debug-mode)",
- " --induction-dir=FOLDER Specify induction directory to use, default is $session.induct",
- " --outfile-check-dir=FOLDER Specify the outfile directory which should be monitored, default is $session.outfiles",
- " --logfile-disable Disable the logfile",
- " --truecrypt-keyfiles=FILE Keyfiles used, separate with comma",
- "",
- "* Resources:",
- "",
- " -b, --benchmark Run benchmark",
- " --benchmark-repeats=NUM Repeat the kernel on the device NUM times to increase benchmark accuracy",
- " -c, --segment-size=NUM Size in MB to cache from the wordfile",
- " --bitmap-min=NUM Minimum number of bits allowed for bitmaps",
- " --bitmap-max=NUM Maximum number of bits allowed for bitmaps",
- " --cpu-affinity=STR Locks to CPU devices, separate with comma",
- " --opencl-platforms=STR OpenCL platforms to use, separate with comma",
- " -d, --opencl-devices=STR OpenCL devices to use, separate with comma",
- " --opencl-device-types=STR OpenCL device-types to use, separate with comma, see references below",
- " --opencl-vector-width=NUM OpenCL vector-width (either 1, 2, 4, 8 or 16), overrides value from device query",
- " -w, --workload-profile=NUM Enable a specific workload profile, see references below",
- " -n, --kernel-accel=NUM Workload tuning, increase the outer-loop step size",
- " -u, --kernel-loops=NUM Workload tuning, increase the inner-loop step size",
- " --gpu-temp-disable Disable temperature and fanspeed readings and triggers",
- #ifdef HAVE_HWMON
- " --gpu-temp-abort=NUM Abort session if GPU temperature reaches NUM degrees celsius",
- " --gpu-temp-retain=NUM Try to retain GPU temperature at NUM degrees celsius (AMD only)",
- #ifdef HAVE_ADL
- " --powertune-enable Enable automatic power tuning option (AMD OverDrive 6 only)",
- #endif
- #endif
- " --scrypt-tmto=NUM Manually override automatically calculated TMTO value for scrypt",
- "",
- "* Distributed:",
- "",
- " -s, --skip=NUM Skip number of words",
- " -l, --limit=NUM Limit number of words",
- " --keyspace Show keyspace base:mod values and quit",
- "",
- "* Rules:",
- "",
- " -j, --rule-left=RULE Single rule applied to each word from left dict",
- " -k, --rule-right=RULE Single rule applied to each word from right dict",
- " -r, --rules-file=FILE Rules-file, multi use: -r 1.rule -r 2.rule",
- " -g, --generate-rules=NUM Generate NUM random rules",
- " --generate-rules-func-min=NUM Force NUM functions per random rule min",
- " --generate-rules-func-max=NUM Force NUM functions per random rule max",
- " --generate-rules-seed=NUM Force RNG seed to NUM",
- "",
- "* Custom charsets:",
- "",
- " -1, --custom-charset1=CS User-defined charsets",
- " -2, --custom-charset2=CS Example:",
- " -3, --custom-charset3=CS --custom-charset1=?dabcdef : sets charset ?1 to 0123456789abcdef",
- " -4, --custom-charset4=CS -2 mycharset.hcchr : sets charset ?2 to chars contained in file",
- "",
- "* Increment:",
- "",
- " -i, --increment Enable increment mode",
- " --increment-min=NUM Start incrementing at NUM",
- " --increment-max=NUM Stop incrementing at NUM",
- "",
- "==========",
- "References",
- "==========",
- "",
- "* Workload Profile:",
- "",
- " 1 = Interactive performance profile, kernel execution runtime to 8ms, lower latency desktop, lower speed",
- " 2 = Default performance profile, kernel execution runtime to 16ms, economic setting",
- " 3 = Headless performance profile, kernel execution runtime to 96ms, higher latency desktop, higher speed",
- "",
- "* OpenCL device-types:",
- "",
- " 1 = CPU devices",
- " 2 = GPU devices",
- " 3 = Accelerator devices (FPGA, CELL Blade, etc.)",
- "",
- "* Outfile Formats:",
- "",
- " 1 = hash[:salt]",
- " 2 = plain",
- " 3 = hash[:salt]:plain",
- " 4 = hex_plain",
- " 5 = hash[:salt]:hex_plain",
- " 6 = plain:hex_plain",
- " 7 = hash[:salt]:plain:hex_plain",
- " 8 = crackpos",
- " 9 = hash[:salt]:crackpos",
- " 10 = plain:crackpos",
- " 11 = hash[:salt]:plain:crackpos",
- " 12 = hex_plain:crackpos",
- " 13 = hash[:salt]:hex_plain:crackpos",
- " 14 = plain:hex_plain:crackpos",
- " 15 = hash[:salt]:plain:hex_plain:crackpos",
- "",
- "* Debug mode output formats (for hybrid mode only, by using rules):",
- "",
- " 1 = save finding rule",
- " 2 = save original word",
- " 3 = save original word and finding rule",
- " 4 = save original word, finding rule and modified plain",
- "",
- "* Built-in charsets:",
- "",
- " ?l = abcdefghijklmnopqrstuvwxyz",
- " ?u = ABCDEFGHIJKLMNOPQRSTUVWXYZ",
- " ?d = 0123456789",
- " ?s = !\"#$%%&'()*+,-./:;<=>?@[\\]^_`{|}~",
- " ?a = ?l?u?d?s",
- " ?b = 0x00 - 0xff",
- "",
- "* Attack modes:",
- "",
- " 0 = Straight",
- " 1 = Combination",
- " 3 = Brute-force",
- " 6 = Hybrid dict + mask",
- " 7 = Hybrid mask + dict",
- "",
- "* Hash types:",
- "",
- "[[ Roll-your-own: Raw Hashes ]]",
- "",
- " 900 = MD4",
- " 0 = MD5",
- " 5100 = Half MD5",
- " 100 = SHA1",
- " 10800 = SHA-384",
- " 1400 = SHA-256",
- " 1700 = SHA-512",
- " 5000 = SHA-3(Keccak)",
- " 10100 = SipHash",
- " 6000 = RipeMD160",
- " 6100 = Whirlpool",
- " 6900 = GOST R 34.11-94",
- " 11700 = GOST R 34.11-2012 (Streebog) 256-bit",
- " 11800 = GOST R 34.11-2012 (Streebog) 512-bit",
- "",
- "[[ Roll-your-own: Iterated and / or Salted Hashes ]]",
- "",
- " 10 = md5($pass.$salt)",
- " 20 = md5($salt.$pass)",
- " 30 = md5(unicode($pass).$salt)",
- " 40 = md5($salt.unicode($pass))",
- " 3800 = md5($salt.$pass.$salt)",
- " 3710 = md5($salt.md5($pass))",
- " 2600 = md5(md5($pass)",
- " 4300 = md5(strtoupper(md5($pass)))",
- " 4400 = md5(sha1($pass))",
- " 110 = sha1($pass.$salt)",
- " 120 = sha1($salt.$pass)",
- " 130 = sha1(unicode($pass).$salt)",
- " 140 = sha1($salt.unicode($pass))",
- " 4500 = sha1(sha1($pass)",
- " 4700 = sha1(md5($pass))",
- " 4900 = sha1($salt.$pass.$salt)",
- " 1410 = sha256($pass.$salt)",
- " 1420 = sha256($salt.$pass)",
- " 1430 = sha256(unicode($pass).$salt)",
- " 1440 = sha256($salt.unicode($pass))",
- " 1710 = sha512($pass.$salt)",
- " 1720 = sha512($salt.$pass)",
- " 1730 = sha512(unicode($pass).$salt)",
- " 1740 = sha512($salt.unicode($pass))",
- "",
- "[[ Roll-your-own: Authenticated Hashes ]]",
- "",
- " 50 = HMAC-MD5 (key = $pass)",
- " 60 = HMAC-MD5 (key = $salt)",
- " 150 = HMAC-SHA1 (key = $pass)",
- " 160 = HMAC-SHA1 (key = $salt)",
- " 1450 = HMAC-SHA256 (key = $pass)",
- " 1460 = HMAC-SHA256 (key = $salt)",
- " 1750 = HMAC-SHA512 (key = $pass)",
- " 1760 = HMAC-SHA512 (key = $salt)",
- "",
- "[[ Generic KDF ]]",
- "",
- " 400 = phpass",
- " 8900 = scrypt",
- " 11900 = PBKDF2-HMAC-MD5",
- " 12000 = PBKDF2-HMAC-SHA1",
- " 10900 = PBKDF2-HMAC-SHA256",
- " 12100 = PBKDF2-HMAC-SHA512",
- "",
- "[[ Network protocols, Challenge-Response ]]",
- "",
- " 23 = Skype",
- " 2500 = WPA/WPA2",
- " 4800 = iSCSI CHAP authentication, MD5(Chap)",
- " 5300 = IKE-PSK MD5",
- " 5400 = IKE-PSK SHA1",
- " 5500 = NetNTLMv1",
- " 5500 = NetNTLMv1 + ESS",
- " 5600 = NetNTLMv2",
- " 7300 = IPMI2 RAKP HMAC-SHA1",
- " 7500 = Kerberos 5 AS-REQ Pre-Auth etype 23",
- " 8300 = DNSSEC (NSEC3)",
- " 10200 = Cram MD5",
- " 11100 = PostgreSQL Challenge-Response Authentication (MD5)",
- " 11200 = MySQL Challenge-Response Authentication (SHA1)",
- " 11400 = SIP digest authentication (MD5)",
- " 13100 = Kerberos 5 TGS-REP etype 23",
- "",
- "[[ Forums, CMS, E-Commerce, Frameworks, Middleware, Wiki, Management ]]",
- "",
- " 121 = SMF (Simple Machines Forum)",
- " 400 = phpBB3",
- " 2611 = vBulletin < v3.8.5",
- " 2711 = vBulletin > v3.8.5",
- " 2811 = MyBB",
- " 2811 = IPB (Invison Power Board)",
- " 8400 = WBB3 (Woltlab Burning Board)",
- " 11 = Joomla < 2.5.18",
- " 400 = Joomla > 2.5.18",
- " 400 = Wordpress",
- " 2612 = PHPS",
- " 7900 = Drupal7",
- " 21 = osCommerce",
- " 21 = xt:Commerce",
- " 11000 = PrestaShop",
- " 124 = Django (SHA-1)",
- " 10000 = Django (PBKDF2-SHA256)",
- " 3711 = Mediawiki B type",
- " 7600 = Redmine",
- "",
- "[[ Database Server ]]",
- "",
- " 12 = PostgreSQL",
- " 131 = MSSQL(2000)",
- " 132 = MSSQL(2005)",
- " 1731 = MSSQL(2012)",
- " 1731 = MSSQL(2014)",
- " 200 = MySQL323",
- " 300 = MySQL4.1/MySQL5",
- " 3100 = Oracle H: Type (Oracle 7+)",
- " 112 = Oracle S: Type (Oracle 11+)",
- " 12300 = Oracle T: Type (Oracle 12+)",
- " 8000 = Sybase ASE",
- "",
- "[[ HTTP, SMTP, LDAP Server ]]",
- "",
- " 141 = EPiServer 6.x < v4",
- " 1441 = EPiServer 6.x > v4",
- " 1600 = Apache $apr1$",
- " 12600 = ColdFusion 10+",
- " 1421 = hMailServer",
- " 101 = nsldap, SHA-1(Base64), Netscape LDAP SHA",
- " 111 = nsldaps, SSHA-1(Base64), Netscape LDAP SSHA",
- " 1711 = SSHA-512(Base64), LDAP {SSHA512}",
- "",
- "[[ Checksums ]]",
- "",
- " 11500 = CRC32",
- "",
- "[[ Operating-Systems ]]",
- "",
- " 3000 = LM",
- " 1000 = NTLM",
- " 1100 = Domain Cached Credentials (DCC), MS Cache",
- " 2100 = Domain Cached Credentials 2 (DCC2), MS Cache 2",
- " 12800 = MS-AzureSync PBKDF2-HMAC-SHA256",
- " 1500 = descrypt, DES(Unix), Traditional DES",
- " 12400 = BSDiCrypt, Extended DES",
- " 500 = md5crypt $1$, MD5(Unix)",
- " 3200 = bcrypt $2*$, Blowfish(Unix)",
- " 7400 = sha256crypt $5$, SHA256(Unix)",
- " 1800 = sha512crypt $6$, SHA512(Unix)",
- " 122 = OSX v10.4",
- " 122 = OSX v10.5",
- " 122 = OSX v10.6",
- " 1722 = OSX v10.7",
- " 7100 = OSX v10.8",
- " 7100 = OSX v10.9",
- " 7100 = OSX v10.10",
- " 6300 = AIX {smd5}",
- " 6700 = AIX {ssha1}",
- " 6400 = AIX {ssha256}",
- " 6500 = AIX {ssha512}",
- " 2400 = Cisco-PIX",
- " 2410 = Cisco-ASA",
- " 500 = Cisco-IOS $1$",
- " 5700 = Cisco-IOS $4$",
- " 9200 = Cisco-IOS $8$",
- " 9300 = Cisco-IOS $9$",
- " 22 = Juniper Netscreen/SSG (ScreenOS)",
- " 501 = Juniper IVE",
- " 5800 = Android PIN",
- " 8100 = Citrix Netscaler",
- " 8500 = RACF",
- " 7200 = GRUB 2",
- " 9900 = Radmin2",
- " 125 = ArubaOS",
- "",
- "[[ Enterprise Application Software (EAS) ]]",
- "",
- " 7700 = SAP CODVN B (BCODE)",
- " 7800 = SAP CODVN F/G (PASSCODE)",
- " 10300 = SAP CODVN H (PWDSALTEDHASH) iSSHA-1",
- " 8600 = Lotus Notes/Domino 5",
- " 8700 = Lotus Notes/Domino 6",
- " 9100 = Lotus Notes/Domino 8",
- " 133 = PeopleSoft",
- " 13500 = PeopleSoft Token",
- "",
- "[[ Archives ]]",
- "",
- " 11600 = 7-Zip",
- " 12500 = RAR3-hp",
- " 13000 = RAR5",
- " 13200 = AxCrypt",
- " 13300 = AxCrypt in memory SHA1",
- "",
- "[[ Full-Disk encryptions (FDE) ]]",
- "",
- " 62XY = TrueCrypt 5.0+",
- " X = 1 = PBKDF2-HMAC-RipeMD160",
- " X = 2 = PBKDF2-HMAC-SHA512",
- " X = 3 = PBKDF2-HMAC-Whirlpool",
- " X = 4 = PBKDF2-HMAC-RipeMD160 + boot-mode",
- " Y = 1 = XTS 512 bit (Ciphers: AES or Serpent or Twofish)",
- " Y = 2 = XTS 1024 bit (Ciphers: AES or Serpent or Twofish or AES-Twofish or Serpent-AES or Twofish-Serpent)",
- " Y = 3 = XTS 1536 bit (Ciphers: All)",
- " 8800 = Android FDE < v4.3",
- " 12900 = Android FDE (Samsung DEK)",
- " 12200 = eCryptfs",
- "",
- "[[ Documents ]]",
- "",
- " 9700 = MS Office <= 2003 MD5 + RC4, oldoffice$0, oldoffice$1",
- " 9710 = MS Office <= 2003 MD5 + RC4, collider-mode #1",
- " 9720 = MS Office <= 2003 MD5 + RC4, collider-mode #2",
- " 9800 = MS Office <= 2003 SHA1 + RC4, oldoffice$3, oldoffice$4",
- " 9810 = MS Office <= 2003 SHA1 + RC4, collider-mode #1",
- " 9820 = MS Office <= 2003 SHA1 + RC4, collider-mode #2",
- " 9400 = MS Office 2007",
- " 9500 = MS Office 2010",
- " 9600 = MS Office 2013",
- " 10400 = PDF 1.1 - 1.3 (Acrobat 2 - 4)",
- " 10410 = PDF 1.1 - 1.3 (Acrobat 2 - 4) + collider-mode #1",
- " 10420 = PDF 1.1 - 1.3 (Acrobat 2 - 4) + collider-mode #2",
- " 10500 = PDF 1.4 - 1.6 (Acrobat 5 - 8)",
- " 10600 = PDF 1.7 Level 3 (Acrobat 9)",
- " 10700 = PDF 1.7 Level 8 (Acrobat 10 - 11)",
- "",
- "[[ Password Managers ]]",
- "",
- " 9000 = Password Safe v2",
- " 5200 = Password Safe v3",
- " 6800 = Lastpass",
- " 6600 = 1Password, agilekeychain",
- " 8200 = 1Password, cloudkeychain",
- " 11300 = Bitcoin/Litecoin wallet.dat",
- " 12700 = Blockchain, My Wallet",
- " 13400 = Keepass 1 (AES/Twofish) and Keepass 2 (AES)",
- "",
- NULL
-};
-
-/**
- * oclHashcat specific functions
- */
-
-static double get_avg_exec_time (hc_device_param_t *device_param, const int last_num_entries)
-{
- int exec_pos = (int) device_param->exec_pos - last_num_entries;
-
- if (exec_pos < 0) exec_pos += EXEC_CACHE;
-
- double exec_ms_sum = 0;
-
- int exec_ms_cnt = 0;
-
- for (int i = 0; i < last_num_entries; i++)
- {
- double exec_ms = device_param->exec_ms[(exec_pos + i) % EXEC_CACHE];
-
- if (exec_ms)
- {
- exec_ms_sum += exec_ms;
-
- exec_ms_cnt++;
- }
- }
-
- if (exec_ms_cnt == 0) return 0;
-
- return exec_ms_sum / exec_ms_cnt;
-}
-
-void status_display_automat ()
-{
- FILE *out = stdout;
-
- fprintf (out, "STATUS\t%u\t", data.devices_status);
-
- /**
- * speed new
- */
-
- fprintf (out, "SPEED\t");
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- u64 speed_cnt = 0;
- double speed_ms = 0;
-
- for (int i = 0; i < SPEED_CACHE; i++)
- {
- speed_cnt += device_param->speed_cnt[i];
- speed_ms += device_param->speed_ms[i];
- }
-
- speed_cnt /= SPEED_CACHE;
- speed_ms /= SPEED_CACHE;
-
- fprintf (out, "%llu\t%f\t", (unsigned long long int) speed_cnt, speed_ms);
- }
-
- /**
- * exec time
- */
-
- fprintf (out, "EXEC_RUNTIME\t");
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- double exec_ms_avg = get_avg_exec_time (device_param, EXEC_CACHE);
-
- fprintf (out, "%f\t", exec_ms_avg);
- }
-
- /**
- * words_cur
- */
-
- u64 words_cur = get_lowest_words_done ();
-
- fprintf (out, "CURKU\t%llu\t", (unsigned long long int) words_cur);
-
- /**
- * counter
- */
-
- u64 progress_total = data.words_cnt * data.salts_cnt;
-
- u64 all_done = 0;
- u64 all_rejected = 0;
- u64 all_restored = 0;
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- all_done += data.words_progress_done[salt_pos];
- all_rejected += data.words_progress_rejected[salt_pos];
- all_restored += data.words_progress_restored[salt_pos];
- }
-
- u64 progress_cur = all_restored + all_done + all_rejected;
- u64 progress_end = progress_total;
-
- u64 progress_skip = 0;
-
- if (data.skip)
- {
- progress_skip = MIN (data.skip, data.words_base) * data.salts_cnt;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT) progress_skip *= data.kernel_rules_cnt;
- else if (data.attack_kern == ATTACK_KERN_COMBI) progress_skip *= data.combs_cnt;
- else if (data.attack_kern == ATTACK_KERN_BF) progress_skip *= data.bfs_cnt;
- }
-
- if (data.limit)
- {
- progress_end = MIN (data.limit, data.words_base) * data.salts_cnt;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT) progress_end *= data.kernel_rules_cnt;
- else if (data.attack_kern == ATTACK_KERN_COMBI) progress_end *= data.combs_cnt;
- else if (data.attack_kern == ATTACK_KERN_BF) progress_end *= data.bfs_cnt;
- }
-
- u64 progress_cur_relative_skip = progress_cur - progress_skip;
- u64 progress_end_relative_skip = progress_end - progress_skip;
-
- fprintf (out, "PROGRESS\t%llu\t%llu\t", (unsigned long long int) progress_cur_relative_skip, (unsigned long long int) progress_end_relative_skip);
-
- /**
- * cracks
- */
-
- fprintf (out, "RECHASH\t%u\t%u\t", data.digests_done, data.digests_cnt);
- fprintf (out, "RECSALT\t%u\t%u\t", data.salts_done, data.salts_cnt);
-
- /**
- * temperature
- */
-
- #ifdef HAVE_HWMON
- if (data.gpu_temp_disable == 0)
- {
- fprintf (out, "TEMP\t");
-
- hc_thread_mutex_lock (mux_adl);
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- int temp = hm_get_temperature_with_device_id (device_id);
-
- fprintf (out, "%d\t", temp);
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_HWMON
-
- /**
- * flush
- */
-
- #ifdef _WIN
- fputc ('\r', out);
- fputc ('\n', out);
- #endif
-
- #ifdef _POSIX
- fputc ('\n', out);
- #endif
-
- fflush (out);
-}
-
-void status_display ()
-{
- if (data.devices_status == STATUS_INIT) return;
- if (data.devices_status == STATUS_STARTING) return;
- if (data.devices_status == STATUS_BYPASS) return;
-
- if (data.status_automat == 1)
- {
- status_display_automat ();
-
- return;
- }
-
- char tmp_buf[1000] = { 0 };
-
- uint tmp_len = 0;
-
- log_info ("Session.Name...: %s", data.session);
-
- char *status_type = strstatus (data.devices_status);
-
- uint hash_mode = data.hash_mode;
-
- char *hash_type = strhashtype (hash_mode); // not a bug
-
- log_info ("Status.........: %s", status_type);
-
- /**
- * show rules
- */
-
- if (data.rp_files_cnt)
- {
- uint i;
-
- for (i = 0, tmp_len = 0; i < data.rp_files_cnt - 1 && tmp_len < sizeof (tmp_buf); i++)
- {
- tmp_len += snprintf (tmp_buf + tmp_len, sizeof (tmp_buf) - tmp_len, "File (%s), ", data.rp_files[i]);
- }
-
- snprintf (tmp_buf + tmp_len, sizeof (tmp_buf) - tmp_len, "File (%s)", data.rp_files[i]);
-
- log_info ("Rules.Type.....: %s", tmp_buf);
-
- tmp_len = 0;
- }
-
- if (data.rp_gen)
- {
- log_info ("Rules.Type.....: Generated (%u)", data.rp_gen);
-
- if (data.rp_gen_seed)
- {
- log_info ("Rules.Seed.....: %u", data.rp_gen_seed);
- }
- }
-
- /**
- * show input
- */
-
- if (data.attack_mode == ATTACK_MODE_STRAIGHT)
- {
- if (data.wordlist_mode == WL_MODE_FILE)
- {
- if (data.dictfile != NULL) log_info ("Input.Mode.....: File (%s)", data.dictfile);
- }
- else if (data.wordlist_mode == WL_MODE_STDIN)
- {
- log_info ("Input.Mode.....: Pipe");
- }
- }
- else if (data.attack_mode == ATTACK_MODE_COMBI)
- {
- if (data.dictfile != NULL) log_info ("Input.Left.....: File (%s)", data.dictfile);
- if (data.dictfile2 != NULL) log_info ("Input.Right....: File (%s)", data.dictfile2);
- }
- else if (data.attack_mode == ATTACK_MODE_BF)
- {
- char *mask = data.mask;
-
- if (mask != NULL)
- {
- uint mask_len = data.css_cnt;
-
- tmp_len += snprintf (tmp_buf + tmp_len, sizeof (tmp_buf) - tmp_len, "Mask (%s)", mask);
-
- if (mask_len > 0)
- {
- if (data.opti_type & OPTI_TYPE_SINGLE_HASH)
- {
- if (data.opti_type & OPTI_TYPE_APPENDED_SALT)
- {
- mask_len -= data.salts_buf[0].salt_len;
- }
- }
-
- if (data.opts_type & OPTS_TYPE_PT_UNICODE) mask_len /= 2;
-
- tmp_len += snprintf (tmp_buf + tmp_len, sizeof (tmp_buf) - tmp_len, " [%i]", mask_len);
- }
-
- if (data.maskcnt > 1)
- {
- float mask_percentage = (float) data.maskpos / (float) data.maskcnt;
-
- tmp_len += snprintf (tmp_buf + tmp_len, sizeof (tmp_buf) - tmp_len, " (%.02f%%)", mask_percentage * 100);
- }
-
- log_info ("Input.Mode.....: %s", tmp_buf);
- }
-
- tmp_len = 0;
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID1)
- {
- if (data.dictfile != NULL) log_info ("Input.Left.....: File (%s)", data.dictfile);
- if (data.mask != NULL) log_info ("Input.Right....: Mask (%s) [%i]", data.mask, data.css_cnt);
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID2)
- {
- if (data.mask != NULL) log_info ("Input.Left.....: Mask (%s) [%i]", data.mask, data.css_cnt);
- if (data.dictfile != NULL) log_info ("Input.Right....: File (%s)", data.dictfile);
- }
-
- if (data.digests_cnt == 1)
- {
- if (data.hash_mode == 2500)
- {
- wpa_t *wpa = (wpa_t *) data.esalts_buf;
-
- log_info ("Hash.Target....: %s (%02x:%02x:%02x:%02x:%02x:%02x <-> %02x:%02x:%02x:%02x:%02x:%02x)",
- (char *) data.salts_buf[0].salt_buf,
- wpa->orig_mac1[0],
- wpa->orig_mac1[1],
- wpa->orig_mac1[2],
- wpa->orig_mac1[3],
- wpa->orig_mac1[4],
- wpa->orig_mac1[5],
- wpa->orig_mac2[0],
- wpa->orig_mac2[1],
- wpa->orig_mac2[2],
- wpa->orig_mac2[3],
- wpa->orig_mac2[4],
- wpa->orig_mac2[5]);
- }
- else if (data.hash_mode == 5200)
- {
- log_info ("Hash.Target....: File (%s)", data.hashfile);
- }
- else if (data.hash_mode == 9000)
- {
- log_info ("Hash.Target....: File (%s)", data.hashfile);
- }
- else if ((data.hash_mode >= 6200) && (data.hash_mode <= 6299))
- {
- log_info ("Hash.Target....: File (%s)", data.hashfile);
- }
- else
- {
- char out_buf[HCBUFSIZ] = { 0 };
-
- ascii_digest (out_buf, 0, 0);
-
- // limit length
- if (strlen (out_buf) > 40)
- {
- out_buf[41] = '.';
- out_buf[42] = '.';
- out_buf[43] = '.';
- out_buf[44] = 0;
- }
-
- log_info ("Hash.Target....: %s", out_buf);
- }
- }
- else
- {
- if (data.hash_mode == 3000)
- {
- char out_buf1[32] = { 0 };
- char out_buf2[32] = { 0 };
-
- ascii_digest (out_buf1, 0, 0);
- ascii_digest (out_buf2, 0, 1);
-
- log_info ("Hash.Target....: %s, %s", out_buf1, out_buf2);
- }
- else
- {
- log_info ("Hash.Target....: File (%s)", data.hashfile);
- }
- }
-
- log_info ("Hash.Type......: %s", hash_type);
-
- /**
- * speed new
- */
-
- u64 speed_cnt[DEVICES_MAX] = { 0 };
- double speed_ms[DEVICES_MAX] = { 0 };
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- speed_cnt[device_id] = 0;
- speed_ms[device_id] = 0;
-
- for (int i = 0; i < SPEED_CACHE; i++)
- {
- speed_cnt[device_id] += device_param->speed_cnt[i];
- speed_ms[device_id] += device_param->speed_ms[i];
- }
-
- speed_cnt[device_id] /= SPEED_CACHE;
- speed_ms[device_id] /= SPEED_CACHE;
- }
-
- float hashes_all_ms = 0;
-
- float hashes_dev_ms[DEVICES_MAX] = { 0 };
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- hashes_dev_ms[device_id] = 0;
-
- if (speed_ms[device_id])
- {
- hashes_dev_ms[device_id] = speed_cnt[device_id] / speed_ms[device_id];
-
- hashes_all_ms += hashes_dev_ms[device_id];
- }
- }
-
- /**
- * exec time
- */
-
- double exec_all_ms[DEVICES_MAX] = { 0 };
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- double exec_ms_avg = get_avg_exec_time (device_param, EXEC_CACHE);
-
- exec_all_ms[device_id] = exec_ms_avg;
- }
-
- /**
- * timers
- */
-
- double ms_running = 0;
-
- hc_timer_get (data.timer_running, ms_running);
-
- double ms_paused = data.ms_paused;
-
- if (data.devices_status == STATUS_PAUSED)
- {
- double ms_paused_tmp = 0;
-
- hc_timer_get (data.timer_paused, ms_paused_tmp);
-
- ms_paused += ms_paused_tmp;
- }
-
- #ifdef WIN
-
- __time64_t sec_run = ms_running / 1000;
-
- #else
-
- time_t sec_run = ms_running / 1000;
-
- #endif
-
- if (sec_run)
- {
- char display_run[32] = { 0 };
-
- struct tm tm_run;
-
- struct tm *tmp = NULL;
-
- #ifdef WIN
-
- tmp = _gmtime64 (&sec_run);
-
- #else
-
- tmp = gmtime (&sec_run);
-
- #endif
-
- if (tmp != NULL)
- {
- memset (&tm_run, 0, sizeof (tm_run));
-
- memcpy (&tm_run, tmp, sizeof (tm_run));
-
- format_timer_display (&tm_run, display_run, sizeof (tm_run));
-
- char *start = ctime (&data.proc_start);
-
- size_t start_len = strlen (start);
-
- if (start[start_len - 1] == '\n') start[start_len - 1] = 0;
- if (start[start_len - 2] == '\r') start[start_len - 2] = 0;
-
- log_info ("Time.Started...: %s (%s)", start, display_run);
- }
- }
- else
- {
- log_info ("Time.Started...: 0 secs");
- }
-
- /**
- * counters
- */
-
- u64 progress_total = data.words_cnt * data.salts_cnt;
-
- u64 all_done = 0;
- u64 all_rejected = 0;
- u64 all_restored = 0;
-
- u64 progress_noneed = 0;
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- all_done += data.words_progress_done[salt_pos];
- all_rejected += data.words_progress_rejected[salt_pos];
- all_restored += data.words_progress_restored[salt_pos];
-
- // Important for ETA only
-
- if (data.salts_shown[salt_pos] == 1)
- {
- const u64 all = data.words_progress_done[salt_pos]
- + data.words_progress_rejected[salt_pos]
- + data.words_progress_restored[salt_pos];
-
- const u64 left = data.words_cnt - all;
-
- progress_noneed += left;
- }
- }
-
- u64 progress_cur = all_restored + all_done + all_rejected;
- u64 progress_end = progress_total;
-
- u64 progress_skip = 0;
-
- if (data.skip)
- {
- progress_skip = MIN (data.skip, data.words_base) * data.salts_cnt;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT) progress_skip *= data.kernel_rules_cnt;
- else if (data.attack_kern == ATTACK_KERN_COMBI) progress_skip *= data.combs_cnt;
- else if (data.attack_kern == ATTACK_KERN_BF) progress_skip *= data.bfs_cnt;
- }
-
- if (data.limit)
- {
- progress_end = MIN (data.limit, data.words_base) * data.salts_cnt;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT) progress_end *= data.kernel_rules_cnt;
- else if (data.attack_kern == ATTACK_KERN_COMBI) progress_end *= data.combs_cnt;
- else if (data.attack_kern == ATTACK_KERN_BF) progress_end *= data.bfs_cnt;
- }
-
- u64 progress_cur_relative_skip = progress_cur - progress_skip;
- u64 progress_end_relative_skip = progress_end - progress_skip;
-
- if ((data.wordlist_mode == WL_MODE_FILE) || (data.wordlist_mode == WL_MODE_MASK))
- {
- if (data.devices_status != STATUS_CRACKED)
- {
- #ifdef WIN
- __time64_t sec_etc = 0;
- #else
- time_t sec_etc = 0;
- #endif
-
- if (hashes_all_ms)
- {
- u64 progress_left_relative_skip = progress_end_relative_skip - progress_cur_relative_skip;
-
- u64 ms_left = (progress_left_relative_skip - progress_noneed) / hashes_all_ms;
-
- sec_etc = ms_left / 1000;
- }
-
- if (sec_etc == 0)
- {
- //log_info ("Time.Estimated.: 0 secs");
- }
- else if ((u64) sec_etc > ETC_MAX)
- {
- log_info ("Time.Estimated.: > 10 Years");
- }
- else
- {
- char display_etc[32] = { 0 };
-
- struct tm tm_etc;
-
- struct tm *tmp = NULL;
-
- #ifdef WIN
-
- tmp = _gmtime64 (&sec_etc);
-
- #else
-
- tmp = gmtime (&sec_etc);
-
- #endif
-
- if (tmp != NULL)
- {
- memset (&tm_etc, 0, sizeof (tm_etc));
-
- memcpy (&tm_etc, tmp, sizeof (tm_etc));
-
- format_timer_display (&tm_etc, display_etc, sizeof (display_etc));
-
- time_t now;
-
- time (&now);
-
- now += sec_etc;
-
- char *etc = ctime (&now);
-
- size_t etc_len = strlen (etc);
-
- if (etc[etc_len - 1] == '\n') etc[etc_len - 1] = 0;
- if (etc[etc_len - 2] == '\r') etc[etc_len - 2] = 0;
-
- log_info ("Time.Estimated.: %s (%s)", etc, display_etc);
- }
- }
- }
- }
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- char display_dev_cur[16] = { 0 };
-
- strncpy (display_dev_cur, "0.00", 4);
-
- format_speed_display (hashes_dev_ms[device_id] * 1000, display_dev_cur, sizeof (display_dev_cur));
-
- log_info ("Speed.Dev.#%d...: %9sH/s (%0.2fms)", device_id + 1, display_dev_cur, exec_all_ms[device_id]);
- }
-
- char display_all_cur[16] = { 0 };
-
- strncpy (display_all_cur, "0.00", 4);
-
- format_speed_display (hashes_all_ms * 1000, display_all_cur, sizeof (display_all_cur));
-
- if (data.devices_active > 1) log_info ("Speed.Dev.#*...: %9sH/s", display_all_cur);
-
- const float digests_percent = (float) data.digests_done / data.digests_cnt;
- const float salts_percent = (float) data.salts_done / data.salts_cnt;
-
- log_info ("Recovered......: %u/%u (%.2f%%) Digests, %u/%u (%.2f%%) Salts", data.digests_done, data.digests_cnt, digests_percent * 100, data.salts_done, data.salts_cnt, salts_percent * 100);
-
- // crack-per-time
-
- if (data.digests_cnt > 100)
- {
- time_t now = time (NULL);
-
- int cpt_cur_min = 0;
- int cpt_cur_hour = 0;
- int cpt_cur_day = 0;
-
- for (int i = 0; i < CPT_BUF; i++)
- {
- const uint cracked = data.cpt_buf[i].cracked;
- const time_t timestamp = data.cpt_buf[i].timestamp;
-
- if ((timestamp + 60) > now)
- {
- cpt_cur_min += cracked;
- }
-
- if ((timestamp + 3600) > now)
- {
- cpt_cur_hour += cracked;
- }
-
- if ((timestamp + 86400) > now)
- {
- cpt_cur_day += cracked;
- }
- }
-
- double ms_real = ms_running - ms_paused;
-
- float cpt_avg_min = (float) data.cpt_total / ((ms_real / 1000) / 60);
- float cpt_avg_hour = (float) data.cpt_total / ((ms_real / 1000) / 3600);
- float cpt_avg_day = (float) data.cpt_total / ((ms_real / 1000) / 86400);
-
- if ((data.cpt_start + 86400) < now)
- {
- log_info ("Recovered/Time.: CUR:%llu,%llu,%llu AVG:%0.2f,%0.2f,%0.2f (Min,Hour,Day)",
- cpt_cur_min,
- cpt_cur_hour,
- cpt_cur_day,
- cpt_avg_min,
- cpt_avg_hour,
- cpt_avg_day);
- }
- else if ((data.cpt_start + 3600) < now)
- {
- log_info ("Recovered/Time.: CUR:%llu,%llu,N/A AVG:%0.2f,%0.2f,%0.2f (Min,Hour,Day)",
- cpt_cur_min,
- cpt_cur_hour,
- cpt_avg_min,
- cpt_avg_hour,
- cpt_avg_day);
- }
- else if ((data.cpt_start + 60) < now)
- {
- log_info ("Recovered/Time.: CUR:%llu,N/A,N/A AVG:%0.2f,%0.2f,%0.2f (Min,Hour,Day)",
- cpt_cur_min,
- cpt_avg_min,
- cpt_avg_hour,
- cpt_avg_day);
- }
- else
- {
- log_info ("Recovered/Time.: CUR:N/A,N/A,N/A AVG:%0.2f,%0.2f,%0.2f (Min,Hour,Day)",
- cpt_avg_min,
- cpt_avg_hour,
- cpt_avg_day);
- }
- }
-
- // Restore point
-
- u64 restore_point = get_lowest_words_done ();
-
- u64 restore_total = data.words_base;
-
- float percent_restore = 0;
-
- if (restore_total != 0) percent_restore = (float) restore_point / (float) restore_total;
-
- if (progress_end_relative_skip)
- {
- if ((data.wordlist_mode == WL_MODE_FILE) || (data.wordlist_mode == WL_MODE_MASK))
- {
- float percent_finished = (float) progress_cur_relative_skip / (float) progress_end_relative_skip;
- float percent_rejected = 0.0;
-
- if (progress_cur)
- {
- percent_rejected = (float) (all_rejected) / (float) progress_cur;
- }
-
- log_info ("Progress.......: %llu/%llu (%.02f%%)", (unsigned long long int) progress_cur_relative_skip, (unsigned long long int) progress_end_relative_skip, percent_finished * 100);
- log_info ("Rejected.......: %llu/%llu (%.02f%%)", (unsigned long long int) all_rejected, (unsigned long long int) progress_cur_relative_skip, percent_rejected * 100);
-
- if (data.restore_disable == 0)
- {
- if (percent_finished != 1)
- {
- log_info ("Restore.Point..: %llu/%llu (%.02f%%)", (unsigned long long int) restore_point, (unsigned long long int) restore_total, percent_restore * 100);
- }
- }
- }
- }
- else
- {
- if ((data.wordlist_mode == WL_MODE_FILE) || (data.wordlist_mode == WL_MODE_MASK))
- {
- log_info ("Progress.......: %llu/%llu (%.02f%%)", (u64) 0, (u64) 0, (float) 100);
- log_info ("Rejected.......: %llu/%llu (%.02f%%)", (u64) 0, (u64) 0, (float) 100);
-
- if (data.restore_disable == 0)
- {
- log_info ("Restore.Point..: %llu/%llu (%.02f%%)", (u64) 0, (u64) 0, (float) 100);
- }
- }
- else
- {
- log_info ("Progress.......: %llu", (unsigned long long int) progress_cur_relative_skip);
- log_info ("Rejected.......: %llu", (unsigned long long int) all_rejected);
-
- // --restore not allowed if stdin is used -- really? why?
-
- //if (data.restore_disable == 0)
- //{
- // log_info ("Restore.Point..: %llu", (unsigned long long int) restore_point);
- //}
- }
- }
-
- #ifdef HAVE_HWMON
- if (data.gpu_temp_disable == 0)
- {
- hc_thread_mutex_lock (mux_adl);
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- #define HM_STR_BUF_SIZE 255
-
- if (data.hm_device[device_id].fan_supported == 1)
- {
- char utilization[HM_STR_BUF_SIZE] = { 0 };
- char temperature[HM_STR_BUF_SIZE] = { 0 };
- char fanspeed[HM_STR_BUF_SIZE] = { 0 };
-
- hm_device_val_to_str ((char *) utilization, HM_STR_BUF_SIZE, "%", hm_get_utilization_with_device_id (device_id));
- hm_device_val_to_str ((char *) temperature, HM_STR_BUF_SIZE, "c", hm_get_temperature_with_device_id (device_id));
-
- if (device_param->vendor_id == VENDOR_ID_AMD)
- {
- hm_device_val_to_str ((char *) fanspeed, HM_STR_BUF_SIZE, "%", hm_get_fanspeed_with_device_id (device_id));
- }
- else if (device_param->vendor_id == VENDOR_ID_NV)
- {
- hm_device_val_to_str ((char *) fanspeed, HM_STR_BUF_SIZE, "%", hm_get_fanspeed_with_device_id (device_id));
- }
-
- log_info ("HWMon.GPU.#%d...: %s Util, %s Temp, %s Fan", device_id + 1, utilization, temperature, fanspeed);
- }
- else
- {
- char utilization[HM_STR_BUF_SIZE] = { 0 };
- char temperature[HM_STR_BUF_SIZE] = { 0 };
-
- hm_device_val_to_str ((char *) utilization, HM_STR_BUF_SIZE, "%", hm_get_utilization_with_device_id (device_id));
- hm_device_val_to_str ((char *) temperature, HM_STR_BUF_SIZE, "c", hm_get_temperature_with_device_id (device_id));
-
- log_info ("HWMon.GPU.#%d...: %s Util, %s Temp, N/A Fan", device_id + 1, utilization, temperature);
- }
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_HWMON
-}
-
-static void status_benchmark ()
-{
- if (data.devices_status == STATUS_INIT) return;
- if (data.devices_status == STATUS_STARTING) return;
-
- if (data.words_cnt == 0) return;
-
- u64 speed_cnt[DEVICES_MAX] = { 0 };
- double speed_ms[DEVICES_MAX] = { 0 };
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- speed_cnt[device_id] = device_param->speed_cnt[0];
- speed_ms[device_id] = device_param->speed_ms[0];
- }
-
- float hashes_all_ms = 0;
-
- float hashes_dev_ms[DEVICES_MAX] = { 0 };
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- hashes_dev_ms[device_id] = 0;
-
- if (speed_ms[device_id])
- {
- hashes_dev_ms[device_id] = speed_cnt[device_id] / speed_ms[device_id];
-
- hashes_all_ms += hashes_dev_ms[device_id];
- }
- }
-
- /**
- * exec time
- */
-
- double exec_all_ms[DEVICES_MAX] = { 0 };
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- double exec_ms_avg = get_avg_exec_time (device_param, EXEC_CACHE);
-
- exec_all_ms[device_id] = exec_ms_avg;
- }
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- char display_dev_cur[16] = { 0 };
-
- strncpy (display_dev_cur, "0.00", 4);
-
- format_speed_display (hashes_dev_ms[device_id] * 1000, display_dev_cur, sizeof (display_dev_cur));
-
- log_info ("Speed.Dev.#%d.: %9sH/s (%0.2fms)", device_id + 1, display_dev_cur, exec_all_ms[device_id]);
- }
-
- char display_all_cur[16] = { 0 };
-
- strncpy (display_all_cur, "0.00", 4);
-
- format_speed_display (hashes_all_ms * 1000, display_all_cur, sizeof (display_all_cur));
-
- if (data.devices_active > 1) log_info ("Speed.Dev.#*.: %9sH/s", display_all_cur);
-}
-
-/**
- * oclHashcat -only- functions
- */
-
-static void generate_source_kernel_filename (const uint attack_exec, const uint attack_kern, const uint kern_type, char *shared_dir, char *source_file)
-{
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- snprintf (source_file, 255, "%s/OpenCL/m%05d_a0.cl", shared_dir, (int) kern_type);
- else if (attack_kern == ATTACK_KERN_COMBI)
- snprintf (source_file, 255, "%s/OpenCL/m%05d_a1.cl", shared_dir, (int) kern_type);
- else if (attack_kern == ATTACK_KERN_BF)
- snprintf (source_file, 255, "%s/OpenCL/m%05d_a3.cl", shared_dir, (int) kern_type);
- }
- else
- snprintf (source_file, 255, "%s/OpenCL/m%05d.cl", shared_dir, (int) kern_type);
-}
-
-static void generate_cached_kernel_filename (const uint attack_exec, const uint attack_kern, const uint kern_type, char *profile_dir, const char *device_name_chksum, char *cached_file)
-{
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- snprintf (cached_file, 255, "%s/kernels/m%05d_a0.%s.kernel", profile_dir, (int) kern_type, device_name_chksum);
- else if (attack_kern == ATTACK_KERN_COMBI)
- snprintf (cached_file, 255, "%s/kernels/m%05d_a1.%s.kernel", profile_dir, (int) kern_type, device_name_chksum);
- else if (attack_kern == ATTACK_KERN_BF)
- snprintf (cached_file, 255, "%s/kernels/m%05d_a3.%s.kernel", profile_dir, (int) kern_type, device_name_chksum);
- }
- else
- {
- snprintf (cached_file, 255, "%s/kernels/m%05d.%s.kernel", profile_dir, (int) kern_type, device_name_chksum);
- }
-}
-
-static void generate_source_kernel_mp_filename (const uint opti_type, const uint opts_type, char *shared_dir, char *source_file)
-{
- if ((opti_type & OPTI_TYPE_BRUTE_FORCE) && (opts_type & OPTS_TYPE_PT_GENERATE_BE))
- {
- snprintf (source_file, 255, "%s/OpenCL/markov_be.cl", shared_dir);
- }
- else
- {
- snprintf (source_file, 255, "%s/OpenCL/markov_le.cl", shared_dir);
- }
-}
-
-static void generate_cached_kernel_mp_filename (const uint opti_type, const uint opts_type, char *profile_dir, const char *device_name_chksum, char *cached_file)
-{
- if ((opti_type & OPTI_TYPE_BRUTE_FORCE) && (opts_type & OPTS_TYPE_PT_GENERATE_BE))
- {
- snprintf (cached_file, 255, "%s/kernels/markov_be.%s.kernel", profile_dir, device_name_chksum);
- }
- else
- {
- snprintf (cached_file, 255, "%s/kernels/markov_le.%s.kernel", profile_dir, device_name_chksum);
- }
-}
-
-static void generate_source_kernel_amp_filename (const uint attack_kern, char *shared_dir, char *source_file)
-{
- snprintf (source_file, 255, "%s/OpenCL/amp_a%d.cl", shared_dir, attack_kern);
-}
-
-static void generate_cached_kernel_amp_filename (const uint attack_kern, char *profile_dir, const char *device_name_chksum, char *cached_file)
-{
- snprintf (cached_file, 255, "%s/kernels/amp_a%d.%s.kernel", profile_dir, attack_kern, device_name_chksum);
-}
-
-static uint convert_from_hex (char *line_buf, const uint line_len)
-{
- if (line_len & 1) return (line_len); // not in hex
-
- if (data.hex_wordlist == 1)
- {
- uint i;
- uint j;
-
- for (i = 0, j = 0; j < line_len; i += 1, j += 2)
- {
- line_buf[i] = hex_to_u8 ((const u8 *) &line_buf[j]);
- }
-
- memset (line_buf + i, 0, line_len - i);
-
- return (i);
- }
- else if (line_len >= 6) // $HEX[] = 6
- {
- if (line_buf[0] != '$') return (line_len);
- if (line_buf[1] != 'H') return (line_len);
- if (line_buf[2] != 'E') return (line_len);
- if (line_buf[3] != 'X') return (line_len);
- if (line_buf[4] != '[') return (line_len);
- if (line_buf[line_len - 1] != ']') return (line_len);
-
- uint i;
- uint j;
-
- for (i = 0, j = 5; j < line_len - 1; i += 1, j += 2)
- {
- line_buf[i] = hex_to_u8 ((const u8 *) &line_buf[j]);
- }
-
- memset (line_buf + i, 0, line_len - i);
-
- return (i);
- }
-
- return (line_len);
-}
-
-static void clear_prompt ()
-{
- fputc ('\r', stdout);
-
- for (size_t i = 0; i < strlen (PROMPT); i++)
- {
- fputc (' ', stdout);
- }
-
- fputc ('\r', stdout);
-
- fflush (stdout);
-}
-
-static void gidd_to_pw_t (hc_device_param_t *device_param, const u64 gidd, pw_t *pw)
-{
- hc_clEnqueueReadBuffer (data.ocl, device_param->command_queue, device_param->d_pws_buf, CL_TRUE, gidd * sizeof (pw_t), sizeof (pw_t), pw, 0, NULL, NULL);
-}
-
-static void check_hash (hc_device_param_t *device_param, const uint salt_pos, const uint digest_pos)
-{
- char *outfile = data.outfile;
- uint quiet = data.quiet;
- FILE *pot_fp = data.pot_fp;
- uint loopback = data.loopback;
- uint debug_mode = data.debug_mode;
- char *debug_file = data.debug_file;
-
- char debug_rule_buf[BLOCK_SIZE] = { 0 };
- int debug_rule_len = 0; // -1 error
- uint debug_plain_len = 0;
-
- u8 debug_plain_ptr[BLOCK_SIZE] = { 0 };
-
- // hash
-
- char out_buf[HCBUFSIZ] = { 0 };
-
- ascii_digest (out_buf, salt_pos, digest_pos);
-
- uint idx = data.salts_buf[salt_pos].digests_offset + digest_pos;
-
- // plain
-
- plain_t plain;
-
- hc_clEnqueueReadBuffer (data.ocl, device_param->command_queue, device_param->d_plain_bufs, CL_TRUE, idx * sizeof (plain_t), sizeof (plain_t), &plain, 0, NULL, NULL);
-
- uint gidvid = plain.gidvid;
- uint il_pos = plain.il_pos;
-
- u64 crackpos = device_param->words_off;
-
- uint plain_buf[16] = { 0 };
-
- u8 *plain_ptr = (u8 *) plain_buf;
- unsigned int plain_len = 0;
-
- if (data.attack_mode == ATTACK_MODE_STRAIGHT)
- {
- u64 gidd = gidvid;
- u64 gidm = 0;
-
- pw_t pw;
-
- gidd_to_pw_t (device_param, gidd, &pw);
-
- for (int i = 0, j = gidm; i < 16; i++, j++)
- {
- plain_buf[i] = pw.i[j];
- }
-
- plain_len = pw.pw_len;
-
- const uint off = device_param->innerloop_pos + il_pos;
-
- if (debug_mode > 0)
- {
- debug_rule_len = 0;
-
- // save rule
- if ((debug_mode == 1) || (debug_mode == 3) || (debug_mode == 4))
- {
- memset (debug_rule_buf, 0, sizeof (debug_rule_buf));
-
- debug_rule_len = kernel_rule_to_cpu_rule (debug_rule_buf, &data.kernel_rules_buf[off]);
- }
-
- // save plain
- if ((debug_mode == 2) || (debug_mode == 3) || (debug_mode == 4))
- {
- memset (debug_plain_ptr, 0, sizeof (debug_plain_ptr));
-
- memcpy (debug_plain_ptr, plain_ptr, plain_len);
-
- debug_plain_len = plain_len;
- }
- }
-
- plain_len = apply_rules (data.kernel_rules_buf[off].cmds, &plain_buf[0], &plain_buf[4], plain_len);
-
- crackpos += gidvid;
- crackpos *= data.kernel_rules_cnt;
- crackpos += device_param->innerloop_pos + il_pos;
-
- if (plain_len > data.pw_max) plain_len = data.pw_max;
- }
- else if (data.attack_mode == ATTACK_MODE_COMBI)
- {
- u64 gidd = gidvid;
- u64 gidm = 0;
-
- pw_t pw;
-
- gidd_to_pw_t (device_param, gidd, &pw);
-
- for (int i = 0, j = gidm; i < 16; i++, j++)
- {
- plain_buf[i] = pw.i[j];
- }
-
- plain_len = pw.pw_len;
-
- char *comb_buf = (char *) device_param->combs_buf[il_pos].i;
- uint comb_len = device_param->combs_buf[il_pos].pw_len;
-
- if (data.combs_mode == COMBINATOR_MODE_BASE_LEFT)
- {
- memcpy (plain_ptr + plain_len, comb_buf, comb_len);
- }
- else
- {
- memmove (plain_ptr + comb_len, plain_ptr, plain_len);
-
- memcpy (plain_ptr, comb_buf, comb_len);
- }
-
- plain_len += comb_len;
-
- crackpos += gidvid;
- crackpos *= data.combs_cnt;
- crackpos += device_param->innerloop_pos + il_pos;
-
- if (data.pw_max != PW_DICTMAX1)
- {
- if (plain_len > data.pw_max) plain_len = data.pw_max;
- }
- }
- else if (data.attack_mode == ATTACK_MODE_BF)
- {
- u64 l_off = device_param->kernel_params_mp_l_buf64[3] + gidvid;
- u64 r_off = device_param->kernel_params_mp_r_buf64[3] + il_pos;
-
- uint l_start = device_param->kernel_params_mp_l_buf32[5];
- uint r_start = device_param->kernel_params_mp_r_buf32[5];
-
- uint l_stop = device_param->kernel_params_mp_l_buf32[4];
- uint r_stop = device_param->kernel_params_mp_r_buf32[4];
-
- sp_exec (l_off, (char *) plain_ptr + l_start, data.root_css_buf, data.markov_css_buf, l_start, l_start + l_stop);
- sp_exec (r_off, (char *) plain_ptr + r_start, data.root_css_buf, data.markov_css_buf, r_start, r_start + r_stop);
-
- plain_len = data.css_cnt;
-
- crackpos += gidvid;
- crackpos *= data.bfs_cnt;
- crackpos += device_param->innerloop_pos + il_pos;
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID1)
- {
- u64 gidd = gidvid;
- u64 gidm = 0;
-
- pw_t pw;
-
- gidd_to_pw_t (device_param, gidd, &pw);
-
- for (int i = 0, j = gidm; i < 16; i++, j++)
- {
- plain_buf[i] = pw.i[j];
- }
-
- plain_len = pw.pw_len;
-
- u64 off = device_param->kernel_params_mp_buf64[3] + il_pos;
-
- uint start = 0;
- uint stop = device_param->kernel_params_mp_buf32[4];
-
- sp_exec (off, (char *) plain_ptr + plain_len, data.root_css_buf, data.markov_css_buf, start, start + stop);
-
- plain_len += start + stop;
-
- crackpos += gidvid;
- crackpos *= data.combs_cnt;
- crackpos += device_param->innerloop_pos + il_pos;
-
- if (data.pw_max != PW_DICTMAX1)
- {
- if (plain_len > data.pw_max) plain_len = data.pw_max;
- }
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID2)
- {
- u64 gidd = gidvid;
- u64 gidm = 0;
-
- pw_t pw;
-
- gidd_to_pw_t (device_param, gidd, &pw);
-
- for (int i = 0, j = gidm; i < 16; i++, j++)
- {
- plain_buf[i] = pw.i[j];
- }
-
- plain_len = pw.pw_len;
-
- u64 off = device_param->kernel_params_mp_buf64[3] + il_pos;
-
- uint start = 0;
- uint stop = device_param->kernel_params_mp_buf32[4];
-
- memmove (plain_ptr + stop, plain_ptr, plain_len);
-
- sp_exec (off, (char *) plain_ptr, data.root_css_buf, data.markov_css_buf, start, start + stop);
-
- plain_len += start + stop;
-
- crackpos += gidvid;
- crackpos *= data.combs_cnt;
- crackpos += device_param->innerloop_pos + il_pos;
-
- if (data.pw_max != PW_DICTMAX1)
- {
- if (plain_len > data.pw_max) plain_len = data.pw_max;
- }
- }
-
- if (data.attack_mode == ATTACK_MODE_BF)
- {
- if (data.opti_type & OPTI_TYPE_BRUTE_FORCE) // lots of optimizations can happen here
- {
- if (data.opti_type & OPTI_TYPE_SINGLE_HASH)
- {
- if (data.opti_type & OPTI_TYPE_APPENDED_SALT)
- {
- plain_len = plain_len - data.salts_buf[0].salt_len;
- }
- }
-
- if (data.opts_type & OPTS_TYPE_PT_UNICODE)
- {
- for (uint i = 0, j = 0; i < plain_len; i += 2, j += 1)
- {
- plain_ptr[j] = plain_ptr[i];
- }
-
- plain_len = plain_len / 2;
- }
- }
- }
-
- // if enabled, update also the potfile
-
- if (pot_fp)
- {
- lock_file (pot_fp);
-
- fprintf (pot_fp, "%s:", out_buf);
-
- format_plain (pot_fp, plain_ptr, plain_len, 1);
-
- fputc ('\n', pot_fp);
-
- fflush (pot_fp);
-
- unlock_file (pot_fp);
- }
-
- // outfile
-
- FILE *out_fp = NULL;
-
- if (outfile != NULL)
- {
- if ((out_fp = fopen (outfile, "ab")) == NULL)
- {
- log_error ("ERROR: %s: %s", outfile, strerror (errno));
-
- out_fp = stdout;
- }
- lock_file (out_fp);
- }
- else
- {
- out_fp = stdout;
-
- if (quiet == 0) clear_prompt ();
- }
-
- format_output (out_fp, out_buf, plain_ptr, plain_len, crackpos, NULL, 0);
-
- if (outfile != NULL)
- {
- if (out_fp != stdout)
- {
- fclose (out_fp);
- }
- }
- else
- {
- if ((data.wordlist_mode == WL_MODE_FILE) || (data.wordlist_mode == WL_MODE_MASK))
- {
- if ((data.devices_status != STATUS_CRACKED) && (data.status != 1))
- {
- if (quiet == 0) fprintf (stdout, "%s", PROMPT);
- if (quiet == 0) fflush (stdout);
- }
- }
- }
-
- // loopback
-
- if (loopback)
- {
- char *loopback_file = data.loopback_file;
-
- FILE *fb_fp = NULL;
-
- if ((fb_fp = fopen (loopback_file, "ab")) != NULL)
- {
- lock_file (fb_fp);
-
- format_plain (fb_fp, plain_ptr, plain_len, 1);
-
- fputc ('\n', fb_fp);
-
- fclose (fb_fp);
- }
- }
-
- // (rule) debug mode
-
- // the next check implies that:
- // - (data.attack_mode == ATTACK_MODE_STRAIGHT)
- // - debug_mode > 0
-
- if ((debug_plain_len > 0) || (debug_rule_len > 0))
- {
- if (debug_rule_len < 0) debug_rule_len = 0;
-
- if ((quiet == 0) && (debug_file == NULL)) clear_prompt ();
-
- format_debug (debug_file, debug_mode, debug_plain_ptr, debug_plain_len, plain_ptr, plain_len, debug_rule_buf, debug_rule_len);
-
- if ((quiet == 0) && (debug_file == NULL))
- {
- fprintf (stdout, "%s", PROMPT);
- fflush (stdout);
- }
- }
-}
-
-static void check_cracked (hc_device_param_t *device_param, const uint salt_pos)
-{
- salt_t *salt_buf = &data.salts_buf[salt_pos];
-
- int found = 0;
-
- hc_clEnqueueReadBuffer (data.ocl, device_param->command_queue, device_param->d_result, CL_TRUE, 0, device_param->size_results, device_param->result, 0, NULL, NULL);
-
- for (uint i = 0; i < device_param->kernel_threads; i++) if (device_param->result[i] == 1) found = 1;
-
- if (found == 1)
- {
- // display hack (for weak hashes etc, it could be that there is still something to clear on the current line)
-
- log_info_nn ("");
-
- hc_clEnqueueReadBuffer (data.ocl, device_param->command_queue, device_param->d_digests_shown, CL_TRUE, salt_buf->digests_offset * sizeof (uint), salt_buf->digests_cnt * sizeof (uint), &data.digests_shown_tmp[salt_buf->digests_offset], 0, NULL, NULL);
-
- uint cpt_cracked = 0;
-
- for (uint digest_pos = 0; digest_pos < salt_buf->digests_cnt; digest_pos++)
- {
- uint idx = salt_buf->digests_offset + digest_pos;
-
- if (data.digests_shown_tmp[idx] == 0) continue;
-
- if (data.digests_shown[idx] == 1) continue;
-
- if ((data.opts_type & OPTS_TYPE_PT_NEVERCRACK) == 0)
- {
- data.digests_shown[idx] = 1;
-
- data.digests_done++;
-
- cpt_cracked++;
-
- salt_buf->digests_done++;
-
- if (salt_buf->digests_done == salt_buf->digests_cnt)
- {
- data.salts_shown[salt_pos] = 1;
-
- data.salts_done++;
- }
- }
-
- if (data.salts_done == data.salts_cnt) data.devices_status = STATUS_CRACKED;
-
- check_hash (device_param, salt_pos, digest_pos);
- }
-
- if (cpt_cracked > 0)
- {
- data.cpt_buf[data.cpt_pos].timestamp = time (NULL);
- data.cpt_buf[data.cpt_pos].cracked = cpt_cracked;
-
- data.cpt_pos++;
-
- data.cpt_total += cpt_cracked;
-
- if (data.cpt_pos == CPT_BUF) data.cpt_pos = 0;
- }
-
- if (data.opts_type & OPTS_TYPE_PT_NEVERCRACK)
- {
- // we need to reset cracked state on the device
- // otherwise host thinks again and again the hash was cracked
- // and returns invalid password each time
-
- memset (data.digests_shown_tmp, 0, salt_buf->digests_cnt * sizeof (uint));
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_digests_shown, CL_TRUE, salt_buf->digests_offset * sizeof (uint), salt_buf->digests_cnt * sizeof (uint), &data.digests_shown_tmp[salt_buf->digests_offset], 0, NULL, NULL);
- }
-
- memset (device_param->result, 0, device_param->size_results);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_result, CL_TRUE, 0, device_param->size_results, device_param->result, 0, NULL, NULL);
- }
-}
-
-static void save_hash ()
-{
- char *hashfile = data.hashfile;
-
- char new_hashfile[256] = { 0 };
- char old_hashfile[256] = { 0 };
-
- snprintf (new_hashfile, 255, "%s.new", hashfile);
- snprintf (old_hashfile, 255, "%s.old", hashfile);
-
- unlink (new_hashfile);
-
- char separator = data.separator;
-
- FILE *fp = fopen (new_hashfile, "wb");
-
- if (fp == NULL)
- {
- log_error ("ERROR: %s: %s", new_hashfile, strerror (errno));
-
- exit (-1);
- }
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- if (data.salts_shown[salt_pos] == 1) continue;
-
- salt_t *salt_buf = &data.salts_buf[salt_pos];
-
- for (uint digest_pos = 0; digest_pos < salt_buf->digests_cnt; digest_pos++)
- {
- uint idx = salt_buf->digests_offset + digest_pos;
-
- if (data.digests_shown[idx] == 1) continue;
-
- if (data.hash_mode != 2500)
- {
- char out_buf[HCBUFSIZ] = { 0 };
-
- if (data.username == 1)
- {
- user_t *user = data.hash_info[idx]->user;
-
- uint i;
-
- for (i = 0; i < user->user_len; i++) fputc (user->user_name[i], fp);
-
- fputc (separator, fp);
- }
-
- ascii_digest (out_buf, salt_pos, digest_pos);
-
- fputs (out_buf, fp);
-
- log_out (fp, "");
- }
- else
- {
- hccap_t hccap;
-
- to_hccap_t (&hccap, salt_pos, digest_pos);
-
- fwrite (&hccap, sizeof (hccap_t), 1, fp);
- }
- }
- }
-
- fflush (fp);
-
- fclose (fp);
-
- unlink (old_hashfile);
-
- if (rename (hashfile, old_hashfile) != 0)
- {
- log_error ("ERROR: Rename file '%s' to '%s': %s", hashfile, old_hashfile, strerror (errno));
-
- exit (-1);
- }
-
- unlink (hashfile);
-
- if (rename (new_hashfile, hashfile) != 0)
- {
- log_error ("ERROR: Rename file '%s' to '%s': %s", new_hashfile, hashfile, strerror (errno));
-
- exit (-1);
- }
-
- unlink (old_hashfile);
-}
-
-static float find_kernel_power_div (const u64 total_left, const uint kernel_power_all)
-{
- // function called only in case kernel_power_all > words_left
-
- float kernel_power_div = (float) (total_left) / kernel_power_all;
-
- kernel_power_div += kernel_power_div / 100;
-
- u32 kernel_power_new = (u32) (kernel_power_all * kernel_power_div);
-
- while (kernel_power_new < total_left)
- {
- kernel_power_div += kernel_power_div / 100;
-
- kernel_power_new = (u32) (kernel_power_all * kernel_power_div);
- }
-
- if (data.quiet == 0)
- {
- clear_prompt ();
-
- log_info ("");
-
- log_info ("INFO: approaching final keyspace, workload adjusted");
-
- log_info ("");
-
- fprintf (stdout, "%s", PROMPT);
-
- fflush (stdout);
- }
-
- if ((kernel_power_all * kernel_power_div) < 8) return 1;
-
- return kernel_power_div;
-}
-
-static void run_kernel (const uint kern_run, hc_device_param_t *device_param, const uint num, const uint event_update)
-{
- uint num_elements = num;
-
- device_param->kernel_params_buf32[30] = data.combs_mode;
- device_param->kernel_params_buf32[31] = num;
-
- uint kernel_threads = device_param->kernel_threads;
-
- while (num_elements % kernel_threads) num_elements++;
-
- cl_kernel kernel = NULL;
-
- switch (kern_run)
- {
- case KERN_RUN_1: kernel = device_param->kernel1; break;
- case KERN_RUN_12: kernel = device_param->kernel12; break;
- case KERN_RUN_2: kernel = device_param->kernel2; break;
- case KERN_RUN_23: kernel = device_param->kernel23; break;
- case KERN_RUN_3: kernel = device_param->kernel3; break;
- }
-
- hc_clSetKernelArg (data.ocl, kernel, 21, sizeof (cl_uint), device_param->kernel_params[21]);
- hc_clSetKernelArg (data.ocl, kernel, 22, sizeof (cl_uint), device_param->kernel_params[22]);
- hc_clSetKernelArg (data.ocl, kernel, 23, sizeof (cl_uint), device_param->kernel_params[23]);
- hc_clSetKernelArg (data.ocl, kernel, 24, sizeof (cl_uint), device_param->kernel_params[24]);
- hc_clSetKernelArg (data.ocl, kernel, 25, sizeof (cl_uint), device_param->kernel_params[25]);
- hc_clSetKernelArg (data.ocl, kernel, 26, sizeof (cl_uint), device_param->kernel_params[26]);
- hc_clSetKernelArg (data.ocl, kernel, 27, sizeof (cl_uint), device_param->kernel_params[27]);
- hc_clSetKernelArg (data.ocl, kernel, 28, sizeof (cl_uint), device_param->kernel_params[28]);
- hc_clSetKernelArg (data.ocl, kernel, 29, sizeof (cl_uint), device_param->kernel_params[29]);
- hc_clSetKernelArg (data.ocl, kernel, 30, sizeof (cl_uint), device_param->kernel_params[30]);
- hc_clSetKernelArg (data.ocl, kernel, 31, sizeof (cl_uint), device_param->kernel_params[31]);
-
- hc_timer_t timer;
-
- hc_timer_set (&timer);
-
- if ((data.opts_type & OPTS_TYPE_PT_BITSLICE) && (data.attack_mode == ATTACK_MODE_BF))
- {
- const size_t global_work_size[3] = { num_elements, 32, 1 };
- const size_t local_work_size[3] = { kernel_threads / 32, 32, 1 };
-
- hc_clEnqueueNDRangeKernel (data.ocl, device_param->command_queue, kernel, 2, NULL, global_work_size, local_work_size, 0, NULL, NULL);
- }
- else
- {
- size_t workgroup_size = 0;
-
- hc_clGetKernelWorkGroupInfo (data.ocl, kernel, device_param->device, CL_KERNEL_WORK_GROUP_SIZE, sizeof (size_t), &workgroup_size, NULL);
-
- if (kern_run == KERN_RUN_2)
- {
- if (data.opti_type & OPTI_TYPE_SLOW_HASH_SIMD)
- {
- num_elements = CEIL ((float) num_elements / device_param->vector_width);
- }
- }
-
- if (kernel_threads > workgroup_size) kernel_threads = workgroup_size;
-
- while (num_elements % kernel_threads) num_elements++;
-
- const size_t global_work_size[3] = { num_elements, 1, 1 };
- const size_t local_work_size[3] = { kernel_threads, 1, 1 };
-
- hc_clEnqueueNDRangeKernel (data.ocl, device_param->command_queue, kernel, 1, NULL, global_work_size, local_work_size, 0, NULL, NULL);
- }
-
- hc_clFlush (data.ocl, device_param->command_queue);
-
- hc_clFinish (data.ocl, device_param->command_queue);
-
- if (event_update)
- {
- double exec_time;
-
- hc_timer_get (timer, exec_time);
-
- uint exec_pos = device_param->exec_pos;
-
- device_param->exec_ms[exec_pos] = exec_time;
-
- exec_pos++;
-
- if (exec_pos == EXEC_CACHE)
- {
- exec_pos = 0;
- }
-
- device_param->exec_pos = exec_pos;
- }
-}
-
-static void run_kernel_mp (const uint kern_run, hc_device_param_t *device_param, const uint num)
-{
- uint num_elements = num;
-
- switch (kern_run)
- {
- case KERN_RUN_MP: device_param->kernel_params_mp_buf32[8] = num; break;
- case KERN_RUN_MP_R: device_param->kernel_params_mp_r_buf32[8] = num; break;
- case KERN_RUN_MP_L: device_param->kernel_params_mp_l_buf32[9] = num; break;
- }
-
- // causes problems with special threads like in bcrypt
- // const uint kernel_threads = device_param->kernel_threads;
-
- uint kernel_threads = device_param->kernel_threads;
-
- while (num_elements % kernel_threads) num_elements++;
-
- cl_kernel kernel = NULL;
-
- switch (kern_run)
- {
- case KERN_RUN_MP: kernel = device_param->kernel_mp; break;
- case KERN_RUN_MP_R: kernel = device_param->kernel_mp_r; break;
- case KERN_RUN_MP_L: kernel = device_param->kernel_mp_l; break;
- }
-
- switch (kern_run)
- {
- case KERN_RUN_MP: hc_clSetKernelArg (data.ocl, kernel, 3, sizeof (cl_ulong), device_param->kernel_params_mp[3]);
- hc_clSetKernelArg (data.ocl, kernel, 4, sizeof (cl_uint), device_param->kernel_params_mp[4]);
- hc_clSetKernelArg (data.ocl, kernel, 5, sizeof (cl_uint), device_param->kernel_params_mp[5]);
- hc_clSetKernelArg (data.ocl, kernel, 6, sizeof (cl_uint), device_param->kernel_params_mp[6]);
- hc_clSetKernelArg (data.ocl, kernel, 7, sizeof (cl_uint), device_param->kernel_params_mp[7]);
- hc_clSetKernelArg (data.ocl, kernel, 8, sizeof (cl_uint), device_param->kernel_params_mp[8]);
- break;
- case KERN_RUN_MP_R: hc_clSetKernelArg (data.ocl, kernel, 3, sizeof (cl_ulong), device_param->kernel_params_mp_r[3]);
- hc_clSetKernelArg (data.ocl, kernel, 4, sizeof (cl_uint), device_param->kernel_params_mp_r[4]);
- hc_clSetKernelArg (data.ocl, kernel, 5, sizeof (cl_uint), device_param->kernel_params_mp_r[5]);
- hc_clSetKernelArg (data.ocl, kernel, 6, sizeof (cl_uint), device_param->kernel_params_mp_r[6]);
- hc_clSetKernelArg (data.ocl, kernel, 7, sizeof (cl_uint), device_param->kernel_params_mp_r[7]);
- hc_clSetKernelArg (data.ocl, kernel, 8, sizeof (cl_uint), device_param->kernel_params_mp_r[8]);
- break;
- case KERN_RUN_MP_L: hc_clSetKernelArg (data.ocl, kernel, 3, sizeof (cl_ulong), device_param->kernel_params_mp_l[3]);
- hc_clSetKernelArg (data.ocl, kernel, 4, sizeof (cl_uint), device_param->kernel_params_mp_l[4]);
- hc_clSetKernelArg (data.ocl, kernel, 5, sizeof (cl_uint), device_param->kernel_params_mp_l[5]);
- hc_clSetKernelArg (data.ocl, kernel, 6, sizeof (cl_uint), device_param->kernel_params_mp_l[6]);
- hc_clSetKernelArg (data.ocl, kernel, 7, sizeof (cl_uint), device_param->kernel_params_mp_l[7]);
- hc_clSetKernelArg (data.ocl, kernel, 8, sizeof (cl_uint), device_param->kernel_params_mp_l[8]);
- hc_clSetKernelArg (data.ocl, kernel, 9, sizeof (cl_uint), device_param->kernel_params_mp_l[9]);
- break;
- }
-
- size_t workgroup_size = 0;
-
- hc_clGetKernelWorkGroupInfo (data.ocl, kernel, device_param->device, CL_KERNEL_WORK_GROUP_SIZE, sizeof(size_t), &workgroup_size, NULL);
-
- if (kernel_threads > workgroup_size) kernel_threads = workgroup_size;
-
- const size_t global_work_size[3] = { num_elements, 1, 1 };
- const size_t local_work_size[3] = { kernel_threads, 1, 1 };
-
- hc_clEnqueueNDRangeKernel (data.ocl, device_param->command_queue, kernel, 1, NULL, global_work_size, local_work_size, 0, NULL, NULL);
-
- hc_clFlush (data.ocl, device_param->command_queue);
-
- hc_clFinish (data.ocl, device_param->command_queue);
-}
-
-static void run_kernel_tm (hc_device_param_t *device_param)
-{
- const uint num_elements = 1024; // fixed
-
- uint kernel_threads = 32;
-
- cl_kernel kernel = device_param->kernel_tm;
-
- size_t workgroup_size = 0;
-
- hc_clGetKernelWorkGroupInfo (data.ocl, kernel, device_param->device, CL_KERNEL_WORK_GROUP_SIZE, sizeof (size_t), &workgroup_size, NULL);
-
- if (kernel_threads > workgroup_size) kernel_threads = workgroup_size;
-
- const size_t global_work_size[3] = { num_elements, 1, 1 };
- const size_t local_work_size[3] = { kernel_threads, 1, 1 };
-
- hc_clEnqueueNDRangeKernel (data.ocl, device_param->command_queue, kernel, 1, NULL, global_work_size, local_work_size, 0, NULL, NULL);
-
- hc_clFlush (data.ocl, device_param->command_queue);
-
- hc_clFinish (data.ocl, device_param->command_queue);
-}
-
-static void run_kernel_amp (hc_device_param_t *device_param, const uint num)
-{
- uint num_elements = num;
-
- device_param->kernel_params_amp_buf32[5] = data.combs_mode;
- device_param->kernel_params_amp_buf32[6] = num_elements;
-
- // causes problems with special threads like in bcrypt
- // const uint kernel_threads = device_param->kernel_threads;
-
- uint kernel_threads = device_param->kernel_threads;
-
- while (num_elements % kernel_threads) num_elements++;
-
- cl_kernel kernel = device_param->kernel_amp;
-
- hc_clSetKernelArg (data.ocl, kernel, 5, sizeof (cl_uint), device_param->kernel_params_amp[5]);
- hc_clSetKernelArg (data.ocl, kernel, 6, sizeof (cl_uint), device_param->kernel_params_amp[6]);
-
- size_t workgroup_size = 0;
-
- hc_clGetKernelWorkGroupInfo (data.ocl, kernel, device_param->device, CL_KERNEL_WORK_GROUP_SIZE, sizeof (size_t), &workgroup_size, NULL);
-
- if (kernel_threads > workgroup_size) kernel_threads = workgroup_size;
-
- const size_t global_work_size[3] = { num_elements, 1, 1 };
- const size_t local_work_size[3] = { kernel_threads, 1, 1 };
-
- hc_clEnqueueNDRangeKernel (data.ocl, device_param->command_queue, kernel, 1, NULL, global_work_size, local_work_size, 0, NULL, NULL);
-
- hc_clFlush (data.ocl, device_param->command_queue);
-
- hc_clFinish (data.ocl, device_param->command_queue);
-}
-
-static void run_kernel_bzero (hc_device_param_t *device_param, cl_mem buf, const size_t size)
-{
- int rc = -1;
-
- if (device_param->opencl_v12 && device_param->vendor_id == VENDOR_ID_AMD)
- {
- // So far tested, amd is the only supporting this OpenCL 1.2 function without segfaulting
-
- const cl_uchar zero = 0;
-
- rc = hc_clEnqueueFillBuffer (data.ocl, device_param->command_queue, buf, &zero, sizeof (cl_uchar), 0, size, 0, NULL, NULL);
- }
-
- if (rc != 0)
- {
- // NOTE: clEnqueueFillBuffer () always fails with -59
- // IOW, it's not supported by Nvidia drivers <= 352.21, also pocl segfaults, also on apple
- // How's that possible, OpenCL 1.2 support is advertised??
- // We need to workaround...
-
- #define FILLSZ 0x100000
-
- char *tmp = (char *) mymalloc (FILLSZ);
-
- for (size_t i = 0; i < size; i += FILLSZ)
- {
- const size_t left = size - i;
-
- const size_t fillsz = MIN (FILLSZ, left);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, buf, CL_TRUE, i, fillsz, tmp, 0, NULL, NULL);
- }
-
- myfree (tmp);
- }
-}
-
-static void choose_kernel (hc_device_param_t *device_param, const uint attack_exec, const uint attack_mode, const uint opts_type, const salt_t *salt_buf, const uint highest_pw_len, const uint pws_cnt)
-{
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- if (attack_mode == ATTACK_MODE_BF)
- {
- if (opts_type & OPTS_TYPE_PT_BITSLICE)
- {
- const uint size_tm = 32 * sizeof (bs_word_t);
-
- run_kernel_bzero (device_param, device_param->d_tm_c, size_tm);
-
- run_kernel_tm (device_param);
-
- hc_clEnqueueCopyBuffer (data.ocl, device_param->command_queue, device_param->d_tm_c, device_param->d_bfs_c, 0, 0, size_tm, 0, NULL, NULL);
- }
- }
-
- if (highest_pw_len < 16)
- {
- run_kernel (KERN_RUN_1, device_param, pws_cnt, true);
- }
- else if (highest_pw_len < 32)
- {
- run_kernel (KERN_RUN_2, device_param, pws_cnt, true);
- }
- else
- {
- run_kernel (KERN_RUN_3, device_param, pws_cnt, true);
- }
- }
- else
- {
- run_kernel_amp (device_param, pws_cnt);
-
- run_kernel (KERN_RUN_1, device_param, pws_cnt, false);
-
- if (opts_type & OPTS_TYPE_HOOK12)
- {
- run_kernel (KERN_RUN_12, device_param, pws_cnt, false);
- }
-
- uint iter = salt_buf->salt_iter;
-
- uint loop_step = device_param->kernel_loops;
-
- for (uint loop_pos = 0; loop_pos < iter; loop_pos += loop_step)
- {
- uint loop_left = iter - loop_pos;
-
- loop_left = MIN (loop_left, loop_step);
-
- device_param->kernel_params_buf32[25] = loop_pos;
- device_param->kernel_params_buf32[26] = loop_left;
-
- run_kernel (KERN_RUN_2, device_param, pws_cnt, true);
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
-
- /**
- * speed
- */
-
- const float iter_part = (float) (loop_pos + loop_left) / iter;
-
- const u64 perf_sum_all = pws_cnt * iter_part;
-
- double speed_ms;
-
- hc_timer_get (device_param->timer_speed, speed_ms);
-
- const u32 speed_pos = device_param->speed_pos;
-
- device_param->speed_cnt[speed_pos] = perf_sum_all;
-
- device_param->speed_ms[speed_pos] = speed_ms;
-
- if (data.benchmark == 1)
- {
- if (speed_ms > 4096) data.devices_status = STATUS_ABORTED;
- }
- }
-
- if (opts_type & OPTS_TYPE_HOOK23)
- {
- run_kernel (KERN_RUN_23, device_param, pws_cnt, false);
-
- hc_clEnqueueReadBuffer (data.ocl, device_param->command_queue, device_param->d_hooks, CL_TRUE, 0, device_param->size_hooks, device_param->hooks_buf, 0, NULL, NULL);
-
- // do something with data
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_hooks, CL_TRUE, 0, device_param->size_hooks, device_param->hooks_buf, 0, NULL, NULL);
- }
-
- run_kernel (KERN_RUN_3, device_param, pws_cnt, false);
- }
-}
-
-static int run_rule_engine (const int rule_len, const char *rule_buf)
-{
- if (rule_len == 0)
- {
- return 0;
- }
- else if (rule_len == 1)
- {
- if (rule_buf[0] == RULE_OP_MANGLE_NOOP) return 0;
- }
-
- return 1;
-}
-
-static void run_copy (hc_device_param_t *device_param, const uint pws_cnt)
-{
- if (data.attack_kern == ATTACK_KERN_STRAIGHT)
- {
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_pws_buf, CL_TRUE, 0, pws_cnt * sizeof (pw_t), device_param->pws_buf, 0, NULL, NULL);
- }
- else if (data.attack_kern == ATTACK_KERN_COMBI)
- {
- if (data.attack_mode == ATTACK_MODE_HYBRID2)
- {
- if (data.opts_type & OPTS_TYPE_PT_ADD01)
- {
- for (u32 i = 0; i < pws_cnt; i++)
- {
- const u32 pw_len = device_param->pws_buf[i].pw_len;
-
- u8 *ptr = (u8 *) device_param->pws_buf[i].i;
-
- ptr[pw_len] = 0x01;
- }
- }
- else if (data.opts_type & OPTS_TYPE_PT_ADD80)
- {
- for (u32 i = 0; i < pws_cnt; i++)
- {
- const u32 pw_len = device_param->pws_buf[i].pw_len;
-
- u8 *ptr = (u8 *) device_param->pws_buf[i].i;
-
- ptr[pw_len] = 0x80;
- }
- }
- }
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_pws_buf, CL_TRUE, 0, pws_cnt * sizeof (pw_t), device_param->pws_buf, 0, NULL, NULL);
- }
- else if (data.attack_kern == ATTACK_KERN_BF)
- {
- const u64 off = device_param->words_off;
-
- device_param->kernel_params_mp_l_buf64[3] = off;
-
- run_kernel_mp (KERN_RUN_MP_L, device_param, pws_cnt);
- }
-}
-
-static double try_run (hc_device_param_t *device_param, const u32 kernel_accel, const u32 kernel_loops)
-{
- const u32 kernel_power = device_param->device_processors * device_param->kernel_threads * kernel_accel;
-
- device_param->kernel_params_buf32[25] = 0;
- device_param->kernel_params_buf32[26] = kernel_loops; // not a bug, both need to be set
- device_param->kernel_params_buf32[27] = kernel_loops; // because there's two variables for inner iters for slow and fast hashes
-
- // init some fake words
-
- if (data.hash_mode == 10700)
- {
- // hash mode 10700 hangs on length 0 (unlimited loop)
-
- for (u32 i = 0; i < kernel_power; i++)
- {
- device_param->pws_buf[i].i[0] = i;
- device_param->pws_buf[i].i[1] = i + 0x01234567;
- device_param->pws_buf[i].i[2] = i + 0x89abcdef;
- device_param->pws_buf[i].i[3] = 0xffffffff;
- device_param->pws_buf[i].pw_len = 4 + (i & 3);
- }
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_pws_buf, CL_TRUE, 0, kernel_power * sizeof (pw_t), device_param->pws_buf, 0, NULL, NULL);
-
- if (data.attack_exec == ATTACK_EXEC_OUTSIDE_KERNEL)
- {
- run_kernel_amp (device_param, kernel_power);
- }
- }
-
- if (data.attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- run_kernel (KERN_RUN_1, device_param, kernel_power, true);
- }
- else
- {
- run_kernel (KERN_RUN_2, device_param, kernel_power, true);
- }
-
- const double exec_ms_prev = get_avg_exec_time (device_param, 1);
-
- // reset fake words
-
- if (data.hash_mode == 10700)
- {
- memset (device_param->pws_buf, 0, kernel_power * sizeof (pw_t));
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_pws_buf, CL_TRUE, 0, kernel_power * sizeof (pw_t), device_param->pws_buf, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_pws_amp_buf, CL_TRUE, 0, kernel_power * sizeof (pw_t), device_param->pws_buf, 0, NULL, NULL);
- }
-
- return exec_ms_prev;
-}
-
-static void autotune (hc_device_param_t *device_param)
-{
- const double target_ms = TARGET_MS_PROFILE[data.workload_profile - 1];
-
- const u32 kernel_accel_min = device_param->kernel_accel_min;
- const u32 kernel_accel_max = device_param->kernel_accel_max;
-
- const u32 kernel_loops_min = device_param->kernel_loops_min;
- const u32 kernel_loops_max = device_param->kernel_loops_max;
-
- u32 kernel_accel = kernel_accel_min;
- u32 kernel_loops = kernel_loops_min;
-
- #define STEPS_CNT 10
-
- #define MAX_RETRIES 1
-
- if ((kernel_loops_min == kernel_loops_max) || (kernel_accel_min == kernel_accel_max))
- {
- // we do this in case the user specified a fixed -u and -n on the commandline
- // so we have a cached kernel for benchmark
-
- try_run (device_param, kernel_accel, kernel_loops);
- try_run (device_param, kernel_accel, kernel_loops);
- try_run (device_param, kernel_accel, kernel_loops);
- try_run (device_param, kernel_accel, kernel_loops);
- try_run (device_param, kernel_accel, kernel_loops);
- }
-
- double exec_ms_final = try_run (device_param, kernel_accel, kernel_loops);
-
- // first find out highest kernel-loops that stays below target_ms
-
- for (kernel_loops = kernel_loops_max; kernel_loops > kernel_loops_min; kernel_loops >>= 1)
- {
- double exec_ms_best = try_run (device_param, kernel_accel_min, kernel_loops);
-
- for (int i = 0; i < MAX_RETRIES; i++)
- {
- const double exec_ms_cur = try_run (device_param, kernel_accel_min, kernel_loops);
-
- exec_ms_best = MIN (exec_ms_best, exec_ms_cur);
- }
-
- if (exec_ms_best < target_ms) break;
- }
-
- // now the same for kernel-accel but with the new kernel-loops from previous loop set
-
- if (kernel_accel_min < kernel_accel_max)
- {
- for (int i = 0; i < STEPS_CNT; i++)
- {
- const u32 kernel_accel_try = 1 << i;
-
- if (kernel_accel_try < kernel_accel_min) continue;
- if (kernel_accel_try > kernel_accel_max) break;
-
- double exec_ms_best = try_run (device_param, kernel_accel_try, kernel_loops);
-
- for (int i = 0; i < MAX_RETRIES; i++)
- {
- const double exec_ms_cur = try_run (device_param, kernel_accel_try, kernel_loops);
-
- exec_ms_best = MIN (exec_ms_best, exec_ms_cur);
- }
-
- if (exec_ms_best > target_ms) break;
-
- exec_ms_final = exec_ms_best;
-
- kernel_accel = kernel_accel_try;
- }
- }
-
- // there's a chance that we have a fixed kernel_loops but not a fixed kernel_accel
- // in such a case the above function would not create any change
- // we'll use the runtime to find out if we're allow to do last improvement
-
- if (exec_ms_final > 0)
- {
- if ((exec_ms_final * 2) <= target_ms)
- {
- const double exec_left = target_ms / exec_ms_final;
-
- const double accel_left = kernel_accel_max / kernel_accel;
-
- const int exec_accel_min = MIN (exec_left, accel_left); // we want that to be int
-
- if (exec_accel_min >= 2)
- {
- kernel_accel *= exec_accel_min;
- }
- }
- }
-
- // sometimes we're in a bad situation that the algorithm is so slow that we can not
- // create enough kernel_accel to do both, keep the gpu busy and stay below target_ms.
- // however, we need to have a minimum kernel_accel and kernel_loops of 32.
- // luckily, at this level of workload, it became a linear function
-
- if (kernel_accel < 32 || kernel_loops < 32)
- {
- const u32 kernel_power = kernel_accel * kernel_loops;
-
- // find sqrt
-
- u32 sqrtv;
-
- for (sqrtv = 1; sqrtv < 0x100000; sqrtv++)
- {
- if ((sqrtv * sqrtv) >= kernel_power) break;
- }
-
- const u32 kernel_accel_try = sqrtv;
- const u32 kernel_loops_try = sqrtv;
-
- if ((kernel_accel_try <= kernel_accel_max) && (kernel_loops_try >= kernel_loops_min))
- {
- kernel_accel = kernel_accel_try;
- kernel_loops = kernel_loops_try;
- }
- }
-
- // reset timer
-
- device_param->exec_pos = 0;
-
- memset (device_param->exec_ms, 0, EXEC_CACHE * sizeof (double));
-
- // store
-
- device_param->kernel_accel = kernel_accel;
- device_param->kernel_loops = kernel_loops;
-
- const u32 kernel_power = device_param->device_processors * device_param->kernel_threads * device_param->kernel_accel;
-
- device_param->kernel_power = kernel_power;
-
- #ifdef DEBUG
-
- if (data.quiet == 0)
- {
- clear_prompt ();
-
- log_info ("Device #%u: autotuned kernel-accel to %u\n"
- "Device #%u: autotuned kernel-loops to %u\n",
- device_param->device_id + 1, kernel_accel,
- device_param->device_id + 1, kernel_loops);
-
- fprintf (stdout, "%s", PROMPT);
-
- fflush (stdout);
- }
-
- #endif
-}
-
-static void run_cracker (hc_device_param_t *device_param, const uint pws_cnt)
-{
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- // init speed timer
-
- uint speed_pos = device_param->speed_pos;
-
- #ifdef _POSIX
- if (device_param->timer_speed.tv_sec == 0)
- {
- hc_timer_set (&device_param->timer_speed);
- }
- #endif
-
- #ifdef _WIN
- if (device_param->timer_speed.QuadPart == 0)
- {
- hc_timer_set (&device_param->timer_speed);
- }
- #endif
-
- // find higest password length, this is for optimization stuff
-
- uint highest_pw_len = 0;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT)
- {
- }
- else if (data.attack_kern == ATTACK_KERN_COMBI)
- {
- }
- else if (data.attack_kern == ATTACK_KERN_BF)
- {
- highest_pw_len = device_param->kernel_params_mp_l_buf32[4]
- + device_param->kernel_params_mp_l_buf32[5];
- }
-
- // iteration type
-
- uint innerloop_step = 0;
- uint innerloop_cnt = 0;
-
- if (data.attack_exec == ATTACK_EXEC_INSIDE_KERNEL) innerloop_step = device_param->kernel_loops;
- else innerloop_step = 1;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT) innerloop_cnt = data.kernel_rules_cnt;
- else if (data.attack_kern == ATTACK_KERN_COMBI) innerloop_cnt = data.combs_cnt;
- else if (data.attack_kern == ATTACK_KERN_BF) innerloop_cnt = data.bfs_cnt;
-
- // loop start: most outer loop = salt iteration, then innerloops (if multi)
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- while (data.devices_status == STATUS_PAUSED) hc_sleep (1);
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
-
- salt_t *salt_buf = &data.salts_buf[salt_pos];
-
- device_param->kernel_params_buf32[24] = salt_pos;
- device_param->kernel_params_buf32[28] = salt_buf->digests_cnt;
- device_param->kernel_params_buf32[29] = salt_buf->digests_offset;
-
- FILE *combs_fp = device_param->combs_fp;
-
- if (data.attack_mode == ATTACK_MODE_COMBI)
- {
- rewind (combs_fp);
- }
-
- // innerloops
-
- for (uint innerloop_pos = 0; innerloop_pos < innerloop_cnt; innerloop_pos += innerloop_step)
- {
- while (data.devices_status == STATUS_PAUSED) hc_sleep (1);
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
-
- uint innerloop_left = innerloop_cnt - innerloop_pos;
-
- if (innerloop_left > innerloop_step) innerloop_left = innerloop_step;
-
- device_param->innerloop_pos = innerloop_pos;
- device_param->innerloop_left = innerloop_left;
-
- device_param->kernel_params_buf32[27] = innerloop_left;
-
- // i think we can get rid of this
- if (innerloop_left == 0)
- {
- puts ("bug, how should this happen????\n");
-
- continue;
- }
-
- if (data.salts_shown[salt_pos] == 1)
- {
- data.words_progress_done[salt_pos] += (u64) pws_cnt * (u64) innerloop_left;
-
- continue;
- }
-
- // initialize amplifiers
-
- if (data.attack_mode == ATTACK_MODE_COMBI)
- {
- uint i = 0;
-
- while (i < innerloop_left)
- {
- if (feof (combs_fp)) break;
-
- int line_len = fgetl (combs_fp, line_buf);
-
- if (line_len >= PW_MAX1) continue;
-
- line_len = convert_from_hex (line_buf, line_len);
-
- char *line_buf_new = line_buf;
-
- if (run_rule_engine (data.rule_len_r, data.rule_buf_r))
- {
- char rule_buf_out[BLOCK_SIZE] = { 0 };
-
- int rule_len_out = _old_apply_rule (data.rule_buf_r, data.rule_len_r, line_buf, line_len, rule_buf_out);
-
- if (rule_len_out < 0)
- {
- data.words_progress_rejected[salt_pos] += pws_cnt;
-
- continue;
- }
-
- line_len = rule_len_out;
-
- line_buf_new = rule_buf_out;
- }
-
- line_len = MIN (line_len, PW_DICTMAX);
-
- u8 *ptr = (u8 *) device_param->combs_buf[i].i;
-
- memcpy (ptr, line_buf_new, line_len);
-
- memset (ptr + line_len, 0, PW_DICTMAX1 - line_len);
-
- if (data.opts_type & OPTS_TYPE_PT_UPPER)
- {
- uppercase (ptr, line_len);
- }
-
- if (data.combs_mode == COMBINATOR_MODE_BASE_LEFT)
- {
- if (data.opts_type & OPTS_TYPE_PT_ADD80)
- {
- ptr[line_len] = 0x80;
- }
-
- if (data.opts_type & OPTS_TYPE_PT_ADD01)
- {
- ptr[line_len] = 0x01;
- }
- }
-
- device_param->combs_buf[i].pw_len = line_len;
-
- i++;
- }
-
- for (uint j = i; j < innerloop_left; j++)
- {
- device_param->combs_buf[j].i[0] = 0;
- device_param->combs_buf[j].i[1] = 0;
- device_param->combs_buf[j].i[2] = 0;
- device_param->combs_buf[j].i[3] = 0;
- device_param->combs_buf[j].i[4] = 0;
- device_param->combs_buf[j].i[5] = 0;
- device_param->combs_buf[j].i[6] = 0;
- device_param->combs_buf[j].i[7] = 0;
-
- device_param->combs_buf[j].pw_len = 0;
- }
-
- innerloop_left = i;
- }
- else if (data.attack_mode == ATTACK_MODE_BF)
- {
- u64 off = innerloop_pos;
-
- device_param->kernel_params_mp_r_buf64[3] = off;
-
- run_kernel_mp (KERN_RUN_MP_R, device_param, innerloop_left);
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID1)
- {
- u64 off = innerloop_pos;
-
- device_param->kernel_params_mp_buf64[3] = off;
-
- run_kernel_mp (KERN_RUN_MP, device_param, innerloop_left);
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID2)
- {
- u64 off = innerloop_pos;
-
- device_param->kernel_params_mp_buf64[3] = off;
-
- run_kernel_mp (KERN_RUN_MP, device_param, innerloop_left);
- }
-
- // copy amplifiers
-
- if (data.attack_mode == ATTACK_MODE_STRAIGHT)
- {
- hc_clEnqueueCopyBuffer (data.ocl, device_param->command_queue, device_param->d_rules, device_param->d_rules_c, innerloop_pos * sizeof (kernel_rule_t), 0, innerloop_left * sizeof (kernel_rule_t), 0, NULL, NULL);
- }
- else if (data.attack_mode == ATTACK_MODE_COMBI)
- {
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_combs_c, CL_TRUE, 0, innerloop_left * sizeof (comb_t), device_param->combs_buf, 0, NULL, NULL);
- }
- else if (data.attack_mode == ATTACK_MODE_BF)
- {
- hc_clEnqueueCopyBuffer (data.ocl, device_param->command_queue, device_param->d_bfs, device_param->d_bfs_c, 0, 0, innerloop_left * sizeof (bf_t), 0, NULL, NULL);
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID1)
- {
- hc_clEnqueueCopyBuffer (data.ocl, device_param->command_queue, device_param->d_combs, device_param->d_combs_c, 0, 0, innerloop_left * sizeof (comb_t), 0, NULL, NULL);
- }
- else if (data.attack_mode == ATTACK_MODE_HYBRID2)
- {
- hc_clEnqueueCopyBuffer (data.ocl, device_param->command_queue, device_param->d_combs, device_param->d_combs_c, 0, 0, innerloop_left * sizeof (comb_t), 0, NULL, NULL);
- }
-
- if (data.benchmark == 1)
- {
- hc_timer_set (&device_param->timer_speed);
- }
-
- choose_kernel (device_param, data.attack_exec, data.attack_mode, data.opts_type, salt_buf, highest_pw_len, pws_cnt);
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
-
- /**
- * result
- */
-
- hc_thread_mutex_lock (mux_display);
-
- check_cracked (device_param, salt_pos);
-
- hc_thread_mutex_unlock (mux_display);
-
- /**
- * progress
- */
-
- u64 perf_sum_all = (u64) pws_cnt * (u64) innerloop_left;
-
- hc_thread_mutex_lock (mux_counter);
-
- data.words_progress_done[salt_pos] += perf_sum_all;
-
- hc_thread_mutex_unlock (mux_counter);
-
- /**
- * speed
- */
-
- double speed_ms;
-
- hc_timer_get (device_param->timer_speed, speed_ms);
-
- hc_timer_set (&device_param->timer_speed);
-
- hc_thread_mutex_lock (mux_display);
-
- // current speed
-
- device_param->speed_cnt[speed_pos] = perf_sum_all;
-
- device_param->speed_ms[speed_pos] = speed_ms;
-
- hc_thread_mutex_unlock (mux_display);
-
- speed_pos++;
-
- if (speed_pos == SPEED_CACHE)
- {
- speed_pos = 0;
- }
-
- /**
- * benchmark
- */
-
- if (data.benchmark == 1) break;
- }
- }
-
- device_param->speed_pos = speed_pos;
-
- myfree (line_buf);
-}
-
-static void load_segment (wl_data_t *wl_data, FILE *fd)
-{
- // NOTE: use (never changing) ->incr here instead of ->avail otherwise the buffer gets bigger and bigger
-
- wl_data->pos = 0;
-
- wl_data->cnt = fread (wl_data->buf, 1, wl_data->incr - 1000, fd);
-
- wl_data->buf[wl_data->cnt] = 0;
-
- if (wl_data->cnt == 0) return;
-
- if (wl_data->buf[wl_data->cnt - 1] == '\n') return;
-
- while (!feof (fd))
- {
- if (wl_data->cnt == wl_data->avail)
- {
- wl_data->buf = (char *) myrealloc (wl_data->buf, wl_data->avail, wl_data->incr);
-
- wl_data->avail += wl_data->incr;
- }
-
- const int c = fgetc (fd);
-
- if (c == EOF) break;
-
- wl_data->buf[wl_data->cnt] = (char) c;
-
- wl_data->cnt++;
-
- if (c == '\n') break;
- }
-
- // ensure stream ends with a newline
-
- if (wl_data->buf[wl_data->cnt - 1] != '\n')
- {
- wl_data->cnt++;
-
- wl_data->buf[wl_data->cnt - 1] = '\n';
- }
-
- return;
-}
-
-static void get_next_word_lm (char *buf, u32 sz, u32 *len, u32 *off)
-{
- char *ptr = buf;
-
- for (u32 i = 0; i < sz; i++, ptr++)
- {
- if (*ptr >= 'a' && *ptr <= 'z') *ptr -= 0x20;
-
- if (i == 7)
- {
- *off = i;
- *len = i;
-
- return;
- }
-
- if (*ptr != '\n') continue;
-
- *off = i + 1;
-
- if ((i > 0) && (buf[i - 1] == '\r')) i--;
-
- *len = i;
-
- return;
- }
-
- *off = sz;
- *len = sz;
-}
-
-static void get_next_word_uc (char *buf, u32 sz, u32 *len, u32 *off)
-{
- char *ptr = buf;
-
- for (u32 i = 0; i < sz; i++, ptr++)
- {
- if (*ptr >= 'a' && *ptr <= 'z') *ptr -= 0x20;
-
- if (*ptr != '\n') continue;
-
- *off = i + 1;
-
- if ((i > 0) && (buf[i - 1] == '\r')) i--;
-
- *len = i;
-
- return;
- }
-
- *off = sz;
- *len = sz;
-}
-
-static void get_next_word_std (char *buf, u32 sz, u32 *len, u32 *off)
-{
- char *ptr = buf;
-
- for (u32 i = 0; i < sz; i++, ptr++)
- {
- if (*ptr != '\n') continue;
-
- *off = i + 1;
-
- if ((i > 0) && (buf[i - 1] == '\r')) i--;
-
- *len = i;
-
- return;
- }
-
- *off = sz;
- *len = sz;
-}
-
-static void get_next_word (wl_data_t *wl_data, FILE *fd, char **out_buf, uint *out_len)
-{
- while (wl_data->pos < wl_data->cnt)
- {
- uint off;
- uint len;
-
- char *ptr = wl_data->buf + wl_data->pos;
-
- get_next_word_func (ptr, wl_data->cnt - wl_data->pos, &len, &off);
-
- wl_data->pos += off;
-
- if (run_rule_engine (data.rule_len_l, data.rule_buf_l))
- {
- char rule_buf_out[BLOCK_SIZE] = { 0 };
-
- int rule_len_out = -1;
-
- if (len < BLOCK_SIZE)
- {
- rule_len_out = _old_apply_rule (data.rule_buf_l, data.rule_len_l, ptr, len, rule_buf_out);
- }
-
- if (rule_len_out < 0)
- {
- continue;
- }
-
- if (rule_len_out > PW_MAX)
- {
- continue;
- }
- }
- else
- {
- if (len > PW_MAX)
- {
- continue;
- }
- }
-
- *out_buf = ptr;
- *out_len = len;
-
- return;
- }
-
- if (feof (fd))
- {
- fprintf (stderr, "BUG feof()!!\n");
-
- return;
- }
-
- load_segment (wl_data, fd);
-
- get_next_word (wl_data, fd, out_buf, out_len);
-}
-
-#ifdef _POSIX
-static u64 count_words (wl_data_t *wl_data, FILE *fd, char *dictfile, dictstat_t *dictstat_base, size_t *dictstat_nmemb)
-#endif
-
-#ifdef _WIN
-static u64 count_words (wl_data_t *wl_data, FILE *fd, char *dictfile, dictstat_t *dictstat_base, uint *dictstat_nmemb)
-#endif
-{
- hc_signal (NULL);
-
- dictstat_t d;
-
- d.cnt = 0;
-
- #ifdef _POSIX
- fstat (fileno (fd), &d.stat);
- #endif
-
- #ifdef _WIN
- _fstat64 (fileno (fd), &d.stat);
- #endif
-
- d.stat.st_mode = 0;
- d.stat.st_nlink = 0;
- d.stat.st_uid = 0;
- d.stat.st_gid = 0;
- d.stat.st_rdev = 0;
- d.stat.st_atime = 0;
-
- #ifdef _POSIX
- d.stat.st_blksize = 0;
- d.stat.st_blocks = 0;
- #endif
-
- if (d.stat.st_size == 0) return 0;
-
- dictstat_t *d_cache = (dictstat_t *) lfind (&d, dictstat_base, dictstat_nmemb, sizeof (dictstat_t), sort_by_dictstat);
-
- if (run_rule_engine (data.rule_len_l, data.rule_buf_l) == 0)
- {
- if (d_cache)
- {
- u64 cnt = d_cache->cnt;
-
- u64 keyspace = cnt;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT)
- {
- keyspace *= data.kernel_rules_cnt;
- }
- else if (data.attack_kern == ATTACK_KERN_COMBI)
- {
- keyspace *= data.combs_cnt;
- }
-
- if (data.quiet == 0) log_info ("Cache-hit dictionary stats %s: %llu bytes, %llu words, %llu keyspace", dictfile, (unsigned long long int) d.stat.st_size, (unsigned long long int) cnt, (unsigned long long int) keyspace);
- if (data.quiet == 0) log_info ("");
-
- hc_signal (sigHandler_default);
-
- return (keyspace);
- }
- }
-
- time_t now = 0;
- time_t prev = 0;
-
- u64 comp = 0;
- u64 cnt = 0;
- u64 cnt2 = 0;
-
- while (!feof (fd))
- {
- load_segment (wl_data, fd);
-
- comp += wl_data->cnt;
-
- u32 i = 0;
-
- while (i < wl_data->cnt)
- {
- u32 len;
- u32 off;
-
- get_next_word_func (wl_data->buf + i, wl_data->cnt - i, &len, &off);
-
- if (run_rule_engine (data.rule_len_l, data.rule_buf_l))
- {
- char rule_buf_out[BLOCK_SIZE] = { 0 };
-
- int rule_len_out = -1;
-
- if (len < BLOCK_SIZE)
- {
- rule_len_out = _old_apply_rule (data.rule_buf_l, data.rule_len_l, wl_data->buf + i, len, rule_buf_out);
- }
-
- if (rule_len_out < 0)
- {
- len = PW_MAX1;
- }
- else
- {
- len = rule_len_out;
- }
- }
-
- if (len < PW_MAX1)
- {
- if (data.attack_kern == ATTACK_KERN_STRAIGHT)
- {
- cnt += data.kernel_rules_cnt;
- }
- else if (data.attack_kern == ATTACK_KERN_COMBI)
- {
- cnt += data.combs_cnt;
- }
-
- d.cnt++;
- }
-
- i += off;
-
- cnt2++;
- }
-
- time (&now);
-
- if ((now - prev) == 0) continue;
-
- float percent = (float) comp / (float) d.stat.st_size;
-
- if (data.quiet == 0) log_info_nn ("Generating dictionary stats for %s: %llu bytes (%.2f%%), %llu words, %llu keyspace", dictfile, (unsigned long long int) comp, percent * 100, (unsigned long long int) cnt2, (unsigned long long int) cnt);
-
- time (&prev);
- }
-
- if (data.quiet == 0) log_info ("Generated dictionary stats for %s: %llu bytes, %llu words, %llu keyspace", dictfile, (unsigned long long int) comp, (unsigned long long int) cnt2, (unsigned long long int) cnt);
- if (data.quiet == 0) log_info ("");
-
- lsearch (&d, dictstat_base, dictstat_nmemb, sizeof (dictstat_t), sort_by_dictstat);
-
- hc_signal (sigHandler_default);
-
- return (cnt);
-}
-
-static void *thread_monitor (void *p)
-{
- uint runtime_check = 0;
- uint remove_check = 0;
- uint status_check = 0;
- uint restore_check = 0;
-
- uint restore_left = data.restore_timer;
- uint remove_left = data.remove_timer;
- uint status_left = data.status_timer;
-
- #ifdef HAVE_HWMON
- uint hwmon_check = 0;
-
- // these variables are mainly used for fan control (AMD only)
-
- int *fan_speed_chgd = (int *) mycalloc (data.devices_cnt, sizeof (int));
-
- // temperature controller "loopback" values
-
- int *temp_diff_old = (int *) mycalloc (data.devices_cnt, sizeof (int));
- int *temp_diff_sum = (int *) mycalloc (data.devices_cnt, sizeof (int));
-
- #ifdef HAVE_ADL
- int temp_threshold = 1; // degrees celcius
-
- int fan_speed_min = 15; // in percentage
- int fan_speed_max = 100;
- #endif // HAVE_ADL
-
- time_t last_temp_check_time;
- #endif // HAVE_HWMON
-
- uint sleep_time = 1;
-
- if (data.runtime)
- {
- runtime_check = 1;
- }
-
- if (data.restore_timer)
- {
- restore_check = 1;
- }
-
- if ((data.remove == 1) && (data.hashlist_mode == HL_MODE_FILE))
- {
- remove_check = 1;
- }
-
- if (data.status == 1)
- {
- status_check = 1;
- }
-
- #ifdef HAVE_HWMON
- if (data.gpu_temp_disable == 0)
- {
- time (&last_temp_check_time);
-
- hwmon_check = 1;
- }
- #endif
-
- if ((runtime_check == 0) && (remove_check == 0) && (status_check == 0) && (restore_check == 0))
- {
- #ifdef HAVE_HWMON
- if (hwmon_check == 0)
- #endif
- return (p);
- }
-
- while ((data.devices_status != STATUS_EXHAUSTED) && (data.devices_status != STATUS_CRACKED) && (data.devices_status != STATUS_ABORTED) && (data.devices_status != STATUS_QUIT))
- {
- hc_sleep (sleep_time);
-
- if (data.devices_status != STATUS_RUNNING) continue;
-
- #ifdef HAVE_HWMON
- if (hwmon_check == 1)
- {
- hc_thread_mutex_lock (mux_adl);
-
- time_t temp_check_time;
-
- time (&temp_check_time);
-
- uint Ta = temp_check_time - last_temp_check_time; // set Ta = sleep_time; is not good enough (see --remove etc)
-
- if (Ta == 0) Ta = 1;
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- if ((data.devices_param[device_id].device_type & CL_DEVICE_TYPE_GPU) == 0) continue;
-
- const int temperature = hm_get_temperature_with_device_id (device_id);
-
- if (temperature > (int) data.gpu_temp_abort)
- {
- log_error ("ERROR: Temperature limit on GPU %d reached, aborting...", device_id + 1);
-
- if (data.devices_status != STATUS_QUIT) myabort ();
-
- break;
- }
-
- #ifdef HAVE_ADL
- const int gpu_temp_retain = data.gpu_temp_retain;
-
- if (gpu_temp_retain) // VENDOR_ID_AMD implied
- {
- if (data.hm_device[device_id].fan_supported == 1)
- {
- int temp_cur = temperature;
-
- int temp_diff_new = gpu_temp_retain - temp_cur;
-
- temp_diff_sum[device_id] = temp_diff_sum[device_id] + temp_diff_new;
-
- // calculate Ta value (time difference in seconds between the last check and this check)
-
- last_temp_check_time = temp_check_time;
-
- float Kp = 1.8;
- float Ki = 0.005;
- float Kd = 6;
-
- // PID controller (3-term controller: proportional - Kp, integral - Ki, derivative - Kd)
-
- int fan_diff_required = (int) (Kp * (float)temp_diff_new + Ki * Ta * (float)temp_diff_sum[device_id] + Kd * ((float)(temp_diff_new - temp_diff_old[device_id])) / Ta);
-
- if (abs (fan_diff_required) >= temp_threshold)
- {
- const int fan_speed_cur = hm_get_fanspeed_with_device_id (device_id);
-
- int fan_speed_level = fan_speed_cur;
-
- if (fan_speed_chgd[device_id] == 0) fan_speed_level = temp_cur;
-
- int fan_speed_new = fan_speed_level - fan_diff_required;
-
- if (fan_speed_new > fan_speed_max) fan_speed_new = fan_speed_max;
- if (fan_speed_new < fan_speed_min) fan_speed_new = fan_speed_min;
-
- if (fan_speed_new != fan_speed_cur)
- {
- int freely_change_fan_speed = (fan_speed_chgd[device_id] == 1);
- int fan_speed_must_change = (fan_speed_new > fan_speed_cur);
-
- if ((freely_change_fan_speed == 1) || (fan_speed_must_change == 1))
- {
- hm_set_fanspeed_with_device_id_amd (device_id, fan_speed_new);
-
- fan_speed_chgd[device_id] = 1;
- }
-
- temp_diff_old[device_id] = temp_diff_new;
- }
- }
- }
- }
- #endif // HAVE_ADL
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_HWMON
-
- if (restore_check == 1)
- {
- restore_left--;
-
- if (restore_left == 0)
- {
- if (data.restore_disable == 0) cycle_restore ();
-
- restore_left = data.restore_timer;
- }
- }
-
- if ((runtime_check == 1) && (data.runtime_start > 0))
- {
- time_t runtime_cur;
-
- time (&runtime_cur);
-
- int runtime_left = data.runtime_start + data.runtime - runtime_cur;
-
- if (runtime_left <= 0)
- {
- if (data.benchmark == 0)
- {
- if (data.quiet == 0) log_info ("\nNOTE: Runtime limit reached, aborting...\n");
- }
-
- if (data.devices_status != STATUS_QUIT) myabort ();
- }
- }
-
- if (remove_check == 1)
- {
- remove_left--;
-
- if (remove_left == 0)
- {
- if (data.digests_saved != data.digests_done)
- {
- data.digests_saved = data.digests_done;
-
- save_hash ();
- }
-
- remove_left = data.remove_timer;
- }
- }
-
- if (status_check == 1)
- {
- status_left--;
-
- if (status_left == 0)
- {
- hc_thread_mutex_lock (mux_display);
-
- if (data.quiet == 0) clear_prompt ();
-
- if (data.quiet == 0) log_info ("");
-
- status_display ();
-
- if (data.quiet == 0) log_info ("");
-
- hc_thread_mutex_unlock (mux_display);
-
- status_left = data.status_timer;
- }
- }
- }
-
- #ifdef HAVE_HWMON
- myfree (fan_speed_chgd);
-
- myfree (temp_diff_old);
- myfree (temp_diff_sum);
- #endif
-
- p = NULL;
-
- return (p);
-}
-
-static void *thread_outfile_remove (void *p)
-{
- // some hash-dependent constants
- char *outfile_dir = data.outfile_check_directory;
- uint dgst_size = data.dgst_size;
- uint isSalted = data.isSalted;
- uint esalt_size = data.esalt_size;
- uint hash_mode = data.hash_mode;
-
- uint outfile_check_timer = data.outfile_check_timer;
-
- char separator = data.separator;
-
- // some hash-dependent functions
- int (*sort_by_digest) (const void *, const void *) = data.sort_by_digest;
- int (*parse_func) (char *, uint, hash_t *) = data.parse_func;
-
- // buffers
- hash_t hash_buf = { 0, 0, 0, 0, 0 };
-
- hash_buf.digest = mymalloc (dgst_size);
-
- if (isSalted) hash_buf.salt = (salt_t *) mymalloc (sizeof (salt_t));
-
- if (esalt_size) hash_buf.esalt = (void *) mymalloc (esalt_size);
-
- uint digest_buf[64] = { 0 };
-
- outfile_data_t *out_info = NULL;
-
- char **out_files = NULL;
-
- time_t folder_mtime = 0;
-
- int out_cnt = 0;
-
- uint check_left = outfile_check_timer; // or 1 if we want to check it at startup
-
- while ((data.devices_status != STATUS_EXHAUSTED) && (data.devices_status != STATUS_CRACKED) && (data.devices_status != STATUS_ABORTED) && (data.devices_status != STATUS_QUIT))
- {
- hc_sleep (1);
-
- if (data.devices_status != STATUS_RUNNING) continue;
-
- check_left--;
-
- if (check_left == 0)
- {
- struct stat outfile_check_stat;
-
- if (stat (outfile_dir, &outfile_check_stat) == 0)
- {
- uint is_dir = S_ISDIR (outfile_check_stat.st_mode);
-
- if (is_dir == 1)
- {
- if (outfile_check_stat.st_mtime > folder_mtime)
- {
- char **out_files_new = scan_directory (outfile_dir);
-
- int out_cnt_new = count_dictionaries (out_files_new);
-
- outfile_data_t *out_info_new = NULL;
-
- if (out_cnt_new > 0)
- {
- out_info_new = (outfile_data_t *) mycalloc (out_cnt_new, sizeof (outfile_data_t));
-
- for (int i = 0; i < out_cnt_new; i++)
- {
- out_info_new[i].file_name = out_files_new[i];
-
- // check if there are files that we have seen/checked before (and not changed)
-
- for (int j = 0; j < out_cnt; j++)
- {
- if (strcmp (out_info[j].file_name, out_info_new[i].file_name) == 0)
- {
- struct stat outfile_stat;
-
- if (stat (out_info_new[i].file_name, &outfile_stat) == 0)
- {
- if (outfile_stat.st_ctime == out_info[j].ctime)
- {
- out_info_new[i].ctime = out_info[j].ctime;
- out_info_new[i].seek = out_info[j].seek;
- }
- }
- }
- }
- }
- }
-
- local_free (out_info);
- local_free (out_files);
-
- out_files = out_files_new;
- out_cnt = out_cnt_new;
- out_info = out_info_new;
-
- folder_mtime = outfile_check_stat.st_mtime;
- }
-
- for (int j = 0; j < out_cnt; j++)
- {
- FILE *fp = fopen (out_info[j].file_name, "rb");
-
- if (fp != NULL)
- {
- //hc_thread_mutex_lock (mux_display);
-
- #ifdef _POSIX
- struct stat outfile_stat;
-
- fstat (fileno (fp), &outfile_stat);
- #endif
-
- #ifdef _WIN
- struct stat64 outfile_stat;
-
- _fstat64 (fileno (fp), &outfile_stat);
- #endif
-
- if (outfile_stat.st_ctime > out_info[j].ctime)
- {
- out_info[j].ctime = outfile_stat.st_ctime;
- out_info[j].seek = 0;
- }
-
- fseek (fp, out_info[j].seek, SEEK_SET);
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- while (!feof (fp))
- {
- char *ptr = fgets (line_buf, HCBUFSIZ - 1, fp);
-
- if (ptr == NULL) break;
-
- int line_len = strlen (line_buf);
-
- if (line_len <= 0) continue;
-
- int iter = MAX_CUT_TRIES;
-
- for (uint i = line_len - 1; i && iter; i--, line_len--)
- {
- if (line_buf[i] != separator) continue;
-
- int parser_status = PARSER_OK;
-
- if ((hash_mode != 2500) && (hash_mode != 6800))
- {
- parser_status = parse_func (line_buf, line_len - 1, &hash_buf);
- }
-
- uint found = 0;
-
- if (parser_status == PARSER_OK)
- {
- for (uint salt_pos = 0; (found == 0) && (salt_pos < data.salts_cnt); salt_pos++)
- {
- if (data.salts_shown[salt_pos] == 1) continue;
-
- salt_t *salt_buf = &data.salts_buf[salt_pos];
-
- for (uint digest_pos = 0; (found == 0) && (digest_pos < salt_buf->digests_cnt); digest_pos++)
- {
- uint idx = salt_buf->digests_offset + digest_pos;
-
- if (data.digests_shown[idx] == 1) continue;
-
- uint cracked = 0;
-
- if (hash_mode == 6800)
- {
- if (i == salt_buf->salt_len)
- {
- cracked = (memcmp (line_buf, salt_buf->salt_buf, salt_buf->salt_len) == 0);
- }
- }
- else if (hash_mode == 2500)
- {
- // BSSID : MAC1 : MAC2 (:plain)
- if (i == (salt_buf->salt_len + 1 + 12 + 1 + 12))
- {
- cracked = (memcmp (line_buf, salt_buf->salt_buf, salt_buf->salt_len) == 0);
-
- if (!cracked) continue;
-
- // now compare MAC1 and MAC2 too, since we have this additional info
- char *mac1_pos = line_buf + salt_buf->salt_len + 1;
- char *mac2_pos = mac1_pos + 12 + 1;
-
- wpa_t *wpas = (wpa_t *) data.esalts_buf;
- wpa_t *wpa = &wpas[salt_pos];
-
- // compare hex string(s) vs binary MAC address(es)
-
- for (uint i = 0, j = 0; i < 6; i++, j += 2)
- {
- if (wpa->orig_mac1[i] != hex_to_u8 ((const u8 *) &mac1_pos[j]))
- {
- cracked = 0;
-
- break;
- }
- }
-
- // early skip ;)
- if (!cracked) continue;
-
- for (uint i = 0, j = 0; i < 6; i++, j += 2)
- {
- if (wpa->orig_mac2[i] != hex_to_u8 ((const u8 *) &mac2_pos[j]))
- {
- cracked = 0;
-
- break;
- }
- }
- }
- }
- else
- {
- char *digests_buf_ptr = (char *) data.digests_buf;
-
- memcpy (digest_buf, digests_buf_ptr + (data.salts_buf[salt_pos].digests_offset * dgst_size) + (digest_pos * dgst_size), dgst_size);
-
- cracked = (sort_by_digest (digest_buf, hash_buf.digest) == 0);
- }
-
- if (cracked == 1)
- {
- found = 1;
-
- data.digests_shown[idx] = 1;
-
- data.digests_done++;
-
- salt_buf->digests_done++;
-
- if (salt_buf->digests_done == salt_buf->digests_cnt)
- {
- data.salts_shown[salt_pos] = 1;
-
- data.salts_done++;
-
- if (data.salts_done == data.salts_cnt) data.devices_status = STATUS_CRACKED;
- }
- }
- }
-
- if (data.devices_status == STATUS_CRACKED) break;
- }
- }
-
- if (found) break;
-
- if (data.devices_status == STATUS_CRACKED) break;
-
- iter--;
- }
-
- if (data.devices_status == STATUS_CRACKED) break;
- }
-
- myfree (line_buf);
-
- out_info[j].seek = ftell (fp);
-
- //hc_thread_mutex_unlock (mux_display);
-
- fclose (fp);
- }
- }
- }
- }
-
- check_left = outfile_check_timer;
- }
- }
-
- if (esalt_size) local_free (hash_buf.esalt);
-
- if (isSalted) local_free (hash_buf.salt);
-
- local_free (hash_buf.digest);
-
- local_free (out_info);
-
- local_free (out_files);
-
- p = NULL;
-
- return (p);
-}
-
-static void pw_add (hc_device_param_t *device_param, const u8 *pw_buf, const int pw_len)
-{
- if (device_param->pws_cnt < device_param->kernel_power)
- {
- pw_t *pw = (pw_t *) device_param->pws_buf + device_param->pws_cnt;
-
- u8 *ptr = (u8 *) pw->i;
-
- memcpy (ptr, pw_buf, pw_len);
-
- memset (ptr + pw_len, 0, sizeof (pw->i) - pw_len);
-
- pw->pw_len = pw_len;
-
- device_param->pws_cnt++;
- }
- else
- {
- fprintf (stderr, "BUG pw_add()!!\n");
-
- return;
- }
-}
-
-static uint get_work (hc_device_param_t *device_param, const u64 max, const bool allow_div)
-{
- hc_thread_mutex_lock (mux_dispatcher);
-
- const u64 words_cur = data.words_cur;
- const u64 words_base = (data.limit == 0) ? data.words_base : data.limit;
-
- device_param->words_off = words_cur;
-
- const u64 words_left = words_base - words_cur;
-
- if (allow_div)
- {
- if (data.kernel_power_all > words_left)
- {
- if (data.kernel_power_div == 0)
- {
- data.kernel_power_div = find_kernel_power_div (words_left, data.kernel_power_all);
- }
- }
-
- if (data.kernel_power_div)
- {
- if (device_param->kernel_power == device_param->kernel_power_user)
- {
- const u32 kernel_power_new = (float) device_param->kernel_power * data.kernel_power_div;
-
- if (kernel_power_new < device_param->kernel_power)
- {
- device_param->kernel_power = kernel_power_new;
- }
- }
- }
- }
-
- const uint kernel_power = device_param->kernel_power;
-
- uint work = MIN (words_left, kernel_power);
-
- work = MIN (work, max);
-
- data.words_cur += work;
-
- hc_thread_mutex_unlock (mux_dispatcher);
-
- return work;
-}
-
-static void *thread_calc_stdin (void *p)
-{
- hc_device_param_t *device_param = (hc_device_param_t *) p;
-
- if (device_param->skipped) return NULL;
-
- autotune (device_param);
-
- char *buf = (char *) mymalloc (HCBUFSIZ);
-
- const uint attack_kern = data.attack_kern;
-
- const uint kernel_power = device_param->kernel_power;
-
- while ((data.devices_status != STATUS_EXHAUSTED) && (data.devices_status != STATUS_CRACKED) && (data.devices_status != STATUS_ABORTED) && (data.devices_status != STATUS_QUIT))
- {
- hc_thread_mutex_lock (mux_dispatcher);
-
- if (feof (stdin) != 0)
- {
- hc_thread_mutex_unlock (mux_dispatcher);
-
- break;
- }
-
- uint words_cur = 0;
-
- while (words_cur < kernel_power)
- {
- char *line_buf = fgets (buf, HCBUFSIZ - 1, stdin);
-
- if (line_buf == NULL) break;
-
- uint line_len = in_superchop (line_buf);
-
- line_len = convert_from_hex (line_buf, line_len);
-
- // post-process rule engine
-
- if (run_rule_engine (data.rule_len_l, data.rule_buf_l))
- {
- char rule_buf_out[BLOCK_SIZE] = { 0 };
-
- int rule_len_out = -1;
-
- if (line_len < BLOCK_SIZE)
- {
- rule_len_out = _old_apply_rule (data.rule_buf_l, data.rule_len_l, line_buf, line_len, rule_buf_out);
- }
-
- if (rule_len_out < 0) continue;
-
- line_buf = rule_buf_out;
- line_len = rule_len_out;
- }
-
- if (line_len > PW_MAX)
- {
- continue;
- }
-
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- {
- if ((line_len < data.pw_min) || (line_len > data.pw_max))
- {
- hc_thread_mutex_lock (mux_counter);
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- data.words_progress_rejected[salt_pos] += data.kernel_rules_cnt;
- }
-
- hc_thread_mutex_unlock (mux_counter);
-
- continue;
- }
- }
- else if (attack_kern == ATTACK_KERN_COMBI)
- {
- // do not check if minimum restriction is satisfied (line_len >= data.pw_min) here
- // since we still need to combine the plains
-
- if (line_len > data.pw_max)
- {
- hc_thread_mutex_lock (mux_counter);
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- data.words_progress_rejected[salt_pos] += data.combs_cnt;
- }
-
- hc_thread_mutex_unlock (mux_counter);
-
- continue;
- }
- }
-
- pw_add (device_param, (u8 *) line_buf, line_len);
-
- words_cur++;
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
- }
-
- hc_thread_mutex_unlock (mux_dispatcher);
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
-
- // flush
-
- const uint pws_cnt = device_param->pws_cnt;
-
- if (pws_cnt)
- {
- run_copy (device_param, pws_cnt);
-
- run_cracker (device_param, pws_cnt);
-
- device_param->pws_cnt = 0;
-
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- {
- run_kernel_bzero (device_param, device_param->d_rules_c, device_param->size_rules_c);
- }
- else if (attack_kern == ATTACK_KERN_COMBI)
- {
- run_kernel_bzero (device_param, device_param->d_combs_c, device_param->size_combs);
- }
- }
- }
-
- device_param->kernel_accel = 0;
- device_param->kernel_loops = 0;
-
- myfree (buf);
-
- return NULL;
-}
-
-static void *thread_calc (void *p)
-{
- hc_device_param_t *device_param = (hc_device_param_t *) p;
-
- if (device_param->skipped) return NULL;
-
- autotune (device_param);
-
- const uint attack_mode = data.attack_mode;
- const uint attack_kern = data.attack_kern;
-
- if (attack_mode == ATTACK_MODE_BF)
- {
- while ((data.devices_status != STATUS_EXHAUSTED) && (data.devices_status != STATUS_CRACKED) && (data.devices_status != STATUS_ABORTED) && (data.devices_status != STATUS_QUIT))
- {
- const uint work = get_work (device_param, -1, true);
-
- if (work == 0) break;
-
- const u64 words_off = device_param->words_off;
- const u64 words_fin = words_off + work;
-
- const uint pws_cnt = work;
-
- device_param->pws_cnt = pws_cnt;
-
- if (pws_cnt)
- {
- run_copy (device_param, pws_cnt);
-
- run_cracker (device_param, pws_cnt);
-
- device_param->pws_cnt = 0;
-
- run_kernel_bzero (device_param, device_param->d_bfs_c, device_param->size_bfs);
- }
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
-
- if (data.benchmark == 1) break;
-
- device_param->words_done = words_fin;
- }
- }
- else
- {
- const uint segment_size = data.segment_size;
-
- char *dictfile = data.dictfile;
-
- if (attack_mode == ATTACK_MODE_COMBI)
- {
- if (data.combs_mode == COMBINATOR_MODE_BASE_RIGHT)
- {
- dictfile = data.dictfile2;
- }
- }
-
- FILE *fd = fopen (dictfile, "rb");
-
- if (fd == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile, strerror (errno));
-
- return NULL;
- }
-
- if (attack_mode == ATTACK_MODE_COMBI)
- {
- const uint combs_mode = data.combs_mode;
-
- if (combs_mode == COMBINATOR_MODE_BASE_LEFT)
- {
- const char *dictfilec = data.dictfile2;
-
- FILE *combs_fp = fopen (dictfilec, "rb");
-
- if (combs_fp == NULL)
- {
- log_error ("ERROR: %s: %s", dictfilec, strerror (errno));
-
- fclose (fd);
-
- return NULL;
- }
-
- device_param->combs_fp = combs_fp;
- }
- else if (combs_mode == COMBINATOR_MODE_BASE_RIGHT)
- {
- const char *dictfilec = data.dictfile;
-
- FILE *combs_fp = fopen (dictfilec, "rb");
-
- if (combs_fp == NULL)
- {
- log_error ("ERROR: %s: %s", dictfilec, strerror (errno));
-
- fclose (fd);
-
- return NULL;
- }
-
- device_param->combs_fp = combs_fp;
- }
- }
-
- wl_data_t *wl_data = (wl_data_t *) mymalloc (sizeof (wl_data_t));
-
- wl_data->buf = (char *) mymalloc (segment_size);
- wl_data->avail = segment_size;
- wl_data->incr = segment_size;
- wl_data->cnt = 0;
- wl_data->pos = 0;
-
- u64 words_cur = 0;
-
- while ((data.devices_status != STATUS_EXHAUSTED) && (data.devices_status != STATUS_CRACKED) && (data.devices_status != STATUS_ABORTED) && (data.devices_status != STATUS_QUIT))
- {
- u64 words_off = 0;
- u64 words_fin = 0;
-
- bool allow_div = true;
-
- u64 max = -1;
-
- while (max)
- {
- const uint work = get_work (device_param, max, allow_div);
-
- allow_div = false;
-
- if (work == 0) break;
-
- words_off = device_param->words_off;
- words_fin = words_off + work;
-
- char *line_buf;
- uint line_len;
-
- for ( ; words_cur < words_off; words_cur++) get_next_word (wl_data, fd, &line_buf, &line_len);
-
- max = 0;
-
- for ( ; words_cur < words_fin; words_cur++)
- {
- get_next_word (wl_data, fd, &line_buf, &line_len);
-
- line_len = convert_from_hex (line_buf, line_len);
-
- // post-process rule engine
-
- if (run_rule_engine (data.rule_len_l, data.rule_buf_l))
- {
- char rule_buf_out[BLOCK_SIZE] = { 0 };
-
- int rule_len_out = -1;
-
- if (line_len < BLOCK_SIZE)
- {
- rule_len_out = _old_apply_rule (data.rule_buf_l, data.rule_len_l, line_buf, line_len, rule_buf_out);
- }
-
- if (rule_len_out < 0) continue;
-
- line_buf = rule_buf_out;
- line_len = rule_len_out;
- }
-
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- {
- if ((line_len < data.pw_min) || (line_len > data.pw_max))
- {
- max++;
-
- hc_thread_mutex_lock (mux_counter);
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- data.words_progress_rejected[salt_pos] += data.kernel_rules_cnt;
- }
-
- hc_thread_mutex_unlock (mux_counter);
-
- continue;
- }
- }
- else if (attack_kern == ATTACK_KERN_COMBI)
- {
- // do not check if minimum restriction is satisfied (line_len >= data.pw_min) here
- // since we still need to combine the plains
-
- if (line_len > data.pw_max)
- {
- max++;
-
- hc_thread_mutex_lock (mux_counter);
-
- for (uint salt_pos = 0; salt_pos < data.salts_cnt; salt_pos++)
- {
- data.words_progress_rejected[salt_pos] += data.combs_cnt;
- }
-
- hc_thread_mutex_unlock (mux_counter);
-
- continue;
- }
- }
-
- pw_add (device_param, (u8 *) line_buf, line_len);
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
- }
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
- }
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
-
- //
- // flush
- //
-
- const uint pws_cnt = device_param->pws_cnt;
-
- if (pws_cnt)
- {
- run_copy (device_param, pws_cnt);
-
- run_cracker (device_param, pws_cnt);
-
- device_param->pws_cnt = 0;
-
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- {
- run_kernel_bzero (device_param, device_param->d_rules_c, device_param->size_rules_c);
- }
- else if (attack_kern == ATTACK_KERN_COMBI)
- {
- run_kernel_bzero (device_param, device_param->d_combs_c, device_param->size_combs);
- }
- }
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
- if (data.devices_status == STATUS_BYPASS) break;
-
- if (words_fin == 0) break;
-
- device_param->words_done = words_fin;
- }
-
- if (attack_mode == ATTACK_MODE_COMBI)
- {
- fclose (device_param->combs_fp);
- }
-
- free (wl_data->buf);
- free (wl_data);
-
- fclose (fd);
- }
-
- device_param->kernel_accel = 0;
- device_param->kernel_loops = 0;
-
- return NULL;
-}
-
-static void weak_hash_check (hc_device_param_t *device_param, const uint salt_pos)
-{
- if (!device_param)
- {
- log_error ("ERROR: %s : Invalid argument", __func__);
-
- exit (-1);
- }
-
- salt_t *salt_buf = &data.salts_buf[salt_pos];
-
- device_param->kernel_params_buf32[24] = salt_pos;
- device_param->kernel_params_buf32[27] = 1;
- device_param->kernel_params_buf32[28] = salt_buf->digests_cnt;
- device_param->kernel_params_buf32[29] = salt_buf->digests_offset;
- device_param->kernel_params_buf32[30] = 0;
- device_param->kernel_params_buf32[31] = 1;
-
- char *dictfile_old = data.dictfile;
-
- const char *weak_hash_check = "weak-hash-check";
-
- data.dictfile = (char *) weak_hash_check;
-
- uint cmd0_rule_old = data.kernel_rules_buf[0].cmds[0];
-
- data.kernel_rules_buf[0].cmds[0] = 0;
-
- /**
- * run the kernel
- */
-
- if (data.attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- run_kernel (KERN_RUN_1, device_param, 1, false);
- }
- else
- {
- run_kernel (KERN_RUN_1, device_param, 1, false);
-
- uint loop_step = 16;
-
- const uint iter = salt_buf->salt_iter;
-
- for (uint loop_pos = 0; loop_pos < iter; loop_pos += loop_step)
- {
- uint loop_left = iter - loop_pos;
-
- loop_left = MIN (loop_left, loop_step);
-
- device_param->kernel_params_buf32[25] = loop_pos;
- device_param->kernel_params_buf32[26] = loop_left;
-
- run_kernel (KERN_RUN_2, device_param, 1, false);
- }
-
- run_kernel (KERN_RUN_3, device_param, 1, false);
- }
-
- /**
- * result
- */
-
- check_cracked (device_param, salt_pos);
-
- /**
- * cleanup
- */
-
- device_param->kernel_params_buf32[24] = 0;
- device_param->kernel_params_buf32[25] = 0;
- device_param->kernel_params_buf32[26] = 0;
- device_param->kernel_params_buf32[27] = 0;
- device_param->kernel_params_buf32[28] = 0;
- device_param->kernel_params_buf32[29] = 0;
- device_param->kernel_params_buf32[30] = 0;
- device_param->kernel_params_buf32[31] = 0;
-
- data.dictfile = dictfile_old;
-
- data.kernel_rules_buf[0].cmds[0] = cmd0_rule_old;
-}
-
-// hlfmt hashcat
-
-static void hlfmt_hash_hashcat (char *line_buf, int line_len, char **hashbuf_pos, int *hashbuf_len)
-{
- if (data.username == 0)
- {
- *hashbuf_pos = line_buf;
- *hashbuf_len = line_len;
- }
- else
- {
- char *pos = line_buf;
- int len = line_len;
-
- for (int i = 0; i < line_len; i++, pos++, len--)
- {
- if (line_buf[i] == data.separator)
- {
- pos++;
-
- len--;
-
- break;
- }
- }
-
- *hashbuf_pos = pos;
- *hashbuf_len = len;
- }
-}
-
-static void hlfmt_user_hashcat (char *line_buf, int line_len, char **userbuf_pos, int *userbuf_len)
-{
- char *pos = NULL;
- int len = 0;
-
- int sep_cnt = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == data.separator)
- {
- sep_cnt++;
-
- continue;
- }
-
- if (sep_cnt == 0)
- {
- if (pos == NULL) pos = line_buf + i;
-
- len++;
- }
- }
-
- *userbuf_pos = pos;
- *userbuf_len = len;
-}
-
-// hlfmt pwdump
-
-static int hlfmt_detect_pwdump (char *line_buf, int line_len)
-{
- int sep_cnt = 0;
-
- int sep2_len = 0;
- int sep3_len = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':')
- {
- sep_cnt++;
-
- continue;
- }
-
- if (sep_cnt == 2) sep2_len++;
- if (sep_cnt == 3) sep3_len++;
- }
-
- if ((sep_cnt == 6) && ((sep2_len == 32) || (sep3_len == 32))) return 1;
-
- return 0;
-}
-
-static void hlfmt_hash_pwdump (char *line_buf, int line_len, char **hashbuf_pos, int *hashbuf_len)
-{
- char *pos = NULL;
- int len = 0;
-
- int sep_cnt = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':')
- {
- sep_cnt++;
-
- continue;
- }
-
- if (data.hash_mode == 1000)
- {
- if (sep_cnt == 3)
- {
- if (pos == NULL) pos = line_buf + i;
-
- len++;
- }
- }
- else if (data.hash_mode == 3000)
- {
- if (sep_cnt == 2)
- {
- if (pos == NULL) pos = line_buf + i;
-
- len++;
- }
- }
- }
-
- *hashbuf_pos = pos;
- *hashbuf_len = len;
-}
-
-static void hlfmt_user_pwdump (char *line_buf, int line_len, char **userbuf_pos, int *userbuf_len)
-{
- char *pos = NULL;
- int len = 0;
-
- int sep_cnt = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':')
- {
- sep_cnt++;
-
- continue;
- }
-
- if (sep_cnt == 0)
- {
- if (pos == NULL) pos = line_buf + i;
-
- len++;
- }
- }
-
- *userbuf_pos = pos;
- *userbuf_len = len;
-}
-
-// hlfmt passwd
-
-static int hlfmt_detect_passwd (char *line_buf, int line_len)
-{
- int sep_cnt = 0;
-
- char sep5_first = 0;
- char sep6_first = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':')
- {
- sep_cnt++;
-
- continue;
- }
-
- if (sep_cnt == 5) if (sep5_first == 0) sep5_first = line_buf[i];
- if (sep_cnt == 6) if (sep6_first == 0) sep6_first = line_buf[i];
- }
-
- if ((sep_cnt == 6) && ((sep5_first == '/') || (sep6_first == '/'))) return 1;
-
- return 0;
-}
-
-static void hlfmt_hash_passwd (char *line_buf, int line_len, char **hashbuf_pos, int *hashbuf_len)
-{
- char *pos = NULL;
- int len = 0;
-
- int sep_cnt = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':')
- {
- sep_cnt++;
-
- continue;
- }
-
- if (sep_cnt == 1)
- {
- if (pos == NULL) pos = line_buf + i;
-
- len++;
- }
- }
-
- *hashbuf_pos = pos;
- *hashbuf_len = len;
-}
-
-static void hlfmt_user_passwd (char *line_buf, int line_len, char **userbuf_pos, int *userbuf_len)
-{
- char *pos = NULL;
- int len = 0;
-
- int sep_cnt = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':')
- {
- sep_cnt++;
-
- continue;
- }
-
- if (sep_cnt == 0)
- {
- if (pos == NULL) pos = line_buf + i;
-
- len++;
- }
- }
-
- *userbuf_pos = pos;
- *userbuf_len = len;
-}
-
-// hlfmt shadow
-
-static int hlfmt_detect_shadow (char *line_buf, int line_len)
-{
- int sep_cnt = 0;
-
- for (int i = 0; i < line_len; i++)
- {
- if (line_buf[i] == ':') sep_cnt++;
- }
-
- if (sep_cnt == 8) return 1;
-
- return 0;
-}
-
-static void hlfmt_hash_shadow (char *line_buf, int line_len, char **hashbuf_pos, int *hashbuf_len)
-{
- hlfmt_hash_passwd (line_buf, line_len, hashbuf_pos, hashbuf_len);
-}
-
-static void hlfmt_user_shadow (char *line_buf, int line_len, char **userbuf_pos, int *userbuf_len)
-{
- hlfmt_user_passwd (line_buf, line_len, userbuf_pos, userbuf_len);
-}
-
-// hlfmt main
-
-static void hlfmt_hash (uint hashfile_format, char *line_buf, int line_len, char **hashbuf_pos, int *hashbuf_len)
-{
- switch (hashfile_format)
- {
- case HLFMT_HASHCAT: hlfmt_hash_hashcat (line_buf, line_len, hashbuf_pos, hashbuf_len); break;
- case HLFMT_PWDUMP: hlfmt_hash_pwdump (line_buf, line_len, hashbuf_pos, hashbuf_len); break;
- case HLFMT_PASSWD: hlfmt_hash_passwd (line_buf, line_len, hashbuf_pos, hashbuf_len); break;
- case HLFMT_SHADOW: hlfmt_hash_shadow (line_buf, line_len, hashbuf_pos, hashbuf_len); break;
- }
-}
-
-static void hlfmt_user (uint hashfile_format, char *line_buf, int line_len, char **userbuf_pos, int *userbuf_len)
-{
- switch (hashfile_format)
- {
- case HLFMT_HASHCAT: hlfmt_user_hashcat (line_buf, line_len, userbuf_pos, userbuf_len); break;
- case HLFMT_PWDUMP: hlfmt_user_pwdump (line_buf, line_len, userbuf_pos, userbuf_len); break;
- case HLFMT_PASSWD: hlfmt_user_passwd (line_buf, line_len, userbuf_pos, userbuf_len); break;
- case HLFMT_SHADOW: hlfmt_user_shadow (line_buf, line_len, userbuf_pos, userbuf_len); break;
- }
-}
-
-char *strhlfmt (const uint hashfile_format)
-{
- switch (hashfile_format)
- {
- case HLFMT_HASHCAT: return ((char *) HLFMT_TEXT_HASHCAT); break;
- case HLFMT_PWDUMP: return ((char *) HLFMT_TEXT_PWDUMP); break;
- case HLFMT_PASSWD: return ((char *) HLFMT_TEXT_PASSWD); break;
- case HLFMT_SHADOW: return ((char *) HLFMT_TEXT_SHADOW); break;
- case HLFMT_DCC: return ((char *) HLFMT_TEXT_DCC); break;
- case HLFMT_DCC2: return ((char *) HLFMT_TEXT_DCC2); break;
- case HLFMT_NETNTLM1: return ((char *) HLFMT_TEXT_NETNTLM1); break;
- case HLFMT_NETNTLM2: return ((char *) HLFMT_TEXT_NETNTLM2); break;
- case HLFMT_NSLDAP: return ((char *) HLFMT_TEXT_NSLDAP); break;
- case HLFMT_NSLDAPS: return ((char *) HLFMT_TEXT_NSLDAPS); break;
- }
-
- return ((char *) "Unknown");
-}
-
-static uint hlfmt_detect (FILE *fp, uint max_check)
-{
- // Exception: those formats are wrongly detected as HLFMT_SHADOW, prevent it
-
- if (data.hash_mode == 5300) return HLFMT_HASHCAT;
- if (data.hash_mode == 5400) return HLFMT_HASHCAT;
-
- uint *formats_cnt = (uint *) mycalloc (HLFMTS_CNT, sizeof (uint));
-
- uint num_check = 0;
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- while (!feof (fp))
- {
- int line_len = fgetl (fp, line_buf);
-
- if (line_len == 0) continue;
-
- if (hlfmt_detect_pwdump (line_buf, line_len)) formats_cnt[HLFMT_PWDUMP]++;
- if (hlfmt_detect_passwd (line_buf, line_len)) formats_cnt[HLFMT_PASSWD]++;
- if (hlfmt_detect_shadow (line_buf, line_len)) formats_cnt[HLFMT_SHADOW]++;
-
- if (num_check == max_check) break;
-
- num_check++;
- }
-
- myfree (line_buf);
-
- uint hashlist_format = HLFMT_HASHCAT;
-
- for (int i = 1; i < HLFMTS_CNT; i++)
- {
- if (formats_cnt[i - 1] >= formats_cnt[i]) continue;
-
- hashlist_format = i;
- }
-
- free (formats_cnt);
-
- return hashlist_format;
-}
-
-/**
- * some further helper function
- */
-
-// wrapper around mymalloc for ADL
-
-#if defined(HAVE_HWMON) && defined(HAVE_ADL)
-void *__stdcall ADL_Main_Memory_Alloc (const int iSize)
-{
- return mymalloc (iSize);
-}
-#endif
-
-static uint generate_bitmaps (const uint digests_cnt, const uint dgst_size, const uint dgst_shifts, char *digests_buf_ptr, const uint bitmap_mask, const uint bitmap_size, uint *bitmap_a, uint *bitmap_b, uint *bitmap_c, uint *bitmap_d, const u64 collisions_max)
-{
- u64 collisions = 0;
-
- const uint dgst_pos0 = data.dgst_pos0;
- const uint dgst_pos1 = data.dgst_pos1;
- const uint dgst_pos2 = data.dgst_pos2;
- const uint dgst_pos3 = data.dgst_pos3;
-
- memset (bitmap_a, 0, bitmap_size);
- memset (bitmap_b, 0, bitmap_size);
- memset (bitmap_c, 0, bitmap_size);
- memset (bitmap_d, 0, bitmap_size);
-
- for (uint i = 0; i < digests_cnt; i++)
- {
- uint *digest_ptr = (uint *) digests_buf_ptr;
-
- digests_buf_ptr += dgst_size;
-
- const uint val0 = 1u << (digest_ptr[dgst_pos0] & 0x1f);
- const uint val1 = 1u << (digest_ptr[dgst_pos1] & 0x1f);
- const uint val2 = 1u << (digest_ptr[dgst_pos2] & 0x1f);
- const uint val3 = 1u << (digest_ptr[dgst_pos3] & 0x1f);
-
- const uint idx0 = (digest_ptr[dgst_pos0] >> dgst_shifts) & bitmap_mask;
- const uint idx1 = (digest_ptr[dgst_pos1] >> dgst_shifts) & bitmap_mask;
- const uint idx2 = (digest_ptr[dgst_pos2] >> dgst_shifts) & bitmap_mask;
- const uint idx3 = (digest_ptr[dgst_pos3] >> dgst_shifts) & bitmap_mask;
-
- if (bitmap_a[idx0] & val0) collisions++;
- if (bitmap_b[idx1] & val1) collisions++;
- if (bitmap_c[idx2] & val2) collisions++;
- if (bitmap_d[idx3] & val3) collisions++;
-
- bitmap_a[idx0] |= val0;
- bitmap_b[idx1] |= val1;
- bitmap_c[idx2] |= val2;
- bitmap_d[idx3] |= val3;
-
- if (collisions >= collisions_max) return 0x7fffffff;
- }
-
- return collisions;
-}
-
-/**
- * main
- */
-
-int main (int argc, char **argv)
-{
- /**
- * To help users a bit
- */
-
- char *compute = getenv ("COMPUTE");
-
- if (compute)
- {
- static char display[100];
-
- snprintf (display, sizeof (display) - 1, "DISPLAY=%s", compute);
-
- putenv (display);
- }
- else
- {
- if (getenv ("DISPLAY") == NULL)
- putenv ((char *) "DISPLAY=:0");
- }
-
- if (getenv ("GPU_MAX_ALLOC_PERCENT") == NULL)
- putenv ((char *) "GPU_MAX_ALLOC_PERCENT=100");
-
- if (getenv ("CPU_MAX_ALLOC_PERCENT") == NULL)
- putenv ((char *) "CPU_MAX_ALLOC_PERCENT=100");
-
- if (getenv ("GPU_USE_SYNC_OBJECTS") == NULL)
- putenv ((char *) "GPU_USE_SYNC_OBJECTS=1");
-
- if (getenv ("CUDA_CACHE_DISABLE") == NULL)
- putenv ((char *) "CUDA_CACHE_DISABLE=1");
-
- if (getenv ("POCL_KERNEL_CACHE") == NULL)
- putenv ((char *) "POCL_KERNEL_CACHE=0");
-
- /**
- * Real init
- */
-
- memset (&data, 0, sizeof (hc_global_data_t));
-
- time_t proc_start;
-
- time (&proc_start);
-
- data.proc_start = proc_start;
-
- int myargc = argc;
- char **myargv = argv;
-
- hc_thread_mutex_init (mux_dispatcher);
- hc_thread_mutex_init (mux_counter);
- hc_thread_mutex_init (mux_display);
- hc_thread_mutex_init (mux_adl);
-
- /**
- * commandline parameters
- */
-
- uint usage = USAGE;
- uint version = VERSION;
- uint quiet = QUIET;
- uint benchmark = BENCHMARK;
- uint show = SHOW;
- uint left = LEFT;
- uint username = USERNAME;
- uint remove = REMOVE;
- uint remove_timer = REMOVE_TIMER;
- u64 skip = SKIP;
- u64 limit = LIMIT;
- uint keyspace = KEYSPACE;
- uint potfile_disable = POTFILE_DISABLE;
- char *potfile_path = NULL;
- uint debug_mode = DEBUG_MODE;
- char *debug_file = NULL;
- char *induction_dir = NULL;
- char *outfile_check_dir = NULL;
- uint force = FORCE;
- uint runtime = RUNTIME;
- uint hash_mode = HASH_MODE;
- uint attack_mode = ATTACK_MODE;
- uint markov_disable = MARKOV_DISABLE;
- uint markov_classic = MARKOV_CLASSIC;
- uint markov_threshold = MARKOV_THRESHOLD;
- char *markov_hcstat = NULL;
- char *outfile = NULL;
- uint outfile_format = OUTFILE_FORMAT;
- uint outfile_autohex = OUTFILE_AUTOHEX;
- uint outfile_check_timer = OUTFILE_CHECK_TIMER;
- uint restore = RESTORE;
- uint restore_timer = RESTORE_TIMER;
- uint restore_disable = RESTORE_DISABLE;
- uint status = STATUS;
- uint status_timer = STATUS_TIMER;
- uint status_automat = STATUS_AUTOMAT;
- uint loopback = LOOPBACK;
- uint weak_hash_threshold = WEAK_HASH_THRESHOLD;
- char *session = NULL;
- uint hex_charset = HEX_CHARSET;
- uint hex_salt = HEX_SALT;
- uint hex_wordlist = HEX_WORDLIST;
- uint rp_gen = RP_GEN;
- uint rp_gen_func_min = RP_GEN_FUNC_MIN;
- uint rp_gen_func_max = RP_GEN_FUNC_MAX;
- uint rp_gen_seed = RP_GEN_SEED;
- char *rule_buf_l = (char *) RULE_BUF_L;
- char *rule_buf_r = (char *) RULE_BUF_R;
- uint increment = INCREMENT;
- uint increment_min = INCREMENT_MIN;
- uint increment_max = INCREMENT_MAX;
- char *cpu_affinity = NULL;
- OCL_PTR *ocl = NULL;
- char *opencl_devices = NULL;
- char *opencl_platforms = NULL;
- char *opencl_device_types = NULL;
- uint opencl_vector_width = OPENCL_VECTOR_WIDTH;
- char *truecrypt_keyfiles = NULL;
- uint workload_profile = WORKLOAD_PROFILE;
- uint kernel_accel = KERNEL_ACCEL;
- uint kernel_loops = KERNEL_LOOPS;
- uint gpu_temp_disable = GPU_TEMP_DISABLE;
- #ifdef HAVE_HWMON
- uint gpu_temp_abort = GPU_TEMP_ABORT;
- uint gpu_temp_retain = GPU_TEMP_RETAIN;
- #ifdef HAVE_ADL
- uint powertune_enable = POWERTUNE_ENABLE;
- #endif
- #endif
- uint logfile_disable = LOGFILE_DISABLE;
- uint segment_size = SEGMENT_SIZE;
- uint scrypt_tmto = SCRYPT_TMTO;
- char separator = SEPARATOR;
- uint bitmap_min = BITMAP_MIN;
- uint bitmap_max = BITMAP_MAX;
- char *custom_charset_1 = NULL;
- char *custom_charset_2 = NULL;
- char *custom_charset_3 = NULL;
- char *custom_charset_4 = NULL;
-
- #define IDX_HELP 'h'
- #define IDX_VERSION 'V'
- #define IDX_VERSION_LOWER 'v'
- #define IDX_QUIET 0xff02
- #define IDX_SHOW 0xff03
- #define IDX_LEFT 0xff04
- #define IDX_REMOVE 0xff05
- #define IDX_REMOVE_TIMER 0xff37
- #define IDX_SKIP 's'
- #define IDX_LIMIT 'l'
- #define IDX_KEYSPACE 0xff35
- #define IDX_POTFILE_DISABLE 0xff06
- #define IDX_POTFILE_PATH 0xffe0
- #define IDX_DEBUG_MODE 0xff43
- #define IDX_DEBUG_FILE 0xff44
- #define IDX_INDUCTION_DIR 0xff46
- #define IDX_OUTFILE_CHECK_DIR 0xff47
- #define IDX_USERNAME 0xff07
- #define IDX_FORCE 0xff08
- #define IDX_RUNTIME 0xff09
- #define IDX_BENCHMARK 'b'
- #define IDX_HASH_MODE 'm'
- #define IDX_ATTACK_MODE 'a'
- #define IDX_RP_FILE 'r'
- #define IDX_RP_GEN 'g'
- #define IDX_RP_GEN_FUNC_MIN 0xff10
- #define IDX_RP_GEN_FUNC_MAX 0xff11
- #define IDX_RP_GEN_SEED 0xff34
- #define IDX_RULE_BUF_L 'j'
- #define IDX_RULE_BUF_R 'k'
- #define IDX_INCREMENT 'i'
- #define IDX_INCREMENT_MIN 0xff12
- #define IDX_INCREMENT_MAX 0xff13
- #define IDX_OUTFILE 'o'
- #define IDX_OUTFILE_FORMAT 0xff14
- #define IDX_OUTFILE_AUTOHEX_DISABLE 0xff39
- #define IDX_OUTFILE_CHECK_TIMER 0xff45
- #define IDX_RESTORE 0xff15
- #define IDX_RESTORE_DISABLE 0xff27
- #define IDX_STATUS 0xff17
- #define IDX_STATUS_TIMER 0xff18
- #define IDX_STATUS_AUTOMAT 0xff50
- #define IDX_LOOPBACK 0xff38
- #define IDX_WEAK_HASH_THRESHOLD 0xff42
- #define IDX_SESSION 0xff19
- #define IDX_HEX_CHARSET 0xff20
- #define IDX_HEX_SALT 0xff21
- #define IDX_HEX_WORDLIST 0xff40
- #define IDX_MARKOV_DISABLE 0xff22
- #define IDX_MARKOV_CLASSIC 0xff23
- #define IDX_MARKOV_THRESHOLD 't'
- #define IDX_MARKOV_HCSTAT 0xff24
- #define IDX_CPU_AFFINITY 0xff25
- #define IDX_OPENCL_DEVICES 'd'
- #define IDX_OPENCL_PLATFORMS 0xff72
- #define IDX_OPENCL_DEVICE_TYPES 0xff73
- #define IDX_OPENCL_VECTOR_WIDTH 0xff74
- #define IDX_WORKLOAD_PROFILE 'w'
- #define IDX_KERNEL_ACCEL 'n'
- #define IDX_KERNEL_LOOPS 'u'
- #define IDX_GPU_TEMP_DISABLE 0xff29
- #define IDX_GPU_TEMP_ABORT 0xff30
- #define IDX_GPU_TEMP_RETAIN 0xff31
- #define IDX_POWERTUNE_ENABLE 0xff41
- #define IDX_LOGFILE_DISABLE 0xff51
- #define IDX_TRUECRYPT_KEYFILES 0xff52
- #define IDX_SCRYPT_TMTO 0xff61
- #define IDX_SEGMENT_SIZE 'c'
- #define IDX_SEPARATOR 'p'
- #define IDX_BITMAP_MIN 0xff70
- #define IDX_BITMAP_MAX 0xff71
- #define IDX_CUSTOM_CHARSET_1 '1'
- #define IDX_CUSTOM_CHARSET_2 '2'
- #define IDX_CUSTOM_CHARSET_3 '3'
- #define IDX_CUSTOM_CHARSET_4 '4'
-
- char short_options[] = "hVvm:a:r:j:k:g:o:t:d:n:u:c:p:s:l:1:2:3:4:ibw:";
-
- struct option long_options[] =
- {
- {"help", no_argument, 0, IDX_HELP},
- {"version", no_argument, 0, IDX_VERSION},
- {"quiet", no_argument, 0, IDX_QUIET},
- {"show", no_argument, 0, IDX_SHOW},
- {"left", no_argument, 0, IDX_LEFT},
- {"username", no_argument, 0, IDX_USERNAME},
- {"remove", no_argument, 0, IDX_REMOVE},
- {"remove-timer", required_argument, 0, IDX_REMOVE_TIMER},
- {"skip", required_argument, 0, IDX_SKIP},
- {"limit", required_argument, 0, IDX_LIMIT},
- {"keyspace", no_argument, 0, IDX_KEYSPACE},
- {"potfile-disable", no_argument, 0, IDX_POTFILE_DISABLE},
- {"potfile-path", required_argument, 0, IDX_POTFILE_PATH},
- {"debug-mode", required_argument, 0, IDX_DEBUG_MODE},
- {"debug-file", required_argument, 0, IDX_DEBUG_FILE},
- {"induction-dir", required_argument, 0, IDX_INDUCTION_DIR},
- {"outfile-check-dir", required_argument, 0, IDX_OUTFILE_CHECK_DIR},
- {"force", no_argument, 0, IDX_FORCE},
- {"benchmark", no_argument, 0, IDX_BENCHMARK},
- {"restore", no_argument, 0, IDX_RESTORE},
- {"restore-disable", no_argument, 0, IDX_RESTORE_DISABLE},
- {"status", no_argument, 0, IDX_STATUS},
- {"status-timer", required_argument, 0, IDX_STATUS_TIMER},
- {"status-automat", no_argument, 0, IDX_STATUS_AUTOMAT},
- {"loopback", no_argument, 0, IDX_LOOPBACK},
- {"weak-hash-threshold",
- required_argument, 0, IDX_WEAK_HASH_THRESHOLD},
- {"session", required_argument, 0, IDX_SESSION},
- {"runtime", required_argument, 0, IDX_RUNTIME},
- {"generate-rules", required_argument, 0, IDX_RP_GEN},
- {"generate-rules-func-min",
- required_argument, 0, IDX_RP_GEN_FUNC_MIN},
- {"generate-rules-func-max",
- required_argument, 0, IDX_RP_GEN_FUNC_MAX},
- {"generate-rules-seed",
- required_argument, 0, IDX_RP_GEN_SEED},
- {"rule-left", required_argument, 0, IDX_RULE_BUF_L},
- {"rule-right", required_argument, 0, IDX_RULE_BUF_R},
- {"hash-type", required_argument, 0, IDX_HASH_MODE},
- {"attack-mode", required_argument, 0, IDX_ATTACK_MODE},
- {"rules-file", required_argument, 0, IDX_RP_FILE},
- {"outfile", required_argument, 0, IDX_OUTFILE},
- {"outfile-format", required_argument, 0, IDX_OUTFILE_FORMAT},
- {"outfile-autohex-disable",
- no_argument, 0, IDX_OUTFILE_AUTOHEX_DISABLE},
- {"outfile-check-timer",
- required_argument, 0, IDX_OUTFILE_CHECK_TIMER},
- {"hex-charset", no_argument, 0, IDX_HEX_CHARSET},
- {"hex-salt", no_argument, 0, IDX_HEX_SALT},
- {"hex-wordlist", no_argument, 0, IDX_HEX_WORDLIST},
- {"markov-disable", no_argument, 0, IDX_MARKOV_DISABLE},
- {"markov-classic", no_argument, 0, IDX_MARKOV_CLASSIC},
- {"markov-threshold", required_argument, 0, IDX_MARKOV_THRESHOLD},
- {"markov-hcstat", required_argument, 0, IDX_MARKOV_HCSTAT},
- {"cpu-affinity", required_argument, 0, IDX_CPU_AFFINITY},
- {"opencl-devices", required_argument, 0, IDX_OPENCL_DEVICES},
- {"opencl-platforms", required_argument, 0, IDX_OPENCL_PLATFORMS},
- {"opencl-device-types", required_argument, 0, IDX_OPENCL_DEVICE_TYPES},
- {"opencl-vector-width", required_argument, 0, IDX_OPENCL_VECTOR_WIDTH},
- {"workload-profile", required_argument, 0, IDX_WORKLOAD_PROFILE},
- {"kernel-accel", required_argument, 0, IDX_KERNEL_ACCEL},
- {"kernel-loops", required_argument, 0, IDX_KERNEL_LOOPS},
- {"gpu-temp-disable", no_argument, 0, IDX_GPU_TEMP_DISABLE},
- #ifdef HAVE_HWMON
- {"gpu-temp-abort", required_argument, 0, IDX_GPU_TEMP_ABORT},
- {"gpu-temp-retain", required_argument, 0, IDX_GPU_TEMP_RETAIN},
- #ifdef HAVE_ADL
- {"powertune-enable", no_argument, 0, IDX_POWERTUNE_ENABLE},
- #endif
- #endif // HAVE_HWMON
- {"logfile-disable", no_argument, 0, IDX_LOGFILE_DISABLE},
- {"truecrypt-keyfiles", required_argument, 0, IDX_TRUECRYPT_KEYFILES},
- {"segment-size", required_argument, 0, IDX_SEGMENT_SIZE},
- {"scrypt-tmto", required_argument, 0, IDX_SCRYPT_TMTO},
- // deprecated
- {"seperator", required_argument, 0, IDX_SEPARATOR},
- {"separator", required_argument, 0, IDX_SEPARATOR},
- {"bitmap-min", required_argument, 0, IDX_BITMAP_MIN},
- {"bitmap-max", required_argument, 0, IDX_BITMAP_MAX},
- {"increment", no_argument, 0, IDX_INCREMENT},
- {"increment-min", required_argument, 0, IDX_INCREMENT_MIN},
- {"increment-max", required_argument, 0, IDX_INCREMENT_MAX},
- {"custom-charset1", required_argument, 0, IDX_CUSTOM_CHARSET_1},
- {"custom-charset2", required_argument, 0, IDX_CUSTOM_CHARSET_2},
- {"custom-charset3", required_argument, 0, IDX_CUSTOM_CHARSET_3},
- {"custom-charset4", required_argument, 0, IDX_CUSTOM_CHARSET_4},
-
- {0, 0, 0, 0}
- };
-
- uint rp_files_cnt = 0;
-
- char **rp_files = (char **) mycalloc (argc, sizeof (char *));
-
- int option_index = 0;
- int c = -1;
-
- optind = 1;
- optopt = 0;
-
- while (((c = getopt_long (argc, argv, short_options, long_options, &option_index)) != -1) && optopt == 0)
- {
- switch (c)
- {
- case IDX_HELP: usage = 1; break;
- case IDX_VERSION:
- case IDX_VERSION_LOWER: version = 1; break;
- case IDX_RESTORE: restore = 1; break;
- case IDX_SESSION: session = optarg; break;
- case IDX_SHOW: show = 1; break;
- case IDX_LEFT: left = 1; break;
- case '?': return (-1);
- }
- }
-
- if (optopt != 0)
- {
- log_error ("ERROR: Invalid argument specified");
-
- return (-1);
- }
-
- /**
- * exit functions
- */
-
- if (version)
- {
- log_info ("%s (%s)", VERSION_TAG, VERSION_SUM);
-
- return (0);
- }
-
- if (usage)
- {
- usage_big_print (PROGNAME);
-
- return (0);
- }
-
- /**
- * session needs to be set, always!
- */
-
- if (session == NULL) session = (char *) PROGNAME;
-
- /**
- * folders, as discussed on https://github.com/hashcat/oclHashcat/issues/20
- */
-
- char *exec_path = get_exec_path ();
-
- #ifdef LINUX
-
- char *resolved_install_folder = realpath (INSTALL_FOLDER, NULL);
- char *resolved_exec_path = realpath (exec_path, NULL);
-
- char *install_dir = get_install_dir (resolved_exec_path);
- char *profile_dir = NULL;
- char *session_dir = NULL;
- char *shared_dir = NULL;
-
- if (strcmp (install_dir, resolved_install_folder) == 0)
- {
- struct passwd *pw = getpwuid (getuid ());
-
- const char *homedir = pw->pw_dir;
-
- profile_dir = get_profile_dir (homedir);
- session_dir = get_session_dir (profile_dir);
- shared_dir = strdup (SHARED_FOLDER);
-
- mkdir (profile_dir, 0700);
- mkdir (session_dir, 0700);
- }
- else
- {
- profile_dir = install_dir;
- session_dir = install_dir;
- shared_dir = install_dir;
- }
-
- myfree (resolved_install_folder);
- myfree (resolved_exec_path);
-
- #else
-
- char *install_dir = get_install_dir (exec_path);
- char *profile_dir = install_dir;
- char *session_dir = install_dir;
- char *shared_dir = install_dir;
-
- #endif
-
- data.install_dir = install_dir;
- data.profile_dir = profile_dir;
- data.session_dir = session_dir;
- data.shared_dir = shared_dir;
-
- myfree (exec_path);
-
- /**
- * kernel cache, we need to make sure folder exist
- */
-
- int kernels_folder_size = strlen (profile_dir) + 1 + 7 + 1 + 1;
-
- char *kernels_folder = (char *) mymalloc (kernels_folder_size);
-
- snprintf (kernels_folder, kernels_folder_size - 1, "%s/kernels", profile_dir);
-
- mkdir (kernels_folder, 0700);
-
- myfree (kernels_folder);
-
- /**
- * session
- */
-
- size_t session_size = strlen (session_dir) + 1 + strlen (session) + 32;
-
- data.session = session;
-
- char *eff_restore_file = (char *) mymalloc (session_size);
- char *new_restore_file = (char *) mymalloc (session_size);
-
- snprintf (eff_restore_file, session_size - 1, "%s/%s.restore", data.session_dir, session);
- snprintf (new_restore_file, session_size - 1, "%s/%s.restore.new", data.session_dir, session);
-
- data.eff_restore_file = eff_restore_file;
- data.new_restore_file = new_restore_file;
-
- if (((show == 1) || (left == 1)) && (restore == 1))
- {
- if (show == 1) log_error ("ERROR: Mixing --restore parameter and --show is not supported");
- else log_error ("ERROR: Mixing --restore parameter and --left is not supported");
-
- return (-1);
- }
-
- // this allows the user to use --show and --left while cracking (i.e. while another instance of oclHashcat is running)
- if ((show == 1) || (left == 1))
- {
- restore_disable = 1;
-
- restore = 0;
- }
-
- data.restore_disable = restore_disable;
-
- restore_data_t *rd = init_restore (argc, argv);
-
- data.rd = rd;
-
- /**
- * restore file
- */
-
- if (restore == 1)
- {
- read_restore (eff_restore_file, rd);
-
- if (rd->version_bin < RESTORE_MIN)
- {
- log_error ("ERROR: Incompatible restore-file version");
-
- return (-1);
- }
-
- myargc = rd->argc;
- myargv = rd->argv;
-
- #ifdef _POSIX
- rd->pid = getpid ();
- #elif _WIN
- rd->pid = GetCurrentProcessId ();
- #endif
- }
-
- uint hash_mode_chgd = 0;
- uint runtime_chgd = 0;
- uint kernel_loops_chgd = 0;
- uint kernel_accel_chgd = 0;
- uint attack_mode_chgd = 0;
- uint outfile_format_chgd = 0;
- uint rp_gen_seed_chgd = 0;
- uint remove_timer_chgd = 0;
- uint increment_min_chgd = 0;
- uint increment_max_chgd = 0;
- uint workload_profile_chgd = 0;
- uint opencl_vector_width_chgd = 0;
-
- #if defined(HAVE_HWMON) && defined(HAVE_ADL)
- uint gpu_temp_retain_chgd = 0;
- uint gpu_temp_abort_chgd = 0;
- #endif
-
- optind = 1;
- optopt = 0;
- option_index = 0;
-
- while (((c = getopt_long (myargc, myargv, short_options, long_options, &option_index)) != -1) && optopt == 0)
- {
- switch (c)
- {
- //case IDX_HELP: usage = 1; break;
- //case IDX_VERSION: version = 1; break;
- //case IDX_RESTORE: restore = 1; break;
- case IDX_QUIET: quiet = 1; break;
- //case IDX_SHOW: show = 1; break;
- case IDX_SHOW: break;
- //case IDX_LEFT: left = 1; break;
- case IDX_LEFT: break;
- case IDX_USERNAME: username = 1; break;
- case IDX_REMOVE: remove = 1; break;
- case IDX_REMOVE_TIMER: remove_timer = atoi (optarg);
- remove_timer_chgd = 1; break;
- case IDX_POTFILE_DISABLE: potfile_disable = 1; break;
- case IDX_POTFILE_PATH: potfile_path = optarg; break;
- case IDX_DEBUG_MODE: debug_mode = atoi (optarg); break;
- case IDX_DEBUG_FILE: debug_file = optarg; break;
- case IDX_INDUCTION_DIR: induction_dir = optarg; break;
- case IDX_OUTFILE_CHECK_DIR: outfile_check_dir = optarg; break;
- case IDX_FORCE: force = 1; break;
- case IDX_SKIP: skip = atoll (optarg); break;
- case IDX_LIMIT: limit = atoll (optarg); break;
- case IDX_KEYSPACE: keyspace = 1; break;
- case IDX_BENCHMARK: benchmark = 1; break;
- case IDX_RESTORE: break;
- case IDX_RESTORE_DISABLE: restore_disable = 1; break;
- case IDX_STATUS: status = 1; break;
- case IDX_STATUS_TIMER: status_timer = atoi (optarg); break;
- case IDX_STATUS_AUTOMAT: status_automat = 1; break;
- case IDX_LOOPBACK: loopback = 1; break;
- case IDX_WEAK_HASH_THRESHOLD:
- weak_hash_threshold = atoi (optarg); break;
- //case IDX_SESSION: session = optarg; break;
- case IDX_SESSION: break;
- case IDX_HASH_MODE: hash_mode = atoi (optarg);
- hash_mode_chgd = 1; break;
- case IDX_RUNTIME: runtime = atoi (optarg);
- runtime_chgd = 1; break;
- case IDX_ATTACK_MODE: attack_mode = atoi (optarg);
- attack_mode_chgd = 1; break;
- case IDX_RP_FILE: rp_files[rp_files_cnt++] = optarg; break;
- case IDX_RP_GEN: rp_gen = atoi (optarg); break;
- case IDX_RP_GEN_FUNC_MIN: rp_gen_func_min = atoi (optarg); break;
- case IDX_RP_GEN_FUNC_MAX: rp_gen_func_max = atoi (optarg); break;
- case IDX_RP_GEN_SEED: rp_gen_seed = atoi (optarg);
- rp_gen_seed_chgd = 1; break;
- case IDX_RULE_BUF_L: rule_buf_l = optarg; break;
- case IDX_RULE_BUF_R: rule_buf_r = optarg; break;
- case IDX_MARKOV_DISABLE: markov_disable = 1; break;
- case IDX_MARKOV_CLASSIC: markov_classic = 1; break;
- case IDX_MARKOV_THRESHOLD: markov_threshold = atoi (optarg); break;
- case IDX_MARKOV_HCSTAT: markov_hcstat = optarg; break;
- case IDX_OUTFILE: outfile = optarg; break;
- case IDX_OUTFILE_FORMAT: outfile_format = atoi (optarg);
- outfile_format_chgd = 1; break;
- case IDX_OUTFILE_AUTOHEX_DISABLE:
- outfile_autohex = 0; break;
- case IDX_OUTFILE_CHECK_TIMER:
- outfile_check_timer = atoi (optarg); break;
- case IDX_HEX_CHARSET: hex_charset = 1; break;
- case IDX_HEX_SALT: hex_salt = 1; break;
- case IDX_HEX_WORDLIST: hex_wordlist = 1; break;
- case IDX_CPU_AFFINITY: cpu_affinity = optarg; break;
- case IDX_OPENCL_DEVICES: opencl_devices = optarg; break;
- case IDX_OPENCL_PLATFORMS: opencl_platforms = optarg; break;
- case IDX_OPENCL_DEVICE_TYPES:
- opencl_device_types = optarg; break;
- case IDX_OPENCL_VECTOR_WIDTH:
- opencl_vector_width = atoi (optarg);
- opencl_vector_width_chgd = 1; break;
- case IDX_WORKLOAD_PROFILE: workload_profile = atoi (optarg);
- workload_profile_chgd = 1; break;
- case IDX_KERNEL_ACCEL: kernel_accel = atoi (optarg);
- kernel_accel_chgd = 1; break;
- case IDX_KERNEL_LOOPS: kernel_loops = atoi (optarg);
- kernel_loops_chgd = 1; break;
- case IDX_GPU_TEMP_DISABLE: gpu_temp_disable = 1; break;
- #ifdef HAVE_HWMON
- case IDX_GPU_TEMP_ABORT: gpu_temp_abort = atoi (optarg);
- #ifdef HAVE_ADL
- gpu_temp_abort_chgd = 1;
- #endif
- break;
- case IDX_GPU_TEMP_RETAIN: gpu_temp_retain = atoi (optarg);
- #ifdef HAVE_ADL
- gpu_temp_retain_chgd = 1;
- #endif
- break;
- #ifdef HAVE_ADL
- case IDX_POWERTUNE_ENABLE: powertune_enable = 1; break;
- #endif
- #endif // HAVE_HWMON
- case IDX_LOGFILE_DISABLE: logfile_disable = 1; break;
- case IDX_TRUECRYPT_KEYFILES: truecrypt_keyfiles = optarg; break;
- case IDX_SEGMENT_SIZE: segment_size = atoi (optarg); break;
- case IDX_SCRYPT_TMTO: scrypt_tmto = atoi (optarg); break;
- case IDX_SEPARATOR: separator = optarg[0]; break;
- case IDX_BITMAP_MIN: bitmap_min = atoi (optarg); break;
- case IDX_BITMAP_MAX: bitmap_max = atoi (optarg); break;
- case IDX_INCREMENT: increment = 1; break;
- case IDX_INCREMENT_MIN: increment_min = atoi (optarg);
- increment_min_chgd = 1; break;
- case IDX_INCREMENT_MAX: increment_max = atoi (optarg);
- increment_max_chgd = 1; break;
- case IDX_CUSTOM_CHARSET_1: custom_charset_1 = optarg; break;
- case IDX_CUSTOM_CHARSET_2: custom_charset_2 = optarg; break;
- case IDX_CUSTOM_CHARSET_3: custom_charset_3 = optarg; break;
- case IDX_CUSTOM_CHARSET_4: custom_charset_4 = optarg; break;
-
- default:
- log_error ("ERROR: Invalid argument specified");
- return (-1);
- }
- }
-
- if (optopt != 0)
- {
- log_error ("ERROR: Invalid argument specified");
-
- return (-1);
- }
-
- /**
- * Inform user things getting started,
- * - this is giving us a visual header before preparations start, so we do not need to clear them afterwards
- * - we do not need to check algorithm_pos
- */
-
- if (quiet == 0)
- {
- if (benchmark == 1)
- {
- log_info ("%s %s (%s) starting in benchmark-mode...", PROGNAME, VERSION_TAG, VERSION_SUM);
-
- log_info ("");
- }
- else if (restore == 1)
- {
- log_info ("%s %s (%s) starting in restore-mode...", PROGNAME, VERSION_TAG, VERSION_SUM);
-
- log_info ("");
- }
- else
- {
- log_info ("%s %s (%s) starting...", PROGNAME, VERSION_TAG, VERSION_SUM);
-
- log_info ("");
- }
- }
-
- /**
- * sanity check
- */
-
- if (attack_mode > 7)
- {
- log_error ("ERROR: Invalid attack-mode specified");
-
- return (-1);
- }
-
- if (runtime_chgd && runtime == 0) // just added to remove compiler warnings for runtime_chgd
- {
- log_error ("ERROR: Invalid runtime specified");
-
- return (-1);
- }
-
- if (hash_mode_chgd && hash_mode > 13500) // just added to remove compiler warnings for hash_mode_chgd
- {
- log_error ("ERROR: Invalid hash-type specified");
-
- return (-1);
- }
-
- // renamed hash modes
-
- if (hash_mode_chgd)
- {
- int n = -1;
-
- switch (hash_mode)
- {
- case 123: n = 124;
- break;
- }
-
- if (n >= 0)
- {
- log_error ("Old -m specified, use -m %d instead", n);
-
- return (-1);
- }
- }
-
- if (username == 1)
- {
- if ((hash_mode == 2500) || (hash_mode == 5200) || ((hash_mode >= 6200) && (hash_mode <= 6299)))
- {
- log_error ("ERROR: Mixing support for user names and hashes of type %s is not supported", strhashtype (hash_mode));
-
- return (-1);
- }
- }
-
- if (outfile_format > 16)
- {
- log_error ("ERROR: Invalid outfile-format specified");
-
- return (-1);
- }
-
- if (left == 1)
- {
- if (outfile_format_chgd == 1)
- {
- if (outfile_format > 1)
- {
- log_error ("ERROR: Mixing outfile-format > 1 is not allowed together with left parameter");
-
- return (-1);
- }
- }
- else
- {
- outfile_format = OUTFILE_FMT_HASH;
- }
- }
-
- if (show == 1)
- {
- if (outfile_format_chgd == 1)
- {
- if ((outfile_format > 7) && (outfile_format < 16))
- {
- log_error ("ERROR: Mixing outfile-format > 7 is not allowed together with show parameter");
-
- return (-1);
- }
- }
- }
-
- if (increment_min < INCREMENT_MIN)
- {
- log_error ("ERROR: Invalid increment-min specified");
-
- return (-1);
- }
-
- if (increment_max > INCREMENT_MAX)
- {
- log_error ("ERROR: Invalid increment-max specified");
-
- return (-1);
- }
-
- if (increment_min > increment_max)
- {
- log_error ("ERROR: Invalid increment-min specified");
-
- return (-1);
- }
-
- if ((increment == 1) && (attack_mode == ATTACK_MODE_STRAIGHT))
- {
- log_error ("ERROR: increment is not allowed in attack-mode 0");
-
- return (-1);
- }
-
- if ((increment == 0) && (increment_min_chgd == 1))
- {
- log_error ("ERROR: increment-min is only supported together with increment switch");
-
- return (-1);
- }
-
- if ((increment == 0) && (increment_max_chgd == 1))
- {
- log_error ("ERROR: increment-max is only supported together with increment switch");
-
- return (-1);
- }
-
- if (rp_files_cnt && rp_gen)
- {
- log_error ("ERROR: Use of both rules-file and rules-generate is not supported");
-
- return (-1);
- }
-
- if (rp_files_cnt || rp_gen)
- {
- if (attack_mode != ATTACK_MODE_STRAIGHT)
- {
- log_error ("ERROR: Use of rules-file or rules-generate only allowed in attack-mode 0");
-
- return (-1);
- }
- }
-
- if (rp_gen_func_min > rp_gen_func_max)
- {
- log_error ("ERROR: Invalid rp-gen-func-min specified");
-
- return (-1);
- }
-
- if (kernel_accel_chgd == 1)
- {
- if (kernel_accel < 1)
- {
- log_error ("ERROR: Invalid kernel-accel specified");
-
- return (-1);
- }
-
- if (kernel_accel > 1024)
- {
- log_error ("ERROR: Invalid kernel-accel specified");
-
- return (-1);
- }
- }
-
- if (kernel_loops_chgd == 1)
- {
- if (kernel_loops < 1)
- {
- log_error ("ERROR: Invalid kernel-loops specified");
-
- return (-1);
- }
-
- if (kernel_loops > 1024)
- {
- log_error ("ERROR: Invalid kernel-loops specified");
-
- return (-1);
- }
- }
-
- if ((workload_profile < 1) || (workload_profile > 3))
- {
- log_error ("ERROR: workload-profile %i not available", workload_profile);
-
- return (-1);
- }
-
- if (opencl_vector_width_chgd && (!is_power_of_2(opencl_vector_width) || opencl_vector_width > 16))
- {
- log_error ("ERROR: opencl-vector-width %i not allowed", opencl_vector_width);
-
- return (-1);
- }
-
- if (show == 1 || left == 1)
- {
- attack_mode = ATTACK_MODE_NONE;
-
- if (remove == 1)
- {
- log_error ("ERROR: Mixing remove parameter not allowed with show parameter or left parameter");
-
- return (-1);
- }
-
- if (potfile_disable == 1)
- {
- log_error ("ERROR: Mixing potfile-disable parameter not allowed with show parameter or left parameter");
-
- return (-1);
- }
- }
-
- uint attack_kern = ATTACK_KERN_NONE;
-
- switch (attack_mode)
- {
- case ATTACK_MODE_STRAIGHT: attack_kern = ATTACK_KERN_STRAIGHT; break;
- case ATTACK_MODE_COMBI: attack_kern = ATTACK_KERN_COMBI; break;
- case ATTACK_MODE_BF: attack_kern = ATTACK_KERN_BF; break;
- case ATTACK_MODE_HYBRID1: attack_kern = ATTACK_KERN_COMBI; break;
- case ATTACK_MODE_HYBRID2: attack_kern = ATTACK_KERN_COMBI; break;
- }
-
- if (benchmark == 0)
- {
- if (keyspace == 1)
- {
- int num_additional_params = 1;
-
- if (attack_kern == ATTACK_KERN_COMBI)
- {
- num_additional_params = 2;
- }
-
- int keyspace_wordlist_specified = myargc - optind - num_additional_params;
-
- if (keyspace_wordlist_specified == 0) optind--;
- }
-
- if (attack_kern == ATTACK_KERN_NONE)
- {
- if ((optind + 1) != myargc)
- {
- usage_mini_print (myargv[0]);
-
- return (-1);
- }
- }
- else if (attack_kern == ATTACK_KERN_STRAIGHT)
- {
- if ((optind + 1) > myargc)
- {
- usage_mini_print (myargv[0]);
-
- return (-1);
- }
- }
- else if (attack_kern == ATTACK_KERN_COMBI)
- {
- if ((optind + 3) != myargc)
- {
- usage_mini_print (myargv[0]);
-
- return (-1);
- }
- }
- else if (attack_kern == ATTACK_KERN_BF)
- {
- if ((optind + 1) > myargc)
- {
- usage_mini_print (myargv[0]);
-
- return (-1);
- }
- }
- else
- {
- usage_mini_print (myargv[0]);
-
- return (-1);
- }
- }
- else
- {
- if (myargv[optind] != 0)
- {
- log_error ("ERROR: Invalid argument for benchmark mode specified");
-
- return (-1);
- }
-
- if (attack_mode_chgd == 1)
- {
- if (attack_mode != ATTACK_MODE_BF)
- {
- log_error ("ERROR: Only attack-mode 3 allowed in benchmark mode");
-
- return (-1);
- }
- }
- }
-
- if (skip != 0 && limit != 0)
- {
- limit += skip;
- }
-
- if (keyspace == 1)
- {
- if (show == 1)
- {
- log_error ("ERROR: Mixing show parameter not supported with keyspace parameter");
-
- return (-1);
- }
- else if (left == 1)
- {
- log_error ("ERROR: Mixing left parameter not supported wiht keyspace parameter");
-
- return (-1);
- }
-
- potfile_disable = 1;
-
- restore_disable = 1;
-
- restore = 0;
-
- weak_hash_threshold = 0;
-
- quiet = 1;
- }
-
- if (remove_timer_chgd == 1)
- {
- if (remove == 0)
- {
- log_error ("ERROR: Parameter remove-timer require parameter remove enabled");
-
- return (-1);
- }
-
- if (remove_timer < 1)
- {
- log_error ("ERROR: Parameter remove-timer must have a value greater than or equal to 1");
-
- return (-1);
- }
- }
-
- if (loopback == 1)
- {
- if (attack_mode == ATTACK_MODE_STRAIGHT)
- {
- if ((rp_files_cnt == 0) && (rp_gen == 0))
- {
- log_error ("ERROR: Parameter loopback not allowed without rules-file or rules-generate");
-
- return (-1);
- }
- }
- else
- {
- log_error ("ERROR: Parameter loopback allowed in attack-mode 0 only");
-
- return (-1);
- }
- }
-
- if (debug_mode > 0)
- {
- if (attack_mode != ATTACK_MODE_STRAIGHT)
- {
- log_error ("ERROR: Parameter debug-mode option is only available with attack-mode 0");
-
- return (-1);
- }
-
- if ((rp_files_cnt == 0) && (rp_gen == 0))
- {
- log_error ("ERROR: Parameter debug-mode not allowed without rules-file or rules-generate");
-
- return (-1);
- }
- }
-
- if (debug_mode > 4)
- {
- log_error ("ERROR: Invalid debug-mode specified");
-
- return (-1);
- }
-
- if (debug_file != NULL)
- {
- if (debug_mode < 1)
- {
- log_error ("ERROR: Parameter debug-file requires parameter debug-mode to be set");
-
- return (-1);
- }
- }
-
- if (induction_dir != NULL)
- {
- if (attack_mode == ATTACK_MODE_BF)
- {
- log_error ("ERROR: Parameter induction-dir not allowed with brute-force attacks");
-
- return (-1);
- }
- }
-
- if (attack_mode != ATTACK_MODE_STRAIGHT)
- {
- if ((weak_hash_threshold != WEAK_HASH_THRESHOLD) && (weak_hash_threshold != 0))
- {
- log_error ("ERROR: setting --weak-hash-threshold allowed only in straight-attack mode");
-
- return (-1);
- }
-
- weak_hash_threshold = 0;
- }
-
- /**
- * induction directory
- */
-
- char *induction_directory = NULL;
-
- if (attack_mode != ATTACK_MODE_BF)
- {
- if (induction_dir == NULL)
- {
- induction_directory = (char *) mymalloc (session_size);
-
- snprintf (induction_directory, session_size - 1, "%s/%s.%s", session_dir, session, INDUCT_DIR);
-
- // create induction folder if it does not already exist
-
- if (keyspace == 0)
- {
- if (rmdir (induction_directory) == -1)
- {
- if (errno == ENOENT)
- {
- // good, we can ignore
- }
- else if (errno == ENOTEMPTY)
- {
- char *induction_directory_mv = (char *) mymalloc (session_size);
-
- snprintf (induction_directory_mv, session_size - 1, "%s/%s.induct.%d", session_dir, session, (int) proc_start);
-
- if (rename (induction_directory, induction_directory_mv) != 0)
- {
- log_error ("ERROR: Rename directory %s to %s: %s", induction_directory, induction_directory_mv, strerror (errno));
-
- return (-1);
- }
- }
- else
- {
- log_error ("ERROR: %s: %s", induction_directory, strerror (errno));
-
- return (-1);
- }
- }
-
- if (mkdir (induction_directory, 0700) == -1)
- {
- log_error ("ERROR: %s: %s", induction_directory, strerror (errno));
-
- return (-1);
- }
- }
- }
- else
- {
- induction_directory = induction_dir;
- }
- }
-
- data.induction_directory = induction_directory;
-
- /**
- * loopback
- */
-
- size_t loopback_size = strlen (session_dir) + 1 + session_size + strlen (LOOPBACK_FILE) + 12;
-
- char *loopback_file = (char *) mymalloc (loopback_size);
-
- /**
- * tuning db
- */
-
- char tuning_db_file[256] = { 0 };
-
- snprintf (tuning_db_file, sizeof (tuning_db_file) - 1, "%s/%s", shared_dir, TUNING_DB_FILE);
-
- tuning_db_t *tuning_db = tuning_db_init (tuning_db_file);
-
- /**
- * outfile-check directory
- */
-
- char *outfile_check_directory = NULL;
-
- if (outfile_check_dir == NULL)
- {
- outfile_check_directory = (char *) mymalloc (session_size);
-
- snprintf (outfile_check_directory, session_size - 1, "%s/%s.%s", session_dir, session, OUTFILES_DIR);
- }
- else
- {
- outfile_check_directory = outfile_check_dir;
- }
-
- data.outfile_check_directory = outfile_check_directory;
-
- if (keyspace == 0)
- {
- struct stat outfile_check_stat;
-
- if (stat (outfile_check_directory, &outfile_check_stat) == 0)
- {
- uint is_dir = S_ISDIR (outfile_check_stat.st_mode);
-
- if (is_dir == 0)
- {
- log_error ("ERROR: Directory specified in outfile-check '%s' is not a valid directory", outfile_check_directory);
-
- return (-1);
- }
- }
- else if (outfile_check_dir == NULL)
- {
- if (mkdir (outfile_check_directory, 0700) == -1)
- {
- log_error ("ERROR: %s: %s", outfile_check_directory, strerror (errno));
-
- return (-1);
- }
- }
- }
-
- /**
- * special other stuff
- */
-
- if (hash_mode == 9710)
- {
- outfile_format = 5;
- outfile_format_chgd = 1;
- }
-
- if (hash_mode == 9810)
- {
- outfile_format = 5;
- outfile_format_chgd = 1;
- }
-
- if (hash_mode == 10410)
- {
- outfile_format = 5;
- outfile_format_chgd = 1;
- }
-
- /**
- * store stuff
- */
-
- data.hash_mode = hash_mode;
- data.restore = restore;
- data.restore_timer = restore_timer;
- data.restore_disable = restore_disable;
- data.status = status;
- data.status_timer = status_timer;
- data.status_automat = status_automat;
- data.loopback = loopback;
- data.runtime = runtime;
- data.remove = remove;
- data.remove_timer = remove_timer;
- data.debug_mode = debug_mode;
- data.debug_file = debug_file;
- data.username = username;
- data.quiet = quiet;
- data.outfile = outfile;
- data.outfile_format = outfile_format;
- data.outfile_autohex = outfile_autohex;
- data.hex_charset = hex_charset;
- data.hex_salt = hex_salt;
- data.hex_wordlist = hex_wordlist;
- data.separator = separator;
- data.rp_files = rp_files;
- data.rp_files_cnt = rp_files_cnt;
- data.rp_gen = rp_gen;
- data.rp_gen_seed = rp_gen_seed;
- data.force = force;
- data.benchmark = benchmark;
- data.skip = skip;
- data.limit = limit;
- #if defined(HAVE_HWMON) && defined(HAVE_ADL)
- data.powertune_enable = powertune_enable;
- #endif
- data.logfile_disable = logfile_disable;
- data.truecrypt_keyfiles = truecrypt_keyfiles;
- data.scrypt_tmto = scrypt_tmto;
- data.workload_profile = workload_profile;
-
- /**
- * cpu affinity
- */
-
- if (cpu_affinity)
- {
- set_cpu_affinity (cpu_affinity);
- }
-
- if (rp_gen_seed_chgd == 0)
- {
- srand (proc_start);
- }
- else
- {
- srand (rp_gen_seed);
- }
-
- /**
- * logfile init
- */
-
- if (logfile_disable == 0)
- {
- size_t logfile_size = strlen (session_dir) + 1 + strlen (session) + 32;
-
- char *logfile = (char *) mymalloc (logfile_size);
-
- snprintf (logfile, logfile_size - 1, "%s/%s.log", session_dir, session);
-
- data.logfile = logfile;
-
- char *topid = logfile_generate_topid ();
-
- data.topid = topid;
- }
-
- // logfile_append() checks for logfile_disable internally to make it easier from here
-
- #define logfile_top_msg(msg) logfile_append ("%s\t%s", data.topid, (msg));
- #define logfile_sub_msg(msg) logfile_append ("%s\t%s\t%s", data.topid, data.subid, (msg));
- #define logfile_top_var_uint64(var,val) logfile_append ("%s\t%s\t%llu", data.topid, (var), (val));
- #define logfile_sub_var_uint64(var,val) logfile_append ("%s\t%s\t%s\t%llu", data.topid, data.subid, (var), (val));
- #define logfile_top_var_uint(var,val) logfile_append ("%s\t%s\t%u", data.topid, (var), (val));
- #define logfile_sub_var_uint(var,val) logfile_append ("%s\t%s\t%s\t%u", data.topid, data.subid, (var), (val));
- #define logfile_top_var_char(var,val) logfile_append ("%s\t%s\t%c", data.topid, (var), (val));
- #define logfile_sub_var_char(var,val) logfile_append ("%s\t%s\t%s\t%c", data.topid, data.subid, (var), (val));
- #define logfile_top_var_string(var,val) if ((val) != NULL) logfile_append ("%s\t%s\t%s", data.topid, (var), (val));
- #define logfile_sub_var_string(var,val) if ((val) != NULL) logfile_append ("%s\t%s\t%s\t%s", data.topid, data.subid, (var), (val));
-
- #define logfile_top_uint64(var) logfile_top_var_uint64 (#var, (var));
- #define logfile_sub_uint64(var) logfile_sub_var_uint64 (#var, (var));
- #define logfile_top_uint(var) logfile_top_var_uint (#var, (var));
- #define logfile_sub_uint(var) logfile_sub_var_uint (#var, (var));
- #define logfile_top_char(var) logfile_top_var_char (#var, (var));
- #define logfile_sub_char(var) logfile_sub_var_char (#var, (var));
- #define logfile_top_string(var) logfile_top_var_string (#var, (var));
- #define logfile_sub_string(var) logfile_sub_var_string (#var, (var));
-
- logfile_top_msg ("START");
-
- logfile_top_uint (attack_mode);
- logfile_top_uint (attack_kern);
- logfile_top_uint (benchmark);
- logfile_top_uint (bitmap_min);
- logfile_top_uint (bitmap_max);
- logfile_top_uint (debug_mode);
- logfile_top_uint (force);
- logfile_top_uint (kernel_accel);
- logfile_top_uint (kernel_loops);
- logfile_top_uint (gpu_temp_disable);
- #ifdef HAVE_HWMON
- logfile_top_uint (gpu_temp_abort);
- logfile_top_uint (gpu_temp_retain);
- #endif
- logfile_top_uint (hash_mode);
- logfile_top_uint (hex_charset);
- logfile_top_uint (hex_salt);
- logfile_top_uint (hex_wordlist);
- logfile_top_uint (increment);
- logfile_top_uint (increment_max);
- logfile_top_uint (increment_min);
- logfile_top_uint (keyspace);
- logfile_top_uint (left);
- logfile_top_uint (logfile_disable);
- logfile_top_uint (loopback);
- logfile_top_uint (markov_classic);
- logfile_top_uint (markov_disable);
- logfile_top_uint (markov_threshold);
- logfile_top_uint (outfile_autohex);
- logfile_top_uint (outfile_check_timer);
- logfile_top_uint (outfile_format);
- logfile_top_uint (potfile_disable);
- logfile_top_string (potfile_path);
- #if defined(HAVE_HWMON) && defined(HAVE_ADL)
- logfile_top_uint (powertune_enable);
- #endif
- logfile_top_uint (scrypt_tmto);
- logfile_top_uint (quiet);
- logfile_top_uint (remove);
- logfile_top_uint (remove_timer);
- logfile_top_uint (restore);
- logfile_top_uint (restore_disable);
- logfile_top_uint (restore_timer);
- logfile_top_uint (rp_gen);
- logfile_top_uint (rp_gen_func_max);
- logfile_top_uint (rp_gen_func_min);
- logfile_top_uint (rp_gen_seed);
- logfile_top_uint (runtime);
- logfile_top_uint (segment_size);
- logfile_top_uint (show);
- logfile_top_uint (status);
- logfile_top_uint (status_automat);
- logfile_top_uint (status_timer);
- logfile_top_uint (usage);
- logfile_top_uint (username);
- logfile_top_uint (version);
- logfile_top_uint (weak_hash_threshold);
- logfile_top_uint (workload_profile);
- logfile_top_uint64 (limit);
- logfile_top_uint64 (skip);
- logfile_top_char (separator);
- logfile_top_string (cpu_affinity);
- logfile_top_string (custom_charset_1);
- logfile_top_string (custom_charset_2);
- logfile_top_string (custom_charset_3);
- logfile_top_string (custom_charset_4);
- logfile_top_string (debug_file);
- logfile_top_string (opencl_devices);
- logfile_top_string (opencl_platforms);
- logfile_top_string (opencl_device_types);
- logfile_top_uint (opencl_vector_width);
- logfile_top_string (induction_dir);
- logfile_top_string (markov_hcstat);
- logfile_top_string (outfile);
- logfile_top_string (outfile_check_dir);
- logfile_top_string (rule_buf_l);
- logfile_top_string (rule_buf_r);
- logfile_top_string (session);
- logfile_top_string (truecrypt_keyfiles);
-
- /**
- * Init OpenCL library loader
- */
-
- if (keyspace == 0)
- {
- ocl = (OCL_PTR *) mymalloc (sizeof (OCL_PTR));
-
- ocl_init (ocl);
-
- data.ocl = ocl;
- }
-
- /**
- * OpenCL platform selection
- */
-
- u32 opencl_platforms_filter = setup_opencl_platforms_filter (opencl_platforms);
-
- /**
- * OpenCL device selection
- */
-
- u32 devices_filter = setup_devices_filter (opencl_devices);
-
- /**
- * OpenCL device type selection
- */
-
- cl_device_type device_types_filter = setup_device_types_filter (opencl_device_types);
-
- /**
- * benchmark
- */
-
- if (benchmark == 1)
- {
- /**
- * disable useless stuff for benchmark
- */
-
- status_timer = 0;
- restore_timer = 0;
- restore_disable = 1;
- potfile_disable = 1;
- weak_hash_threshold = 0;
- gpu_temp_disable = 1;
-
- data.status_timer = status_timer;
- data.restore_timer = restore_timer;
- data.restore_disable = restore_disable;
-
- /**
- * force attack mode to be bruteforce
- */
-
- attack_mode = ATTACK_MODE_BF;
- attack_kern = ATTACK_KERN_BF;
-
- if (workload_profile_chgd == 0)
- {
- workload_profile = 3;
-
- data.workload_profile = workload_profile;
- }
- }
-
- /**
- * config
- */
-
- uint hash_type = 0;
- uint salt_type = 0;
- uint attack_exec = 0;
- uint opts_type = 0;
- uint kern_type = 0;
- uint dgst_size = 0;
- uint esalt_size = 0;
- uint opti_type = 0;
- uint dgst_pos0 = -1;
- uint dgst_pos1 = -1;
- uint dgst_pos2 = -1;
- uint dgst_pos3 = -1;
-
- int (*parse_func) (char *, uint, hash_t *);
- int (*sort_by_digest) (const void *, const void *);
-
- uint algorithm_pos = 0;
- uint algorithm_max = 1;
-
- uint *algorithms = default_benchmark_algorithms;
-
- if (benchmark == 1 && hash_mode_chgd == 0) algorithm_max = NUM_DEFAULT_BENCHMARK_ALGORITHMS;
-
- for (algorithm_pos = 0; algorithm_pos < algorithm_max; algorithm_pos++)
- {
- /*
- * We need to reset 'rd' in benchmark mode otherwise when the user hits 'bypass'
- * the following algos are skipped entirely
- */
-
- if (algorithm_pos > 0)
- {
- local_free (rd);
-
- rd = init_restore (argc, argv);
-
- data.rd = rd;
- }
-
- /**
- * update hash_mode in case of multihash benchmark
- */
-
- if (benchmark == 1)
- {
- if (hash_mode_chgd == 0)
- {
- hash_mode = algorithms[algorithm_pos];
-
- data.hash_mode = hash_mode;
- }
-
- quiet = 1;
-
- data.quiet = quiet;
- }
-
- switch (hash_mode)
- {
- case 0: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 10: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_MD5_PWSLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5s_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 11: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_MD5_PWSLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = joomla_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 12: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_MD5_PWSLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = postgresql_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 20: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLTPW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5s_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 21: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLTPW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = osc_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 22: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLTPW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = netscreen_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 23: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLTPW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = skype_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 30: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_MD5_PWUSLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5s_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 40: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_MD5_SLTPWU;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5s_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 50: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_HMACMD5_PW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = hmacmd5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 60: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_HMACMD5_SLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = hmacmd5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 100: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 101: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1b64_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 110: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_PWSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1s_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 111: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_PWSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1b64s_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 112: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA1_PWSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = oracles_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 120: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_SLTPW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1s_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 121: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_ST_LOWER;
- kern_type = KERN_TYPE_SHA1_SLTPW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = smf_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 122: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA1_SLTPW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = osx1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 124: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_SLTPW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = djangosha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 125: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA1_SLTPW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = arubaos_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 130: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_PWUSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1s_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 131: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_PT_UPPER
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA1_PWUSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = mssql2000_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 132: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA1_PWUSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = mssql2005_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 133: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_PWUSLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = peoplesoft_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 140: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_SHA1_SLTPWU;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1s_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 141: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_BASE64;
- kern_type = KERN_TYPE_SHA1_SLTPWU;
- dgst_size = DGST_SIZE_4_5;
- parse_func = episerver_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 150: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_HMACSHA1_PW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = hmacsha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 160: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_HMACSHA1_SLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = hmacsha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 190: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_LINKEDIN;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1linkedin_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED;
- dgst_pos0 = 0;
- dgst_pos1 = 4;
- dgst_pos2 = 3;
- dgst_pos3 = 2;
- break;
-
- case 200: hash_type = HASH_TYPE_MYSQL;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = 0;
- kern_type = KERN_TYPE_MYSQL;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = mysql323_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 300: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_MYSQL41;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 400: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_PHPASS;
- dgst_size = DGST_SIZE_4_4;
- parse_func = phpass_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_SLOW_HASH_SIMD;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 500: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_MD5CRYPT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5crypt_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 501: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_MD5CRYPT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = juniper_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 900: hash_type = HASH_TYPE_MD4;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD4;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md4_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 1000: hash_type = HASH_TYPE_MD4;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_MD4_PWU;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md4_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 1100: hash_type = HASH_TYPE_MD4;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_UNICODE
- | OPTS_TYPE_ST_LOWER;
- kern_type = KERN_TYPE_MD44_PWUSLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = dcc_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 1400: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA256;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1410: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA256_PWSLT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256s_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1420: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA256_SLTPW;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256s_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1421: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA256_SLTPW;
- dgst_size = DGST_SIZE_4_8;
- parse_func = hmailserver_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1430: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA256_PWUSLT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256s_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1440: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_SHA256_SLTPWU;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256s_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1441: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_BASE64;
- kern_type = KERN_TYPE_SHA256_SLTPWU;
- dgst_size = DGST_SIZE_4_8;
- parse_func = episerver4_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1450: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_HMACSHA256_PW;
- dgst_size = DGST_SIZE_4_8;
- parse_func = hmacsha256_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1460: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_HMACSHA256_SLT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = hmacsha256_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 1500: hash_type = HASH_TYPE_DESCRYPT;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_BITSLICE;
- kern_type = KERN_TYPE_DESCRYPT;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = descrypt_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_PERMUT;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 1600: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_APR1CRYPT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5apr1_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 1700: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA512;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1710: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA512_PWSLT;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512s_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1711: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA512_PWSLT;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512b64s_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1720: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA512_SLTPW;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512s_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1722: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA512_SLTPW;
- dgst_size = DGST_SIZE_8_8;
- parse_func = osx512_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1730: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_SHA512_PWSLTU;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512s_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1731: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SHA512_PWSLTU;
- dgst_size = DGST_SIZE_8_8;
- parse_func = mssql2012_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1740: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_SHA512_SLTPWU;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512s_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1750: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_HMACSHA512_PW;
- dgst_size = DGST_SIZE_8_8;
- parse_func = hmacsha512_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1760: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_HMACSHA512_SLT;
- dgst_size = DGST_SIZE_8_8;
- parse_func = hmacsha512_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 14;
- dgst_pos1 = 15;
- dgst_pos2 = 6;
- dgst_pos3 = 7;
- break;
-
- case 1800: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_SHA512CRYPT;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512crypt_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 2100: hash_type = HASH_TYPE_DCC2;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE // should be OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_LOWER
- | OPTS_TYPE_ST_UNICODE;
- kern_type = KERN_TYPE_DCC2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = dcc2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 2400: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_MD5PIX;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5pix_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 2410: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_MD5ASA;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5asa_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 2500: hash_type = HASH_TYPE_WPA;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_WPA;
- dgst_size = DGST_SIZE_4_4;
- parse_func = wpa_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 2600: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_VIRTUAL;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_MD55_PWSLT1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5md5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 2611: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_MD55_PWSLT1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = vb3_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 2612: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_MD55_PWSLT1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = phps_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 2711: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_MD55_PWSLT2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = vb30_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 2811: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD55_SLTPW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = ipb2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 3000: hash_type = HASH_TYPE_LM;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_UPPER
- | OPTS_TYPE_PT_BITSLICE;
- kern_type = KERN_TYPE_LM;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = lm_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_PERMUT;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 3100: hash_type = HASH_TYPE_ORACLEH;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_UPPER
- | OPTS_TYPE_ST_UPPER;
- kern_type = KERN_TYPE_ORACLEH;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = oracleh_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 3200: hash_type = HASH_TYPE_BCRYPT;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_GENERATE_LE;
- kern_type = KERN_TYPE_BCRYPT;
- dgst_size = DGST_SIZE_4_6;
- parse_func = bcrypt_parse_hash;
- sort_by_digest = sort_by_digest_4_6;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 3710: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLT_MD5_PW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5s_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 3711: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLT_MD5_PW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = mediawiki_b_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 3800: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_MD5_SLT_PW_SLT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5s_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 4300: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_VIRTUAL;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_MD5U5_PWSLT1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5md5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
-
- case 4400: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_MD5_SHA1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 4500: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA11;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_SALTED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 4700: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_SHA1_MD5;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 4800: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5_CHAP;
- dgst_size = DGST_SIZE_4_4;
- parse_func = chap_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_MEET_IN_MIDDLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 4900: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_SHA1_SLT_PW_SLT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1s_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 5000: hash_type = HASH_TYPE_KECCAK;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD01;
- kern_type = KERN_TYPE_KECCAK;
- dgst_size = DGST_SIZE_8_25;
- parse_func = keccak_parse_hash;
- sort_by_digest = sort_by_digest_8_25;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 2;
- dgst_pos1 = 3;
- dgst_pos2 = 4;
- dgst_pos3 = 5;
- break;
-
- case 5100: hash_type = HASH_TYPE_MD5H;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14;
- kern_type = KERN_TYPE_MD5H;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = md5half_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 5200: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_PSAFE3;
- dgst_size = DGST_SIZE_4_8;
- parse_func = psafe3_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 5300: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_IKEPSK_MD5;
- dgst_size = DGST_SIZE_4_4;
- parse_func = ikepsk_md5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 5400: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_IKEPSK_SHA1;
- dgst_size = DGST_SIZE_4_5;
- parse_func = ikepsk_sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 5500: hash_type = HASH_TYPE_NETNTLM;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_NETNTLMv1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = netntlmv1_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_PERMUT;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 5600: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS14
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_NETNTLMv2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = netntlmv2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 5700: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA256;
- dgst_size = DGST_SIZE_4_8;
- parse_func = cisco4_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 5800: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE // should be OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_ANDROIDPIN;
- dgst_size = DGST_SIZE_4_5;
- parse_func = androidpin_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6000: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80;
- kern_type = KERN_TYPE_RIPEMD160;
- dgst_size = DGST_SIZE_4_5;
- parse_func = ripemd160_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6100: hash_type = HASH_TYPE_WHIRLPOOL;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80;
- kern_type = KERN_TYPE_WHIRLPOOL;
- dgst_size = DGST_SIZE_4_16;
- parse_func = whirlpool_parse_hash;
- sort_by_digest = sort_by_digest_4_16;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6211: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCRIPEMD160_XTS512;
- dgst_size = DGST_SIZE_4_5;
- parse_func = truecrypt_parse_hash_2k;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6212: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCRIPEMD160_XTS1024;
- dgst_size = DGST_SIZE_4_5;
- parse_func = truecrypt_parse_hash_2k;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6213: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCRIPEMD160_XTS1536;
- dgst_size = DGST_SIZE_4_5;
- parse_func = truecrypt_parse_hash_2k;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6221: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_TCSHA512_XTS512;
- dgst_size = DGST_SIZE_8_8;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6222: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_TCSHA512_XTS1024;
- dgst_size = DGST_SIZE_8_8;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6223: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_TCSHA512_XTS1536;
- dgst_size = DGST_SIZE_8_8;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6231: hash_type = HASH_TYPE_WHIRLPOOL;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCWHIRLPOOL_XTS512;
- dgst_size = DGST_SIZE_4_8;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6232: hash_type = HASH_TYPE_WHIRLPOOL;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCWHIRLPOOL_XTS1024;
- dgst_size = DGST_SIZE_4_8;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6233: hash_type = HASH_TYPE_WHIRLPOOL;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCWHIRLPOOL_XTS1536;
- dgst_size = DGST_SIZE_4_8;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6241: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCRIPEMD160_XTS512;
- dgst_size = DGST_SIZE_4_5;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6242: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCRIPEMD160_XTS1024;
- dgst_size = DGST_SIZE_4_5;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6243: hash_type = HASH_TYPE_RIPEMD160;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_TCRIPEMD160_XTS1536;
- dgst_size = DGST_SIZE_4_5;
- parse_func = truecrypt_parse_hash_1k;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6300: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_MD5AIX;
- dgst_size = DGST_SIZE_4_4;
- parse_func = md5aix_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6400: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_SHA256AIX;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256aix_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6500: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_SHA512AIX;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha512aix_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6600: hash_type = HASH_TYPE_AES;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_AGILEKEY;
- dgst_size = DGST_SIZE_4_5; // because kernel uses _SHA1_
- parse_func = agilekey_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6700: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_SHA1AIX;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1aix_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6800: hash_type = HASH_TYPE_AES;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_LASTPASS;
- dgst_size = DGST_SIZE_4_8; // because kernel uses _SHA256_
- parse_func = lastpass_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 6900: hash_type = HASH_TYPE_GOST;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_GOST;
- dgst_size = DGST_SIZE_4_8;
- parse_func = gost_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 7100: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_PBKDF2_SHA512;
- dgst_size = DGST_SIZE_8_16;
- parse_func = sha512osx_parse_hash;
- sort_by_digest = sort_by_digest_8_16;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 7200: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_PBKDF2_SHA512;
- dgst_size = DGST_SIZE_8_16;
- parse_func = sha512grub_parse_hash;
- sort_by_digest = sort_by_digest_8_16;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 7300: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15;
- kern_type = KERN_TYPE_RAKP;
- dgst_size = DGST_SIZE_4_5;
- parse_func = rakp_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 7400: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_SHA256CRYPT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sha256crypt_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 7500: hash_type = HASH_TYPE_KRB5PA;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_KRB5PA;
- dgst_size = DGST_SIZE_4_4;
- parse_func = krb5pa_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 7600: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_SLT_SHA1_PW;
- dgst_size = DGST_SIZE_4_5;
- parse_func = redmine_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 7700: hash_type = HASH_TYPE_SAPB;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_UPPER
- | OPTS_TYPE_ST_UPPER;
- kern_type = KERN_TYPE_SAPB;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = sapb_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 7800: hash_type = HASH_TYPE_SAPG;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_UPPER;
- kern_type = KERN_TYPE_SAPG;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sapg_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 7900: hash_type = HASH_TYPE_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_DRUPAL7;
- dgst_size = DGST_SIZE_8_8;
- parse_func = drupal7_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 8000: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_SYBASEASE;
- dgst_size = DGST_SIZE_4_8;
- parse_func = sybasease_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 8100: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE;
- kern_type = KERN_TYPE_NETSCALER;
- dgst_size = DGST_SIZE_4_5;
- parse_func = netscaler_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 8200: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_CLOUDKEY;
- dgst_size = DGST_SIZE_4_8;
- parse_func = cloudkey_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 8300: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_HEX
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_NSEC3;
- dgst_size = DGST_SIZE_4_5;
- parse_func = nsec3_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 8400: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_WBB3;
- dgst_size = DGST_SIZE_4_5;
- parse_func = wbb3_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 8500: hash_type = HASH_TYPE_DESRACF;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_UPPER;
- kern_type = KERN_TYPE_RACF;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = racf_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_PERMUT;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 8600: hash_type = HASH_TYPE_LOTUS5;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_LOTUS5;
- dgst_size = DGST_SIZE_4_4;
- parse_func = lotus5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 8700: hash_type = HASH_TYPE_LOTUS6;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_LOTUS6;
- dgst_size = DGST_SIZE_4_4;
- parse_func = lotus6_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 8800: hash_type = HASH_TYPE_ANDROIDFDE;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_ANDROIDFDE;
- dgst_size = DGST_SIZE_4_4;
- parse_func = androidfde_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 8900: hash_type = HASH_TYPE_SCRYPT;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_SCRYPT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = scrypt_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9000: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_GENERATE_LE;
- kern_type = KERN_TYPE_PSAFE2;
- dgst_size = DGST_SIZE_4_5;
- parse_func = psafe2_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9100: hash_type = HASH_TYPE_LOTUS8;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_LOTUS8;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = lotus8_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9200: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_PBKDF2_SHA256;
- dgst_size = DGST_SIZE_4_32;
- parse_func = cisco8_parse_hash;
- sort_by_digest = sort_by_digest_4_32;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9300: hash_type = HASH_TYPE_SCRYPT;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_SCRYPT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = cisco9_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9400: hash_type = HASH_TYPE_OFFICE2007;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_OFFICE2007;
- dgst_size = DGST_SIZE_4_4;
- parse_func = office2007_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9500: hash_type = HASH_TYPE_OFFICE2010;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_OFFICE2010;
- dgst_size = DGST_SIZE_4_4;
- parse_func = office2010_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9600: hash_type = HASH_TYPE_OFFICE2013;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_OFFICE2013;
- dgst_size = DGST_SIZE_4_4;
- parse_func = office2013_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9700: hash_type = HASH_TYPE_OLDOFFICE01;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_OLDOFFICE01;
- dgst_size = DGST_SIZE_4_4;
- parse_func = oldoffice01_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9710: hash_type = HASH_TYPE_OLDOFFICE01;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80;
- kern_type = KERN_TYPE_OLDOFFICE01CM1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = oldoffice01cm1_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9720: hash_type = HASH_TYPE_OLDOFFICE01;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_PT_NEVERCRACK;
- kern_type = KERN_TYPE_OLDOFFICE01CM2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = oldoffice01cm2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9800: hash_type = HASH_TYPE_OLDOFFICE34;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_UNICODE;
- kern_type = KERN_TYPE_OLDOFFICE34;
- dgst_size = DGST_SIZE_4_4;
- parse_func = oldoffice34_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9810: hash_type = HASH_TYPE_OLDOFFICE34;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_OLDOFFICE34CM1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = oldoffice34cm1_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9820: hash_type = HASH_TYPE_OLDOFFICE34;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_PT_NEVERCRACK;
- kern_type = KERN_TYPE_OLDOFFICE34CM2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = oldoffice34cm2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 9900: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_RADMIN2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = radmin2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 10000: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_PBKDF2_SHA256;
- dgst_size = DGST_SIZE_4_32;
- parse_func = djangopbkdf2_parse_hash;
- sort_by_digest = sort_by_digest_4_32;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10100: hash_type = HASH_TYPE_SIPHASH;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_SIPHASH;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = siphash_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10200: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS14;
- kern_type = KERN_TYPE_HMACMD5_PW;
- dgst_size = DGST_SIZE_4_4;
- parse_func = crammd5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 10300: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE; // should be OPTS_TYPE_PT_GENERATE_BE
- kern_type = KERN_TYPE_SAPH_SHA1;
- dgst_size = DGST_SIZE_4_5;
- parse_func = saph_sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10400: hash_type = HASH_TYPE_PDFU16;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_PDF11;
- dgst_size = DGST_SIZE_4_4;
- parse_func = pdf11_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10410: hash_type = HASH_TYPE_PDFU16;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_PDF11CM1;
- dgst_size = DGST_SIZE_4_4;
- parse_func = pdf11cm1_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10420: hash_type = HASH_TYPE_PDFU16;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_PDF11CM2;
- dgst_size = DGST_SIZE_4_4;
- parse_func = pdf11cm2_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10500: hash_type = HASH_TYPE_PDFU16;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_PDF14;
- dgst_size = DGST_SIZE_4_4;
- parse_func = pdf14_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10600: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_ST_ADD80
- | OPTS_TYPE_ST_ADDBITS15
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_SHA256_PWSLT;
- dgst_size = DGST_SIZE_4_8;
- parse_func = pdf17l3_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_APPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 10700: hash_type = HASH_TYPE_PDFU32;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_PDF17L8;
- dgst_size = DGST_SIZE_4_8;
- parse_func = pdf17l8_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 10800: hash_type = HASH_TYPE_SHA384;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA384;
- dgst_size = DGST_SIZE_8_8;
- parse_func = sha384_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED
- | OPTI_TYPE_USES_BITS_64
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 6;
- dgst_pos1 = 7;
- dgst_pos2 = 4;
- dgst_pos3 = 5;
- break;
-
- case 10900: hash_type = HASH_TYPE_PBKDF2_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_BASE64
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_PBKDF2_SHA256;
- dgst_size = DGST_SIZE_4_32;
- parse_func = pbkdf2_sha256_parse_hash;
- sort_by_digest = sort_by_digest_4_32;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 11000: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80;
- kern_type = KERN_TYPE_PRESTASHOP;
- dgst_size = DGST_SIZE_4_4;
- parse_func = prestashop_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 11100: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_POSTGRESQL_AUTH;
- dgst_size = DGST_SIZE_4_4;
- parse_func = postgresql_auth_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_PRECOMPUTE_MERKLE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 11200: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_MYSQL_AUTH;
- dgst_size = DGST_SIZE_4_5;
- parse_func = mysql_auth_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_EARLY_SKIP;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 11300: hash_type = HASH_TYPE_BITCOIN_WALLET;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_HEX
- | OPTS_TYPE_ST_ADD80;
- kern_type = KERN_TYPE_BITCOIN_WALLET;
- dgst_size = DGST_SIZE_4_4;
- parse_func = bitcoin_wallet_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 11400: hash_type = HASH_TYPE_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_SIP_AUTH;
- dgst_size = DGST_SIZE_4_4;
- parse_func = sip_auth_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 3;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- case 11500: hash_type = HASH_TYPE_CRC32;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_GENERATE_LE
- | OPTS_TYPE_ST_HEX;
- kern_type = KERN_TYPE_CRC32;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = crc32_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 11600: hash_type = HASH_TYPE_AES;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_NEVERCRACK;
- kern_type = KERN_TYPE_SEVEN_ZIP;
- dgst_size = DGST_SIZE_4_4; // originally DGST_SIZE_4_2
- parse_func = seven_zip_parse_hash;
- sort_by_digest = sort_by_digest_4_4; // originally sort_by_digest_4_2
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 11700: hash_type = HASH_TYPE_GOST_2012SBOG_256;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD01;
- kern_type = KERN_TYPE_GOST_2012SBOG_256;
- dgst_size = DGST_SIZE_4_8;
- parse_func = gost2012sbog_256_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 11800: hash_type = HASH_TYPE_GOST_2012SBOG_512;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_PT_ADD01;
- kern_type = KERN_TYPE_GOST_2012SBOG_512;
- dgst_size = DGST_SIZE_4_16;
- parse_func = gost2012sbog_512_parse_hash;
- sort_by_digest = sort_by_digest_4_16;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 11900: hash_type = HASH_TYPE_PBKDF2_MD5;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_BASE64
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_PBKDF2_MD5;
- dgst_size = DGST_SIZE_4_32;
- parse_func = pbkdf2_md5_parse_hash;
- sort_by_digest = sort_by_digest_4_32;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12000: hash_type = HASH_TYPE_PBKDF2_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_BASE64
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_PBKDF2_SHA1;
- dgst_size = DGST_SIZE_4_32;
- parse_func = pbkdf2_sha1_parse_hash;
- sort_by_digest = sort_by_digest_4_32;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12100: hash_type = HASH_TYPE_PBKDF2_SHA512;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_ST_BASE64
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_PBKDF2_SHA512;
- dgst_size = DGST_SIZE_8_16;
- parse_func = pbkdf2_sha512_parse_hash;
- sort_by_digest = sort_by_digest_8_16;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12200: hash_type = HASH_TYPE_ECRYPTFS;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_ECRYPTFS;
- dgst_size = DGST_SIZE_8_8;
- parse_func = ecryptfs_parse_hash;
- sort_by_digest = sort_by_digest_8_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12300: hash_type = HASH_TYPE_ORACLET;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_ORACLET;
- dgst_size = DGST_SIZE_8_16;
- parse_func = oraclet_parse_hash;
- sort_by_digest = sort_by_digest_8_16;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_USES_BITS_64;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12400: hash_type = HASH_TYPE_BSDICRYPT;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_BSDICRYPT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = bsdicrypt_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_PERMUT;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12500: hash_type = HASH_TYPE_RAR3HP;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_RAR3;
- dgst_size = DGST_SIZE_4_4;
- parse_func = rar3hp_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12600: hash_type = HASH_TYPE_SHA256;
- salt_type = SALT_TYPE_INTERN;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80;
- kern_type = KERN_TYPE_CF10;
- dgst_size = DGST_SIZE_4_8;
- parse_func = cf10_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 3;
- dgst_pos1 = 7;
- dgst_pos2 = 2;
- dgst_pos3 = 6;
- break;
-
- case 12700: hash_type = HASH_TYPE_AES;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE
- | OPTS_TYPE_HASH_COPY;
- kern_type = KERN_TYPE_MYWALLET;
- dgst_size = DGST_SIZE_4_5; // because kernel uses _SHA1_
- parse_func = mywallet_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12800: hash_type = HASH_TYPE_PBKDF2_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_MS_DRSR;
- dgst_size = DGST_SIZE_4_8;
- parse_func = ms_drsr_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 12900: hash_type = HASH_TYPE_PBKDF2_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_ANDROIDFDE_SAMSUNG;
- dgst_size = DGST_SIZE_4_8;
- parse_func = androidfde_samsung_parse_hash;
- sort_by_digest = sort_by_digest_4_8;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 13000: hash_type = HASH_TYPE_PBKDF2_SHA256;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_RAR5;
- dgst_size = DGST_SIZE_4_4;
- parse_func = rar5_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 13100: hash_type = HASH_TYPE_KRB5TGS;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_KRB5TGS;
- dgst_size = DGST_SIZE_4_4;
- parse_func = krb5tgs_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_NOT_ITERATED;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 13200: hash_type = HASH_TYPE_AES;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_AXCRYPT;
- dgst_size = DGST_SIZE_4_4;
- parse_func = axcrypt_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 13300: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_NONE;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_ADD80
- | OPTS_TYPE_PT_ADDBITS15;
- kern_type = KERN_TYPE_SHA1_AXCRYPT;
- dgst_size = DGST_SIZE_4_5;
- parse_func = sha1axcrypt_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_NOT_SALTED;
- dgst_pos0 = 0;
- dgst_pos1 = 4;
- dgst_pos2 = 3;
- dgst_pos3 = 2;
- break;
-
- case 13400: hash_type = HASH_TYPE_AES;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_OUTSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_LE;
- kern_type = KERN_TYPE_KEEPASS;
- dgst_size = DGST_SIZE_4_4;
- parse_func = keepass_parse_hash;
- sort_by_digest = sort_by_digest_4_4;
- opti_type = OPTI_TYPE_ZERO_BYTE;
- dgst_pos0 = 0;
- dgst_pos1 = 1;
- dgst_pos2 = 2;
- dgst_pos3 = 3;
- break;
-
- case 13500: hash_type = HASH_TYPE_SHA1;
- salt_type = SALT_TYPE_EMBEDDED;
- attack_exec = ATTACK_EXEC_INSIDE_KERNEL;
- opts_type = OPTS_TYPE_PT_GENERATE_BE
- | OPTS_TYPE_PT_UNICODE
- | OPTS_TYPE_PT_ADD80;
- kern_type = KERN_TYPE_PSTOKEN;
- dgst_size = DGST_SIZE_4_5;
- parse_func = pstoken_parse_hash;
- sort_by_digest = sort_by_digest_4_5;
- opti_type = OPTI_TYPE_ZERO_BYTE
- | OPTI_TYPE_PRECOMPUTE_INIT
- | OPTI_TYPE_EARLY_SKIP
- | OPTI_TYPE_NOT_ITERATED
- | OPTI_TYPE_PREPENDED_SALT
- | OPTI_TYPE_RAW_HASH;
- dgst_pos0 = 3;
- dgst_pos1 = 4;
- dgst_pos2 = 2;
- dgst_pos3 = 1;
- break;
-
- default: usage_mini_print (PROGNAME); return (-1);
- }
-
- /**
- * parser
- */
-
- data.parse_func = parse_func;
-
- /**
- * misc stuff
- */
-
- if (hex_salt)
- {
- if (salt_type == SALT_TYPE_INTERN)
- {
- opts_type |= OPTS_TYPE_ST_HEX;
- }
- else
- {
- log_error ("ERROR: Parameter hex-salt not valid for hash-type %u", hash_mode);
-
- return (-1);
- }
- }
-
- uint isSalted = ((salt_type == SALT_TYPE_INTERN)
- | (salt_type == SALT_TYPE_EXTERN)
- | (salt_type == SALT_TYPE_EMBEDDED)
- | (salt_type == SALT_TYPE_VIRTUAL));
-
- sort_by_digest = sort_by_digest_p0p1; // overruled by 64 bit digest
-
- data.hash_type = hash_type;
- data.attack_mode = attack_mode;
- data.attack_kern = attack_kern;
- data.attack_exec = attack_exec;
- data.kern_type = kern_type;
- data.opts_type = opts_type;
- data.dgst_size = dgst_size;
- data.salt_type = salt_type;
- data.isSalted = isSalted;
- data.sort_by_digest = sort_by_digest;
- data.dgst_pos0 = dgst_pos0;
- data.dgst_pos1 = dgst_pos1;
- data.dgst_pos2 = dgst_pos2;
- data.dgst_pos3 = dgst_pos3;
-
- esalt_size = 0;
-
- switch (hash_mode)
- {
- case 2500: esalt_size = sizeof (wpa_t); break;
- case 5300: esalt_size = sizeof (ikepsk_t); break;
- case 5400: esalt_size = sizeof (ikepsk_t); break;
- case 5500: esalt_size = sizeof (netntlm_t); break;
- case 5600: esalt_size = sizeof (netntlm_t); break;
- case 6211: esalt_size = sizeof (tc_t); break;
- case 6212: esalt_size = sizeof (tc_t); break;
- case 6213: esalt_size = sizeof (tc_t); break;
- case 6221: esalt_size = sizeof (tc_t); break;
- case 6222: esalt_size = sizeof (tc_t); break;
- case 6223: esalt_size = sizeof (tc_t); break;
- case 6231: esalt_size = sizeof (tc_t); break;
- case 6232: esalt_size = sizeof (tc_t); break;
- case 6233: esalt_size = sizeof (tc_t); break;
- case 6241: esalt_size = sizeof (tc_t); break;
- case 6242: esalt_size = sizeof (tc_t); break;
- case 6243: esalt_size = sizeof (tc_t); break;
- case 6600: esalt_size = sizeof (agilekey_t); break;
- case 7100: esalt_size = sizeof (pbkdf2_sha512_t); break;
- case 7200: esalt_size = sizeof (pbkdf2_sha512_t); break;
- case 7300: esalt_size = sizeof (rakp_t); break;
- case 7500: esalt_size = sizeof (krb5pa_t); break;
- case 8200: esalt_size = sizeof (cloudkey_t); break;
- case 8800: esalt_size = sizeof (androidfde_t); break;
- case 9200: esalt_size = sizeof (pbkdf2_sha256_t); break;
- case 9400: esalt_size = sizeof (office2007_t); break;
- case 9500: esalt_size = sizeof (office2010_t); break;
- case 9600: esalt_size = sizeof (office2013_t); break;
- case 9700: esalt_size = sizeof (oldoffice01_t); break;
- case 9710: esalt_size = sizeof (oldoffice01_t); break;
- case 9720: esalt_size = sizeof (oldoffice01_t); break;
- case 9800: esalt_size = sizeof (oldoffice34_t); break;
- case 9810: esalt_size = sizeof (oldoffice34_t); break;
- case 9820: esalt_size = sizeof (oldoffice34_t); break;
- case 10000: esalt_size = sizeof (pbkdf2_sha256_t); break;
- case 10200: esalt_size = sizeof (cram_md5_t); break;
- case 10400: esalt_size = sizeof (pdf_t); break;
- case 10410: esalt_size = sizeof (pdf_t); break;
- case 10420: esalt_size = sizeof (pdf_t); break;
- case 10500: esalt_size = sizeof (pdf_t); break;
- case 10600: esalt_size = sizeof (pdf_t); break;
- case 10700: esalt_size = sizeof (pdf_t); break;
- case 10900: esalt_size = sizeof (pbkdf2_sha256_t); break;
- case 11300: esalt_size = sizeof (bitcoin_wallet_t); break;
- case 11400: esalt_size = sizeof (sip_t); break;
- case 11600: esalt_size = sizeof (seven_zip_t); break;
- case 11900: esalt_size = sizeof (pbkdf2_md5_t); break;
- case 12000: esalt_size = sizeof (pbkdf2_sha1_t); break;
- case 12100: esalt_size = sizeof (pbkdf2_sha512_t); break;
- case 13000: esalt_size = sizeof (rar5_t); break;
- case 13100: esalt_size = sizeof (krb5tgs_t); break;
- case 13400: esalt_size = sizeof (keepass_t); break;
- case 13500: esalt_size = sizeof (pstoken_t); break;
- }
-
- data.esalt_size = esalt_size;
-
- /**
- * choose dictionary parser
- */
-
- if (hash_type == HASH_TYPE_LM)
- {
- get_next_word_func = get_next_word_lm;
- }
- else if (opts_type & OPTS_TYPE_PT_UPPER)
- {
- get_next_word_func = get_next_word_uc;
- }
- else
- {
- get_next_word_func = get_next_word_std;
- }
-
- /**
- * dictstat
- */
-
- dictstat_t *dictstat_base = (dictstat_t *) mycalloc (MAX_DICTSTAT, sizeof (dictstat_t));
-
- #ifdef _POSIX
- size_t dictstat_nmemb = 0;
- #endif
-
- #ifdef _WIN
- uint dictstat_nmemb = 0;
- #endif
-
- char dictstat[256] = { 0 };
-
- FILE *dictstat_fp = NULL;
-
- if (keyspace == 0)
- {
- snprintf (dictstat, sizeof (dictstat) - 1, "%s/%s", profile_dir, DICTSTAT_FILENAME);
-
- dictstat_fp = fopen (dictstat, "rb");
-
- if (dictstat_fp)
- {
- #ifdef _POSIX
- struct stat tmpstat;
-
- fstat (fileno (dictstat_fp), &tmpstat);
- #endif
-
- #ifdef _WIN
- struct stat64 tmpstat;
-
- _fstat64 (fileno (dictstat_fp), &tmpstat);
- #endif
-
- if (tmpstat.st_mtime < COMPTIME)
- {
- /* with v0.15 the format changed so we have to ensure user is using a good version
- since there is no version-header in the dictstat file */
-
- fclose (dictstat_fp);
-
- unlink (dictstat);
- }
- else
- {
- while (!feof (dictstat_fp))
- {
- dictstat_t d;
-
- if (fread (&d, sizeof (dictstat_t), 1, dictstat_fp) == 0) continue;
-
- lsearch (&d, dictstat_base, &dictstat_nmemb, sizeof (dictstat_t), sort_by_dictstat);
-
- if (dictstat_nmemb == (MAX_DICTSTAT - 1000))
- {
- log_error ("ERROR: There are too many entries in the %s database. You have to remove/rename it.", dictstat);
-
- return -1;
- }
- }
-
- fclose (dictstat_fp);
- }
- }
- }
-
- /**
- * potfile
- */
-
- char potfile[256] = { 0 };
-
- if (potfile_path == NULL)
- {
- snprintf (potfile, sizeof (potfile) - 1, "%s/%s", profile_dir, POTFILE_FILENAME);
- }
- else
- {
- strncpy (potfile, potfile_path, sizeof (potfile) - 1);
- }
-
- data.pot_fp = NULL;
-
- FILE *out_fp = NULL;
- FILE *pot_fp = NULL;
-
- if (show == 1 || left == 1)
- {
- pot_fp = fopen (potfile, "rb");
-
- if (pot_fp == NULL)
- {
- log_error ("ERROR: %s: %s", potfile, strerror (errno));
-
- return (-1);
- }
-
- if (outfile != NULL)
- {
- if ((out_fp = fopen (outfile, "ab")) == NULL)
- {
- log_error ("ERROR: %s: %s", outfile, strerror (errno));
-
- fclose (pot_fp);
-
- return (-1);
- }
- }
- else
- {
- out_fp = stdout;
- }
- }
- else
- {
- if (potfile_disable == 0)
- {
- pot_fp = fopen (potfile, "ab");
-
- if (pot_fp == NULL)
- {
- log_error ("ERROR: %s: %s", potfile, strerror (errno));
-
- return (-1);
- }
-
- data.pot_fp = pot_fp;
- }
- }
-
- pot_t *pot = NULL;
-
- uint pot_cnt = 0;
- uint pot_avail = 0;
-
- if (show == 1 || left == 1)
- {
- SUPPRESS_OUTPUT = 1;
-
- pot_avail = count_lines (pot_fp);
-
- rewind (pot_fp);
-
- pot = (pot_t *) mycalloc (pot_avail, sizeof (pot_t));
-
- uint pot_hashes_avail = 0;
-
- uint line_num = 0;
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- while (!feof (pot_fp))
- {
- line_num++;
-
- int line_len = fgetl (pot_fp, line_buf);
-
- if (line_len == 0) continue;
-
- char *plain_buf = line_buf + line_len;
-
- pot_t *pot_ptr = &pot[pot_cnt];
-
- hash_t *hashes_buf = &pot_ptr->hash;
-
- // we do not initialize all hashes_buf->digest etc at the beginning, since many lines may not be
- // valid lines of this specific hash type (otherwise it would be more waste of memory than gain)
-
- if (pot_cnt == pot_hashes_avail)
- {
- uint pos = 0;
-
- for (pos = 0; pos < INCR_POT; pos++)
- {
- if ((pot_cnt + pos) >= pot_avail) break;
-
- pot_t *tmp_pot = &pot[pot_cnt + pos];
-
- hash_t *tmp_hash = &tmp_pot->hash;
-
- tmp_hash->digest = mymalloc (dgst_size);
-
- if (isSalted)
- {
- tmp_hash->salt = (salt_t *) mymalloc (sizeof (salt_t));
- }
-
- if (esalt_size)
- {
- tmp_hash->esalt = mymalloc (esalt_size);
- }
-
- pot_hashes_avail++;
- }
- }
-
- int plain_len = 0;
-
- int parser_status;
-
- int iter = MAX_CUT_TRIES;
-
- do
- {
- for (int i = line_len - 1; i; i--, plain_len++, plain_buf--, line_len--)
- {
- if (line_buf[i] == ':')
- {
- line_len--;
-
- break;
- }
- }
-
- if (data.hash_mode != 2500)
- {
- parser_status = parse_func (line_buf, line_len, hashes_buf);
- }
- else
- {
- int max_salt_size = sizeof (hashes_buf->salt->salt_buf);
-
- if (line_len > max_salt_size)
- {
- parser_status = PARSER_GLOBAL_LENGTH;
- }
- else
- {
- memset (&hashes_buf->salt->salt_buf, 0, max_salt_size);
-
- memcpy (&hashes_buf->salt->salt_buf, line_buf, line_len);
-
- hashes_buf->salt->salt_len = line_len;
-
- parser_status = PARSER_OK;
- }
- }
-
- // if NOT parsed without error, we add the ":" to the plain
-
- if (parser_status == PARSER_GLOBAL_LENGTH || parser_status == PARSER_HASH_LENGTH || parser_status == PARSER_SALT_LENGTH)
- {
- plain_len++;
- plain_buf--;
- }
-
- } while ((parser_status == PARSER_GLOBAL_LENGTH || parser_status == PARSER_HASH_LENGTH || parser_status == PARSER_SALT_LENGTH) && --iter);
-
- if (parser_status < PARSER_GLOBAL_ZERO)
- {
- // log_info ("WARNING: Potfile '%s' in line %u (%s): %s", potfile, line_num, line_buf, strparser (parser_status));
-
- continue;
- }
-
- if (plain_len >= 255) continue;
-
- memcpy (pot_ptr->plain_buf, plain_buf, plain_len);
-
- pot_ptr->plain_len = plain_len;
-
- pot_cnt++;
- }
-
- myfree (line_buf);
-
- fclose (pot_fp);
-
- SUPPRESS_OUTPUT = 0;
-
- qsort (pot, pot_cnt, sizeof (pot_t), sort_by_pot);
- }
-
- /**
- * word len
- */
-
- uint pw_min = PW_MIN;
- uint pw_max = PW_MAX;
-
- switch (hash_mode)
- {
- case 125: if (pw_max > 32) pw_max = 32;
- break;
- case 400: if (pw_max > 40) pw_max = 40;
- break;
- case 500: if (pw_max > 16) pw_max = 16;
- break;
- case 1500: if (pw_max > 8) pw_max = 8;
- break;
- case 1600: if (pw_max > 16) pw_max = 16;
- break;
- case 1800: if (pw_max > 16) pw_max = 16;
- break;
- case 2100: if (pw_max > 16) pw_max = 16;
- break;
- case 2500: if (pw_min < 8) pw_min = 8;
- break;
- case 3000: if (pw_max > 7) pw_max = 7;
- break;
- case 5200: if (pw_max > 24) pw_max = 24;
- break;
- case 5800: if (pw_max > 16) pw_max = 16;
- break;
- case 6300: if (pw_max > 16) pw_max = 16;
- break;
- case 7400: if (pw_max > 16) pw_max = 16;
- break;
- case 7900: if (pw_max > 48) pw_max = 48;
- break;
- case 8500: if (pw_max > 8) pw_max = 8;
- break;
- case 8600: if (pw_max > 16) pw_max = 16;
- break;
- case 9710: pw_min = 5;
- pw_max = 5;
- break;
- case 9810: pw_min = 5;
- pw_max = 5;
- break;
- case 10410: pw_min = 5;
- pw_max = 5;
- break;
- case 10300: if (pw_max < 3) pw_min = 3;
- if (pw_max > 40) pw_max = 40;
- break;
- case 10500: if (pw_max < 3) pw_min = 3;
- if (pw_max > 40) pw_max = 40;
- break;
- case 10700: if (pw_max > 16) pw_max = 16;
- break;
- case 11300: if (pw_max > 40) pw_max = 40;
- break;
- case 11600: if (pw_max > 32) pw_max = 32;
- break;
- case 12500: if (pw_max > 20) pw_max = 20;
- break;
- case 12800: if (pw_max > 24) pw_max = 24;
- break;
- }
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- switch (attack_kern)
- {
- case ATTACK_KERN_STRAIGHT: if (pw_max > PW_DICTMAX) pw_max = PW_DICTMAX1;
- break;
- case ATTACK_KERN_COMBI: if (pw_max > PW_DICTMAX) pw_max = PW_DICTMAX1;
- break;
- }
- }
-
- /**
- * charsets : keep them together for more easy maintainnce
- */
-
- cs_t mp_sys[6] = { { { 0 }, 0 } };
- cs_t mp_usr[4] = { { { 0 }, 0 } };
-
- mp_setup_sys (mp_sys);
-
- if (custom_charset_1) mp_setup_usr (mp_sys, mp_usr, custom_charset_1, 0);
- if (custom_charset_2) mp_setup_usr (mp_sys, mp_usr, custom_charset_2, 1);
- if (custom_charset_3) mp_setup_usr (mp_sys, mp_usr, custom_charset_3, 2);
- if (custom_charset_4) mp_setup_usr (mp_sys, mp_usr, custom_charset_4, 3);
-
- /**
- * load hashes, part I: find input mode, count hashes
- */
-
- uint hashlist_mode = 0;
- uint hashlist_format = HLFMT_HASHCAT;
-
- uint hashes_avail = 0;
-
- if (benchmark == 0)
- {
- struct stat f;
-
- hashlist_mode = (stat (myargv[optind], &f) == 0) ? HL_MODE_FILE : HL_MODE_ARG;
-
- if ((hash_mode == 2500) ||
- (hash_mode == 5200) ||
- ((hash_mode >= 6200) && (hash_mode <= 6299)) ||
- (hash_mode == 9000))
- {
- hashlist_mode = HL_MODE_ARG;
-
- char *hashfile = myargv[optind];
-
- data.hashfile = hashfile;
-
- logfile_top_var_string ("target", hashfile);
- }
-
- if (hashlist_mode == HL_MODE_ARG)
- {
- if (hash_mode == 2500)
- {
- struct stat st;
-
- if (stat (data.hashfile, &st) == -1)
- {
- log_error ("ERROR: %s: %s", data.hashfile, strerror (errno));
-
- return (-1);
- }
-
- hashes_avail = st.st_size / sizeof (hccap_t);
- }
- else
- {
- hashes_avail = 1;
- }
- }
- else if (hashlist_mode == HL_MODE_FILE)
- {
- char *hashfile = myargv[optind];
-
- data.hashfile = hashfile;
-
- logfile_top_var_string ("target", hashfile);
-
- FILE *fp = NULL;
-
- if ((fp = fopen (hashfile, "rb")) == NULL)
- {
- log_error ("ERROR: %s: %s", hashfile, strerror (errno));
-
- return (-1);
- }
-
- if (data.quiet == 0) log_info_nn ("Counting lines in %s", hashfile);
-
- hashes_avail = count_lines (fp);
-
- rewind (fp);
-
- if (hashes_avail == 0)
- {
- log_error ("ERROR: hashfile is empty or corrupt");
-
- fclose (fp);
-
- return (-1);
- }
-
- hashlist_format = hlfmt_detect (fp, 100); // 100 = max numbers to "scan". could be hashes_avail, too
-
- if ((remove == 1) && (hashlist_format != HLFMT_HASHCAT))
- {
- log_error ("ERROR: remove not supported in native hashfile-format mode");
-
- fclose (fp);
-
- return (-1);
- }
-
- fclose (fp);
- }
- }
- else
- {
- hashlist_mode = HL_MODE_ARG;
-
- hashes_avail = 1;
- }
-
- if (hash_mode == 3000) hashes_avail *= 2;
-
- data.hashlist_mode = hashlist_mode;
- data.hashlist_format = hashlist_format;
-
- logfile_top_uint (hashlist_mode);
- logfile_top_uint (hashlist_format);
-
- /**
- * load hashes, part II: allocate required memory, set pointers
- */
-
- hash_t *hashes_buf = NULL;
- void *digests_buf = NULL;
- salt_t *salts_buf = NULL;
- void *esalts_buf = NULL;
-
- hashes_buf = (hash_t *) mycalloc (hashes_avail, sizeof (hash_t));
-
- digests_buf = (void *) mycalloc (hashes_avail, dgst_size);
-
- if ((username && (remove || show)) || (opts_type & OPTS_TYPE_HASH_COPY))
- {
- u32 hash_pos;
-
- for (hash_pos = 0; hash_pos < hashes_avail; hash_pos++)
- {
- hashinfo_t *hash_info = (hashinfo_t *) mymalloc (sizeof (hashinfo_t));
-
- hashes_buf[hash_pos].hash_info = hash_info;
-
- if (username && (remove || show || left))
- {
- hash_info->user = (user_t*) mymalloc (sizeof (user_t));
- }
-
- if (benchmark)
- {
- hash_info->orighash = (char *) mymalloc (256);
- }
- }
- }
-
- if (isSalted)
- {
- salts_buf = (salt_t *) mycalloc (hashes_avail, sizeof (salt_t));
-
- if (esalt_size)
- {
- esalts_buf = (void *) mycalloc (hashes_avail, esalt_size);
- }
- }
- else
- {
- salts_buf = (salt_t *) mycalloc (1, sizeof (salt_t));
- }
-
- for (uint hash_pos = 0; hash_pos < hashes_avail; hash_pos++)
- {
- hashes_buf[hash_pos].digest = ((char *) digests_buf) + (hash_pos * dgst_size);
-
- if (isSalted)
- {
- hashes_buf[hash_pos].salt = &salts_buf[hash_pos];
-
- if (esalt_size)
- {
- hashes_buf[hash_pos].esalt = ((char *) esalts_buf) + (hash_pos * esalt_size);
- }
- }
- else
- {
- hashes_buf[hash_pos].salt = &salts_buf[0];
- }
- }
-
- /**
- * load hashes, part III: parse hashes or generate them if benchmark
- */
-
- uint hashes_cnt = 0;
-
- if (benchmark == 0)
- {
- if (keyspace == 1)
- {
- // useless to read hash file for keyspace, cheat a little bit w/ optind
- }
- else if (hashes_avail == 0)
- {
- }
- else if (hashlist_mode == HL_MODE_ARG)
- {
- char *input_buf = myargv[optind];
-
- uint input_len = strlen (input_buf);
-
- logfile_top_var_string ("target", input_buf);
-
- char *hash_buf = NULL;
- int hash_len = 0;
-
- hlfmt_hash (hashlist_format, input_buf, input_len, &hash_buf, &hash_len);
-
- bool hash_fmt_error = 0;
-
- if (hash_len < 1) hash_fmt_error = 1;
- if (hash_buf == NULL) hash_fmt_error = 1;
-
- if (hash_fmt_error)
- {
- log_info ("WARNING: failed to parse hashes using the '%s' format", strhlfmt (hashlist_format));
- }
- else
- {
- if (opts_type & OPTS_TYPE_HASH_COPY)
- {
- hashinfo_t *hash_info_tmp = hashes_buf[hashes_cnt].hash_info;
-
- hash_info_tmp->orighash = mystrdup (hash_buf);
- }
-
- if (isSalted)
- {
- memset (hashes_buf[0].salt, 0, sizeof (salt_t));
- }
-
- int parser_status = PARSER_OK;
-
- if (hash_mode == 2500)
- {
- if (hash_len == 0)
- {
- log_error ("ERROR: hccap file not specified");
-
- return (-1);
- }
-
- hashlist_mode = HL_MODE_FILE;
-
- data.hashlist_mode = hashlist_mode;
-
- FILE *fp = fopen (hash_buf, "rb");
-
- if (fp == NULL)
- {
- log_error ("ERROR: %s: %s", hash_buf, strerror (errno));
-
- return (-1);
- }
-
- if (hashes_avail < 1)
- {
- log_error ("ERROR: hccap file is empty or corrupt");
-
- fclose (fp);
-
- return (-1);
- }
-
- uint hccap_size = sizeof (hccap_t);
-
- char *in = (char *) mymalloc (hccap_size);
-
- while (!feof (fp))
- {
- int n = fread (in, hccap_size, 1, fp);
-
- if (n != 1)
- {
- if (hashes_cnt < 1) parser_status = PARSER_HCCAP_FILE_SIZE;
-
- break;
- }
-
- parser_status = parse_func (in, hccap_size, &hashes_buf[hashes_cnt]);
-
- if (parser_status != PARSER_OK)
- {
- log_info ("WARNING: Hash '%s': %s", hash_buf, strparser (parser_status));
-
- continue;
- }
-
- // hack: append MAC1 and MAC2 s.t. in --show and --left the line matches with the .pot file format (i.e. ESSID:MAC1:MAC2)
-
- if ((show == 1) || (left == 1))
- {
- salt_t *tmp_salt = hashes_buf[hashes_cnt].salt;
-
- char *salt_ptr = (char *) tmp_salt->salt_buf;
-
- int cur_pos = tmp_salt->salt_len;
- int rem_len = sizeof (hashes_buf[hashes_cnt].salt->salt_buf) - cur_pos;
-
- wpa_t *wpa = (wpa_t *) hashes_buf[hashes_cnt].esalt;
-
- // do the appending task
-
- snprintf (salt_ptr + cur_pos,
- rem_len,
- ":%02x%02x%02x%02x%02x%02x:%02x%02x%02x%02x%02x%02x",
- wpa->orig_mac1[0],
- wpa->orig_mac1[1],
- wpa->orig_mac1[2],
- wpa->orig_mac1[3],
- wpa->orig_mac1[4],
- wpa->orig_mac1[5],
- wpa->orig_mac2[0],
- wpa->orig_mac2[1],
- wpa->orig_mac2[2],
- wpa->orig_mac2[3],
- wpa->orig_mac2[4],
- wpa->orig_mac2[5]);
-
- // memset () the remaining part of the salt
-
- cur_pos = tmp_salt->salt_len + 1 + 12 + 1 + 12;
- rem_len = sizeof (hashes_buf[hashes_cnt].salt->salt_buf) - cur_pos;
-
- if (rem_len > 0) memset (salt_ptr + cur_pos, 0, rem_len);
-
- tmp_salt->salt_len += 1 + 12 + 1 + 12;
- }
-
- if (show == 1) handle_show_request (pot, pot_cnt, (char *) hashes_buf[hashes_cnt].salt->salt_buf, hashes_buf[hashes_cnt].salt->salt_len, &hashes_buf[hashes_cnt], sort_by_salt_buf, out_fp);
- if (left == 1) handle_left_request (pot, pot_cnt, (char *) hashes_buf[hashes_cnt].salt->salt_buf, hashes_buf[hashes_cnt].salt->salt_len, &hashes_buf[hashes_cnt], sort_by_salt_buf, out_fp);
-
- hashes_cnt++;
- }
-
- fclose (fp);
-
- myfree (in);
- }
- else if (hash_mode == 3000)
- {
- if (hash_len == 32)
- {
- parser_status = parse_func (hash_buf, 16, &hashes_buf[hashes_cnt]);
-
- hash_t *lm_hash_left = NULL;
-
- if (parser_status == PARSER_OK)
- {
- lm_hash_left = &hashes_buf[hashes_cnt];
-
- hashes_cnt++;
- }
- else
- {
- log_info ("WARNING: Hash '%s': %s", input_buf, strparser (parser_status));
- }
-
- parser_status = parse_func (hash_buf + 16, 16, &hashes_buf[hashes_cnt]);
-
- hash_t *lm_hash_right = NULL;
-
- if (parser_status == PARSER_OK)
- {
- lm_hash_right = &hashes_buf[hashes_cnt];
-
- hashes_cnt++;
- }
- else
- {
- log_info ("WARNING: Hash '%s': %s", input_buf, strparser (parser_status));
- }
-
- // show / left
-
- if ((lm_hash_left != NULL) && (lm_hash_right != NULL))
- {
- if (show == 1) handle_show_request_lm (pot, pot_cnt, input_buf, input_len, lm_hash_left, lm_hash_right, sort_by_pot, out_fp);
- if (left == 1) handle_left_request_lm (pot, pot_cnt, input_buf, input_len, lm_hash_left, lm_hash_right, sort_by_pot, out_fp);
- }
- }
- else
- {
- parser_status = parse_func (hash_buf, hash_len, &hashes_buf[hashes_cnt]);
-
- if (parser_status == PARSER_OK)
- {
- if (show == 1) handle_show_request (pot, pot_cnt, input_buf, input_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
- if (left == 1) handle_left_request (pot, pot_cnt, input_buf, input_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
- }
-
- if (parser_status == PARSER_OK)
- {
- hashes_cnt++;
- }
- else
- {
- log_info ("WARNING: Hash '%s': %s", input_buf, strparser (parser_status));
- }
- }
- }
- else
- {
- parser_status = parse_func (hash_buf, hash_len, &hashes_buf[hashes_cnt]);
-
- if (parser_status == PARSER_OK)
- {
- if (show == 1) handle_show_request (pot, pot_cnt, input_buf, input_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
- if (left == 1) handle_left_request (pot, pot_cnt, input_buf, input_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
- }
-
- if (parser_status == PARSER_OK)
- {
- hashes_cnt++;
- }
- else
- {
- log_info ("WARNING: Hash '%s': %s", input_buf, strparser (parser_status));
- }
- }
- }
- }
- else if (hashlist_mode == HL_MODE_FILE)
- {
- char *hashfile = data.hashfile;
-
- FILE *fp;
-
- if ((fp = fopen (hashfile, "rb")) == NULL)
- {
- log_error ("ERROR: %s: %s", hashfile, strerror (errno));
-
- return (-1);
- }
-
- uint line_num = 0;
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- while (!feof (fp))
- {
- line_num++;
-
- int line_len = fgetl (fp, line_buf);
-
- if (line_len == 0) continue;
-
- char *hash_buf = NULL;
- int hash_len = 0;
-
- hlfmt_hash (hashlist_format, line_buf, line_len, &hash_buf, &hash_len);
-
- bool hash_fmt_error = 0;
-
- if (hash_len < 1) hash_fmt_error = 1;
- if (hash_buf == NULL) hash_fmt_error = 1;
-
- if (hash_fmt_error)
- {
- log_info ("WARNING: failed to parse hashes using the '%s' format", strhlfmt (hashlist_format));
-
- continue;
- }
-
- if (username)
- {
- char *user_buf = NULL;
- int user_len = 0;
-
- hlfmt_user (hashlist_format, line_buf, line_len, &user_buf, &user_len);
-
- if (remove || show)
- {
- user_t **user = &hashes_buf[hashes_cnt].hash_info->user;
-
- *user = (user_t *) mymalloc (sizeof (user_t));
-
- user_t *user_ptr = *user;
-
- if (user_buf != NULL)
- {
- user_ptr->user_name = mystrdup (user_buf);
- }
- else
- {
- user_ptr->user_name = mystrdup ("");
- }
-
- user_ptr->user_len = user_len;
- }
- }
-
- if (opts_type & OPTS_TYPE_HASH_COPY)
- {
- hashinfo_t *hash_info_tmp = hashes_buf[hashes_cnt].hash_info;
-
- hash_info_tmp->orighash = mystrdup (hash_buf);
- }
-
- if (isSalted)
- {
- memset (hashes_buf[hashes_cnt].salt, 0, sizeof (salt_t));
- }
-
- if (hash_mode == 3000)
- {
- if (hash_len == 32)
- {
- int parser_status = parse_func (hash_buf, 16, &hashes_buf[hashes_cnt]);
-
- if (parser_status < PARSER_GLOBAL_ZERO)
- {
- log_info ("WARNING: Hashfile '%s' in line %u (%s): %s", data.hashfile, line_num, line_buf, strparser (parser_status));
-
- continue;
- }
-
- hash_t *lm_hash_left = &hashes_buf[hashes_cnt];
-
- hashes_cnt++;
-
- parser_status = parse_func (hash_buf + 16, 16, &hashes_buf[hashes_cnt]);
-
- if (parser_status < PARSER_GLOBAL_ZERO)
- {
- log_info ("WARNING: Hashfile '%s' in line %u (%s): %s", data.hashfile, line_num, line_buf, strparser (parser_status));
-
- continue;
- }
-
- hash_t *lm_hash_right = &hashes_buf[hashes_cnt];
-
- if (data.quiet == 0) if ((hashes_cnt % 0x20000) == 0) log_info_nn ("Parsed Hashes: %u/%u (%0.2f%%)", hashes_cnt, hashes_avail, ((float) hashes_cnt / hashes_avail) * 100);
-
- hashes_cnt++;
-
- // show / left
-
- if (show == 1) handle_show_request_lm (pot, pot_cnt, line_buf, line_len, lm_hash_left, lm_hash_right, sort_by_pot, out_fp);
- if (left == 1) handle_left_request_lm (pot, pot_cnt, line_buf, line_len, lm_hash_left, lm_hash_right, sort_by_pot, out_fp);
- }
- else
- {
- int parser_status = parse_func (hash_buf, hash_len, &hashes_buf[hashes_cnt]);
-
- if (parser_status < PARSER_GLOBAL_ZERO)
- {
- log_info ("WARNING: Hashfile '%s' in line %u (%s): %s", data.hashfile, line_num, line_buf, strparser (parser_status));
-
- continue;
- }
-
- if (data.quiet == 0) if ((hashes_cnt % 0x20000) == 0) log_info_nn ("Parsed Hashes: %u/%u (%0.2f%%)", hashes_cnt, hashes_avail, ((float) hashes_cnt / hashes_avail) * 100);
-
- if (show == 1) handle_show_request (pot, pot_cnt, line_buf, line_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
- if (left == 1) handle_left_request (pot, pot_cnt, line_buf, line_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
-
- hashes_cnt++;
- }
- }
- else
- {
- int parser_status = parse_func (hash_buf, hash_len, &hashes_buf[hashes_cnt]);
-
- if (parser_status < PARSER_GLOBAL_ZERO)
- {
- log_info ("WARNING: Hashfile '%s' in line %u (%s): %s", data.hashfile, line_num, line_buf, strparser (parser_status));
-
- continue;
- }
-
- if (data.quiet == 0) if ((hashes_cnt % 0x20000) == 0) log_info_nn ("Parsed Hashes: %u/%u (%0.2f%%)", hashes_cnt, hashes_avail, ((float) hashes_cnt / hashes_avail) * 100);
-
- if (show == 1) handle_show_request (pot, pot_cnt, line_buf, line_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
- if (left == 1) handle_left_request (pot, pot_cnt, line_buf, line_len, &hashes_buf[hashes_cnt], sort_by_pot, out_fp);
-
- hashes_cnt++;
- }
- }
-
- myfree (line_buf);
-
- fclose (fp);
-
- if (data.quiet == 0) log_info_nn ("Parsed Hashes: %u/%u (%0.2f%%)", hashes_avail, hashes_avail, 100.00);
-
- if ((out_fp != NULL) && (out_fp != stdout)) fclose (out_fp);
- }
- }
- else
- {
- if (isSalted)
- {
- hashes_buf[0].salt->salt_len = 8;
-
- // special salt handling
-
- switch (hash_mode)
- {
- case 1500: hashes_buf[0].salt->salt_len = 2;
- hashes_buf[0].salt->salt_buf[0] = 388; // pure magic
- break;
- case 1731: hashes_buf[0].salt->salt_len = 4;
- break;
- case 2410: hashes_buf[0].salt->salt_len = 4;
- break;
- case 2500: memcpy (hashes_buf[0].salt->salt_buf, "hashcat.net", 11);
- break;
- case 3100: hashes_buf[0].salt->salt_len = 1;
- break;
- case 5000: hashes_buf[0].salt->keccak_mdlen = 32;
- break;
- case 5800: hashes_buf[0].salt->salt_len = 16;
- break;
- case 6800: hashes_buf[0].salt->salt_len = 32;
- break;
- case 8400: hashes_buf[0].salt->salt_len = 40;
- break;
- case 8800: hashes_buf[0].salt->salt_len = 16;
- break;
- case 8900: hashes_buf[0].salt->salt_len = 16;
- hashes_buf[0].salt->scrypt_N = 1024;
- hashes_buf[0].salt->scrypt_r = 1;
- hashes_buf[0].salt->scrypt_p = 1;
- break;
- case 9100: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9300: hashes_buf[0].salt->salt_len = 14;
- hashes_buf[0].salt->scrypt_N = 16384;
- hashes_buf[0].salt->scrypt_r = 1;
- hashes_buf[0].salt->scrypt_p = 1;
- break;
- case 9400: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9500: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9600: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9700: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9710: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9720: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9800: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9810: hashes_buf[0].salt->salt_len = 16;
- break;
- case 9820: hashes_buf[0].salt->salt_len = 16;
- break;
- case 10300: hashes_buf[0].salt->salt_len = 12;
- break;
- case 11500: hashes_buf[0].salt->salt_len = 4;
- break;
- case 11600: hashes_buf[0].salt->salt_len = 4;
- break;
- case 12400: hashes_buf[0].salt->salt_len = 4;
- break;
- case 12500: hashes_buf[0].salt->salt_len = 8;
- break;
- case 12600: hashes_buf[0].salt->salt_len = 64;
- break;
- }
-
- // special esalt handling
-
- switch (hash_mode)
- {
- case 2500: ((wpa_t *) hashes_buf[0].esalt)->eapol_size = 128;
- break;
- case 5300: ((ikepsk_t *) hashes_buf[0].esalt)->nr_len = 1;
- ((ikepsk_t *) hashes_buf[0].esalt)->msg_len = 1;
- break;
- case 5400: ((ikepsk_t *) hashes_buf[0].esalt)->nr_len = 1;
- ((ikepsk_t *) hashes_buf[0].esalt)->msg_len = 1;
- break;
- case 5500: ((netntlm_t *) hashes_buf[0].esalt)->user_len = 1;
- ((netntlm_t *) hashes_buf[0].esalt)->domain_len = 1;
- ((netntlm_t *) hashes_buf[0].esalt)->srvchall_len = 1;
- ((netntlm_t *) hashes_buf[0].esalt)->clichall_len = 1;
- break;
- case 5600: ((netntlm_t *) hashes_buf[0].esalt)->user_len = 1;
- ((netntlm_t *) hashes_buf[0].esalt)->domain_len = 1;
- ((netntlm_t *) hashes_buf[0].esalt)->srvchall_len = 1;
- ((netntlm_t *) hashes_buf[0].esalt)->clichall_len = 1;
- break;
- case 7300: ((rakp_t *) hashes_buf[0].esalt)->salt_len = 32;
- break;
- case 10400: ((pdf_t *) hashes_buf[0].esalt)->id_len = 16;
- ((pdf_t *) hashes_buf[0].esalt)->o_len = 32;
- ((pdf_t *) hashes_buf[0].esalt)->u_len = 32;
- break;
- case 10410: ((pdf_t *) hashes_buf[0].esalt)->id_len = 16;
- ((pdf_t *) hashes_buf[0].esalt)->o_len = 32;
- ((pdf_t *) hashes_buf[0].esalt)->u_len = 32;
- break;
- case 10420: ((pdf_t *) hashes_buf[0].esalt)->id_len = 16;
- ((pdf_t *) hashes_buf[0].esalt)->o_len = 32;
- ((pdf_t *) hashes_buf[0].esalt)->u_len = 32;
- break;
- case 10500: ((pdf_t *) hashes_buf[0].esalt)->id_len = 16;
- ((pdf_t *) hashes_buf[0].esalt)->o_len = 32;
- ((pdf_t *) hashes_buf[0].esalt)->u_len = 32;
- break;
- case 10600: ((pdf_t *) hashes_buf[0].esalt)->id_len = 16;
- ((pdf_t *) hashes_buf[0].esalt)->o_len = 127;
- ((pdf_t *) hashes_buf[0].esalt)->u_len = 127;
- break;
- case 10700: ((pdf_t *) hashes_buf[0].esalt)->id_len = 16;
- ((pdf_t *) hashes_buf[0].esalt)->o_len = 127;
- ((pdf_t *) hashes_buf[0].esalt)->u_len = 127;
- break;
- case 11600: ((seven_zip_t *) hashes_buf[0].esalt)->iv_len = 16;
- ((seven_zip_t *) hashes_buf[0].esalt)->data_len = 112;
- ((seven_zip_t *) hashes_buf[0].esalt)->unpack_size = 112;
- break;
- case 13400: ((keepass_t *) hashes_buf[0].esalt)->version = 2;
- break;
- case 13500: ((pstoken_t *) hashes_buf[0].esalt)->salt_len = 113;
- break;
- }
- }
-
- // set hashfile
-
- switch (hash_mode)
- {
- case 5200: data.hashfile = mystrdup ("hashcat.psafe3");
- break;
- case 5300: data.hashfile = mystrdup ("hashcat.ikemd5");
- break;
- case 5400: data.hashfile = mystrdup ("hashcat.ikesha1");
- break;
- case 6211: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6212: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6213: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6221: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6222: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6223: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6231: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6232: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6233: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6241: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6242: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6243: data.hashfile = mystrdup ("hashcat.tc");
- break;
- case 6600: data.hashfile = mystrdup ("hashcat.agilekey");
- break;
- case 8200: data.hashfile = mystrdup ("hashcat.cloudkey");
- break;
- case 9000: data.hashfile = mystrdup ("hashcat.psafe2");
- break;
- }
-
- // set default iterations
-
- switch (hash_mode)
- {
- case 400: hashes_buf[0].salt->salt_iter = ROUNDS_PHPASS;
- break;
- case 500: hashes_buf[0].salt->salt_iter = ROUNDS_MD5CRYPT;
- break;
- case 501: hashes_buf[0].salt->salt_iter = ROUNDS_MD5CRYPT;
- break;
- case 1600: hashes_buf[0].salt->salt_iter = ROUNDS_MD5CRYPT;
- break;
- case 1800: hashes_buf[0].salt->salt_iter = ROUNDS_SHA512CRYPT;
- break;
- case 2100: hashes_buf[0].salt->salt_iter = ROUNDS_DCC2;
- break;
- case 2500: hashes_buf[0].salt->salt_iter = ROUNDS_WPA2;
- break;
- case 3200: hashes_buf[0].salt->salt_iter = ROUNDS_BCRYPT;
- break;
- case 5200: hashes_buf[0].salt->salt_iter = ROUNDS_PSAFE3;
- break;
- case 5800: hashes_buf[0].salt->salt_iter = ROUNDS_ANDROIDPIN - 1;
- break;
- case 6211: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_2K;
- break;
- case 6212: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_2K;
- break;
- case 6213: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_2K;
- break;
- case 6221: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6222: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6223: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6231: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6232: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6233: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6241: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6242: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6243: hashes_buf[0].salt->salt_iter = ROUNDS_TRUECRYPT_1K;
- break;
- case 6300: hashes_buf[0].salt->salt_iter = ROUNDS_MD5CRYPT;
- break;
- case 6400: hashes_buf[0].salt->salt_iter = ROUNDS_SHA256AIX;
- break;
- case 6500: hashes_buf[0].salt->salt_iter = ROUNDS_SHA512AIX;
- break;
- case 6700: hashes_buf[0].salt->salt_iter = ROUNDS_SHA1AIX;
- break;
- case 6600: hashes_buf[0].salt->salt_iter = ROUNDS_AGILEKEY;
- break;
- case 6800: hashes_buf[0].salt->salt_iter = ROUNDS_LASTPASS;
- break;
- case 7100: hashes_buf[0].salt->salt_iter = ROUNDS_SHA512OSX;
- break;
- case 7200: hashes_buf[0].salt->salt_iter = ROUNDS_GRUB;
- break;
- case 7400: hashes_buf[0].salt->salt_iter = ROUNDS_SHA256CRYPT;
- break;
- case 7900: hashes_buf[0].salt->salt_iter = ROUNDS_DRUPAL7;
- break;
- case 8200: hashes_buf[0].salt->salt_iter = ROUNDS_CLOUDKEY;
- break;
- case 8300: hashes_buf[0].salt->salt_iter = ROUNDS_NSEC3;
- break;
- case 8800: hashes_buf[0].salt->salt_iter = ROUNDS_ANDROIDFDE;
- break;
- case 8900: hashes_buf[0].salt->salt_iter = 1;
- break;
- case 9000: hashes_buf[0].salt->salt_iter = ROUNDS_PSAFE2;
- break;
- case 9100: hashes_buf[0].salt->salt_iter = ROUNDS_LOTUS8;
- break;
- case 9200: hashes_buf[0].salt->salt_iter = ROUNDS_CISCO8;
- break;
- case 9300: hashes_buf[0].salt->salt_iter = 1;
- break;
- case 9400: hashes_buf[0].salt->salt_iter = ROUNDS_OFFICE2007;
- break;
- case 9500: hashes_buf[0].salt->salt_iter = ROUNDS_OFFICE2010;
- break;
- case 9600: hashes_buf[0].salt->salt_iter = ROUNDS_OFFICE2013;
- break;
- case 10000: hashes_buf[0].salt->salt_iter = ROUNDS_DJANGOPBKDF2;
- break;
- case 10300: hashes_buf[0].salt->salt_iter = ROUNDS_SAPH_SHA1 - 1;
- break;
- case 10500: hashes_buf[0].salt->salt_iter = ROUNDS_PDF14;
- break;
- case 10700: hashes_buf[0].salt->salt_iter = ROUNDS_PDF17L8;
- break;
- case 10900: hashes_buf[0].salt->salt_iter = ROUNDS_PBKDF2_SHA256 - 1;
- break;
- case 11300: hashes_buf[0].salt->salt_iter = ROUNDS_BITCOIN_WALLET - 1;
- break;
- case 11600: hashes_buf[0].salt->salt_iter = ROUNDS_SEVEN_ZIP;
- break;
- case 11900: hashes_buf[0].salt->salt_iter = ROUNDS_PBKDF2_MD5 - 1;
- break;
- case 12000: hashes_buf[0].salt->salt_iter = ROUNDS_PBKDF2_SHA1 - 1;
- break;
- case 12100: hashes_buf[0].salt->salt_iter = ROUNDS_PBKDF2_SHA512 - 1;
- break;
- case 12200: hashes_buf[0].salt->salt_iter = ROUNDS_ECRYPTFS - 1;
- break;
- case 12300: hashes_buf[0].salt->salt_iter = ROUNDS_ORACLET - 1;
- break;
- case 12400: hashes_buf[0].salt->salt_iter = ROUNDS_BSDICRYPT - 1;
- break;
- case 12500: hashes_buf[0].salt->salt_iter = ROUNDS_RAR3;
- break;
- case 12700: hashes_buf[0].salt->salt_iter = ROUNDS_MYWALLET;
- break;
- case 12800: hashes_buf[0].salt->salt_iter = ROUNDS_MS_DRSR - 1;
- break;
- case 12900: hashes_buf[0].salt->salt_iter = ROUNDS_ANDROIDFDE_SAMSUNG - 1;
- break;
- case 13000: hashes_buf[0].salt->salt_iter = ROUNDS_RAR5 - 1;
- break;
- case 13200: hashes_buf[0].salt->salt_iter = ROUNDS_AXCRYPT;
- break;
- case 13400: hashes_buf[0].salt->salt_iter = ROUNDS_KEEPASS;
- break;
- }
-
- hashes_cnt = 1;
- }
-
- if (show == 1 || left == 1)
- {
- for (uint i = 0; i < pot_cnt; i++)
- {
- pot_t *pot_ptr = &pot[i];
-
- hash_t *hashes_buf = &pot_ptr->hash;
-
- local_free (hashes_buf->digest);
-
- if (isSalted)
- {
- local_free (hashes_buf->salt);
- }
- }
-
- local_free (pot);
-
- if (data.quiet == 0) log_info_nn ("");
-
- return (0);
- }
-
- if (keyspace == 0)
- {
- if (hashes_cnt == 0)
- {
- log_error ("ERROR: No hashes loaded");
-
- return (-1);
- }
- }
-
- /**
- * Sanity check for hashfile vs outfile (should not point to the same physical file)
- */
-
- if (data.outfile != NULL)
- {
- if (data.hashfile != NULL)
- {
- #ifdef _POSIX
- struct stat tmpstat_outfile;
- struct stat tmpstat_hashfile;
- #endif
-
- #ifdef _WIN
- struct stat64 tmpstat_outfile;
- struct stat64 tmpstat_hashfile;
- #endif
-
- FILE *tmp_outfile_fp = fopen (data.outfile, "r");
-
- if (tmp_outfile_fp)
- {
- #ifdef _POSIX
- fstat (fileno (tmp_outfile_fp), &tmpstat_outfile);
- #endif
-
- #ifdef _WIN
- _fstat64 (fileno (tmp_outfile_fp), &tmpstat_outfile);
- #endif
-
- fclose (tmp_outfile_fp);
- }
-
- FILE *tmp_hashfile_fp = fopen (data.hashfile, "r");
-
- if (tmp_hashfile_fp)
- {
- #ifdef _POSIX
- fstat (fileno (tmp_hashfile_fp), &tmpstat_hashfile);
- #endif
-
- #ifdef _WIN
- _fstat64 (fileno (tmp_hashfile_fp), &tmpstat_hashfile);
- #endif
-
- fclose (tmp_hashfile_fp);
- }
-
- if (tmp_outfile_fp && tmp_outfile_fp)
- {
- tmpstat_outfile.st_mode = 0;
- tmpstat_outfile.st_nlink = 0;
- tmpstat_outfile.st_uid = 0;
- tmpstat_outfile.st_gid = 0;
- tmpstat_outfile.st_rdev = 0;
- tmpstat_outfile.st_atime = 0;
-
- tmpstat_hashfile.st_mode = 0;
- tmpstat_hashfile.st_nlink = 0;
- tmpstat_hashfile.st_uid = 0;
- tmpstat_hashfile.st_gid = 0;
- tmpstat_hashfile.st_rdev = 0;
- tmpstat_hashfile.st_atime = 0;
-
- #ifdef _POSIX
- tmpstat_outfile.st_blksize = 0;
- tmpstat_outfile.st_blocks = 0;
-
- tmpstat_hashfile.st_blksize = 0;
- tmpstat_hashfile.st_blocks = 0;
- #endif
-
- #ifdef _POSIX
- if (memcmp (&tmpstat_outfile, &tmpstat_hashfile, sizeof (struct stat)) == 0)
- {
- log_error ("ERROR: Hashfile and Outfile are not allowed to point to the same file");
-
- return (-1);
- }
- #endif
-
- #ifdef _WIN
- if (memcmp (&tmpstat_outfile, &tmpstat_hashfile, sizeof (struct stat64)) == 0)
- {
- log_error ("ERROR: Hashfile and Outfile are not allowed to point to the same file");
-
- return (-1);
- }
- #endif
- }
- }
- }
-
- /**
- * Remove duplicates
- */
-
- if (data.quiet == 0) log_info_nn ("Removing duplicate hashes...");
-
- if (isSalted)
- {
- qsort (hashes_buf, hashes_cnt, sizeof (hash_t), sort_by_hash);
- }
- else
- {
- qsort (hashes_buf, hashes_cnt, sizeof (hash_t), sort_by_hash_no_salt);
- }
-
- uint hashes_cnt_orig = hashes_cnt;
-
- hashes_cnt = 1;
-
- for (uint hashes_pos = 1; hashes_pos < hashes_cnt_orig; hashes_pos++)
- {
- if (isSalted)
- {
- if (sort_by_salt (hashes_buf[hashes_pos].salt, hashes_buf[hashes_pos - 1].salt) == 0)
- {
- if (sort_by_digest (hashes_buf[hashes_pos].digest, hashes_buf[hashes_pos - 1].digest) == 0) continue;
- }
- }
- else
- {
- if (sort_by_digest (hashes_buf[hashes_pos].digest, hashes_buf[hashes_pos - 1].digest) == 0) continue;
- }
-
- if (hashes_pos > hashes_cnt)
- {
- memcpy (&hashes_buf[hashes_cnt], &hashes_buf[hashes_pos], sizeof (hash_t));
- }
-
- hashes_cnt++;
- }
-
- /**
- * Potfile removes
- */
-
- uint potfile_remove_cracks = 0;
-
- if (potfile_disable == 0)
- {
- hash_t hash_buf;
-
- hash_buf.digest = mymalloc (dgst_size);
- hash_buf.salt = NULL;
- hash_buf.esalt = NULL;
- hash_buf.hash_info = NULL;
- hash_buf.cracked = 0;
-
- if (isSalted)
- {
- hash_buf.salt = (salt_t *) mymalloc (sizeof (salt_t));
- }
-
- if (esalt_size)
- {
- hash_buf.esalt = mymalloc (esalt_size);
- }
-
- if (quiet == 0) log_info_nn ("Comparing hashes with potfile entries...");
-
- // no solution for these special hash types (for instane because they use hashfile in output etc)
- if ((hash_mode != 5200) &&
- !((hash_mode >= 6200) && (hash_mode <= 6299)) &&
- (hash_mode != 9000))
- {
- FILE *fp = fopen (potfile, "rb");
-
- if (fp != NULL)
- {
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- // to be safe work with a copy (because of line_len loop, i etc)
- // moved up here because it's easier to handle continue case
- // it's just 64kb
-
- char *line_buf_cpy = (char *) mymalloc (HCBUFSIZ);
-
- while (!feof (fp))
- {
- char *ptr = fgets (line_buf, HCBUFSIZ - 1, fp);
-
- if (ptr == NULL) break;
-
- int line_len = strlen (line_buf);
-
- if (line_len == 0) continue;
-
- int iter = MAX_CUT_TRIES;
-
- for (int i = line_len - 1; i && iter; i--, line_len--)
- {
- if (line_buf[i] != ':') continue;
-
- if (isSalted)
- {
- memset (hash_buf.salt, 0, sizeof (salt_t));
- }
-
- hash_t *found = NULL;
-
- if (hash_mode == 6800)
- {
- if (i < 64) // 64 = 16 * uint in salt_buf[]
- {
- // manipulate salt_buf
- memcpy (hash_buf.salt->salt_buf, line_buf, i);
-
- hash_buf.salt->salt_len = i;
-
- found = (hash_t *) bsearch (&hash_buf, hashes_buf, hashes_cnt, sizeof (hash_t), sort_by_hash_t_salt);
- }
- }
- else if (hash_mode == 2500)
- {
- if (i < 64) // 64 = 16 * uint in salt_buf[]
- {
- // here we have in line_buf: ESSID:MAC1:MAC2 (without the plain)
- // manipulate salt_buf
-
- memcpy (line_buf_cpy, line_buf, i);
-
- char *mac2_pos = strrchr (line_buf_cpy, ':');
-
- if (mac2_pos == NULL) continue;
-
- mac2_pos[0] = 0;
- mac2_pos++;
-
- if (strlen (mac2_pos) != 12) continue;
-
- char *mac1_pos = strrchr (line_buf_cpy, ':');
-
- if (mac1_pos == NULL) continue;
-
- mac1_pos[0] = 0;
- mac1_pos++;
-
- if (strlen (mac1_pos) != 12) continue;
-
- uint essid_length = mac1_pos - line_buf_cpy - 1;
-
- // here we need the ESSID
- memcpy (hash_buf.salt->salt_buf, line_buf_cpy, essid_length);
-
- hash_buf.salt->salt_len = essid_length;
-
- found = (hash_t *) bsearch (&hash_buf, hashes_buf, hashes_cnt, sizeof (hash_t), sort_by_hash_t_salt_hccap);
-
- if (found)
- {
- wpa_t *wpa = (wpa_t *) found->esalt;
-
- // compare hex string(s) vs binary MAC address(es)
-
- for (uint i = 0, j = 0; i < 6; i++, j += 2)
- {
- if (wpa->orig_mac1[i] != hex_to_u8 ((const u8 *) &mac1_pos[j]))
- {
- found = NULL;
-
- break;
- }
- }
-
- // early skip ;)
- if (!found) continue;
-
- for (uint i = 0, j = 0; i < 6; i++, j += 2)
- {
- if (wpa->orig_mac2[i] != hex_to_u8 ((const u8 *) &mac2_pos[j]))
- {
- found = NULL;
-
- break;
- }
- }
- }
- }
- }
- else
- {
- int parser_status = parse_func (line_buf, line_len - 1, &hash_buf);
-
- if (parser_status == PARSER_OK)
- {
- if (isSalted)
- {
- found = (hash_t *) bsearch (&hash_buf, hashes_buf, hashes_cnt, sizeof (hash_t), sort_by_hash);
- }
- else
- {
- found = (hash_t *) bsearch (&hash_buf, hashes_buf, hashes_cnt, sizeof (hash_t), sort_by_hash_no_salt);
- }
- }
- }
-
- if (found == NULL) continue;
-
- if (!found->cracked) potfile_remove_cracks++;
-
- found->cracked = 1;
-
- if (found) break;
-
- iter--;
- }
- }
-
- myfree (line_buf_cpy);
-
- myfree (line_buf);
-
- fclose (fp);
- }
- }
-
- if (esalt_size)
- {
- local_free (hash_buf.esalt);
- }
-
- if (isSalted)
- {
- local_free (hash_buf.salt);
- }
-
- local_free (hash_buf.digest);
- }
-
- /**
- * Now generate all the buffers required for later
- */
-
- void *digests_buf_new = (void *) mycalloc (hashes_avail, dgst_size);
-
- salt_t *salts_buf_new = NULL;
- void *esalts_buf_new = NULL;
-
- if (isSalted)
- {
- salts_buf_new = (salt_t *) mycalloc (hashes_avail, sizeof (salt_t));
-
- if (esalt_size)
- {
- esalts_buf_new = (void *) mycalloc (hashes_avail, esalt_size);
- }
- }
- else
- {
- salts_buf_new = (salt_t *) mycalloc (1, sizeof (salt_t));
- }
-
- if (data.quiet == 0) log_info_nn ("Structuring salts for cracking task...");
-
- uint digests_cnt = hashes_cnt;
- uint digests_done = 0;
-
- size_t size_digests = digests_cnt * dgst_size;
- size_t size_shown = digests_cnt * sizeof (uint);
-
- uint *digests_shown = (uint *) mymalloc (size_shown);
- uint *digests_shown_tmp = (uint *) mymalloc (size_shown);
-
- uint salts_cnt = 0;
- uint salts_done = 0;
-
- hashinfo_t **hash_info = NULL;
-
- if ((username && (remove || show)) || (opts_type & OPTS_TYPE_HASH_COPY))
- {
- hash_info = (hashinfo_t**) mymalloc (hashes_cnt * sizeof (hashinfo_t *));
-
- if (username && (remove || show))
- {
- uint user_pos;
-
- for (user_pos = 0; user_pos < hashes_cnt; user_pos++)
- {
- hash_info[user_pos] = (hashinfo_t*) mycalloc (hashes_cnt, sizeof (hashinfo_t));
-
- hash_info[user_pos]->user = (user_t*) mymalloc (sizeof (user_t));
- }
- }
- }
-
- uint *salts_shown = (uint *) mymalloc (size_shown);
-
- salt_t *salt_buf;
-
- {
- // copied from inner loop
-
- salt_buf = &salts_buf_new[salts_cnt];
-
- memcpy (salt_buf, hashes_buf[0].salt, sizeof (salt_t));
-
- if (esalt_size)
- {
- memcpy (((char *) esalts_buf_new) + (salts_cnt * esalt_size), hashes_buf[0].esalt, esalt_size);
- }
-
- salt_buf->digests_cnt = 0;
- salt_buf->digests_done = 0;
- salt_buf->digests_offset = 0;
-
- salts_cnt++;
- }
-
- if (hashes_buf[0].cracked == 1)
- {
- digests_shown[0] = 1;
-
- digests_done++;
-
- salt_buf->digests_done++;
- }
-
- salt_buf->digests_cnt++;
-
- memcpy (((char *) digests_buf_new) + (0 * dgst_size), hashes_buf[0].digest, dgst_size);
-
- if ((username && (remove || show)) || (opts_type & OPTS_TYPE_HASH_COPY))
- {
- hash_info[0] = hashes_buf[0].hash_info;
- }
-
- // copy from inner loop
-
- for (uint hashes_pos = 1; hashes_pos < hashes_cnt; hashes_pos++)
- {
- if (isSalted)
- {
- if (sort_by_salt (hashes_buf[hashes_pos].salt, hashes_buf[hashes_pos - 1].salt) != 0)
- {
- salt_buf = &salts_buf_new[salts_cnt];
-
- memcpy (salt_buf, hashes_buf[hashes_pos].salt, sizeof (salt_t));
-
- if (esalt_size)
- {
- memcpy (((char *) esalts_buf_new) + (salts_cnt * esalt_size), hashes_buf[hashes_pos].esalt, esalt_size);
- }
-
- salt_buf->digests_cnt = 0;
- salt_buf->digests_done = 0;
- salt_buf->digests_offset = hashes_pos;
-
- salts_cnt++;
- }
- }
-
- if (hashes_buf[hashes_pos].cracked == 1)
- {
- digests_shown[hashes_pos] = 1;
-
- digests_done++;
-
- salt_buf->digests_done++;
- }
-
- salt_buf->digests_cnt++;
-
- memcpy (((char *) digests_buf_new) + (hashes_pos * dgst_size), hashes_buf[hashes_pos].digest, dgst_size);
-
- if ((username && (remove || show)) || (opts_type & OPTS_TYPE_HASH_COPY))
- {
- hash_info[hashes_pos] = hashes_buf[hashes_pos].hash_info;
- }
- }
-
- for (uint salt_pos = 0; salt_pos < salts_cnt; salt_pos++)
- {
- salt_t *salt_buf = &salts_buf_new[salt_pos];
-
- if (salt_buf->digests_done == salt_buf->digests_cnt)
- {
- salts_shown[salt_pos] = 1;
-
- salts_done++;
- }
-
- if (salts_done == salts_cnt) data.devices_status = STATUS_CRACKED;
- }
-
- local_free (digests_buf);
- local_free (salts_buf);
- local_free (esalts_buf);
-
- digests_buf = digests_buf_new;
- salts_buf = salts_buf_new;
- esalts_buf = esalts_buf_new;
-
- local_free (hashes_buf);
-
- /**
- * special modification not set from parser
- */
-
- switch (hash_mode)
- {
- case 6211: salts_buf->truecrypt_mdlen = 1 * 512; break;
- case 6212: salts_buf->truecrypt_mdlen = 2 * 512; break;
- case 6213: salts_buf->truecrypt_mdlen = 3 * 512; break;
- case 6221: salts_buf->truecrypt_mdlen = 1 * 512; break;
- case 6222: salts_buf->truecrypt_mdlen = 2 * 512; break;
- case 6223: salts_buf->truecrypt_mdlen = 3 * 512; break;
- case 6231: salts_buf->truecrypt_mdlen = 1 * 512; break;
- case 6232: salts_buf->truecrypt_mdlen = 2 * 512; break;
- case 6233: salts_buf->truecrypt_mdlen = 3 * 512; break;
- case 6241: salts_buf->truecrypt_mdlen = 1 * 512; break;
- case 6242: salts_buf->truecrypt_mdlen = 2 * 512; break;
- case 6243: salts_buf->truecrypt_mdlen = 3 * 512; break;
- }
-
- if (truecrypt_keyfiles)
- {
- uint *keyfile_buf = ((tc_t *) esalts_buf)->keyfile_buf;
-
- char *keyfiles = strdup (truecrypt_keyfiles);
-
- char *keyfile = strtok (keyfiles, ",");
-
- do
- {
- truecrypt_crc32 (keyfile, (u8 *) keyfile_buf);
-
- } while ((keyfile = strtok (NULL, ",")) != NULL);
-
- free (keyfiles);
- }
-
- data.digests_cnt = digests_cnt;
- data.digests_done = digests_done;
- data.digests_buf = digests_buf;
- data.digests_shown = digests_shown;
- data.digests_shown_tmp = digests_shown_tmp;
-
- data.salts_cnt = salts_cnt;
- data.salts_done = salts_done;
- data.salts_buf = salts_buf;
- data.salts_shown = salts_shown;
-
- data.esalts_buf = esalts_buf;
- data.hash_info = hash_info;
-
- /**
- * Automatic Optimizers
- */
-
- if (salts_cnt == 1)
- opti_type |= OPTI_TYPE_SINGLE_SALT;
-
- if (digests_cnt == 1)
- opti_type |= OPTI_TYPE_SINGLE_HASH;
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- opti_type |= OPTI_TYPE_NOT_ITERATED;
-
- if (attack_mode == ATTACK_MODE_BF)
- opti_type |= OPTI_TYPE_BRUTE_FORCE;
-
- data.opti_type = opti_type;
-
- if (opti_type & OPTI_TYPE_BRUTE_FORCE)
- {
- if (opti_type & OPTI_TYPE_SINGLE_HASH)
- {
- if (opti_type & OPTI_TYPE_APPENDED_SALT)
- {
- if (opts_type & OPTS_TYPE_ST_ADD80)
- {
- opts_type &= ~OPTS_TYPE_ST_ADD80;
- opts_type |= OPTS_TYPE_PT_ADD80;
- }
-
- if (opts_type & OPTS_TYPE_ST_ADDBITS14)
- {
- opts_type &= ~OPTS_TYPE_ST_ADDBITS14;
- opts_type |= OPTS_TYPE_PT_ADDBITS14;
- }
-
- if (opts_type & OPTS_TYPE_ST_ADDBITS15)
- {
- opts_type &= ~OPTS_TYPE_ST_ADDBITS15;
- opts_type |= OPTS_TYPE_PT_ADDBITS15;
- }
- }
- }
- }
-
- /**
- * Some algorithm, like descrypt, can benefit from JIT compilation
- */
-
- int force_jit_compilation = -1;
-
- if (hash_mode == 8900)
- {
- force_jit_compilation = 8900;
- }
- else if (hash_mode == 9300)
- {
- force_jit_compilation = 8900;
- }
- else if (hash_mode == 1500 && attack_mode == ATTACK_MODE_BF && data.salts_cnt == 1)
- {
- force_jit_compilation = 1500;
- }
-
- /**
- * generate bitmap tables
- */
-
- const uint bitmap_shift1 = 5;
- const uint bitmap_shift2 = 13;
-
- if (bitmap_max < bitmap_min) bitmap_max = bitmap_min;
-
- uint *bitmap_s1_a = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s1_b = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s1_c = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s1_d = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s2_a = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s2_b = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s2_c = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
- uint *bitmap_s2_d = (uint *) mymalloc ((1 << bitmap_max) * sizeof (uint));
-
- uint bitmap_bits;
- uint bitmap_nums;
- uint bitmap_mask;
- uint bitmap_size;
-
- for (bitmap_bits = bitmap_min; bitmap_bits < bitmap_max; bitmap_bits++)
- {
- if (data.quiet == 0) log_info_nn ("Generating bitmap tables with %u bits...", bitmap_bits);
-
- bitmap_nums = 1 << bitmap_bits;
-
- bitmap_mask = bitmap_nums - 1;
-
- bitmap_size = bitmap_nums * sizeof (uint);
-
- if ((hashes_cnt & bitmap_mask) == hashes_cnt) break;
-
- if (generate_bitmaps (digests_cnt, dgst_size, bitmap_shift1, (char *) data.digests_buf, bitmap_mask, bitmap_size, bitmap_s1_a, bitmap_s1_b, bitmap_s1_c, bitmap_s1_d, digests_cnt / 2) == 0x7fffffff) continue;
- if (generate_bitmaps (digests_cnt, dgst_size, bitmap_shift2, (char *) data.digests_buf, bitmap_mask, bitmap_size, bitmap_s1_a, bitmap_s1_b, bitmap_s1_c, bitmap_s1_d, digests_cnt / 2) == 0x7fffffff) continue;
-
- break;
- }
-
- bitmap_nums = 1 << bitmap_bits;
-
- bitmap_mask = bitmap_nums - 1;
-
- bitmap_size = bitmap_nums * sizeof (uint);
-
- generate_bitmaps (digests_cnt, dgst_size, bitmap_shift1, (char *) data.digests_buf, bitmap_mask, bitmap_size, bitmap_s1_a, bitmap_s1_b, bitmap_s1_c, bitmap_s1_d, -1);
- generate_bitmaps (digests_cnt, dgst_size, bitmap_shift2, (char *) data.digests_buf, bitmap_mask, bitmap_size, bitmap_s2_a, bitmap_s2_b, bitmap_s2_c, bitmap_s2_d, -1);
-
- /**
- * prepare quick rule
- */
-
- data.rule_buf_l = rule_buf_l;
- data.rule_buf_r = rule_buf_r;
-
- int rule_len_l = (int) strlen (rule_buf_l);
- int rule_len_r = (int) strlen (rule_buf_r);
-
- data.rule_len_l = rule_len_l;
- data.rule_len_r = rule_len_r;
-
- /**
- * load rules
- */
-
- uint *all_kernel_rules_cnt = NULL;
-
- kernel_rule_t **all_kernel_rules_buf = NULL;
-
- if (rp_files_cnt)
- {
- all_kernel_rules_cnt = (uint *) mycalloc (rp_files_cnt, sizeof (uint));
-
- all_kernel_rules_buf = (kernel_rule_t **) mycalloc (rp_files_cnt, sizeof (kernel_rule_t *));
- }
-
- char *rule_buf = (char *) mymalloc (HCBUFSIZ);
-
- int rule_len = 0;
-
- for (uint i = 0; i < rp_files_cnt; i++)
- {
- uint kernel_rules_avail = 0;
-
- uint kernel_rules_cnt = 0;
-
- kernel_rule_t *kernel_rules_buf = NULL;
-
- char *rp_file = rp_files[i];
-
- char in[BLOCK_SIZE] = { 0 };
- char out[BLOCK_SIZE] = { 0 };
-
- FILE *fp = NULL;
-
- uint rule_line = 0;
-
- if ((fp = fopen (rp_file, "rb")) == NULL)
- {
- log_error ("ERROR: %s: %s", rp_file, strerror (errno));
-
- return (-1);
- }
-
- while (!feof (fp))
- {
- memset (rule_buf, 0, HCBUFSIZ);
-
- rule_len = fgetl (fp, rule_buf);
-
- rule_line++;
-
- if (rule_len == 0) continue;
-
- if (rule_buf[0] == '#') continue;
-
- if (kernel_rules_avail == kernel_rules_cnt)
- {
- kernel_rules_buf = (kernel_rule_t *) myrealloc (kernel_rules_buf, kernel_rules_avail * sizeof (kernel_rule_t), INCR_RULES * sizeof (kernel_rule_t));
-
- kernel_rules_avail += INCR_RULES;
- }
-
- memset (in, 0, BLOCK_SIZE);
- memset (out, 0, BLOCK_SIZE);
-
- int result = _old_apply_rule (rule_buf, rule_len, in, 1, out);
-
- if (result == -1)
- {
- log_info ("WARNING: Skipping invalid or unsupported rule in file %s in line %u: %s", rp_file, rule_line, rule_buf);
-
- continue;
- }
-
- if (cpu_rule_to_kernel_rule (rule_buf, rule_len, &kernel_rules_buf[kernel_rules_cnt]) == -1)
- {
- log_info ("WARNING: Cannot convert rule for use on device in file %s in line %u: %s", rp_file, rule_line, rule_buf);
-
- memset (&kernel_rules_buf[kernel_rules_cnt], 0, sizeof (kernel_rule_t)); // needs to be cleared otherwise we could have some remaining data
-
- continue;
- }
-
- /* its so slow
- if (rulefind (&kernel_rules_buf[kernel_rules_cnt], kernel_rules_buf, kernel_rules_cnt, sizeof (kernel_rule_t), sort_by_kernel_rule))
- {
- log_info ("Duplicate rule for use on device in file %s in line %u: %s", rp_file, rule_line, rule_buf);
-
- continue;
- }
- */
-
- kernel_rules_cnt++;
- }
-
- fclose (fp);
-
- all_kernel_rules_cnt[i] = kernel_rules_cnt;
-
- all_kernel_rules_buf[i] = kernel_rules_buf;
- }
-
- /**
- * merge rules or automatic rule generator
- */
-
- uint kernel_rules_cnt = 0;
-
- kernel_rule_t *kernel_rules_buf = NULL;
-
- if (attack_mode == ATTACK_MODE_STRAIGHT)
- {
- if (rp_files_cnt)
- {
- kernel_rules_cnt = 1;
-
- uint *repeats = (uint *) mycalloc (rp_files_cnt + 1, sizeof (uint));
-
- repeats[0] = kernel_rules_cnt;
-
- for (uint i = 0; i < rp_files_cnt; i++)
- {
- kernel_rules_cnt *= all_kernel_rules_cnt[i];
-
- repeats[i + 1] = kernel_rules_cnt;
- }
-
- kernel_rules_buf = (kernel_rule_t *) mycalloc (kernel_rules_cnt, sizeof (kernel_rule_t));
-
- memset (kernel_rules_buf, 0, kernel_rules_cnt * sizeof (kernel_rule_t));
-
- for (uint i = 0; i < kernel_rules_cnt; i++)
- {
- uint out_pos = 0;
-
- kernel_rule_t *out = &kernel_rules_buf[i];
-
- for (uint j = 0; j < rp_files_cnt; j++)
- {
- uint in_off = (i / repeats[j]) % all_kernel_rules_cnt[j];
- uint in_pos;
-
- kernel_rule_t *in = &all_kernel_rules_buf[j][in_off];
-
- for (in_pos = 0; in->cmds[in_pos]; in_pos++, out_pos++)
- {
- if (out_pos == RULES_MAX - 1)
- {
- // log_info ("WARNING: Truncating chaining of rule %d and rule %d as maximum number of function calls per rule exceeded", i, in_off);
-
- break;
- }
-
- out->cmds[out_pos] = in->cmds[in_pos];
- }
- }
- }
-
- local_free (repeats);
- }
- else if (rp_gen)
- {
- uint kernel_rules_avail = 0;
-
- while (kernel_rules_cnt < rp_gen)
- {
- if (kernel_rules_avail == kernel_rules_cnt)
- {
- kernel_rules_buf = (kernel_rule_t *) myrealloc (kernel_rules_buf, kernel_rules_avail * sizeof (kernel_rule_t), INCR_RULES * sizeof (kernel_rule_t));
-
- kernel_rules_avail += INCR_RULES;
- }
-
- memset (rule_buf, 0, HCBUFSIZ);
-
- rule_len = (int) generate_random_rule (rule_buf, rp_gen_func_min, rp_gen_func_max);
-
- if (cpu_rule_to_kernel_rule (rule_buf, rule_len, &kernel_rules_buf[kernel_rules_cnt]) == -1) continue;
-
- kernel_rules_cnt++;
- }
- }
- }
-
- myfree (rule_buf);
-
- /**
- * generate NOP rules
- */
-
- if (kernel_rules_cnt == 0)
- {
- kernel_rules_buf = (kernel_rule_t *) mymalloc (sizeof (kernel_rule_t));
-
- kernel_rules_buf[kernel_rules_cnt].cmds[0] = RULE_OP_MANGLE_NOOP;
-
- kernel_rules_cnt++;
- }
-
- data.kernel_rules_cnt = kernel_rules_cnt;
- data.kernel_rules_buf = kernel_rules_buf;
-
- /**
- * OpenCL platforms: detect
- */
-
- cl_platform_id platforms[CL_PLATFORMS_MAX] = { 0 };
- cl_device_id platform_devices[DEVICES_MAX] = { 0 };
-
- cl_uint platforms_cnt = 0;
- cl_uint platform_devices_cnt = 0;
-
- if (keyspace == 0)
- {
- hc_clGetPlatformIDs (data.ocl, CL_PLATFORMS_MAX, platforms, &platforms_cnt);
-
- if (platforms_cnt == 0)
- {
- log_error ("ERROR: No OpenCL compatible platform found");
-
- return (-1);
- }
-
- if (opencl_platforms_filter != (uint) -1)
- {
- uint platform_cnt_mask = ~(((uint) -1 >> platforms_cnt) << platforms_cnt);
-
- if (opencl_platforms_filter > platform_cnt_mask)
- {
- log_error ("ERROR: The platform selected by the --opencl-platforms parameter is larger than the number of available platforms (%d)", platforms_cnt);
-
- return (-1);
- }
- }
- }
-
- /**
- * OpenCL platforms: For each platform check if we need to unset features that we can not use, eg: temp_retain
- */
-
- for (uint platform_id = 0; platform_id < platforms_cnt; platform_id++)
- {
- cl_platform_id platform = platforms[platform_id];
-
- char platform_vendor[INFOSZ] = { 0 };
-
- hc_clGetPlatformInfo (data.ocl, platform, CL_PLATFORM_VENDOR, sizeof (platform_vendor), platform_vendor, NULL);
-
- #ifdef HAVE_HWMON
- #if defined(HAVE_NVML) || defined(HAVE_NVAPI)
- if (strcmp (platform_vendor, CL_VENDOR_NV) == 0)
- {
- // make sure that we do not directly control the fan for NVidia
-
- gpu_temp_retain = 0;
-
- data.gpu_temp_retain = gpu_temp_retain;
- }
- #endif // HAVE_NVML || HAVE_NVAPI
- #endif
- }
-
- /**
- * OpenCL devices: simply push all devices from all platforms into the same device array
- */
-
- hc_device_param_t *devices_param = (hc_device_param_t *) mycalloc (DEVICES_MAX, sizeof (hc_device_param_t));
-
- data.devices_param = devices_param;
-
- uint devices_cnt = 0;
-
- uint devices_active = 0;
-
- for (uint platform_id = 0; platform_id < platforms_cnt; platform_id++)
- {
- if ((opencl_platforms_filter & (1 << platform_id)) == 0) continue;
-
- cl_platform_id platform = platforms[platform_id];
-
- hc_clGetDeviceIDs (data.ocl, platform, CL_DEVICE_TYPE_ALL, DEVICES_MAX, platform_devices, &platform_devices_cnt);
-
- char platform_vendor[INFOSZ] = { 0 };
-
- hc_clGetPlatformInfo (data.ocl, platform, CL_PLATFORM_VENDOR, sizeof (platform_vendor), platform_vendor, NULL);
-
- // find our own platform vendor because pocl and mesa are pushing original vendor_id through opencl
- // this causes trouble with vendor id based macros
- // we'll assign generic to those without special optimization available
-
- cl_uint vendor_id = 0;
-
- if (strcmp (platform_vendor, CL_VENDOR_AMD) == 0)
- {
- vendor_id = VENDOR_ID_AMD;
- }
- else if (strcmp (platform_vendor, CL_VENDOR_APPLE) == 0)
- {
- vendor_id = VENDOR_ID_GENERIC;
- }
- else if (strcmp (platform_vendor, CL_VENDOR_INTEL_BEIGNET) == 0)
- {
- vendor_id = VENDOR_ID_GENERIC;
- }
- else if (strcmp (platform_vendor, CL_VENDOR_INTEL_SDK) == 0)
- {
- vendor_id = VENDOR_ID_GENERIC;
- }
- else if (strcmp (platform_vendor, CL_VENDOR_MESA) == 0)
- {
- vendor_id = VENDOR_ID_GENERIC;
- }
- else if (strcmp (platform_vendor, CL_VENDOR_NV) == 0)
- {
- vendor_id = VENDOR_ID_NV;
- }
- else if (strcmp (platform_vendor, CL_VENDOR_POCL) == 0)
- {
- vendor_id = VENDOR_ID_GENERIC;
- }
- else
- {
- vendor_id = VENDOR_ID_GENERIC;
- }
-
- for (uint platform_devices_id = 0; platform_devices_id < platform_devices_cnt; platform_devices_id++)
- {
- size_t param_value_size = 0;
-
- const uint device_id = devices_cnt;
-
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- device_param->vendor_id = vendor_id;
-
- device_param->device = platform_devices[platform_devices_id];
-
- device_param->device_id = device_id;
-
- device_param->platform_devices_id = platform_devices_id;
-
- // device_type
-
- cl_device_type device_type;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_TYPE, sizeof (device_type), &device_type, NULL);
-
- device_type &= ~CL_DEVICE_TYPE_DEFAULT;
-
- device_param->device_type = device_type;
-
- // device_name
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_NAME, 0, NULL, ¶m_value_size);
-
- char *device_name = (char *) mymalloc (param_value_size);
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_NAME, param_value_size, device_name, NULL);
-
- device_param->device_name = device_name;
-
- // tuning db
-
- tuning_db_entry_t *tuningdb_entry = tuning_db_search (tuning_db, device_param, attack_mode, hash_mode);
-
- // device_version
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_VERSION, 0, NULL, ¶m_value_size);
-
- char *device_version = (char *) mymalloc (param_value_size);
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_VERSION, param_value_size, device_version, NULL);
-
- device_param->device_version = device_version;
-
- // device_opencl_version
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_OPENCL_C_VERSION, 0, NULL, ¶m_value_size);
-
- char *device_opencl_version = (char *) mymalloc (param_value_size);
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_OPENCL_C_VERSION, param_value_size, device_opencl_version, NULL);
-
- device_param->opencl_v12 = device_opencl_version[9] > '1' || device_opencl_version[11] >= '2';
-
- myfree (device_opencl_version);
-
- // vector_width
-
- cl_uint vector_width;
-
- if (opencl_vector_width_chgd == 0)
- {
- if (tuningdb_entry == NULL || tuningdb_entry->vector_width == -1)
- {
- if (opti_type & OPTI_TYPE_USES_BITS_64)
- {
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_NATIVE_VECTOR_WIDTH_LONG, sizeof (vector_width), &vector_width, NULL);
- }
- else
- {
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_NATIVE_VECTOR_WIDTH_INT, sizeof (vector_width), &vector_width, NULL);
- }
- }
- else
- {
- vector_width = (cl_uint) tuningdb_entry->vector_width;
- }
- }
- else
- {
- vector_width = opencl_vector_width;
- }
-
- if (vector_width > 16) vector_width = 16;
-
- device_param->vector_width = vector_width;
-
- // max_compute_units
-
- cl_uint device_processors;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_MAX_COMPUTE_UNITS, sizeof (device_processors), &device_processors, NULL);
-
- device_param->device_processors = device_processors;
-
- // device_maxmem_alloc
- // note we'll limit to 2gb, otherwise this causes all kinds of weird errors because of possible integer overflows in opencl runtimes
-
- cl_ulong device_maxmem_alloc;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_MAX_MEM_ALLOC_SIZE, sizeof (device_maxmem_alloc), &device_maxmem_alloc, NULL);
-
- device_param->device_maxmem_alloc = MIN (device_maxmem_alloc, 0x7fffffff);
-
- // device_global_mem
-
- cl_ulong device_global_mem;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_GLOBAL_MEM_SIZE, sizeof (device_global_mem), &device_global_mem, NULL);
-
- device_param->device_global_mem = device_global_mem;
-
- // max_work_group_size
-
- size_t device_maxworkgroup_size;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_MAX_WORK_GROUP_SIZE, sizeof (device_maxworkgroup_size), &device_maxworkgroup_size, NULL);
-
- device_param->device_maxworkgroup_size = device_maxworkgroup_size;
-
- // max_clock_frequency
-
- cl_uint device_maxclock_frequency;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_MAX_CLOCK_FREQUENCY, sizeof (device_maxclock_frequency), &device_maxclock_frequency, NULL);
-
- device_param->device_maxclock_frequency = device_maxclock_frequency;
-
- // device_endian_little
-
- cl_bool device_endian_little;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_ENDIAN_LITTLE, sizeof (device_endian_little), &device_endian_little, NULL);
-
- if (device_endian_little == CL_FALSE)
- {
- log_info ("Device #%u: WARNING: not little endian device", device_id + 1);
-
- device_param->skipped = 1;
- }
-
- // device_available
-
- cl_bool device_available;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_AVAILABLE, sizeof (device_available), &device_available, NULL);
-
- if (device_available == CL_FALSE)
- {
- log_info ("Device #%u: WARNING: device not available", device_id + 1);
-
- device_param->skipped = 1;
- }
-
- // device_compiler_available
-
- cl_bool device_compiler_available;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_COMPILER_AVAILABLE, sizeof (device_compiler_available), &device_compiler_available, NULL);
-
- if (device_compiler_available == CL_FALSE)
- {
- log_info ("Device #%u: WARNING: device no compiler available", device_id + 1);
-
- device_param->skipped = 1;
- }
-
- // device_execution_capabilities
-
- cl_device_exec_capabilities device_execution_capabilities;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_EXECUTION_CAPABILITIES, sizeof (device_execution_capabilities), &device_execution_capabilities, NULL);
-
- if ((device_execution_capabilities & CL_EXEC_KERNEL) == 0)
- {
- log_info ("Device #%u: WARNING: device does not support executing kernels", device_id + 1);
-
- device_param->skipped = 1;
- }
-
- // device_extensions
-
- size_t device_extensions_size;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_EXTENSIONS, 0, NULL, &device_extensions_size);
-
- char *device_extensions = mymalloc (device_extensions_size + 1);
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_EXTENSIONS, device_extensions_size, device_extensions, NULL);
-
- if (strstr (device_extensions, "base_atomics") == 0)
- {
- log_info ("Device #%u: WARNING: device does not support base atomics", device_id + 1);
-
- device_param->skipped = 1;
- }
-
- if (strstr (device_extensions, "byte_addressable_store") == 0)
- {
- log_info ("Device #%u: WARNING: device does not support byte addressable store", device_id + 1);
-
- device_param->skipped = 1;
- }
-
- myfree (device_extensions);
-
- // device_local_mem_size
-
- cl_ulong device_local_mem_size;
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_LOCAL_MEM_SIZE, sizeof (device_local_mem_size), &device_local_mem_size, NULL);
-
- if (device_local_mem_size < 32768)
- {
- log_info ("Device #%u: WARNING: device local mem size is too small", device_id + 1);
-
- device_param->skipped = 1;
- }
-
-
- // skipped
-
- device_param->skipped |= ((devices_filter & (1 << device_id)) == 0);
- device_param->skipped |= ((device_types_filter & (device_type)) == 0);
-
- // driver_version
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DRIVER_VERSION, 0, NULL, ¶m_value_size);
-
- char *driver_version = (char *) mymalloc (param_value_size);
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DRIVER_VERSION, param_value_size, driver_version, NULL);
-
- device_param->driver_version = driver_version;
-
- // device_name_chksum
-
- char *device_name_chksum = (char *) mymalloc (INFOSZ);
-
- #if __x86_64__
- snprintf (device_name_chksum, INFOSZ - 1, "%u-%u-%u-%s-%s-%s-%u", 64, device_param->vendor_id, device_param->vector_width, device_param->device_name, device_param->device_version, device_param->driver_version, COMPTIME);
- #else
- snprintf (device_name_chksum, INFOSZ - 1, "%u-%u-%u-%s-%s-%s-%u", 32, device_param->vendor_id, device_param->vector_width, device_param->device_name, device_param->device_version, device_param->driver_version, COMPTIME);
- #endif
-
- uint device_name_digest[4] = { 0 };
-
- md5_64 ((uint *) device_name_chksum, device_name_digest);
-
- snprintf (device_name_chksum, INFOSZ - 1, "%08x", device_name_digest[0]);
-
- device_param->device_name_chksum = device_name_chksum;
-
- // device_processor_cores
-
- if (device_type & CL_DEVICE_TYPE_CPU)
- {
- cl_uint device_processor_cores = 1;
-
- device_param->device_processor_cores = device_processor_cores;
- }
-
- if (device_type & CL_DEVICE_TYPE_GPU)
- {
- if (vendor_id == VENDOR_ID_AMD)
- {
- cl_uint device_processor_cores = 0;
-
- #define CL_DEVICE_WAVEFRONT_WIDTH_AMD 0x4043
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_WAVEFRONT_WIDTH_AMD, sizeof (device_processor_cores), &device_processor_cores, NULL);
-
- device_param->device_processor_cores = device_processor_cores;
- }
- else if (vendor_id == VENDOR_ID_NV)
- {
- cl_uint kernel_exec_timeout = 0;
-
- #define CL_DEVICE_KERNEL_EXEC_TIMEOUT_NV 0x4005
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_KERNEL_EXEC_TIMEOUT_NV, sizeof (kernel_exec_timeout), &kernel_exec_timeout, NULL);
-
- device_param->kernel_exec_timeout = kernel_exec_timeout;
-
- cl_uint device_processor_cores = 0;
-
- #define CL_DEVICE_WARP_SIZE_NV 0x4003
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_WARP_SIZE_NV, sizeof (device_processor_cores), &device_processor_cores, NULL);
-
- device_param->device_processor_cores = device_processor_cores;
-
- cl_uint sm_minor = 0;
- cl_uint sm_major = 0;
-
- #define CL_DEVICE_COMPUTE_CAPABILITY_MAJOR_NV 0x4000
- #define CL_DEVICE_COMPUTE_CAPABILITY_MINOR_NV 0x4001
-
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_COMPUTE_CAPABILITY_MINOR_NV, sizeof (sm_minor), &sm_minor, NULL);
- hc_clGetDeviceInfo (data.ocl, device_param->device, CL_DEVICE_COMPUTE_CAPABILITY_MAJOR_NV, sizeof (sm_major), &sm_major, NULL);
-
- device_param->sm_minor = sm_minor;
- device_param->sm_major = sm_major;
- }
- else
- {
- cl_uint device_processor_cores = 1;
-
- device_param->device_processor_cores = device_processor_cores;
- }
- }
-
- // display results
-
- if ((benchmark == 1 || quiet == 0) && (algorithm_pos == 0))
- {
- if (device_param->skipped == 0)
- {
- log_info ("Device #%u: %s, %lu/%lu MB allocatable, %dMhz, %uMCU",
- device_id + 1,
- device_name,
- (unsigned int) (device_maxmem_alloc / 1024 / 1024),
- (unsigned int) (device_global_mem / 1024 / 1024),
- (unsigned int) (device_maxclock_frequency),
- (unsigned int) device_processors);
- }
- else
- {
- log_info ("Device #%u: %s, skipped",
- device_id + 1,
- device_name);
- }
- }
-
- // common driver check
-
- if (device_param->skipped == 0)
- {
- if (device_type & CL_DEVICE_TYPE_GPU)
- {
- if (vendor_id == VENDOR_ID_AMD)
- {
- int catalyst_check = (force == 1) ? 0 : 1;
-
- int catalyst_warn = 0;
-
- int catalyst_broken = 0;
-
- if (catalyst_check == 1)
- {
- catalyst_warn = 1;
-
- // v14.9 and higher
- if (atoi (device_param->driver_version) >= 1573)
- {
- catalyst_warn = 0;
- }
-
- catalyst_check = 0;
- }
-
- if (catalyst_broken == 1)
- {
- log_info ("");
- log_info ("ATTENTION! The installed catalyst driver in your system is known to be broken!");
- log_info ("It will pass over cracked hashes and does not report them as cracked");
- log_info ("You are STRONGLY encouraged not to use it");
- log_info ("You can use --force to override this but do not post error reports if you do so");
- log_info ("");
-
- return (-1);
- }
-
- if (catalyst_warn == 1)
- {
- log_info ("");
- log_info ("ATTENTION! Unsupported or incorrect installed catalyst driver detected!");
- log_info ("You are STRONGLY encouraged to use the official supported catalyst driver for good reasons");
- log_info ("See oclHashcat's homepage for official supported catalyst drivers");
- #ifdef _WIN
- log_info ("Also see: http://hashcat.net/wiki/doku.php?id=upgrading_amd_drivers_how_to");
- #endif
- log_info ("You can use --force to override this but do not post error reports if you do so");
- log_info ("");
-
- return (-1);
- }
- }
- else if (vendor_id == VENDOR_ID_NV)
- {
- if (device_param->kernel_exec_timeout != 0)
- {
- if (data.quiet == 0) log_info ("Device #%u: WARNING! Kernel exec timeout is not disabled, it might cause you errors of code 702", device_id + 1);
- if (data.quiet == 0) log_info (" See the wiki on how to disable it: https://hashcat.net/wiki/doku.php?id=timeout_patch");
- }
- }
- }
-
- if (device_type & CL_DEVICE_TYPE_CPU)
- {
- if (vendor_id == VENDOR_ID_AMD)
- {
- if (force == 0)
- {
- log_info ("");
- log_info ("ATTENTION! OpenCL support for CPU of catalyst driver is not reliable.");
- log_info ("You are STRONGLY encouraged not to use it");
- log_info ("You can use --force to override this but do not post error reports if you do so");
- log_info ("A good alternative is the free pocl >= v0.13, but make sure to use a LLVM >= v3.8");
- log_info ("");
-
- return (-1);
- }
- }
- }
-
- /**
- * kernel accel and loops tuning db adjustment
- */
-
- device_param->kernel_accel_min = 1;
- device_param->kernel_accel_max = 1024;
-
- device_param->kernel_loops_min = 1;
- device_param->kernel_loops_max = 1024;
-
- tuning_db_entry_t *tuningdb_entry = tuning_db_search (tuning_db, device_param, attack_mode, hash_mode);
-
- if (tuningdb_entry)
- {
- u32 _kernel_accel = tuningdb_entry->kernel_accel;
- u32 _kernel_loops = tuningdb_entry->kernel_loops;
-
- if (_kernel_accel)
- {
- device_param->kernel_accel_min = _kernel_accel;
- device_param->kernel_accel_max = _kernel_accel;
- }
-
- if (_kernel_loops)
- {
- if (workload_profile == 1)
- {
- _kernel_loops = (_kernel_loops > 8) ? _kernel_loops / 8 : 1;
- }
- else if (workload_profile == 2)
- {
- _kernel_loops = (_kernel_loops > 4) ? _kernel_loops / 4 : 1;
- }
-
- device_param->kernel_loops_min = _kernel_loops;
- device_param->kernel_loops_max = _kernel_loops;
- }
- }
-
- // commandline parameters overwrite tuningdb entries
-
- if (kernel_accel)
- {
- device_param->kernel_accel_min = kernel_accel;
- device_param->kernel_accel_max = kernel_accel;
- }
-
- if (kernel_loops)
- {
- device_param->kernel_loops_min = kernel_loops;
- device_param->kernel_loops_max = kernel_loops;
- }
-
- /**
- * activate device
- */
-
- devices_active++;
- }
-
- // next please
-
- devices_cnt++;
- }
- }
-
- if (keyspace == 0 && devices_active == 0)
- {
- log_error ("ERROR: No devices found/left");
-
- return (-1);
- }
-
- // additional check to see if the user has chosen a device that is not within the range of available devices (i.e. larger than devices_cnt)
-
- if (devices_filter != (uint) -1)
- {
- uint devices_cnt_mask = ~(((uint) -1 >> devices_cnt) << devices_cnt);
-
- if (devices_filter > devices_cnt_mask)
- {
- log_error ("ERROR: The device specified by the --opencl-devices parameter is larger than the number of available devices (%d)", devices_cnt);
-
- return (-1);
- }
- }
-
- data.devices_cnt = devices_cnt;
-
- data.devices_active = devices_active;
-
- if ((benchmark == 1 || quiet == 0) && (algorithm_pos == 0))
- {
- log_info ("");
- }
-
- /**
- * HM devices: init
- */
-
- #ifdef HAVE_HWMON
- #if defined(HAVE_NVML) || defined(HAVE_NVAPI)
- hm_attrs_t hm_adapters_nv[DEVICES_MAX] = { { { 0 }, 0, 0 } };
- #endif
-
- #ifdef HAVE_ADL
- hm_attrs_t hm_adapters_amd[DEVICES_MAX] = { { { 0 }, 0, 0 } };
- #endif
-
- if (gpu_temp_disable == 0)
- {
- #if defined(WIN) && defined(HAVE_NVAPI)
- NVAPI_PTR *nvapi = (NVAPI_PTR *) mymalloc (sizeof (NVAPI_PTR));
-
- if (nvapi_init (nvapi) == 0)
- data.hm_nv = nvapi;
-
- if (data.hm_nv)
- {
- if (hm_NvAPI_Initialize (data.hm_nv) == NVAPI_OK)
- {
- HM_ADAPTER_NV nvGPUHandle[DEVICES_MAX] = { 0 };
-
- int tmp_in = hm_get_adapter_index_nv (nvGPUHandle);
-
- int tmp_out = 0;
-
- for (int i = 0; i < tmp_in; i++)
- {
- hm_adapters_nv[tmp_out++].adapter_index.nv = nvGPUHandle[i];
- }
-
- for (int i = 0; i < tmp_out; i++)
- {
- NV_GPU_COOLER_SETTINGS pCoolerSettings;
-
- pCoolerSettings.Version = GPU_COOLER_SETTINGS_VER | sizeof (NV_GPU_COOLER_SETTINGS);
-
- if (hm_NvAPI_GPU_GetCoolerSettings (data.hm_nv, hm_adapters_nv[i].adapter_index.nv, 0, &pCoolerSettings) != NVAPI_NOT_SUPPORTED) hm_adapters_nv[i].fan_supported = 1;
- }
- }
- }
- #endif // WIN && HAVE_NVAPI
-
- #if defined(LINUX) && defined(HAVE_NVML)
- NVML_PTR *nvml = (NVML_PTR *) mymalloc (sizeof (NVML_PTR));
-
- if (nvml_init (nvml) == 0)
- data.hm_nv = nvml;
-
- if (data.hm_nv)
- {
- if (hm_NVML_nvmlInit (data.hm_nv) == NVML_SUCCESS)
- {
- HM_ADAPTER_NV nvGPUHandle[DEVICES_MAX] = { 0 };
-
- int tmp_in = hm_get_adapter_index_nv (nvGPUHandle);
-
- int tmp_out = 0;
-
- for (int i = 0; i < tmp_in; i++)
- {
- hm_adapters_nv[tmp_out++].adapter_index.nv = nvGPUHandle[i];
- }
-
- for (int i = 0; i < tmp_out; i++)
- {
- unsigned int speed;
-
- if (hm_NVML_nvmlDeviceGetFanSpeed (data.hm_nv, 1, hm_adapters_nv[i].adapter_index.nv, &speed) != NVML_ERROR_NOT_SUPPORTED) hm_adapters_nv[i].fan_supported = 1;
- }
- }
- }
- #endif // LINUX && HAVE_NVML
-
- data.hm_amd = NULL;
-
- #ifdef HAVE_ADL
- ADL_PTR *adl = (ADL_PTR *) mymalloc (sizeof (ADL_PTR));
-
- if (adl_init (adl) == 0)
- data.hm_amd = adl;
-
- if (data.hm_amd)
- {
- if (hm_ADL_Main_Control_Create (data.hm_amd, ADL_Main_Memory_Alloc, 0) == ADL_OK)
- {
- // total number of adapters
-
- int hm_adapters_num;
-
- if (get_adapters_num_amd (data.hm_amd, &hm_adapters_num) != 0) return (-1);
-
- // adapter info
-
- LPAdapterInfo lpAdapterInfo = hm_get_adapter_info_amd (data.hm_amd, hm_adapters_num);
-
- if (lpAdapterInfo == NULL) return (-1);
-
- // get a list (of ids of) valid/usable adapters
-
- int num_adl_adapters = 0;
-
- u32 *valid_adl_device_list = hm_get_list_valid_adl_adapters (hm_adapters_num, &num_adl_adapters, lpAdapterInfo);
-
- if (num_adl_adapters > 0)
- {
- hc_thread_mutex_lock (mux_adl);
-
- // hm_get_opencl_busid_devid (hm_adapters_amd, devices_all_cnt, devices_all);
-
- hm_get_adapter_index_amd (hm_adapters_amd, valid_adl_device_list, num_adl_adapters, lpAdapterInfo);
-
- hm_get_overdrive_version (data.hm_amd, hm_adapters_amd, valid_adl_device_list, num_adl_adapters, lpAdapterInfo);
- hm_check_fanspeed_control (data.hm_amd, hm_adapters_amd, valid_adl_device_list, num_adl_adapters, lpAdapterInfo);
-
- hc_thread_mutex_unlock (mux_adl);
- }
-
- myfree (valid_adl_device_list);
- myfree (lpAdapterInfo);
- }
- }
- #endif // HAVE_ADL
-
- if (data.hm_amd == NULL && data.hm_nv == NULL)
- {
- gpu_temp_disable = 1;
- }
- }
-
- /**
- * OpenCL devices: allocate buffer for device specific information
- */
-
- #ifdef HAVE_HWMON
- int *temp_retain_fanspeed_value = (int *) mycalloc (data.devices_cnt, sizeof (int));
-
- #ifdef HAVE_ADL
- ADLOD6MemClockState *od_clock_mem_status = (ADLOD6MemClockState *) mycalloc (data.devices_cnt, sizeof (ADLOD6MemClockState));
-
- int *od_power_control_status = (int *) mycalloc (data.devices_cnt, sizeof (int));
- #endif // ADL
- #endif
-
- /**
- * enable custom signal handler(s)
- */
-
- if (benchmark == 0)
- {
- hc_signal (sigHandler_default);
- }
- else
- {
- hc_signal (sigHandler_benchmark);
- }
-
- /**
- * User-defined GPU temp handling
- */
-
- #ifdef HAVE_HWMON
- if (gpu_temp_disable == 1)
- {
- gpu_temp_abort = 0;
- gpu_temp_retain = 0;
- }
-
- if ((gpu_temp_abort != 0) && (gpu_temp_retain != 0))
- {
- if (gpu_temp_abort < gpu_temp_retain)
- {
- log_error ("ERROR: invalid values for gpu-temp-abort. Parameter gpu-temp-abort is less than gpu-temp-retain.");
-
- return (-1);
- }
- }
-
- data.gpu_temp_disable = gpu_temp_disable;
- data.gpu_temp_abort = gpu_temp_abort;
- data.gpu_temp_retain = gpu_temp_retain;
- #endif
-
- /**
- * inform the user
- */
-
- if (data.quiet == 0)
- {
- log_info ("Hashes: %u hashes; %u unique digests, %u unique salts", hashes_cnt_orig, digests_cnt, salts_cnt);
-
- log_info ("Bitmaps: %u bits, %u entries, 0x%08x mask, %u bytes, %u/%u rotates", bitmap_bits, bitmap_nums, bitmap_mask, bitmap_size, bitmap_shift1, bitmap_shift2);
-
- if (attack_mode == ATTACK_MODE_STRAIGHT)
- {
- log_info ("Rules: %u", kernel_rules_cnt);
- }
-
- if (opti_type)
- {
- log_info ("Applicable Optimizers:");
-
- for (uint i = 0; i < 32; i++)
- {
- const uint opti_bit = 1u << i;
-
- if (opti_type & opti_bit) log_info ("* %s", stroptitype (opti_bit));
- }
- }
-
- /**
- * Watchdog and Temperature balance
- */
-
- #ifdef HAVE_HWMON
- if (gpu_temp_disable == 0 && data.hm_amd == NULL && data.hm_nv == NULL)
- {
- log_info ("Watchdog: Hardware Monitoring Interface not found on your system");
- }
-
- if (gpu_temp_abort == 0)
- {
- log_info ("Watchdog: Temperature abort trigger disabled");
- }
- else
- {
- log_info ("Watchdog: Temperature abort trigger set to %uc", gpu_temp_abort);
- }
-
- if (gpu_temp_retain == 0)
- {
- log_info ("Watchdog: Temperature retain trigger disabled");
- }
- else
- {
- log_info ("Watchdog: Temperature retain trigger set to %uc", gpu_temp_retain);
- }
- #endif
- }
-
- if (data.quiet == 0) log_info ("");
-
- /**
- * HM devices: copy
- */
-
- if (gpu_temp_disable == 0)
- {
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if ((device_param->device_type & CL_DEVICE_TYPE_GPU) == 0) continue;
-
- if (device_param->skipped) continue;
-
- const uint platform_devices_id = device_param->platform_devices_id;
-
- #if defined(HAVE_NVML) || defined(HAVE_NVAPI)
- if (device_param->vendor_id == VENDOR_ID_NV)
- {
- memcpy (&data.hm_device[device_id], &hm_adapters_nv[platform_devices_id], sizeof (hm_attrs_t));
- }
- #endif
-
- #ifdef HAVE_ADL
- if (device_param->vendor_id == VENDOR_ID_AMD)
- {
- memcpy (&data.hm_device[device_id], &hm_adapters_amd[platform_devices_id], sizeof (hm_attrs_t));
- }
- #endif
- }
- }
-
- /*
- * Temporary fix:
- * with AMD r9 295x cards it seems that we need to set the powertune value just AFTER the ocl init stuff
- * otherwise after hc_clCreateContext () etc, powertune value was set back to "normal" and cards unfortunately
- * were not working @ full speed (setting hm_ADL_Overdrive_PowerControl_Set () here seems to fix the problem)
- * Driver / ADL bug?
- */
-
- #ifdef HAVE_ADL
- if (powertune_enable == 1)
- {
- hc_thread_mutex_lock (mux_adl);
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- if (data.hm_device[device_id].od_version == 6)
- {
- // set powertune value only
-
- int powertune_supported = 0;
-
- int ADL_rc = 0;
-
- if ((ADL_rc = hm_ADL_Overdrive6_PowerControl_Caps (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &powertune_supported)) != ADL_OK)
- {
- log_error ("ERROR: Failed to get ADL PowerControl Capabilities");
-
- return (-1);
- }
-
- if (powertune_supported != 0)
- {
- // powertune set
- ADLOD6PowerControlInfo powertune = {0, 0, 0, 0, 0};
-
- if ((ADL_rc = hm_ADL_Overdrive_PowerControlInfo_Get (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &powertune)) != ADL_OK)
- {
- log_error ("ERROR: Failed to get current ADL PowerControl settings");
-
- return (-1);
- }
-
- if ((ADL_rc = hm_ADL_Overdrive_PowerControl_Set (data.hm_amd, data.hm_device[device_id].adapter_index.amd, powertune.iMaxValue)) != ADL_OK)
- {
- log_error ("ERROR: Failed to set new ADL PowerControl values");
-
- return (-1);
- }
- }
- }
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_ADK
- #endif // HAVE_HWMON
-
- #ifdef DEBUG
- if (benchmark == 1) log_info ("Hashmode: %d", data.hash_mode);
- #endif
-
- uint kernel_power_all = 0;
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- /**
- * host buffer
- */
-
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- /**
- * device properties
- */
-
- const char *device_name_chksum = device_param->device_name_chksum;
- const u32 device_processors = device_param->device_processors;
- const u32 device_processor_cores = device_param->device_processor_cores;
-
- /**
- * create context for each device
- */
-
- device_param->context = hc_clCreateContext (data.ocl, NULL, 1, &device_param->device, NULL, NULL);
-
- /**
- * create command-queue
- */
-
- // not supported with NV
- // device_param->command_queue = hc_clCreateCommandQueueWithProperties (device_param->context, device_param->device, NULL);
-
- device_param->command_queue = hc_clCreateCommandQueue (data.ocl, device_param->context, device_param->device, CL_QUEUE_PROFILING_ENABLE);
-
- /**
- * kernel threads: some algorithms need a fixed kernel-threads count
- * because of shared memory usage or bitslice
- * there needs to be some upper limit, otherwise there's too much overhead
- */
-
- uint kernel_threads = MIN (KERNEL_THREADS_MAX, device_param->device_maxworkgroup_size);
-
- if (device_param->device_type & CL_DEVICE_TYPE_CPU)
- {
- kernel_threads = KERNEL_THREADS_MAX_CPU;
- }
-
- if (hash_mode == 1500) kernel_threads = 64; // DES
- if (hash_mode == 3000) kernel_threads = 64; // DES
- if (hash_mode == 3200) kernel_threads = 8; // Blowfish
- if (hash_mode == 7500) kernel_threads = 64; // RC4
- if (hash_mode == 9000) kernel_threads = 8; // Blowfish
- if (hash_mode == 9700) kernel_threads = 64; // RC4
- if (hash_mode == 9710) kernel_threads = 64; // RC4
- if (hash_mode == 9800) kernel_threads = 64; // RC4
- if (hash_mode == 9810) kernel_threads = 64; // RC4
- if (hash_mode == 10400) kernel_threads = 64; // RC4
- if (hash_mode == 10410) kernel_threads = 64; // RC4
- if (hash_mode == 10500) kernel_threads = 64; // RC4
- if (hash_mode == 13100) kernel_threads = 64; // RC4
-
- /**
- * create input buffers on device : calculate size of fixed memory buffers
- */
-
- size_t size_root_css = SP_PW_MAX * sizeof (cs_t);
- size_t size_markov_css = SP_PW_MAX * CHARSIZ * sizeof (cs_t);
-
- device_param->size_root_css = size_root_css;
- device_param->size_markov_css = size_markov_css;
-
- size_t size_results = kernel_threads * sizeof (uint);
-
- device_param->size_results = size_results;
-
- size_t size_rules = kernel_rules_cnt * sizeof (kernel_rule_t);
- size_t size_rules_c = KERNEL_RULES * sizeof (kernel_rule_t);
-
- size_t size_plains = digests_cnt * sizeof (plain_t);
- size_t size_salts = salts_cnt * sizeof (salt_t);
- size_t size_esalts = salts_cnt * esalt_size;
-
- device_param->size_plains = size_plains;
- device_param->size_digests = size_digests;
- device_param->size_shown = size_shown;
- device_param->size_salts = size_salts;
-
- size_t size_combs = KERNEL_COMBS * sizeof (comb_t);
- size_t size_bfs = KERNEL_BFS * sizeof (bf_t);
- size_t size_tm = 32 * sizeof (bs_word_t);
-
- // scryptV stuff
-
- size_t size_scryptV = 1;
-
- if ((hash_mode == 8900) || (hash_mode == 9300))
- {
- uint tmto_start = 0;
- uint tmto_stop = 10;
-
- if (scrypt_tmto)
- {
- tmto_start = scrypt_tmto;
- }
- else
- {
- // in case the user did not specify the tmto manually
- // use some values known to run best (tested on 290x for AMD and 980ti for NV)
- // but set the lower end only in case the user has a device with too less memory
-
- if (hash_mode == 8900)
- {
- if (device_param->vendor_id == VENDOR_ID_AMD)
- {
- tmto_start = 1;
- }
- else if (device_param->vendor_id == VENDOR_ID_NV)
- {
- tmto_start = 2;
- }
- }
- else if (hash_mode == 9300)
- {
- if (device_param->vendor_id == VENDOR_ID_AMD)
- {
- tmto_start = 2;
- }
- else if (device_param->vendor_id == VENDOR_ID_NV)
- {
- tmto_start = 2;
- }
- }
- }
-
- if (quiet == 0) log_info ("");
-
- for (uint tmto = tmto_start; tmto < tmto_stop; tmto++)
- {
- // TODO: in theory the following calculation needs to be done per salt, not global
- // we assume all hashes have the same scrypt settings
-
- size_scryptV = (128 * data.salts_buf[0].scrypt_r) * data.salts_buf[0].scrypt_N;
-
- size_scryptV /= 1 << tmto;
-
- size_scryptV *= device_processors * device_processor_cores;
-
- if (size_scryptV > device_param->device_maxmem_alloc)
- {
- if (quiet == 0) log_info ("WARNING: not enough device memory allocatable to use --scrypt-tmto %d, increasing...", tmto);
-
- continue;
- }
-
- for (uint salts_pos = 0; salts_pos < data.salts_cnt; salts_pos++)
- {
- data.salts_buf[salts_pos].scrypt_tmto = tmto;
- data.salts_buf[salts_pos].scrypt_phy = device_processors * device_processor_cores;
- }
-
- break;
- }
-
- if (data.salts_buf[0].scrypt_phy == 0)
- {
- log_error ("ERROR: can't allocate enough device memory");
-
- return -1;
- }
-
- if (quiet == 0) log_info ("");
- if (quiet == 0) log_info ("SCRYPT tmto optimizer value set to: %u, mem: %u\n", data.salts_buf[0].scrypt_tmto, size_scryptV);
- }
-
- /**
- * some algorithms need a fixed kernel-loops count
- */
-
- if (hash_mode == 1500)
- {
- const u32 kernel_loops_fixed = 1024;
-
- device_param->kernel_loops_min = kernel_loops_fixed;
- device_param->kernel_loops_max = kernel_loops_fixed;
- }
-
- if (hash_mode == 3000)
- {
- const u32 kernel_loops_fixed = 1024;
-
- device_param->kernel_loops_min = kernel_loops_fixed;
- device_param->kernel_loops_max = kernel_loops_fixed;
- }
-
- if (hash_mode == 8900)
- {
- const u32 kernel_loops_fixed = 1;
-
- device_param->kernel_loops_min = kernel_loops_fixed;
- device_param->kernel_loops_max = kernel_loops_fixed;
- }
-
- if (hash_mode == 9300)
- {
- const u32 kernel_loops_fixed = 1;
-
- device_param->kernel_loops_min = kernel_loops_fixed;
- device_param->kernel_loops_max = kernel_loops_fixed;
- }
-
- if (hash_mode == 12500)
- {
- const u32 kernel_loops_fixed = ROUNDS_RAR3 / 16;
-
- device_param->kernel_loops_min = kernel_loops_fixed;
- device_param->kernel_loops_max = kernel_loops_fixed;
- }
-
- /**
- * some algorithms have a maximum kernel-loops count
- */
-
- if (attack_exec == ATTACK_EXEC_OUTSIDE_KERNEL)
- {
- if (data.salts_buf[0].salt_iter < device_param->kernel_loops_max)
- {
- device_param->kernel_loops_max = data.salts_buf[0].salt_iter;
- }
- }
-
- /**
- * some algorithms need a special kernel-accel
- */
-
- if (hash_mode == 8900)
- {
- device_param->kernel_accel_min = 1;
- device_param->kernel_accel_max = 64;
- }
-
- if (hash_mode == 9300)
- {
- device_param->kernel_accel_min = 1;
- device_param->kernel_accel_max = 64;
- }
-
- u32 kernel_accel_min = device_param->kernel_accel_min;
- u32 kernel_accel_max = device_param->kernel_accel_max;
-
- // find out if we would request too much memory on memory blocks which are based on kernel_accel
-
- size_t size_pws = 4;
- size_t size_tmps = 4;
- size_t size_hooks = 4;
-
- while (kernel_accel_max >= kernel_accel_min)
- {
- const u32 kernel_power_max = device_processors * kernel_threads * kernel_accel_max;
-
- // size_pws
-
- size_pws = kernel_power_max * sizeof (pw_t);
-
- // size_tmps
-
- switch (hash_mode)
- {
- case 400: size_tmps = kernel_power_max * sizeof (phpass_tmp_t); break;
- case 500: size_tmps = kernel_power_max * sizeof (md5crypt_tmp_t); break;
- case 501: size_tmps = kernel_power_max * sizeof (md5crypt_tmp_t); break;
- case 1600: size_tmps = kernel_power_max * sizeof (md5crypt_tmp_t); break;
- case 1800: size_tmps = kernel_power_max * sizeof (sha512crypt_tmp_t); break;
- case 2100: size_tmps = kernel_power_max * sizeof (dcc2_tmp_t); break;
- case 2500: size_tmps = kernel_power_max * sizeof (wpa_tmp_t); break;
- case 3200: size_tmps = kernel_power_max * sizeof (bcrypt_tmp_t); break;
- case 5200: size_tmps = kernel_power_max * sizeof (pwsafe3_tmp_t); break;
- case 5800: size_tmps = kernel_power_max * sizeof (androidpin_tmp_t); break;
- case 6211: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6212: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6213: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6221: size_tmps = kernel_power_max * sizeof (tc64_tmp_t); break;
- case 6222: size_tmps = kernel_power_max * sizeof (tc64_tmp_t); break;
- case 6223: size_tmps = kernel_power_max * sizeof (tc64_tmp_t); break;
- case 6231: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6232: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6233: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6241: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6242: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6243: size_tmps = kernel_power_max * sizeof (tc_tmp_t); break;
- case 6300: size_tmps = kernel_power_max * sizeof (md5crypt_tmp_t); break;
- case 6400: size_tmps = kernel_power_max * sizeof (sha256aix_tmp_t); break;
- case 6500: size_tmps = kernel_power_max * sizeof (sha512aix_tmp_t); break;
- case 6600: size_tmps = kernel_power_max * sizeof (agilekey_tmp_t); break;
- case 6700: size_tmps = kernel_power_max * sizeof (sha1aix_tmp_t); break;
- case 6800: size_tmps = kernel_power_max * sizeof (lastpass_tmp_t); break;
- case 7100: size_tmps = kernel_power_max * sizeof (pbkdf2_sha512_tmp_t); break;
- case 7200: size_tmps = kernel_power_max * sizeof (pbkdf2_sha512_tmp_t); break;
- case 7400: size_tmps = kernel_power_max * sizeof (sha256crypt_tmp_t); break;
- case 7900: size_tmps = kernel_power_max * sizeof (drupal7_tmp_t); break;
- case 8200: size_tmps = kernel_power_max * sizeof (pbkdf2_sha512_tmp_t); break;
- case 8800: size_tmps = kernel_power_max * sizeof (androidfde_tmp_t); break;
- case 8900: size_tmps = kernel_power_max * sizeof (scrypt_tmp_t); break;
- case 9000: size_tmps = kernel_power_max * sizeof (pwsafe2_tmp_t); break;
- case 9100: size_tmps = kernel_power_max * sizeof (lotus8_tmp_t); break;
- case 9200: size_tmps = kernel_power_max * sizeof (pbkdf2_sha256_tmp_t); break;
- case 9300: size_tmps = kernel_power_max * sizeof (scrypt_tmp_t); break;
- case 9400: size_tmps = kernel_power_max * sizeof (office2007_tmp_t); break;
- case 9500: size_tmps = kernel_power_max * sizeof (office2010_tmp_t); break;
- case 9600: size_tmps = kernel_power_max * sizeof (office2013_tmp_t); break;
- case 10000: size_tmps = kernel_power_max * sizeof (pbkdf2_sha256_tmp_t); break;
- case 10200: size_tmps = kernel_power_max * sizeof (cram_md5_t); break;
- case 10300: size_tmps = kernel_power_max * sizeof (saph_sha1_tmp_t); break;
- case 10500: size_tmps = kernel_power_max * sizeof (pdf14_tmp_t); break;
- case 10700: size_tmps = kernel_power_max * sizeof (pdf17l8_tmp_t); break;
- case 10900: size_tmps = kernel_power_max * sizeof (pbkdf2_sha256_tmp_t); break;
- case 11300: size_tmps = kernel_power_max * sizeof (bitcoin_wallet_tmp_t); break;
- case 11600: size_tmps = kernel_power_max * sizeof (seven_zip_tmp_t); break;
- case 11900: size_tmps = kernel_power_max * sizeof (pbkdf2_md5_tmp_t); break;
- case 12000: size_tmps = kernel_power_max * sizeof (pbkdf2_sha1_tmp_t); break;
- case 12100: size_tmps = kernel_power_max * sizeof (pbkdf2_sha512_tmp_t); break;
- case 12200: size_tmps = kernel_power_max * sizeof (ecryptfs_tmp_t); break;
- case 12300: size_tmps = kernel_power_max * sizeof (oraclet_tmp_t); break;
- case 12400: size_tmps = kernel_power_max * sizeof (bsdicrypt_tmp_t); break;
- case 12500: size_tmps = kernel_power_max * sizeof (rar3_tmp_t); break;
- case 12700: size_tmps = kernel_power_max * sizeof (mywallet_tmp_t); break;
- case 12800: size_tmps = kernel_power_max * sizeof (pbkdf2_sha256_tmp_t); break;
- case 12900: size_tmps = kernel_power_max * sizeof (pbkdf2_sha256_tmp_t); break;
- case 13000: size_tmps = kernel_power_max * sizeof (pbkdf2_sha256_tmp_t); break;
- case 13200: size_tmps = kernel_power_max * sizeof (axcrypt_tmp_t); break;
- case 13400: size_tmps = kernel_power_max * sizeof (keepass_tmp_t); break;
- };
-
- // size_hooks
-
- if ((opts_type & OPTS_TYPE_HOOK12) || (opts_type & OPTS_TYPE_HOOK23))
- {
- // none yet
- }
-
- // now check if all device-memory sizes which depend on the kernel_accel_max amplifier are within its boundaries
- // if not, decrease amplifier and try again
-
- int skip = 0;
-
- if (size_pws > device_param->device_maxmem_alloc) skip = 1;
- if (size_tmps > device_param->device_maxmem_alloc) skip = 1;
- if (size_hooks > device_param->device_maxmem_alloc) skip = 1;
-
- if (( bitmap_size
- + bitmap_size
- + bitmap_size
- + bitmap_size
- + bitmap_size
- + bitmap_size
- + bitmap_size
- + bitmap_size
- + size_bfs
- + size_combs
- + size_digests
- + size_esalts
- + size_hooks
- + size_markov_css
- + size_plains
- + size_pws
- + size_pws // not a bug
- + size_results
- + size_root_css
- + size_rules
- + size_rules_c
- + size_salts
- + size_scryptV
- + size_shown
- + size_tm
- + size_tmps) > device_param->device_global_mem) skip = 1;
-
- if (skip == 1)
- {
- kernel_accel_max--;
-
- continue;
- }
-
- break;
- }
-
- /*
- if (kernel_accel_max == 0)
- {
- log_error ("Device #%u: Device does not provide enough allocatable device-memory to handle hash-type %u", device_id + 1, data.hash_mode);
-
- return -1;
- }
- */
-
- device_param->kernel_accel_min = kernel_accel_min;
- device_param->kernel_accel_max = kernel_accel_max;
-
- /*
- if (kernel_accel_max < kernel_accel)
- {
- if (quiet == 0) log_info ("Device #%u: Reduced maximum kernel-accel to %u", device_id + 1, kernel_accel_max);
-
- device_param->kernel_accel = kernel_accel_max;
- }
- */
-
- device_param->size_bfs = size_bfs;
- device_param->size_combs = size_combs;
- device_param->size_rules = size_rules;
- device_param->size_rules_c = size_rules_c;
- device_param->size_pws = size_pws;
- device_param->size_tmps = size_tmps;
- device_param->size_hooks = size_hooks;
-
- // do not confuse kernel_accel_max with kernel_accel here
-
- const u32 kernel_power = device_processors * kernel_threads * kernel_accel_max;
-
- device_param->kernel_threads = kernel_threads;
- device_param->kernel_power_user = kernel_power;
-
- kernel_power_all += kernel_power;
-
- /**
- * default building options
- */
-
- char build_opts[1024] = { 0 };
-
- // we don't have sm_* on vendors not NV but it doesn't matter
-
- snprintf (build_opts, sizeof (build_opts) - 1, "-cl-std=CL1.1 -I\"%s/\" -DVENDOR_ID=%u -DCUDA_ARCH=%d -DVECT_SIZE=%u -DDEVICE_TYPE=%u -DKERN_TYPE=%u -D_unroll", shared_dir, device_param->vendor_id, (device_param->sm_major * 100) + device_param->sm_minor, device_param->vector_width, (u32) device_param->device_type, kern_type);
-
- /**
- * main kernel
- */
-
- {
- /**
- * kernel source filename
- */
-
- char source_file[256] = { 0 };
-
- generate_source_kernel_filename (attack_exec, attack_kern, kern_type, shared_dir, source_file);
-
- struct stat sst;
-
- if (stat (source_file, &sst) == -1)
- {
- log_error ("ERROR: %s: %s", source_file, strerror (errno));
-
- return -1;
- }
-
- /**
- * kernel cached filename
- */
-
- char cached_file[256] = { 0 };
-
- generate_cached_kernel_filename (attack_exec, attack_kern, kern_type, profile_dir, device_name_chksum, cached_file);
-
- int cached = 1;
-
- struct stat cst;
-
- if ((stat (cached_file, &cst) == -1) || cst.st_size == 0)
- {
- cached = 0;
- }
-
- /**
- * kernel compile or load
- */
-
- size_t *kernel_lengths = (size_t *) mymalloc (sizeof (size_t));
-
- const u8 **kernel_sources = (const u8 **) mymalloc (sizeof (u8 *));
-
- if (force_jit_compilation == -1)
- {
- if (cached == 0)
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s not found in cache! Building may take a while...", device_id + 1, cached_file);
-
- load_kernel (source_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program = hc_clCreateProgramWithSource (data.ocl, device_param->context, 1, (const char **) kernel_sources, NULL);
-
- int rc = hc_clBuildProgram (data.ocl, device_param->program, 1, &device_param->device, build_opts, NULL, NULL, false);
-
- #ifdef DEBUG
- size_t build_log_size = 0;
-
- hc_clGetProgramBuildInfo (data.ocl, device_param->program, device_param->device, CL_PROGRAM_BUILD_LOG, 0, NULL, &build_log_size);
-
- if (build_log_size > 1)
- {
- char *build_log = (char *) malloc (build_log_size + 1);
-
- memset (build_log, 0, build_log_size + 1);
-
- hc_clGetProgramBuildInfo (data.ocl, device_param->program, device_param->device, CL_PROGRAM_BUILD_LOG, build_log_size, build_log, NULL);
-
- puts (build_log);
-
- free (build_log);
- }
- #endif
-
- if (rc != 0)
- {
- device_param->skipped = true;
- log_info ("Device #%u: Kernel %s build failure. Proceed without this device.", device_id + 1, source_file);
- continue;
- }
-
- size_t binary_size;
-
- hc_clGetProgramInfo (data.ocl, device_param->program, CL_PROGRAM_BINARY_SIZES, sizeof (size_t), &binary_size, NULL);
-
- u8 *binary = (u8 *) mymalloc (binary_size);
-
- hc_clGetProgramInfo (data.ocl, device_param->program, CL_PROGRAM_BINARIES, sizeof (binary), &binary, NULL);
-
- writeProgramBin (cached_file, binary, binary_size);
-
- local_free (binary);
- }
- else
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s (%ld bytes)", device_id + 1, cached_file, cst.st_size);
-
- load_kernel (cached_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program = hc_clCreateProgramWithBinary (data.ocl, device_param->context, 1, &device_param->device, kernel_lengths, (const u8 **) kernel_sources, NULL);
-
- hc_clBuildProgram (data.ocl, device_param->program, 1, &device_param->device, build_opts, NULL, NULL, true);
- }
- }
- else
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s (%ld bytes)", device_id + 1, source_file, sst.st_size);
-
- load_kernel (source_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program = hc_clCreateProgramWithSource (data.ocl, device_param->context, 1, (const char **) kernel_sources, NULL);
-
- char build_opts_update[1024] = { 0 };
-
- if (force_jit_compilation == 1500)
- {
- snprintf (build_opts_update, sizeof (build_opts_update) - 1, "%s -DDESCRYPT_SALT=%d", build_opts, data.salts_buf[0].salt_buf[0]);
- }
- else if (force_jit_compilation == 8900)
- {
- snprintf (build_opts_update, sizeof (build_opts_update) - 1, "%s -DSCRYPT_N=%d -DSCRYPT_R=%d -DSCRYPT_P=%d -DSCRYPT_TMTO=%d", build_opts, data.salts_buf[0].scrypt_N, data.salts_buf[0].scrypt_r, data.salts_buf[0].scrypt_p, 1 << data.salts_buf[0].scrypt_tmto);
- }
- else
- {
- snprintf (build_opts_update, sizeof (build_opts_update) - 1, "%s", build_opts);
- }
-
- int rc = hc_clBuildProgram (data.ocl, device_param->program, 1, &device_param->device, build_opts_update, NULL, NULL, false);
-
- #ifdef DEBUG
- size_t build_log_size = 0;
-
- hc_clGetProgramBuildInfo (data.ocl, device_param->program, device_param->device, CL_PROGRAM_BUILD_LOG, 0, NULL, &build_log_size);
-
- if (build_log_size > 1)
- {
- char *build_log = (char *) malloc (build_log_size + 1);
-
- memset (build_log, 0, build_log_size + 1);
-
- hc_clGetProgramBuildInfo (data.ocl, device_param->program, device_param->device, CL_PROGRAM_BUILD_LOG, build_log_size, build_log, NULL);
-
- puts (build_log);
-
- free (build_log);
- }
- #endif
-
- if (rc != 0)
- {
- device_param->skipped = true;
-
- log_info ("Device #%u: Kernel %s build failure. Proceed without this device.", device_id + 1, source_file);
- }
- }
-
- local_free (kernel_lengths);
- local_free (kernel_sources[0]);
- local_free (kernel_sources);
- }
-
- /**
- * word generator kernel
- */
-
- if (attack_mode != ATTACK_MODE_STRAIGHT)
- {
- /**
- * kernel mp source filename
- */
-
- char source_file[256] = { 0 };
-
- generate_source_kernel_mp_filename (opti_type, opts_type, shared_dir, source_file);
-
- struct stat sst;
-
- if (stat (source_file, &sst) == -1)
- {
- log_error ("ERROR: %s: %s", source_file, strerror (errno));
-
- return -1;
- }
-
- /**
- * kernel mp cached filename
- */
-
- char cached_file[256] = { 0 };
-
- generate_cached_kernel_mp_filename (opti_type, opts_type, profile_dir, device_name_chksum, cached_file);
-
- int cached = 1;
-
- struct stat cst;
-
- if (stat (cached_file, &cst) == -1)
- {
- cached = 0;
- }
-
- /**
- * kernel compile or load
- */
-
- size_t *kernel_lengths = (size_t *) mymalloc (sizeof (size_t));
-
- const u8 **kernel_sources = (const u8 **) mymalloc (sizeof (u8 *));
-
- if (cached == 0)
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s not found in cache! Building may take a while...", device_id + 1, cached_file);
-
- load_kernel (source_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program_mp = hc_clCreateProgramWithSource (data.ocl, device_param->context, 1, (const char **) kernel_sources, NULL);
-
- int rc = hc_clBuildProgram (data.ocl, device_param->program_mp, 1, &device_param->device, build_opts, NULL, NULL, false);
-
- if (rc != 0)
- {
- device_param->skipped = true;
- log_info ("Device #%u: Kernel %s build failure. Proceed without this device.", device_id + 1, source_file);
- continue;
- }
-
- size_t binary_size;
-
- hc_clGetProgramInfo (data.ocl, device_param->program_mp, CL_PROGRAM_BINARY_SIZES, sizeof (size_t), &binary_size, NULL);
-
- u8 *binary = (u8 *) mymalloc (binary_size);
-
- hc_clGetProgramInfo (data.ocl, device_param->program_mp, CL_PROGRAM_BINARIES, sizeof (binary), &binary, NULL);
-
- writeProgramBin (cached_file, binary, binary_size);
-
- local_free (binary);
- }
- else
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s (%ld bytes)", device_id + 1, cached_file, cst.st_size);
-
- load_kernel (cached_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program_mp = hc_clCreateProgramWithBinary (data.ocl, device_param->context, 1, &device_param->device, kernel_lengths, (const u8 **) kernel_sources, NULL);
-
- hc_clBuildProgram (data.ocl, device_param->program_mp, 1, &device_param->device, build_opts, NULL, NULL, true);
- }
-
- local_free (kernel_lengths);
- local_free (kernel_sources[0]);
- local_free (kernel_sources);
- }
-
- /**
- * amplifier kernel
- */
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
-
- }
- else
- {
- /**
- * kernel amp source filename
- */
-
- char source_file[256] = { 0 };
-
- generate_source_kernel_amp_filename (attack_kern, shared_dir, source_file);
-
- struct stat sst;
-
- if (stat (source_file, &sst) == -1)
- {
- log_error ("ERROR: %s: %s", source_file, strerror (errno));
-
- return -1;
- }
-
- /**
- * kernel amp cached filename
- */
-
- char cached_file[256] = { 0 };
-
- generate_cached_kernel_amp_filename (attack_kern, profile_dir, device_name_chksum, cached_file);
-
- int cached = 1;
-
- struct stat cst;
-
- if (stat (cached_file, &cst) == -1)
- {
- cached = 0;
- }
-
- /**
- * kernel compile or load
- */
-
- size_t *kernel_lengths = (size_t *) mymalloc (sizeof (size_t));
-
- const u8 **kernel_sources = (const u8 **) mymalloc (sizeof (u8 *));
-
- if (cached == 0)
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s not found in cache! Building may take a while...", device_id + 1, cached_file);
-
- load_kernel (source_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program_amp = hc_clCreateProgramWithSource (data.ocl, device_param->context, 1, (const char **) kernel_sources, NULL);
-
- int rc = hc_clBuildProgram (data.ocl, device_param->program_amp, 1, &device_param->device, build_opts, NULL, NULL, false);
-
- if (rc != 0)
- {
- device_param->skipped = true;
- log_info ("Device #%u: Kernel %s build failure. Proceed without this device.", device_id + 1, source_file);
- continue;
- }
-
- size_t binary_size;
-
- hc_clGetProgramInfo (data.ocl, device_param->program_amp, CL_PROGRAM_BINARY_SIZES, sizeof (size_t), &binary_size, NULL);
-
- u8 *binary = (u8 *) mymalloc (binary_size);
-
- hc_clGetProgramInfo (data.ocl, device_param->program_amp, CL_PROGRAM_BINARIES, sizeof (binary), &binary, NULL);
-
- writeProgramBin (cached_file, binary, binary_size);
-
- local_free (binary);
- }
- else
- {
- if (quiet == 0) log_info ("Device #%u: Kernel %s (%ld bytes)", device_id + 1, cached_file, cst.st_size);
-
- load_kernel (cached_file, 1, kernel_lengths, kernel_sources);
-
- device_param->program_amp = hc_clCreateProgramWithBinary (data.ocl, device_param->context, 1, &device_param->device, kernel_lengths, (const u8 **) kernel_sources, NULL);
-
- hc_clBuildProgram (data.ocl, device_param->program_amp, 1, &device_param->device, build_opts, NULL, NULL, true);
- }
-
- local_free (kernel_lengths);
- local_free (kernel_sources[0]);
- local_free (kernel_sources);
- }
-
- // some algorithm collide too fast, make that impossible
-
- if (benchmark == 1)
- {
- ((uint *) digests_buf)[0] = -1;
- ((uint *) digests_buf)[1] = -1;
- ((uint *) digests_buf)[2] = -1;
- ((uint *) digests_buf)[3] = -1;
- }
-
- /**
- * global buffers
- */
-
- device_param->d_pws_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_pws, NULL);
- device_param->d_pws_amp_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_pws, NULL);
- device_param->d_tmps = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_WRITE, size_tmps, NULL);
- device_param->d_hooks = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_WRITE, size_hooks, NULL);
- device_param->d_bitmap_s1_a = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s1_b = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s1_c = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s1_d = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s2_a = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s2_b = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s2_c = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_bitmap_s2_d = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, bitmap_size, NULL);
- device_param->d_plain_bufs = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_WRITE, size_plains, NULL);
- device_param->d_digests_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_digests, NULL);
- device_param->d_digests_shown = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_WRITE, size_shown, NULL);
- device_param->d_salt_bufs = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_salts, NULL);
- device_param->d_result = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_WRITE, size_results, NULL);
- device_param->d_scryptV_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_WRITE, size_scryptV, NULL);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s1_a, CL_TRUE, 0, bitmap_size, bitmap_s1_a, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s1_b, CL_TRUE, 0, bitmap_size, bitmap_s1_b, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s1_c, CL_TRUE, 0, bitmap_size, bitmap_s1_c, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s1_d, CL_TRUE, 0, bitmap_size, bitmap_s1_d, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s2_a, CL_TRUE, 0, bitmap_size, bitmap_s2_a, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s2_b, CL_TRUE, 0, bitmap_size, bitmap_s2_b, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s2_c, CL_TRUE, 0, bitmap_size, bitmap_s2_c, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_bitmap_s2_d, CL_TRUE, 0, bitmap_size, bitmap_s2_d, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_digests_buf, CL_TRUE, 0, size_digests, data.digests_buf, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_digests_shown, CL_TRUE, 0, size_shown, data.digests_shown, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_salt_bufs, CL_TRUE, 0, size_salts, data.salts_buf, 0, NULL, NULL);
-
- run_kernel_bzero (device_param, device_param->d_pws_buf, size_pws);
- run_kernel_bzero (device_param, device_param->d_pws_amp_buf, size_pws);
- run_kernel_bzero (device_param, device_param->d_tmps, size_tmps);
- run_kernel_bzero (device_param, device_param->d_hooks, size_hooks);
- run_kernel_bzero (device_param, device_param->d_plain_bufs, size_plains);
- run_kernel_bzero (device_param, device_param->d_result, size_results);
-
- /**
- * special buffers
- */
-
- if (attack_kern == ATTACK_KERN_STRAIGHT)
- {
- device_param->d_rules = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_rules, NULL);
- device_param->d_rules_c = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_rules_c, NULL);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_rules, CL_TRUE, 0, size_rules, kernel_rules_buf, 0, NULL, NULL);
-
- run_kernel_bzero (device_param, device_param->d_rules_c, size_rules_c);
- }
- else if (attack_kern == ATTACK_KERN_COMBI)
- {
- device_param->d_combs = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_combs, NULL);
- device_param->d_combs_c = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_combs, NULL);
- device_param->d_root_css_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_root_css, NULL);
- device_param->d_markov_css_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_markov_css, NULL);
-
- run_kernel_bzero (device_param, device_param->d_combs, size_combs);
- run_kernel_bzero (device_param, device_param->d_combs_c, size_combs);
- run_kernel_bzero (device_param, device_param->d_root_css_buf, size_root_css);
- run_kernel_bzero (device_param, device_param->d_markov_css_buf, size_markov_css);
- }
- else if (attack_kern == ATTACK_KERN_BF)
- {
- device_param->d_bfs = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_bfs, NULL);
- device_param->d_bfs_c = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_bfs, NULL);
- device_param->d_tm_c = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_tm, NULL);
- device_param->d_root_css_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_root_css, NULL);
- device_param->d_markov_css_buf = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_markov_css, NULL);
-
- run_kernel_bzero (device_param, device_param->d_bfs, size_bfs);
- run_kernel_bzero (device_param, device_param->d_bfs_c, size_bfs);
- run_kernel_bzero (device_param, device_param->d_tm_c, size_tm);
- run_kernel_bzero (device_param, device_param->d_root_css_buf, size_root_css);
- run_kernel_bzero (device_param, device_param->d_markov_css_buf, size_markov_css);
- }
-
- if (size_esalts)
- {
- device_param->d_esalt_bufs = hc_clCreateBuffer (data.ocl, device_param->context, CL_MEM_READ_ONLY, size_esalts, NULL);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_esalt_bufs, CL_TRUE, 0, size_esalts, data.esalts_buf, 0, NULL, NULL);
- }
-
- /**
- * main host data
- */
-
- uint *result = (uint *) mymalloc (size_results);
-
- device_param->result = result;
-
- pw_t *pws_buf = (pw_t *) mymalloc (size_pws);
-
- device_param->pws_buf = pws_buf;
-
- comb_t *combs_buf = (comb_t *) mycalloc (KERNEL_COMBS, sizeof (comb_t));
-
- device_param->combs_buf = combs_buf;
-
- void *hooks_buf = mymalloc (size_hooks);
-
- device_param->hooks_buf = hooks_buf;
-
- /**
- * kernel args
- */
-
- device_param->kernel_params_buf32[21] = bitmap_mask;
- device_param->kernel_params_buf32[22] = bitmap_shift1;
- device_param->kernel_params_buf32[23] = bitmap_shift2;
- device_param->kernel_params_buf32[24] = 0; // salt_pos
- device_param->kernel_params_buf32[25] = 0; // loop_pos
- device_param->kernel_params_buf32[26] = 0; // loop_cnt
- device_param->kernel_params_buf32[27] = 0; // kernel_rules_cnt
- device_param->kernel_params_buf32[28] = 0; // digests_cnt
- device_param->kernel_params_buf32[29] = 0; // digests_offset
- device_param->kernel_params_buf32[30] = 0; // combs_mode
- device_param->kernel_params_buf32[31] = 0; // gid_max
-
- device_param->kernel_params[ 0] = (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- ? &device_param->d_pws_buf
- : &device_param->d_pws_amp_buf;
- device_param->kernel_params[ 1] = &device_param->d_rules_c;
- device_param->kernel_params[ 2] = &device_param->d_combs_c;
- device_param->kernel_params[ 3] = &device_param->d_bfs_c;
- device_param->kernel_params[ 4] = &device_param->d_tmps;
- device_param->kernel_params[ 5] = &device_param->d_hooks;
- device_param->kernel_params[ 6] = &device_param->d_bitmap_s1_a;
- device_param->kernel_params[ 7] = &device_param->d_bitmap_s1_b;
- device_param->kernel_params[ 8] = &device_param->d_bitmap_s1_c;
- device_param->kernel_params[ 9] = &device_param->d_bitmap_s1_d;
- device_param->kernel_params[10] = &device_param->d_bitmap_s2_a;
- device_param->kernel_params[11] = &device_param->d_bitmap_s2_b;
- device_param->kernel_params[12] = &device_param->d_bitmap_s2_c;
- device_param->kernel_params[13] = &device_param->d_bitmap_s2_d;
- device_param->kernel_params[14] = &device_param->d_plain_bufs;
- device_param->kernel_params[15] = &device_param->d_digests_buf;
- device_param->kernel_params[16] = &device_param->d_digests_shown;
- device_param->kernel_params[17] = &device_param->d_salt_bufs;
- device_param->kernel_params[18] = &device_param->d_esalt_bufs;
- device_param->kernel_params[19] = &device_param->d_result;
- device_param->kernel_params[20] = &device_param->d_scryptV_buf;
- device_param->kernel_params[21] = &device_param->kernel_params_buf32[21];
- device_param->kernel_params[22] = &device_param->kernel_params_buf32[22];
- device_param->kernel_params[23] = &device_param->kernel_params_buf32[23];
- device_param->kernel_params[24] = &device_param->kernel_params_buf32[24];
- device_param->kernel_params[25] = &device_param->kernel_params_buf32[25];
- device_param->kernel_params[26] = &device_param->kernel_params_buf32[26];
- device_param->kernel_params[27] = &device_param->kernel_params_buf32[27];
- device_param->kernel_params[28] = &device_param->kernel_params_buf32[28];
- device_param->kernel_params[29] = &device_param->kernel_params_buf32[29];
- device_param->kernel_params[30] = &device_param->kernel_params_buf32[30];
- device_param->kernel_params[31] = &device_param->kernel_params_buf32[31];
-
- device_param->kernel_params_mp_buf64[3] = 0;
- device_param->kernel_params_mp_buf32[4] = 0;
- device_param->kernel_params_mp_buf32[5] = 0;
- device_param->kernel_params_mp_buf32[6] = 0;
- device_param->kernel_params_mp_buf32[7] = 0;
- device_param->kernel_params_mp_buf32[8] = 0;
-
- device_param->kernel_params_mp[0] = NULL;
- device_param->kernel_params_mp[1] = NULL;
- device_param->kernel_params_mp[2] = NULL;
- device_param->kernel_params_mp[3] = &device_param->kernel_params_mp_buf64[3];
- device_param->kernel_params_mp[4] = &device_param->kernel_params_mp_buf32[4];
- device_param->kernel_params_mp[5] = &device_param->kernel_params_mp_buf32[5];
- device_param->kernel_params_mp[6] = &device_param->kernel_params_mp_buf32[6];
- device_param->kernel_params_mp[7] = &device_param->kernel_params_mp_buf32[7];
- device_param->kernel_params_mp[8] = &device_param->kernel_params_mp_buf32[8];
-
- device_param->kernel_params_mp_l_buf64[3] = 0;
- device_param->kernel_params_mp_l_buf32[4] = 0;
- device_param->kernel_params_mp_l_buf32[5] = 0;
- device_param->kernel_params_mp_l_buf32[6] = 0;
- device_param->kernel_params_mp_l_buf32[7] = 0;
- device_param->kernel_params_mp_l_buf32[8] = 0;
- device_param->kernel_params_mp_l_buf32[9] = 0;
-
- device_param->kernel_params_mp_l[0] = NULL;
- device_param->kernel_params_mp_l[1] = NULL;
- device_param->kernel_params_mp_l[2] = NULL;
- device_param->kernel_params_mp_l[3] = &device_param->kernel_params_mp_l_buf64[3];
- device_param->kernel_params_mp_l[4] = &device_param->kernel_params_mp_l_buf32[4];
- device_param->kernel_params_mp_l[5] = &device_param->kernel_params_mp_l_buf32[5];
- device_param->kernel_params_mp_l[6] = &device_param->kernel_params_mp_l_buf32[6];
- device_param->kernel_params_mp_l[7] = &device_param->kernel_params_mp_l_buf32[7];
- device_param->kernel_params_mp_l[8] = &device_param->kernel_params_mp_l_buf32[8];
- device_param->kernel_params_mp_l[9] = &device_param->kernel_params_mp_l_buf32[9];
-
- device_param->kernel_params_mp_r_buf64[3] = 0;
- device_param->kernel_params_mp_r_buf32[4] = 0;
- device_param->kernel_params_mp_r_buf32[5] = 0;
- device_param->kernel_params_mp_r_buf32[6] = 0;
- device_param->kernel_params_mp_r_buf32[7] = 0;
- device_param->kernel_params_mp_r_buf32[8] = 0;
-
- device_param->kernel_params_mp_r[0] = NULL;
- device_param->kernel_params_mp_r[1] = NULL;
- device_param->kernel_params_mp_r[2] = NULL;
- device_param->kernel_params_mp_r[3] = &device_param->kernel_params_mp_r_buf64[3];
- device_param->kernel_params_mp_r[4] = &device_param->kernel_params_mp_r_buf32[4];
- device_param->kernel_params_mp_r[5] = &device_param->kernel_params_mp_r_buf32[5];
- device_param->kernel_params_mp_r[6] = &device_param->kernel_params_mp_r_buf32[6];
- device_param->kernel_params_mp_r[7] = &device_param->kernel_params_mp_r_buf32[7];
- device_param->kernel_params_mp_r[8] = &device_param->kernel_params_mp_r_buf32[8];
-
- device_param->kernel_params_amp_buf32[5] = 0; // combs_mode
- device_param->kernel_params_amp_buf32[6] = 0; // gid_max
-
- device_param->kernel_params_amp[0] = &device_param->d_pws_buf;
- device_param->kernel_params_amp[1] = &device_param->d_pws_amp_buf;
- device_param->kernel_params_amp[2] = &device_param->d_rules_c;
- device_param->kernel_params_amp[3] = &device_param->d_combs_c;
- device_param->kernel_params_amp[4] = &device_param->d_bfs_c;
- device_param->kernel_params_amp[5] = &device_param->kernel_params_amp_buf32[5];
- device_param->kernel_params_amp[6] = &device_param->kernel_params_amp_buf32[6];
-
- device_param->kernel_params_tm[0] = &device_param->d_bfs_c;
- device_param->kernel_params_tm[1] = &device_param->d_tm_c;
-
- /**
- * kernel name
- */
-
- char kernel_name[64] = { 0 };
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- if (opti_type & OPTI_TYPE_SINGLE_HASH)
- {
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_s%02d", kern_type, 4);
-
- device_param->kernel1 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_s%02d", kern_type, 8);
-
- device_param->kernel2 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_s%02d", kern_type, 16);
-
- device_param->kernel3 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
- }
- else
- {
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_m%02d", kern_type, 4);
-
- device_param->kernel1 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_m%02d", kern_type, 8);
-
- device_param->kernel2 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_m%02d", kern_type, 16);
-
- device_param->kernel3 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
- }
-
- if (data.attack_mode == ATTACK_MODE_BF)
- {
- if (opts_type & OPTS_TYPE_PT_BITSLICE)
- {
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_tm", kern_type);
-
- device_param->kernel_tm = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
- }
- }
- }
- else
- {
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_init", kern_type);
-
- device_param->kernel1 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_loop", kern_type);
-
- device_param->kernel2 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_comp", kern_type);
-
- device_param->kernel3 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
-
- if (opts_type & OPTS_TYPE_HOOK12)
- {
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_hook12", kern_type);
-
- device_param->kernel12 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
- }
-
- if (opts_type & OPTS_TYPE_HOOK23)
- {
- snprintf (kernel_name, sizeof (kernel_name) - 1, "m%05d_hook23", kern_type);
-
- device_param->kernel23 = hc_clCreateKernel (data.ocl, device_param->program, kernel_name);
- }
- }
-
- for (uint i = 0; i <= 20; i++)
- {
- hc_clSetKernelArg (data.ocl, device_param->kernel1, i, sizeof (cl_mem), device_param->kernel_params[i]);
- hc_clSetKernelArg (data.ocl, device_param->kernel2, i, sizeof (cl_mem), device_param->kernel_params[i]);
- hc_clSetKernelArg (data.ocl, device_param->kernel3, i, sizeof (cl_mem), device_param->kernel_params[i]);
-
- if (opts_type & OPTS_TYPE_HOOK12) hc_clSetKernelArg (data.ocl, device_param->kernel12, i, sizeof (cl_mem), device_param->kernel_params[i]);
- if (opts_type & OPTS_TYPE_HOOK23) hc_clSetKernelArg (data.ocl, device_param->kernel23, i, sizeof (cl_mem), device_param->kernel_params[i]);
- }
-
- for (uint i = 21; i <= 31; i++)
- {
- hc_clSetKernelArg (data.ocl, device_param->kernel1, i, sizeof (cl_uint), device_param->kernel_params[i]);
- hc_clSetKernelArg (data.ocl, device_param->kernel2, i, sizeof (cl_uint), device_param->kernel_params[i]);
- hc_clSetKernelArg (data.ocl, device_param->kernel3, i, sizeof (cl_uint), device_param->kernel_params[i]);
-
- if (opts_type & OPTS_TYPE_HOOK12) hc_clSetKernelArg (data.ocl, device_param->kernel12, i, sizeof (cl_uint), device_param->kernel_params[i]);
- if (opts_type & OPTS_TYPE_HOOK23) hc_clSetKernelArg (data.ocl, device_param->kernel23, i, sizeof (cl_uint), device_param->kernel_params[i]);
- }
-
- if (attack_mode == ATTACK_MODE_BF)
- {
- device_param->kernel_mp_l = hc_clCreateKernel (data.ocl, device_param->program_mp, "l_markov");
- device_param->kernel_mp_r = hc_clCreateKernel (data.ocl, device_param->program_mp, "r_markov");
-
- if (opts_type & OPTS_TYPE_PT_BITSLICE)
- {
- hc_clSetKernelArg (data.ocl, device_param->kernel_tm, 0, sizeof (cl_mem), device_param->kernel_params_tm[0]);
- hc_clSetKernelArg (data.ocl, device_param->kernel_tm, 1, sizeof (cl_mem), device_param->kernel_params_tm[1]);
- }
- }
- else if (attack_mode == ATTACK_MODE_HYBRID1)
- {
- device_param->kernel_mp = hc_clCreateKernel (data.ocl, device_param->program_mp, "C_markov");
- }
- else if (attack_mode == ATTACK_MODE_HYBRID2)
- {
- device_param->kernel_mp = hc_clCreateKernel (data.ocl, device_param->program_mp, "C_markov");
- }
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- // nothing to do
- }
- else
- {
- device_param->kernel_amp = hc_clCreateKernel (data.ocl, device_param->program_amp, "amp");
- }
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- // nothing to do
- }
- else
- {
- for (uint i = 0; i < 5; i++)
- {
- hc_clSetKernelArg (data.ocl, device_param->kernel_amp, i, sizeof (cl_mem), device_param->kernel_params_amp[i]);
- }
-
- for (uint i = 5; i < 7; i++)
- {
- hc_clSetKernelArg (data.ocl, device_param->kernel_amp, i, sizeof (cl_uint), device_param->kernel_params_amp[i]);
- }
- }
-
- /**
- * Store initial fanspeed if gpu_temp_retain is enabled
- */
-
- #if defined(HAVE_HWMON) && defined(HAVE_ADL)
- int gpu_temp_retain_set = 0;
-
- if (gpu_temp_disable == 0)
- {
- if (gpu_temp_retain != 0) // VENDOR_ID_AMD implied
- {
- hc_thread_mutex_lock (mux_adl);
-
- if (data.hm_device[device_id].fan_supported == 1)
- {
- if (gpu_temp_retain_chgd == 0)
- {
- uint cur_temp = 0;
- uint default_temp = 0;
-
- int ADL_rc = hm_ADL_Overdrive6_TargetTemperatureData_Get (data.hm_amd, data.hm_device[device_id].adapter_index.amd, (int *) &cur_temp, (int *) &default_temp);
-
- if (ADL_rc == ADL_OK)
- {
- #define GPU_TEMP_RETAIN_ABORT_DIFF 15
-
- const uint gpu_temp_retain_target = default_temp - GPU_TEMP_RETAIN_ABORT_DIFF;
-
- // special case with multi gpu setups: always use minimum retain
-
- if (gpu_temp_retain_set == 0)
- {
- gpu_temp_retain = gpu_temp_retain_target;
- gpu_temp_retain_set = 1;
- }
- else
- {
- gpu_temp_retain = MIN (gpu_temp_retain, gpu_temp_retain_target);
- }
-
- if (gpu_temp_abort_chgd == 0) gpu_temp_abort = gpu_temp_retain + GPU_TEMP_RETAIN_ABORT_DIFF;
- }
- }
-
- const int fan_speed = hm_get_fanspeed_with_device_id (device_id);
-
- temp_retain_fanspeed_value[device_id] = fan_speed;
-
- if (fan_speed == -1)
- {
- log_info ("WARNING: Failed to get current fan speed settings for gpu number: %i:", device_id + 1);
-
- temp_retain_fanspeed_value[device_id] = 0;
- }
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- }
-
- /**
- * Store original powercontrol/clocks settings, set overdrive 6 performance tuning settings
- */
-
- if (powertune_enable == 1) // VENDOR_ID_AMD implied
- {
- hc_thread_mutex_lock (mux_adl);
-
- if (data.hm_device[device_id].od_version == 6)
- {
- int ADL_rc;
-
- // check powertune capabilities first, if not available then skip device
-
- int powertune_supported = 0;
-
- if ((ADL_rc = hm_ADL_Overdrive6_PowerControl_Caps (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &powertune_supported)) != ADL_OK)
- {
- log_error ("ERROR: Failed to get ADL PowerControl Capabilities");
-
- return (-1);
- }
-
- if (powertune_supported != 0)
- {
- // powercontrol settings
-
- ADLOD6PowerControlInfo powertune = {0, 0, 0, 0, 0};
-
- if ((ADL_rc = hm_ADL_Overdrive_PowerControlInfo_Get (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &powertune)) == ADL_OK)
- {
- ADL_rc = hm_ADL_Overdrive_PowerControl_Get (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &od_power_control_status[device_id]);
- }
-
- if (ADL_rc != ADL_OK)
- {
- log_error ("ERROR: Failed to get current ADL PowerControl settings");
-
- return (-1);
- }
-
- if ((ADL_rc = hm_ADL_Overdrive_PowerControl_Set (data.hm_amd, data.hm_device[device_id].adapter_index.amd, powertune.iMaxValue)) != ADL_OK)
- {
- log_error ("ERROR: Failed to set new ADL PowerControl values");
-
- return (-1);
- }
-
- // clocks
-
- memset (&od_clock_mem_status[device_id], 0, sizeof (ADLOD6MemClockState));
-
- od_clock_mem_status[device_id].state.iNumberOfPerformanceLevels = 2;
-
- if ((ADL_rc = hm_ADL_Overdrive_StateInfo_Get (data.hm_amd, data.hm_device[device_id].adapter_index.amd, ADL_OD6_GETSTATEINFO_CUSTOM_PERFORMANCE, &od_clock_mem_status[device_id])) != ADL_OK)
- {
- log_error ("ERROR: Failed to get ADL memory and engine clock frequency");
-
- return (-1);
- }
-
- // Query capabilities only to see if profiles were not "damaged", if so output a warning but do accept the users profile settings
-
- ADLOD6Capabilities caps = {0, 0, 0, {0, 0, 0}, {0, 0, 0}, 0, 0};
-
- if ((ADL_rc = hm_ADL_Overdrive_Capabilities_Get (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &caps)) != ADL_OK)
- {
- log_error ("ERROR: Failed to get ADL device capabilities");
-
- return (-1);
- }
-
- int engine_clock_max = caps.sEngineClockRange.iMax * 0.6666;
- int memory_clock_max = caps.sMemoryClockRange.iMax * 0.6250;
-
- int warning_trigger_engine = (int) (0.25 * (float) engine_clock_max);
- int warning_trigger_memory = (int) (0.25 * (float) memory_clock_max);
-
- int engine_clock_profile_max = od_clock_mem_status[device_id].state.aLevels[1].iEngineClock;
- int memory_clock_profile_max = od_clock_mem_status[device_id].state.aLevels[1].iMemoryClock;
-
- // warning if profile has too low max values
-
- if ((engine_clock_max - engine_clock_profile_max) > warning_trigger_engine)
- {
- log_info ("WARN: the custom profile seems to have too low maximum engine clock values. You therefore may not reach full performance");
- }
-
- if ((memory_clock_max - memory_clock_profile_max) > warning_trigger_memory)
- {
- log_info ("WARN: the custom profile seems to have too low maximum memory clock values. You therefore may not reach full performance");
- }
-
- ADLOD6StateInfo *performance_state = (ADLOD6StateInfo*) mycalloc (1, sizeof (ADLOD6StateInfo) + sizeof (ADLOD6PerformanceLevel));
-
- performance_state->iNumberOfPerformanceLevels = 2;
-
- performance_state->aLevels[0].iEngineClock = engine_clock_profile_max;
- performance_state->aLevels[1].iEngineClock = engine_clock_profile_max;
- performance_state->aLevels[0].iMemoryClock = memory_clock_profile_max;
- performance_state->aLevels[1].iMemoryClock = memory_clock_profile_max;
-
- if ((ADL_rc = hm_ADL_Overdrive_State_Set (data.hm_amd, data.hm_device[device_id].adapter_index.amd, ADL_OD6_SETSTATE_PERFORMANCE, performance_state)) != ADL_OK)
- {
- log_info ("ERROR: Failed to set ADL performance state");
-
- return (-1);
- }
-
- local_free (performance_state);
- }
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_HWMON && HAVE_ADL
- }
-
- data.kernel_power_all = kernel_power_all;
-
- if (data.quiet == 0) log_info ("");
-
- /**
- * In benchmark-mode, inform user which algorithm is checked
- */
-
- if (benchmark == 1)
- {
- quiet = 0;
-
- data.quiet = quiet;
-
- char *hash_type = strhashtype (data.hash_mode); // not a bug
-
- log_info ("Hashtype: %s", hash_type);
- log_info ("");
- }
-
- /**
- * keep track of the progress
- */
-
- data.words_progress_done = (u64 *) mycalloc (data.salts_cnt, sizeof (u64));
- data.words_progress_rejected = (u64 *) mycalloc (data.salts_cnt, sizeof (u64));
- data.words_progress_restored = (u64 *) mycalloc (data.salts_cnt, sizeof (u64));
-
- /**
- * open filehandles
- */
-
- #if _WIN
- if (_setmode (_fileno (stdin), _O_BINARY) == -1)
- {
- log_error ("ERROR: %s: %s", "stdin", strerror (errno));
-
- return (-1);
- }
-
- if (_setmode (_fileno (stdout), _O_BINARY) == -1)
- {
- log_error ("ERROR: %s: %s", "stdout", strerror (errno));
-
- return (-1);
- }
-
- if (_setmode (_fileno (stderr), _O_BINARY) == -1)
- {
- log_error ("ERROR: %s: %s", "stderr", strerror (errno));
-
- return (-1);
- }
- #endif
-
- /**
- * dictionary pad
- */
-
- segment_size *= (1024 * 1024);
-
- data.segment_size = segment_size;
-
- wl_data_t *wl_data = (wl_data_t *) mymalloc (sizeof (wl_data_t));
-
- wl_data->buf = (char *) mymalloc (segment_size);
- wl_data->avail = segment_size;
- wl_data->incr = segment_size;
- wl_data->cnt = 0;
- wl_data->pos = 0;
-
- uint wordlist_mode = ((optind + 1) < myargc) ? WL_MODE_FILE : WL_MODE_STDIN;
-
- data.wordlist_mode = wordlist_mode;
-
- cs_t *css_buf = NULL;
- uint css_cnt = 0;
- uint dictcnt = 0;
- uint maskcnt = 1;
- char **masks = NULL;
- char **dictfiles = NULL;
-
- uint mask_from_file = 0;
-
- if (attack_mode == ATTACK_MODE_STRAIGHT)
- {
- if (wordlist_mode == WL_MODE_FILE)
- {
- int wls_left = myargc - (optind + 1);
-
- for (int i = 0; i < wls_left; i++)
- {
- char *l0_filename = myargv[optind + 1 + i];
-
- struct stat l0_stat;
-
- if (stat (l0_filename, &l0_stat) == -1)
- {
- log_error ("ERROR: %s: %s", l0_filename, strerror (errno));
-
- return (-1);
- }
-
- uint is_dir = S_ISDIR (l0_stat.st_mode);
-
- if (is_dir == 0)
- {
- dictfiles = (char **) myrealloc (dictfiles, dictcnt * sizeof (char *), sizeof (char *));
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = l0_filename;
- }
- else
- {
- // do not allow --keyspace w/ a directory
-
- if (keyspace == 1)
- {
- log_error ("ERROR: keyspace parameter is not allowed together with a directory");
-
- return (-1);
- }
-
- char **dictionary_files = NULL;
-
- dictionary_files = scan_directory (l0_filename);
-
- if (dictionary_files != NULL)
- {
- qsort (dictionary_files, count_dictionaries (dictionary_files), sizeof (char *), sort_by_stringptr);
-
- for (int d = 0; dictionary_files[d] != NULL; d++)
- {
- char *l1_filename = dictionary_files[d];
-
- struct stat l1_stat;
-
- if (stat (l1_filename, &l1_stat) == -1)
- {
- log_error ("ERROR: %s: %s", l1_filename, strerror (errno));
-
- return (-1);
- }
-
- if (S_ISREG (l1_stat.st_mode))
- {
- dictfiles = (char **) myrealloc (dictfiles, dictcnt * sizeof (char *), sizeof (char *));
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = strdup (l1_filename);
- }
- }
- }
-
- local_free (dictionary_files);
- }
- }
-
- if (dictcnt < 1)
- {
- log_error ("ERROR: No usable dictionary file found.");
-
- return (-1);
- }
- }
- else if (wordlist_mode == WL_MODE_STDIN)
- {
- dictcnt = 1;
- }
- }
- else if (attack_mode == ATTACK_MODE_COMBI)
- {
- // display
-
- char *dictfile1 = myargv[optind + 1 + 0];
- char *dictfile2 = myargv[optind + 1 + 1];
-
- // find the bigger dictionary and use as base
-
- FILE *fp1 = NULL;
- FILE *fp2 = NULL;
-
- struct stat tmp_stat;
-
- if ((fp1 = fopen (dictfile1, "rb")) == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile1, strerror (errno));
-
- return (-1);
- }
-
- if (stat (dictfile1, &tmp_stat) == -1)
- {
- log_error ("ERROR: %s: %s", dictfile1, strerror (errno));
-
- fclose (fp1);
-
- return (-1);
- }
-
- if (S_ISDIR (tmp_stat.st_mode))
- {
- log_error ("ERROR: %s must be a regular file", dictfile1, strerror (errno));
-
- fclose (fp1);
-
- return (-1);
- }
-
- if ((fp2 = fopen (dictfile2, "rb")) == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile2, strerror (errno));
-
- fclose (fp1);
-
- return (-1);
- }
-
- if (stat (dictfile2, &tmp_stat) == -1)
- {
- log_error ("ERROR: %s: %s", dictfile2, strerror (errno));
-
- fclose (fp1);
- fclose (fp2);
-
- return (-1);
- }
-
- if (S_ISDIR (tmp_stat.st_mode))
- {
- log_error ("ERROR: %s must be a regular file", dictfile2, strerror (errno));
-
- fclose (fp1);
- fclose (fp2);
-
- return (-1);
- }
-
- data.combs_cnt = 1;
-
- data.quiet = 1;
-
- const u64 words1_cnt = count_words (wl_data, fp1, dictfile1, dictstat_base, &dictstat_nmemb);
-
- data.quiet = quiet;
-
- if (words1_cnt == 0)
- {
- log_error ("ERROR: %s: empty file", dictfile1);
-
- fclose (fp1);
- fclose (fp2);
-
- return (-1);
- }
-
- data.combs_cnt = 1;
-
- data.quiet = 1;
-
- const u64 words2_cnt = count_words (wl_data, fp2, dictfile2, dictstat_base, &dictstat_nmemb);
-
- data.quiet = quiet;
-
- if (words2_cnt == 0)
- {
- log_error ("ERROR: %s: empty file", dictfile2);
-
- fclose (fp1);
- fclose (fp2);
-
- return (-1);
- }
-
- fclose (fp1);
- fclose (fp2);
-
- data.dictfile = dictfile1;
- data.dictfile2 = dictfile2;
-
- if (words1_cnt >= words2_cnt)
- {
- data.combs_cnt = words2_cnt;
- data.combs_mode = COMBINATOR_MODE_BASE_LEFT;
-
- dictfiles = &data.dictfile;
-
- dictcnt = 1;
- }
- else
- {
- data.combs_cnt = words1_cnt;
- data.combs_mode = COMBINATOR_MODE_BASE_RIGHT;
-
- dictfiles = &data.dictfile2;
-
- dictcnt = 1;
-
- // we also have to switch wordlist related rules!
-
- char *tmpc = data.rule_buf_l;
-
- data.rule_buf_l = data.rule_buf_r;
- data.rule_buf_r = tmpc;
-
- int tmpi = data.rule_len_l;
-
- data.rule_len_l = data.rule_len_r;
- data.rule_len_r = tmpi;
- }
- }
- else if (attack_mode == ATTACK_MODE_BF)
- {
- char *mask = NULL;
-
- maskcnt = 0;
-
- if (benchmark == 0)
- {
- mask = myargv[optind + 1];
-
- masks = (char **) mymalloc (INCR_MASKS * sizeof (char *));
-
- if ((optind + 2) <= myargc)
- {
- struct stat file_stat;
-
- if (stat (mask, &file_stat) == -1)
- {
- maskcnt = 1;
-
- masks[maskcnt - 1] = mystrdup (mask);
- }
- else
- {
- int wls_left = myargc - (optind + 1);
-
- uint masks_avail = INCR_MASKS;
-
- for (int i = 0; i < wls_left; i++)
- {
- if (i != 0)
- {
- mask = myargv[optind + 1 + i];
-
- if (stat (mask, &file_stat) == -1)
- {
- log_error ("ERROR: %s: %s", mask, strerror (errno));
-
- return (-1);
- }
- }
-
- uint is_file = S_ISREG (file_stat.st_mode);
-
- if (is_file == 1)
- {
- FILE *mask_fp;
-
- if ((mask_fp = fopen (mask, "r")) == NULL)
- {
- log_error ("ERROR: %s: %s", mask, strerror (errno));
-
- return (-1);
- }
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- while (!feof (mask_fp))
- {
- memset (line_buf, 0, HCBUFSIZ);
-
- int line_len = fgetl (mask_fp, line_buf);
-
- if (line_len == 0) continue;
-
- if (line_buf[0] == '#') continue;
-
- if (masks_avail == maskcnt)
- {
- masks = (char **) myrealloc (masks, masks_avail * sizeof (char *), INCR_MASKS * sizeof (char *));
-
- masks_avail += INCR_MASKS;
- }
-
- masks[maskcnt] = mystrdup (line_buf);
-
- maskcnt++;
- }
-
- myfree (line_buf);
-
- fclose (mask_fp);
- }
- else
- {
- log_error ("ERROR: %s: unsupported file-type", mask);
-
- return (-1);
- }
- }
-
- mask_from_file = 1;
- }
- }
- else
- {
- custom_charset_1 = (char *) "?l?d?u";
- custom_charset_2 = (char *) "?l?d";
- custom_charset_3 = (char *) "?l?d*!$@_";
-
- mp_setup_usr (mp_sys, mp_usr, custom_charset_1, 0);
- mp_setup_usr (mp_sys, mp_usr, custom_charset_2, 1);
- mp_setup_usr (mp_sys, mp_usr, custom_charset_3, 2);
-
- masks[maskcnt] = mystrdup ("?1?2?2?2?2?2?2?3?3?3?3?d?d?d?d");
-
- wordlist_mode = WL_MODE_MASK;
-
- data.wordlist_mode = wordlist_mode;
-
- increment = 1;
-
- maskcnt = 1;
- }
- }
- else
- {
- /**
- * generate full masks and charsets
- */
-
- masks = (char **) mymalloc (sizeof (char *));
-
- switch (hash_mode)
- {
- case 1731: pw_min = 5;
- pw_max = 5;
- mask = mystrdup ("?b?b?b?b?b");
- break;
- case 12500: pw_min = 5;
- pw_max = 5;
- mask = mystrdup ("?b?b?b?b?b");
- break;
- default: pw_min = 7;
- pw_max = 7;
- mask = mystrdup ("?b?b?b?b?b?b?b");
- break;
- }
-
- maskcnt = 1;
-
- masks[maskcnt - 1] = mystrdup (mask);
-
- wordlist_mode = WL_MODE_MASK;
-
- data.wordlist_mode = wordlist_mode;
-
- increment = 1;
- }
-
- dictfiles = (char **) mycalloc (pw_max, sizeof (char *));
-
- if (increment)
- {
- if (increment_min > pw_min) pw_min = increment_min;
-
- if (increment_max < pw_max) pw_max = increment_max;
- }
- }
- else if (attack_mode == ATTACK_MODE_HYBRID1)
- {
- data.combs_mode = COMBINATOR_MODE_BASE_LEFT;
-
- // display
-
- char *mask = myargv[myargc - 1];
-
- maskcnt = 0;
-
- masks = (char **) mymalloc (1 * sizeof (char *));
-
- // mod
-
- struct stat file_stat;
-
- if (stat (mask, &file_stat) == -1)
- {
- maskcnt = 1;
-
- masks[maskcnt - 1] = mystrdup (mask);
- }
- else
- {
- uint is_file = S_ISREG (file_stat.st_mode);
-
- if (is_file == 1)
- {
- FILE *mask_fp;
-
- if ((mask_fp = fopen (mask, "r")) == NULL)
- {
- log_error ("ERROR: %s: %s", mask, strerror (errno));
-
- return (-1);
- }
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- uint masks_avail = 1;
-
- while (!feof (mask_fp))
- {
- memset (line_buf, 0, HCBUFSIZ);
-
- int line_len = fgetl (mask_fp, line_buf);
-
- if (line_len == 0) continue;
-
- if (line_buf[0] == '#') continue;
-
- if (masks_avail == maskcnt)
- {
- masks = (char **) myrealloc (masks, masks_avail * sizeof (char *), INCR_MASKS * sizeof (char *));
-
- masks_avail += INCR_MASKS;
- }
-
- masks[maskcnt] = mystrdup (line_buf);
-
- maskcnt++;
- }
-
- myfree (line_buf);
-
- fclose (mask_fp);
-
- mask_from_file = 1;
- }
- else
- {
- maskcnt = 1;
-
- masks[maskcnt - 1] = mystrdup (mask);
- }
- }
-
- // base
-
- int wls_left = myargc - (optind + 2);
-
- for (int i = 0; i < wls_left; i++)
- {
- char *filename = myargv[optind + 1 + i];
-
- struct stat file_stat;
-
- if (stat (filename, &file_stat) == -1)
- {
- log_error ("ERROR: %s: %s", filename, strerror (errno));
-
- return (-1);
- }
-
- uint is_dir = S_ISDIR (file_stat.st_mode);
-
- if (is_dir == 0)
- {
- dictfiles = (char **) myrealloc (dictfiles, dictcnt * sizeof (char *), sizeof (char *));
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = filename;
- }
- else
- {
- // do not allow --keyspace w/ a directory
-
- if (keyspace == 1)
- {
- log_error ("ERROR: keyspace parameter is not allowed together with a directory");
-
- return (-1);
- }
-
- char **dictionary_files = NULL;
-
- dictionary_files = scan_directory (filename);
-
- if (dictionary_files != NULL)
- {
- qsort (dictionary_files, count_dictionaries (dictionary_files), sizeof (char *), sort_by_stringptr);
-
- for (int d = 0; dictionary_files[d] != NULL; d++)
- {
- char *l1_filename = dictionary_files[d];
-
- struct stat l1_stat;
-
- if (stat (l1_filename, &l1_stat) == -1)
- {
- log_error ("ERROR: %s: %s", l1_filename, strerror (errno));
-
- return (-1);
- }
-
- if (S_ISREG (l1_stat.st_mode))
- {
- dictfiles = (char **) myrealloc (dictfiles, dictcnt * sizeof (char *), sizeof (char *));
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = strdup (l1_filename);
- }
- }
- }
-
- local_free (dictionary_files);
- }
- }
-
- if (dictcnt < 1)
- {
- log_error ("ERROR: No usable dictionary file found.");
-
- return (-1);
- }
-
- if (increment)
- {
- maskcnt = 0;
-
- uint mask_min = increment_min; // we can't reject smaller masks here
- uint mask_max = (increment_max < pw_max) ? increment_max : pw_max;
-
- for (uint mask_cur = mask_min; mask_cur <= mask_max; mask_cur++)
- {
- char *cur_mask = mp_get_truncated_mask (mask, strlen (mask), mask_cur);
-
- if (cur_mask == NULL) break;
-
- masks[maskcnt] = cur_mask;
-
- maskcnt++;
-
- masks = (char **) myrealloc (masks, maskcnt * sizeof (char *), sizeof (char *));
- }
- }
- }
- else if (attack_mode == ATTACK_MODE_HYBRID2)
- {
- data.combs_mode = COMBINATOR_MODE_BASE_RIGHT;
-
- // display
-
- char *mask = myargv[optind + 1 + 0];
-
- maskcnt = 0;
-
- masks = (char **) mymalloc (1 * sizeof (char *));
-
- // mod
-
- struct stat file_stat;
-
- if (stat (mask, &file_stat) == -1)
- {
- maskcnt = 1;
-
- masks[maskcnt - 1] = mystrdup (mask);
- }
- else
- {
- uint is_file = S_ISREG (file_stat.st_mode);
-
- if (is_file == 1)
- {
- FILE *mask_fp;
-
- if ((mask_fp = fopen (mask, "r")) == NULL)
- {
- log_error ("ERROR: %s: %s", mask, strerror (errno));
-
- return (-1);
- }
-
- char *line_buf = (char *) mymalloc (HCBUFSIZ);
-
- uint masks_avail = 1;
-
- while (!feof (mask_fp))
- {
- memset (line_buf, 0, HCBUFSIZ);
-
- int line_len = fgetl (mask_fp, line_buf);
-
- if (line_len == 0) continue;
-
- if (line_buf[0] == '#') continue;
-
- if (masks_avail == maskcnt)
- {
- masks = (char **) myrealloc (masks, masks_avail * sizeof (char *), INCR_MASKS * sizeof (char *));
-
- masks_avail += INCR_MASKS;
- }
-
- masks[maskcnt] = mystrdup (line_buf);
-
- maskcnt++;
- }
-
- myfree (line_buf);
-
- fclose (mask_fp);
-
- mask_from_file = 1;
- }
- else
- {
- maskcnt = 1;
-
- masks[maskcnt - 1] = mystrdup (mask);
- }
- }
-
- // base
-
- int wls_left = myargc - (optind + 2);
-
- for (int i = 0; i < wls_left; i++)
- {
- char *filename = myargv[optind + 2 + i];
-
- struct stat file_stat;
-
- if (stat (filename, &file_stat) == -1)
- {
- log_error ("ERROR: %s: %s", filename, strerror (errno));
-
- return (-1);
- }
-
- uint is_dir = S_ISDIR (file_stat.st_mode);
-
- if (is_dir == 0)
- {
- dictfiles = (char **) myrealloc (dictfiles, dictcnt * sizeof (char *), sizeof (char *));
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = filename;
- }
- else
- {
- // do not allow --keyspace w/ a directory
-
- if (keyspace == 1)
- {
- log_error ("ERROR: keyspace parameter is not allowed together with a directory");
-
- return (-1);
- }
-
- char **dictionary_files = NULL;
-
- dictionary_files = scan_directory (filename);
-
- if (dictionary_files != NULL)
- {
- qsort (dictionary_files, count_dictionaries (dictionary_files), sizeof (char *), sort_by_stringptr);
-
- for (int d = 0; dictionary_files[d] != NULL; d++)
- {
- char *l1_filename = dictionary_files[d];
-
- struct stat l1_stat;
-
- if (stat (l1_filename, &l1_stat) == -1)
- {
- log_error ("ERROR: %s: %s", l1_filename, strerror (errno));
-
- return (-1);
- }
-
- if (S_ISREG (l1_stat.st_mode))
- {
- dictfiles = (char **) myrealloc (dictfiles, dictcnt * sizeof (char *), sizeof (char *));
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = strdup (l1_filename);
- }
- }
- }
-
- local_free (dictionary_files);
- }
- }
-
- if (dictcnt < 1)
- {
- log_error ("ERROR: No usable dictionary file found.");
-
- return (-1);
- }
-
- if (increment)
- {
- maskcnt = 0;
-
- uint mask_min = increment_min; // we can't reject smaller masks here
- uint mask_max = (increment_max < pw_max) ? increment_max : pw_max;
-
- for (uint mask_cur = mask_min; mask_cur <= mask_max; mask_cur++)
- {
- char *cur_mask = mp_get_truncated_mask (mask, strlen (mask), mask_cur);
-
- if (cur_mask == NULL) break;
-
- masks[maskcnt] = cur_mask;
-
- maskcnt++;
-
- masks = (char **) myrealloc (masks, maskcnt * sizeof (char *), sizeof (char *));
- }
- }
- }
-
- data.pw_min = pw_min;
- data.pw_max = pw_max;
-
- /**
- * weak hash check
- */
-
- if (weak_hash_threshold >= salts_cnt)
- {
- hc_device_param_t *device_param = NULL;
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- break;
- }
-
- if (data.quiet == 0) log_info_nn ("Checking for weak hashes...");
-
- for (uint salt_pos = 0; salt_pos < salts_cnt; salt_pos++)
- {
- weak_hash_check (device_param, salt_pos);
- }
- }
-
- // Display hack, guarantee that there is at least one \r before real start
-
- if (data.quiet == 0) log_info_nn ("");
-
- /**
- * status and monitor threads
- */
-
- if (data.devices_status != STATUS_CRACKED) data.devices_status = STATUS_STARTING;
-
- hc_thread_t i_thread = 0;
-
- if ((data.wordlist_mode == WL_MODE_FILE) || (data.wordlist_mode == WL_MODE_MASK))
- {
- hc_thread_create (i_thread, thread_keypress, &benchmark);
- }
-
- if (wordlist_mode == WL_MODE_STDIN) data.status = 1;
-
- uint ni_threads_cnt = 0;
-
- hc_thread_t *ni_threads = (hc_thread_t *) mycalloc (10, sizeof (hc_thread_t));
-
- hc_thread_create (ni_threads[ni_threads_cnt], thread_monitor, NULL);
-
- ni_threads_cnt++;
-
- /**
- * Outfile remove
- */
-
- if (keyspace == 0)
- {
- if (outfile_check_timer != 0)
- {
- if (data.outfile_check_directory != NULL)
- {
- if ((hash_mode != 5200) &&
- !((hash_mode >= 6200) && (hash_mode <= 6299)) &&
- (hash_mode != 9000))
- {
- hc_thread_create (ni_threads[ni_threads_cnt], thread_outfile_remove, NULL);
-
- ni_threads_cnt++;
- }
- else
- {
- outfile_check_timer = 0;
- }
- }
- else
- {
- outfile_check_timer = 0;
- }
- }
- }
-
- /**
- * Inform the user if we got some hashes remove because of the pot file remove feature
- */
-
- if (data.quiet == 0)
- {
- if (potfile_remove_cracks > 0)
- {
- if (potfile_remove_cracks == 1) log_info ("INFO: removed 1 hash found in pot file\n");
- else log_info ("INFO: removed %u hashes found in pot file\n", potfile_remove_cracks);
- }
- }
-
- data.outfile_check_timer = outfile_check_timer;
-
- /**
- * main loop
- */
-
- char **induction_dictionaries = NULL;
-
- int induction_dictionaries_cnt = 0;
-
- hcstat_table_t *root_table_buf = NULL;
- hcstat_table_t *markov_table_buf = NULL;
-
- uint initial_restore_done = 0;
-
- data.maskcnt = maskcnt;
-
- for (uint maskpos = rd->maskpos; maskpos < maskcnt; maskpos++)
- {
- if (data.devices_status == STATUS_CRACKED) break;
-
- data.devices_status = STATUS_INIT;
-
- if (maskpos > rd->maskpos)
- {
- rd->dictpos = 0;
- }
-
- rd->maskpos = maskpos;
- data.maskpos = maskpos;
-
- if (attack_mode == ATTACK_MODE_HYBRID1 || attack_mode == ATTACK_MODE_HYBRID2 || attack_mode == ATTACK_MODE_BF)
- {
- char *mask = masks[maskpos];
-
- if (mask_from_file == 1)
- {
- if (mask[0] == '\\' && mask[1] == '#') mask++; // escaped comment sign (sharp) "\#"
-
- char *str_ptr;
- uint str_pos;
-
- uint mask_offset = 0;
-
- uint separator_cnt;
-
- for (separator_cnt = 0; separator_cnt < 4; separator_cnt++)
- {
- str_ptr = strstr (mask + mask_offset, ",");
-
- if (str_ptr == NULL) break;
-
- str_pos = str_ptr - mask;
-
- // escaped separator, i.e. "\,"
-
- if (str_pos > 0)
- {
- if (mask[str_pos - 1] == '\\')
- {
- separator_cnt --;
-
- mask_offset = str_pos + 1;
-
- continue;
- }
- }
-
- // reset the offset
-
- mask_offset = 0;
-
- mask[str_pos] = '\0';
-
- switch (separator_cnt)
- {
- case 0:
- mp_reset_usr (mp_usr, 0);
-
- custom_charset_1 = mask;
- mp_setup_usr (mp_sys, mp_usr, custom_charset_1, 0);
- break;
-
- case 1:
- mp_reset_usr (mp_usr, 1);
-
- custom_charset_2 = mask;
- mp_setup_usr (mp_sys, mp_usr, custom_charset_2, 1);
- break;
-
- case 2:
- mp_reset_usr (mp_usr, 2);
-
- custom_charset_3 = mask;
- mp_setup_usr (mp_sys, mp_usr, custom_charset_3, 2);
- break;
-
- case 3:
- mp_reset_usr (mp_usr, 3);
-
- custom_charset_4 = mask;
- mp_setup_usr (mp_sys, mp_usr, custom_charset_4, 3);
- break;
- }
-
- mask = mask + str_pos + 1;
- }
- }
-
- if ((attack_mode == ATTACK_MODE_HYBRID1) || (attack_mode == ATTACK_MODE_HYBRID2))
- {
- if (maskpos > 0)
- {
- local_free (css_buf);
- local_free (data.root_css_buf);
- local_free (data.markov_css_buf);
-
- local_free (masks[maskpos - 1]);
- }
-
- css_buf = mp_gen_css (mask, strlen (mask), mp_sys, mp_usr, &css_cnt);
-
- data.mask = mask;
- data.css_cnt = css_cnt;
- data.css_buf = css_buf;
-
- uint uniq_tbls[SP_PW_MAX][CHARSIZ] = { { 0 } };
-
- mp_css_to_uniq_tbl (css_cnt, css_buf, uniq_tbls);
-
- if (root_table_buf == NULL) root_table_buf = (hcstat_table_t *) mycalloc (SP_ROOT_CNT, sizeof (hcstat_table_t));
- if (markov_table_buf == NULL) markov_table_buf = (hcstat_table_t *) mycalloc (SP_MARKOV_CNT, sizeof (hcstat_table_t));
-
- sp_setup_tbl (shared_dir, markov_hcstat, markov_disable, markov_classic, root_table_buf, markov_table_buf);
-
- markov_threshold = (markov_threshold != 0) ? markov_threshold : CHARSIZ;
-
- cs_t *root_css_buf = (cs_t *) mycalloc (SP_PW_MAX, sizeof (cs_t));
- cs_t *markov_css_buf = (cs_t *) mycalloc (SP_PW_MAX * CHARSIZ, sizeof (cs_t));
-
- data.root_css_buf = root_css_buf;
- data.markov_css_buf = markov_css_buf;
-
- sp_tbl_to_css (root_table_buf, markov_table_buf, root_css_buf, markov_css_buf, markov_threshold, uniq_tbls);
-
- data.combs_cnt = sp_get_sum (0, css_cnt, root_css_buf);
-
- local_free (root_table_buf);
- local_free (markov_table_buf);
-
- // args
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- device_param->kernel_params_mp[0] = &device_param->d_combs;
- device_param->kernel_params_mp[1] = &device_param->d_root_css_buf;
- device_param->kernel_params_mp[2] = &device_param->d_markov_css_buf;
-
- device_param->kernel_params_mp_buf64[3] = 0;
- device_param->kernel_params_mp_buf32[4] = css_cnt;
- device_param->kernel_params_mp_buf32[5] = 0;
- device_param->kernel_params_mp_buf32[6] = 0;
- device_param->kernel_params_mp_buf32[7] = 0;
-
- if (attack_mode == ATTACK_MODE_HYBRID1)
- {
- if (opts_type & OPTS_TYPE_PT_ADD01) device_param->kernel_params_mp_buf32[5] = full01;
- if (opts_type & OPTS_TYPE_PT_ADD80) device_param->kernel_params_mp_buf32[5] = full80;
- if (opts_type & OPTS_TYPE_PT_ADDBITS14) device_param->kernel_params_mp_buf32[6] = 1;
- if (opts_type & OPTS_TYPE_PT_ADDBITS15) device_param->kernel_params_mp_buf32[7] = 1;
- }
- else if (attack_mode == ATTACK_MODE_HYBRID2)
- {
- device_param->kernel_params_mp_buf32[5] = 0;
- device_param->kernel_params_mp_buf32[6] = 0;
- device_param->kernel_params_mp_buf32[7] = 0;
- }
-
- for (uint i = 0; i < 3; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp, i, sizeof (cl_mem), (void *) device_param->kernel_params_mp[i]);
- for (uint i = 3; i < 4; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp, i, sizeof (cl_ulong), (void *) device_param->kernel_params_mp[i]);
- for (uint i = 4; i < 8; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp, i, sizeof (cl_uint), (void *) device_param->kernel_params_mp[i]);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_root_css_buf, CL_TRUE, 0, device_param->size_root_css, root_css_buf, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_markov_css_buf, CL_TRUE, 0, device_param->size_markov_css, markov_css_buf, 0, NULL, NULL);
- }
- }
- else if (attack_mode == ATTACK_MODE_BF)
- {
- dictcnt = 0; // number of "sub-masks", i.e. when using incremental mode
-
- if (increment)
- {
- for (uint i = 0; i < dictcnt; i++)
- {
- local_free (dictfiles[i]);
- }
-
- for (uint pw_len = MAX (1, pw_min); pw_len <= pw_max; pw_len++)
- {
- char *l1_filename = mp_get_truncated_mask (mask, strlen (mask), pw_len);
-
- if (l1_filename == NULL) break;
-
- dictcnt++;
-
- dictfiles[dictcnt - 1] = l1_filename;
- }
- }
- else
- {
- dictcnt++;
-
- dictfiles[dictcnt - 1] = mask;
- }
-
- if (dictcnt == 0)
- {
- log_error ("ERROR: Mask is too small");
-
- return (-1);
- }
- }
- }
-
- free (induction_dictionaries);
-
- // induction_dictionaries_cnt = 0; // implied
-
- if (attack_mode != ATTACK_MODE_BF)
- {
- if (keyspace == 0)
- {
- induction_dictionaries = scan_directory (induction_directory);
-
- induction_dictionaries_cnt = count_dictionaries (induction_dictionaries);
- }
- }
-
- if (induction_dictionaries_cnt)
- {
- qsort (induction_dictionaries, induction_dictionaries_cnt, sizeof (char *), sort_by_mtime);
- }
-
- /**
- * prevent the user from using --keyspace together w/ maskfile and or dictfile
- */
- if (keyspace == 1)
- {
- if ((maskcnt > 1) || (dictcnt > 1))
- {
- log_error ("ERROR: --keyspace is not supported with --increment or mask files");
-
- return (-1);
- }
- }
-
- for (uint dictpos = rd->dictpos; dictpos < dictcnt; )
- {
- char *subid = logfile_generate_subid ();
-
- data.subid = subid;
-
- logfile_sub_msg ("START");
-
- data.devices_status = STATUS_INIT;
-
- memset (data.words_progress_done, 0, data.salts_cnt * sizeof (u64));
- memset (data.words_progress_rejected, 0, data.salts_cnt * sizeof (u64));
- memset (data.words_progress_restored, 0, data.salts_cnt * sizeof (u64));
-
- memset (data.cpt_buf, 0, CPT_BUF * sizeof (cpt_t));
-
- data.cpt_pos = 0;
-
- data.cpt_start = time (NULL);
-
- data.cpt_total = 0;
-
- if (data.restore == 0)
- {
- rd->words_cur = skip;
-
- skip = 0;
-
- data.skip = 0;
- }
-
- data.ms_paused = 0;
-
- data.words_cur = rd->words_cur;
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- device_param->speed_pos = 0;
-
- memset (device_param->speed_cnt, 0, SPEED_CACHE * sizeof (u64));
- memset (device_param->speed_ms, 0, SPEED_CACHE * sizeof (double));
-
- device_param->exec_pos = 0;
-
- memset (device_param->exec_ms, 0, EXEC_CACHE * sizeof (double));
-
- device_param->kernel_power = device_param->kernel_power_user;
-
- device_param->outerloop_pos = 0;
- device_param->outerloop_left = 0;
- device_param->innerloop_pos = 0;
- device_param->innerloop_left = 0;
-
- // some more resets:
-
- if (device_param->pws_buf) memset (device_param->pws_buf, 0, device_param->size_pws);
-
- device_param->pws_cnt = 0;
-
- device_param->words_off = 0;
- device_param->words_done = 0;
- }
-
- data.kernel_power_div = 0;
-
- // figure out some workload
-
- if (attack_mode == ATTACK_MODE_STRAIGHT)
- {
- if (data.wordlist_mode == WL_MODE_FILE)
- {
- char *dictfile = NULL;
-
- if (induction_dictionaries_cnt)
- {
- dictfile = induction_dictionaries[0];
- }
- else
- {
- dictfile = dictfiles[dictpos];
- }
-
- data.dictfile = dictfile;
-
- logfile_sub_string (dictfile);
-
- for (uint i = 0; i < rp_files_cnt; i++)
- {
- logfile_sub_var_string ("rulefile", rp_files[i]);
- }
-
- FILE *fd2 = fopen (dictfile, "rb");
-
- if (fd2 == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile, strerror (errno));
-
- return (-1);
- }
-
- data.words_cnt = count_words (wl_data, fd2, dictfile, dictstat_base, &dictstat_nmemb);
-
- fclose (fd2);
-
- if (data.words_cnt == 0)
- {
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
-
- dictpos++;
-
- continue;
- }
- }
- }
- else if (attack_mode == ATTACK_MODE_COMBI)
- {
- char *dictfile = data.dictfile;
- char *dictfile2 = data.dictfile2;
-
- logfile_sub_string (dictfile);
- logfile_sub_string (dictfile2);
-
- if (data.combs_mode == COMBINATOR_MODE_BASE_LEFT)
- {
- FILE *fd2 = fopen (dictfile, "rb");
-
- if (fd2 == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile, strerror (errno));
-
- return (-1);
- }
-
- data.words_cnt = count_words (wl_data, fd2, dictfile, dictstat_base, &dictstat_nmemb);
-
- fclose (fd2);
- }
- else if (data.combs_mode == COMBINATOR_MODE_BASE_RIGHT)
- {
- FILE *fd2 = fopen (dictfile2, "rb");
-
- if (fd2 == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile2, strerror (errno));
-
- return (-1);
- }
-
- data.words_cnt = count_words (wl_data, fd2, dictfile2, dictstat_base, &dictstat_nmemb);
-
- fclose (fd2);
- }
-
- if (data.words_cnt == 0)
- {
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
-
- dictpos++;
-
- continue;
- }
- }
- else if ((attack_mode == ATTACK_MODE_HYBRID1) || (attack_mode == ATTACK_MODE_HYBRID2))
- {
- char *dictfile = NULL;
-
- if (induction_dictionaries_cnt)
- {
- dictfile = induction_dictionaries[0];
- }
- else
- {
- dictfile = dictfiles[dictpos];
- }
-
- data.dictfile = dictfile;
-
- char *mask = data.mask;
-
- logfile_sub_string (dictfile);
- logfile_sub_string (mask);
-
- FILE *fd2 = fopen (dictfile, "rb");
-
- if (fd2 == NULL)
- {
- log_error ("ERROR: %s: %s", dictfile, strerror (errno));
-
- return (-1);
- }
-
- data.words_cnt = count_words (wl_data, fd2, dictfile, dictstat_base, &dictstat_nmemb);
-
- fclose (fd2);
-
- if (data.words_cnt == 0)
- {
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
-
- dictpos++;
-
- continue;
- }
- }
- else if (attack_mode == ATTACK_MODE_BF)
- {
- local_free (css_buf);
- local_free (data.root_css_buf);
- local_free (data.markov_css_buf);
-
- char *mask = dictfiles[dictpos];
-
- logfile_sub_string (mask);
-
- // base
-
- css_buf = mp_gen_css (mask, strlen (mask), mp_sys, mp_usr, &css_cnt);
-
- if (opts_type & OPTS_TYPE_PT_UNICODE)
- {
- uint css_cnt_unicode = css_cnt * 2;
-
- cs_t *css_buf_unicode = (cs_t *) mycalloc (css_cnt_unicode, sizeof (cs_t));
-
- for (uint i = 0, j = 0; i < css_cnt; i += 1, j += 2)
- {
- memcpy (&css_buf_unicode[j + 0], &css_buf[i], sizeof (cs_t));
-
- css_buf_unicode[j + 1].cs_buf[0] = 0;
- css_buf_unicode[j + 1].cs_len = 1;
- }
-
- free (css_buf);
-
- css_buf = css_buf_unicode;
- css_cnt = css_cnt_unicode;
- }
-
- // check if mask is not too large or too small for pw_min/pw_max (*2 if unicode)
-
- uint mask_min = pw_min;
- uint mask_max = pw_max;
-
- if (opts_type & OPTS_TYPE_PT_UNICODE)
- {
- mask_min *= 2;
- mask_max *= 2;
- }
-
- if ((css_cnt < mask_min) || (css_cnt > mask_max))
- {
- if (css_cnt < mask_min)
- {
- log_info ("WARNING: skipping mask '%s' because it is smaller than the minimum password length", mask);
- }
-
- if (css_cnt > mask_max)
- {
- log_info ("WARNING: skipping mask '%s' because it is larger than the maximum password length", mask);
- }
-
- // skip to next mask
-
- dictpos++;
-
- rd->dictpos = dictpos;
-
- logfile_sub_msg ("STOP");
-
- continue;
- }
-
- uint save_css_cnt = css_cnt;
-
- if (opti_type & OPTI_TYPE_SINGLE_HASH)
- {
- if (opti_type & OPTI_TYPE_APPENDED_SALT)
- {
- uint salt_len = (uint) data.salts_buf[0].salt_len;
- char *salt_buf = (char *) data.salts_buf[0].salt_buf;
-
- uint css_cnt_salt = css_cnt + salt_len;
-
- cs_t *css_buf_salt = (cs_t *) mycalloc (css_cnt_salt, sizeof (cs_t));
-
- memcpy (css_buf_salt, css_buf, css_cnt * sizeof (cs_t));
-
- for (uint i = 0, j = css_cnt; i < salt_len; i++, j++)
- {
- css_buf_salt[j].cs_buf[0] = salt_buf[i];
- css_buf_salt[j].cs_len = 1;
- }
-
- free (css_buf);
-
- css_buf = css_buf_salt;
- css_cnt = css_cnt_salt;
- }
- }
-
- data.mask = mask;
- data.css_cnt = css_cnt;
- data.css_buf = css_buf;
-
- if (maskpos > 0 && dictpos == 0) free (masks[maskpos - 1]);
-
- uint uniq_tbls[SP_PW_MAX][CHARSIZ] = { { 0 } };
-
- mp_css_to_uniq_tbl (css_cnt, css_buf, uniq_tbls);
-
- if (root_table_buf == NULL) root_table_buf = (hcstat_table_t *) mycalloc (SP_ROOT_CNT, sizeof (hcstat_table_t));
- if (markov_table_buf == NULL) markov_table_buf = (hcstat_table_t *) mycalloc (SP_MARKOV_CNT, sizeof (hcstat_table_t));
-
- sp_setup_tbl (shared_dir, markov_hcstat, markov_disable, markov_classic, root_table_buf, markov_table_buf);
-
- markov_threshold = (markov_threshold != 0) ? markov_threshold : CHARSIZ;
-
- cs_t *root_css_buf = (cs_t *) mycalloc (SP_PW_MAX, sizeof (cs_t));
- cs_t *markov_css_buf = (cs_t *) mycalloc (SP_PW_MAX * CHARSIZ, sizeof (cs_t));
-
- data.root_css_buf = root_css_buf;
- data.markov_css_buf = markov_css_buf;
-
- sp_tbl_to_css (root_table_buf, markov_table_buf, root_css_buf, markov_css_buf, markov_threshold, uniq_tbls);
-
- data.words_cnt = sp_get_sum (0, css_cnt, root_css_buf);
-
- local_free (root_table_buf);
- local_free (markov_table_buf);
-
- // copy + args
-
- uint css_cnt_l = css_cnt;
- uint css_cnt_r;
-
- if (attack_exec == ATTACK_EXEC_INSIDE_KERNEL)
- {
- if (save_css_cnt < 6)
- {
- css_cnt_r = 1;
- }
- else if (save_css_cnt == 6)
- {
- css_cnt_r = 2;
- }
- else
- {
- if (opts_type & OPTS_TYPE_PT_UNICODE)
- {
- if (save_css_cnt == 8 || save_css_cnt == 10)
- {
- css_cnt_r = 2;
- }
- else
- {
- css_cnt_r = 4;
- }
- }
- else
- {
- if ((css_buf[0].cs_len * css_buf[1].cs_len * css_buf[2].cs_len) > 256)
- {
- css_cnt_r = 3;
- }
- else
- {
- css_cnt_r = 4;
- }
- }
- }
- }
- else
- {
- css_cnt_r = 1;
-
- /* unfinished code?
- int sum = css_buf[css_cnt_r - 1].cs_len;
-
- for (uint i = 1; i < 4 && i < css_cnt; i++)
- {
- if (sum > 1) break; // we really don't need alot of amplifier them for slow hashes
-
- css_cnt_r++;
-
- sum *= css_buf[css_cnt_r - 1].cs_len;
- }
- */
- }
-
- css_cnt_l -= css_cnt_r;
-
- data.bfs_cnt = sp_get_sum (0, css_cnt_r, root_css_buf);
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- device_param->kernel_params_mp_l[0] = &device_param->d_pws_buf;
- device_param->kernel_params_mp_l[1] = &device_param->d_root_css_buf;
- device_param->kernel_params_mp_l[2] = &device_param->d_markov_css_buf;
-
- device_param->kernel_params_mp_l_buf64[3] = 0;
- device_param->kernel_params_mp_l_buf32[4] = css_cnt_l;
- device_param->kernel_params_mp_l_buf32[5] = css_cnt_r;
- device_param->kernel_params_mp_l_buf32[6] = 0;
- device_param->kernel_params_mp_l_buf32[7] = 0;
- device_param->kernel_params_mp_l_buf32[8] = 0;
-
- if (opts_type & OPTS_TYPE_PT_ADD01) device_param->kernel_params_mp_l_buf32[6] = full01;
- if (opts_type & OPTS_TYPE_PT_ADD80) device_param->kernel_params_mp_l_buf32[6] = full80;
- if (opts_type & OPTS_TYPE_PT_ADDBITS14) device_param->kernel_params_mp_l_buf32[7] = 1;
- if (opts_type & OPTS_TYPE_PT_ADDBITS15) device_param->kernel_params_mp_l_buf32[8] = 1;
-
- device_param->kernel_params_mp_r[0] = &device_param->d_bfs;
- device_param->kernel_params_mp_r[1] = &device_param->d_root_css_buf;
- device_param->kernel_params_mp_r[2] = &device_param->d_markov_css_buf;
-
- device_param->kernel_params_mp_r_buf64[3] = 0;
- device_param->kernel_params_mp_r_buf32[4] = css_cnt_r;
- device_param->kernel_params_mp_r_buf32[5] = 0;
- device_param->kernel_params_mp_r_buf32[6] = 0;
- device_param->kernel_params_mp_r_buf32[7] = 0;
-
- for (uint i = 0; i < 3; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp_l, i, sizeof (cl_mem), (void *) device_param->kernel_params_mp_l[i]);
- for (uint i = 3; i < 4; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp_l, i, sizeof (cl_ulong), (void *) device_param->kernel_params_mp_l[i]);
- for (uint i = 4; i < 9; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp_l, i, sizeof (cl_uint), (void *) device_param->kernel_params_mp_l[i]);
-
- for (uint i = 0; i < 3; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp_r, i, sizeof (cl_mem), (void *) device_param->kernel_params_mp_r[i]);
- for (uint i = 3; i < 4; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp_r, i, sizeof (cl_ulong), (void *) device_param->kernel_params_mp_r[i]);
- for (uint i = 4; i < 8; i++) hc_clSetKernelArg (data.ocl, device_param->kernel_mp_r, i, sizeof (cl_uint), (void *) device_param->kernel_params_mp_r[i]);
-
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_root_css_buf, CL_TRUE, 0, device_param->size_root_css, root_css_buf, 0, NULL, NULL);
- hc_clEnqueueWriteBuffer (data.ocl, device_param->command_queue, device_param->d_markov_css_buf, CL_TRUE, 0, device_param->size_markov_css, markov_css_buf, 0, NULL, NULL);
- }
- }
-
- u64 words_base = data.words_cnt;
-
- if (data.attack_kern == ATTACK_KERN_STRAIGHT)
- {
- if (data.kernel_rules_cnt)
- {
- words_base /= data.kernel_rules_cnt;
- }
- }
- else if (data.attack_kern == ATTACK_KERN_COMBI)
- {
- if (data.combs_cnt)
- {
- words_base /= data.combs_cnt;
- }
- }
- else if (data.attack_kern == ATTACK_KERN_BF)
- {
- if (data.bfs_cnt)
- {
- words_base /= data.bfs_cnt;
- }
- }
-
- data.words_base = words_base;
-
- if (keyspace == 1)
- {
- log_info ("%llu", (unsigned long long int) words_base);
-
- return (0);
- }
-
- if (data.words_cur > data.words_base)
- {
- log_error ("ERROR: restore value greater keyspace");
-
- return (-1);
- }
-
- if (data.words_cur)
- {
- if (data.attack_kern == ATTACK_KERN_STRAIGHT)
- {
- for (uint i = 0; i < data.salts_cnt; i++)
- {
- data.words_progress_restored[i] = data.words_cur * data.kernel_rules_cnt;
- }
- }
- else if (data.attack_kern == ATTACK_KERN_COMBI)
- {
- for (uint i = 0; i < data.salts_cnt; i++)
- {
- data.words_progress_restored[i] = data.words_cur * data.combs_cnt;
- }
- }
- else if (data.attack_kern == ATTACK_KERN_BF)
- {
- for (uint i = 0; i < data.salts_cnt; i++)
- {
- data.words_progress_restored[i] = data.words_cur * data.bfs_cnt;
- }
- }
- }
-
- /*
- * Inform user about possible slow speeds
- */
-
- if ((wordlist_mode == WL_MODE_FILE) || (wordlist_mode == WL_MODE_MASK))
- {
- if (data.words_base < kernel_power_all)
- {
- if (quiet == 0)
- {
- log_info ("");
- log_info ("ATTENTION!");
- log_info (" The wordlist or mask you are using is too small.");
- log_info (" Therefore, oclHashcat is unable to utilize the full parallelization power of your device(s).");
- log_info (" The cracking speed will drop.");
- log_info (" Workaround: https://hashcat.net/wiki/doku.php?id=frequently_asked_questions#how_to_create_more_work_for_full_speed");
- log_info ("");
- }
- }
- }
-
- /*
- * Update loopback file
- */
-
- if (loopback == 1)
- {
- time_t now;
-
- time (&now);
-
- uint random_num = get_random_num (0, 9999);
-
- snprintf (loopback_file, loopback_size - 1, "%s/%s.%d_%i", induction_directory, LOOPBACK_FILE, (int) now, random_num);
-
- data.loopback_file = loopback_file;
- }
-
- /*
- * Update dictionary statistic
- */
-
- if (keyspace == 0)
- {
- dictstat_fp = fopen (dictstat, "wb");
-
- if (dictstat_fp)
- {
- lock_file (dictstat_fp);
-
- fwrite (dictstat_base, sizeof (dictstat_t), dictstat_nmemb, dictstat_fp);
-
- fclose (dictstat_fp);
- }
- }
-
- data.devices_status = STATUS_RUNNING;
-
- if (initial_restore_done == 0)
- {
- if (data.restore_disable == 0) cycle_restore ();
-
- initial_restore_done = 1;
- }
-
- hc_timer_set (&data.timer_running);
-
- if ((wordlist_mode == WL_MODE_FILE) || (wordlist_mode == WL_MODE_MASK))
- {
- if ((quiet == 0) && (status == 0) && (benchmark == 0))
- {
- if (quiet == 0) fprintf (stdout, "%s", PROMPT);
- if (quiet == 0) fflush (stdout);
- }
- }
- else if (wordlist_mode == WL_MODE_STDIN)
- {
- if (data.quiet == 0) log_info ("Starting attack in stdin mode...");
- if (data.quiet == 0) log_info ("");
- }
-
- time_t runtime_start;
-
- time (&runtime_start);
-
- data.runtime_start = runtime_start;
-
- /**
- * create cracker threads
- */
-
- hc_thread_t *c_threads = (hc_thread_t *) mycalloc (data.devices_cnt, sizeof (hc_thread_t));
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &devices_param[device_id];
-
- if (wordlist_mode == WL_MODE_STDIN)
- {
- hc_thread_create (c_threads[device_id], thread_calc_stdin, device_param);
- }
- else
- {
- hc_thread_create (c_threads[device_id], thread_calc, device_param);
- }
- }
-
- // wait for crack threads to exit
-
- hc_thread_wait (data.devices_cnt, c_threads);
-
- local_free (c_threads);
-
- data.restore = 0;
-
- // finalize task
-
- logfile_sub_var_uint ("status-after-work", data.devices_status);
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
-
- if (data.devices_status == STATUS_BYPASS)
- {
- data.devices_status = STATUS_RUNNING;
- }
-
- if (induction_dictionaries_cnt)
- {
- unlink (induction_dictionaries[0]);
- }
-
- free (induction_dictionaries);
-
- if (attack_mode != ATTACK_MODE_BF)
- {
- induction_dictionaries = scan_directory (induction_directory);
-
- induction_dictionaries_cnt = count_dictionaries (induction_dictionaries);
- }
-
- if (benchmark == 0)
- {
- if (((dictpos + 1) < dictcnt) || ((maskpos + 1) < maskcnt) || induction_dictionaries_cnt)
- {
- if (quiet == 0) clear_prompt ();
-
- if (quiet == 0) log_info ("");
-
- if (status == 1)
- {
- status_display ();
- }
- else
- {
- if (quiet == 0) status_display ();
- }
-
- if (quiet == 0) log_info ("");
- }
- }
-
- if (attack_mode == ATTACK_MODE_BF)
- {
- dictpos++;
-
- rd->dictpos = dictpos;
- }
- else
- {
- if (induction_dictionaries_cnt)
- {
- qsort (induction_dictionaries, induction_dictionaries_cnt, sizeof (char *), sort_by_mtime);
- }
- else
- {
- dictpos++;
-
- rd->dictpos = dictpos;
- }
- }
-
- time_t runtime_stop;
-
- time (&runtime_stop);
-
- data.runtime_stop = runtime_stop;
-
- logfile_sub_uint (runtime_start);
- logfile_sub_uint (runtime_stop);
-
- logfile_sub_msg ("STOP");
-
- global_free (subid);
- }
-
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) check_checkpoint ();
-
- if (data.devices_status == STATUS_CRACKED) break;
- if (data.devices_status == STATUS_ABORTED) break;
- if (data.devices_status == STATUS_QUIT) break;
-
- if (data.devices_status == STATUS_BYPASS)
- {
- data.devices_status = STATUS_RUNNING;
- }
- }
-
- // problems could occur if already at startup everything was cracked (because of .pot file reading etc), we must set some variables here to avoid NULL pointers
-
- if (attack_mode == ATTACK_MODE_STRAIGHT)
- {
- if (data.wordlist_mode == WL_MODE_FILE)
- {
- if (data.dictfile == NULL)
- {
- if (dictfiles != NULL)
- {
- data.dictfile = dictfiles[0];
-
- hc_timer_set (&data.timer_running);
- }
- }
- }
- }
- // NOTE: combi is okay because it is already set beforehand
- else if (attack_mode == ATTACK_MODE_HYBRID1 || attack_mode == ATTACK_MODE_HYBRID2)
- {
- if (data.dictfile == NULL)
- {
- if (dictfiles != NULL)
- {
- hc_timer_set (&data.timer_running);
-
- data.dictfile = dictfiles[0];
- }
- }
- }
- else if (attack_mode == ATTACK_MODE_BF)
- {
- if (data.mask == NULL)
- {
- hc_timer_set (&data.timer_running);
-
- data.mask = masks[0];
- }
- }
-
- if ((data.devices_status != STATUS_CRACKED) && (data.devices_status != STATUS_ABORTED) && (data.devices_status != STATUS_QUIT))
- {
- data.devices_status = STATUS_EXHAUSTED;
- }
-
- // if cracked / aborted remove last induction dictionary
-
- for (int file_pos = 0; file_pos < induction_dictionaries_cnt; file_pos++)
- {
- struct stat induct_stat;
-
- if (stat (induction_dictionaries[file_pos], &induct_stat) == 0)
- {
- unlink (induction_dictionaries[file_pos]);
- }
- }
-
- // wait for non-interactive threads
-
- for (uint thread_idx = 0; thread_idx < ni_threads_cnt; thread_idx++)
- {
- hc_thread_wait (1, &ni_threads[thread_idx]);
- }
-
- local_free (ni_threads);
-
- // wait for interactive threads
-
- if ((data.wordlist_mode == WL_MODE_FILE) || (data.wordlist_mode == WL_MODE_MASK))
- {
- hc_thread_wait (1, &i_thread);
- }
-
- // we dont need restore file anymore
- if (data.restore_disable == 0)
- {
- if ((data.devices_status == STATUS_EXHAUSTED) || (data.devices_status == STATUS_CRACKED))
- {
- unlink (eff_restore_file);
- unlink (new_restore_file);
- }
- else
- {
- cycle_restore ();
- }
- }
-
- // finally save left hashes
-
- if ((hashlist_mode == HL_MODE_FILE) && (remove == 1) && (data.digests_saved != data.digests_done))
- {
- save_hash ();
- }
-
- /**
- * Clean up
- */
-
- if (benchmark == 1)
- {
- status_benchmark ();
-
- log_info ("");
- }
- else
- {
- if (quiet == 0) clear_prompt ();
-
- if (quiet == 0) log_info ("");
-
- if (status == 1)
- {
- status_display ();
- }
- else
- {
- if (quiet == 0) status_display ();
- }
-
- if (quiet == 0) log_info ("");
- }
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- local_free (device_param->result);
-
- local_free (device_param->combs_buf);
-
- local_free (device_param->hooks_buf);
-
- local_free (device_param->device_name);
-
- local_free (device_param->device_name_chksum);
-
- local_free (device_param->device_version);
-
- local_free (device_param->driver_version);
-
- if (device_param->pws_buf) myfree (device_param->pws_buf);
- if (device_param->d_pws_buf) hc_clReleaseMemObject (data.ocl, device_param->d_pws_buf);
- if (device_param->d_pws_amp_buf) hc_clReleaseMemObject (data.ocl, device_param->d_pws_amp_buf);
- if (device_param->d_rules) hc_clReleaseMemObject (data.ocl, device_param->d_rules);
- if (device_param->d_rules_c) hc_clReleaseMemObject (data.ocl, device_param->d_rules_c);
- if (device_param->d_combs) hc_clReleaseMemObject (data.ocl, device_param->d_combs);
- if (device_param->d_combs_c) hc_clReleaseMemObject (data.ocl, device_param->d_combs_c);
- if (device_param->d_bfs) hc_clReleaseMemObject (data.ocl, device_param->d_bfs);
- if (device_param->d_bfs_c) hc_clReleaseMemObject (data.ocl, device_param->d_bfs_c);
- if (device_param->d_bitmap_s1_a) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s1_a);
- if (device_param->d_bitmap_s1_b) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s1_b);
- if (device_param->d_bitmap_s1_c) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s1_c);
- if (device_param->d_bitmap_s1_d) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s1_d);
- if (device_param->d_bitmap_s2_a) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s2_a);
- if (device_param->d_bitmap_s2_b) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s2_b);
- if (device_param->d_bitmap_s2_c) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s2_c);
- if (device_param->d_bitmap_s2_d) hc_clReleaseMemObject (data.ocl, device_param->d_bitmap_s2_d);
- if (device_param->d_plain_bufs) hc_clReleaseMemObject (data.ocl, device_param->d_plain_bufs);
- if (device_param->d_digests_buf) hc_clReleaseMemObject (data.ocl, device_param->d_digests_buf);
- if (device_param->d_digests_shown) hc_clReleaseMemObject (data.ocl, device_param->d_digests_shown);
- if (device_param->d_salt_bufs) hc_clReleaseMemObject (data.ocl, device_param->d_salt_bufs);
- if (device_param->d_esalt_bufs) hc_clReleaseMemObject (data.ocl, device_param->d_esalt_bufs);
- if (device_param->d_tmps) hc_clReleaseMemObject (data.ocl, device_param->d_tmps);
- if (device_param->d_hooks) hc_clReleaseMemObject (data.ocl, device_param->d_hooks);
- if (device_param->d_result) hc_clReleaseMemObject (data.ocl, device_param->d_result);
- if (device_param->d_scryptV_buf) hc_clReleaseMemObject (data.ocl, device_param->d_scryptV_buf);
- if (device_param->d_root_css_buf) hc_clReleaseMemObject (data.ocl, device_param->d_root_css_buf);
- if (device_param->d_markov_css_buf) hc_clReleaseMemObject (data.ocl, device_param->d_markov_css_buf);
- if (device_param->d_tm_c) hc_clReleaseMemObject (data.ocl, device_param->d_tm_c);
-
- if (device_param->kernel1) hc_clReleaseKernel (data.ocl, device_param->kernel1);
- if (device_param->kernel12) hc_clReleaseKernel (data.ocl, device_param->kernel12);
- if (device_param->kernel2) hc_clReleaseKernel (data.ocl, device_param->kernel2);
- if (device_param->kernel23) hc_clReleaseKernel (data.ocl, device_param->kernel23);
- if (device_param->kernel3) hc_clReleaseKernel (data.ocl, device_param->kernel3);
- if (device_param->kernel_mp) hc_clReleaseKernel (data.ocl, device_param->kernel_mp);
- if (device_param->kernel_mp_l) hc_clReleaseKernel (data.ocl, device_param->kernel_mp_l);
- if (device_param->kernel_mp_r) hc_clReleaseKernel (data.ocl, device_param->kernel_mp_r);
- if (device_param->kernel_tm) hc_clReleaseKernel (data.ocl, device_param->kernel_tm);
- if (device_param->kernel_amp) hc_clReleaseKernel (data.ocl, device_param->kernel_amp);
-
- if (device_param->program) hc_clReleaseProgram (data.ocl, device_param->program);
- if (device_param->program_mp) hc_clReleaseProgram (data.ocl, device_param->program_mp);
- if (device_param->program_amp) hc_clReleaseProgram (data.ocl, device_param->program_amp);
-
- if (device_param->command_queue) hc_clReleaseCommandQueue (data.ocl, device_param->command_queue);
- if (device_param->context) hc_clReleaseContext (data.ocl, device_param->context);
- }
-
- // reset default fan speed
-
- #ifdef HAVE_HWMON
- if (gpu_temp_disable == 0)
- {
- #ifdef HAVE_ADL
- if (gpu_temp_retain != 0) // VENDOR_ID_AMD is implied here
- {
- hc_thread_mutex_lock (mux_adl);
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- if (data.hm_device[device_id].fan_supported == 1)
- {
- int fanspeed = temp_retain_fanspeed_value[device_id];
-
- if (fanspeed == -1) continue;
-
- int rc = hm_set_fanspeed_with_device_id_amd (device_id, fanspeed);
-
- if (rc == -1) log_info ("WARNING: Failed to restore default fan speed for gpu number: %i:", device_id);
- }
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_ADL
- }
-
- #ifdef HAVE_ADL
- // reset power tuning
-
- if (powertune_enable == 1) // VENDOR_ID_AMD is implied here
- {
- hc_thread_mutex_lock (mux_adl);
-
- for (uint device_id = 0; device_id < data.devices_cnt; device_id++)
- {
- hc_device_param_t *device_param = &data.devices_param[device_id];
-
- if (device_param->skipped) continue;
-
- if (data.hm_device[device_id].od_version == 6)
- {
- // check powertune capabilities first, if not available then skip device
-
- int powertune_supported = 0;
-
- if ((hm_ADL_Overdrive6_PowerControl_Caps (data.hm_amd, data.hm_device[device_id].adapter_index.amd, &powertune_supported)) != ADL_OK)
- {
- log_error ("ERROR: Failed to get ADL PowerControl Capabilities");
-
- return (-1);
- }
-
- if (powertune_supported != 0)
- {
- // powercontrol settings
-
- if ((hm_ADL_Overdrive_PowerControl_Set (data.hm_amd, data.hm_device[device_id].adapter_index.amd, od_power_control_status[device_id])) != ADL_OK)
- {
- log_info ("ERROR: Failed to restore the ADL PowerControl values");
-
- return (-1);
- }
-
- // clocks
-
- ADLOD6StateInfo *performance_state = (ADLOD6StateInfo*) mycalloc (1, sizeof (ADLOD6StateInfo) + sizeof (ADLOD6PerformanceLevel));
-
- performance_state->iNumberOfPerformanceLevels = 2;
-
- performance_state->aLevels[0].iEngineClock = od_clock_mem_status[device_id].state.aLevels[0].iEngineClock;
- performance_state->aLevels[1].iEngineClock = od_clock_mem_status[device_id].state.aLevels[1].iEngineClock;
- performance_state->aLevels[0].iMemoryClock = od_clock_mem_status[device_id].state.aLevels[0].iMemoryClock;
- performance_state->aLevels[1].iMemoryClock = od_clock_mem_status[device_id].state.aLevels[1].iMemoryClock;
-
- if ((hm_ADL_Overdrive_State_Set (data.hm_amd, data.hm_device[device_id].adapter_index.amd, ADL_OD6_SETSTATE_PERFORMANCE, performance_state)) != ADL_OK)
- {
- log_info ("ERROR: Failed to restore ADL performance state");
-
- return (-1);
- }
-
- local_free (performance_state);
- }
- }
- }
-
- hc_thread_mutex_unlock (mux_adl);
- }
- #endif // HAVE_ADL
-
- if (gpu_temp_disable == 0)
- {
- #if defined(HAVE_NVML) || defined(HAVE_NVAPI)
- if (data.hm_nv)
- {
- #if defined(LINUX) && defined(HAVE_NVML)
-
- hm_NVML_nvmlShutdown (data.hm_nv);
-
- nvml_close (data.hm_nv);
-
- #elif defined(WIN) && (HAVE_NVAPI)
-
- hm_NvAPI_Unload (data.hm_nv);
-
- nvapi_close (data.hm_nv);
-
- #endif
-
- data.hm_nv = NULL;
- }
- #endif
-
- #ifdef HAVE_ADL
- if (data.hm_amd)
- {
- hm_ADL_Main_Control_Destroy (data.hm_amd);
-
- adl_close (data.hm_amd);
- data.hm_amd = NULL;
- }
- #endif
- }
- #endif // HAVE_HWMON
-
- // free memory
-
- local_free (masks);
-
- local_free (dictstat_base);
-
- for (uint pot_pos = 0; pot_pos < pot_cnt; pot_pos++)
- {
- pot_t *pot_ptr = &pot[pot_pos];
-
- hash_t *hash = &pot_ptr->hash;
-
- local_free (hash->digest);
-
- if (isSalted)
- {
- local_free (hash->salt);
- }
- }
-
- local_free (pot);
-
- local_free (all_kernel_rules_cnt);
- local_free (all_kernel_rules_buf);
-
- local_free (wl_data->buf);
- local_free (wl_data);
-
- local_free (bitmap_s1_a);
- local_free (bitmap_s1_b);
- local_free (bitmap_s1_c);
- local_free (bitmap_s1_d);
- local_free (bitmap_s2_a);
- local_free (bitmap_s2_b);
- local_free (bitmap_s2_c);
- local_free (bitmap_s2_d);
-
- #ifdef HAVE_HWMON
- local_free (temp_retain_fanspeed_value);
- #ifdef HAVE_ADL
- local_free (od_clock_mem_status);
- local_free (od_power_control_status);
- #endif // ADL
- #endif
-
- global_free (devices_param);
-
- global_free (kernel_rules_buf);
-
- global_free (root_css_buf);
- global_free (markov_css_buf);
-
- global_free (digests_buf);
- global_free (digests_shown);
- global_free (digests_shown_tmp);
-
- global_free (salts_buf);
- global_free (salts_shown);
-
- global_free (esalts_buf);
-
- global_free (words_progress_done);
- global_free (words_progress_rejected);
- global_free (words_progress_restored);
-
- if (pot_fp) fclose (pot_fp);
-
- if (data.devices_status == STATUS_QUIT) break;
- }
-
- // destroy others mutex
-
- hc_thread_mutex_delete (mux_dispatcher);
- hc_thread_mutex_delete (mux_counter);
- hc_thread_mutex_delete (mux_display);
- hc_thread_mutex_delete (mux_adl);
-
- // free memory
-
- local_free (eff_restore_file);
- local_free (new_restore_file);
-
- local_free (rd);
-
- // tuning db
-
- tuning_db_destroy (tuning_db);
-
- // loopback
-
- local_free (loopback_file);
-
- if (loopback == 1) unlink (loopback_file);
-
- // induction directory
-
- if (induction_dir == NULL)
- {
- if (attack_mode != ATTACK_MODE_BF)
- {
- if (rmdir (induction_directory) == -1)
- {
- if (errno == ENOENT)
- {
- // good, we can ignore
- }
- else if (errno == ENOTEMPTY)
- {
- // good, we can ignore
- }
- else
- {
- log_error ("ERROR: %s: %s", induction_directory, strerror (errno));
-
- return (-1);
- }
- }
-
- local_free (induction_directory);
- }
- }
-
- // outfile-check directory
-
- if (outfile_check_dir == NULL)
- {
- if (rmdir (outfile_check_directory) == -1)
- {
- if (errno == ENOENT)
- {
- // good, we can ignore
- }
- else if (errno == ENOTEMPTY)
- {
- // good, we can ignore
- }
- else
- {
- log_error ("ERROR: %s: %s", outfile_check_directory, strerror (errno));
-
- return (-1);
- }
- }
-
- local_free (outfile_check_directory);
- }
-
- time_t proc_stop;
-
- time (&proc_stop);
-
- logfile_top_uint (proc_start);
- logfile_top_uint (proc_stop);
-
- logfile_top_msg ("STOP");
-
- if (quiet == 0) log_info_nn ("Started: %s", ctime (&proc_start));
- if (quiet == 0) log_info_nn ("Stopped: %s", ctime (&proc_stop));
-
- if (data.ocl) ocl_close (data.ocl);
-
- if (data.devices_status == STATUS_ABORTED) return 2;
- if (data.devices_status == STATUS_QUIT) return 2;
- if (data.devices_status == STATUS_STOP_AT_CHECKPOINT) return 2;
- if (data.devices_status == STATUS_EXHAUSTED) return 1;
- if (data.devices_status == STATUS_CRACKED) return 0;
-
- return -1;
-}