mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-11 00:01:16 +00:00
Add support for -a 1 in -S mode
This commit is contained in:
parent
32b915fd01
commit
d96b649751
@ -6,6 +6,7 @@
|
|||||||
#ifndef _HASH_MANAGEMENT_H
|
#ifndef _HASH_MANAGEMENT_H
|
||||||
#define _HASH_MANAGEMENT_H
|
#define _HASH_MANAGEMENT_H
|
||||||
|
|
||||||
|
int sort_by_string (const void *v1, const void *v2);
|
||||||
int sort_by_digest_p0p1 (const void *v1, const void *v2, void *v3);
|
int sort_by_digest_p0p1 (const void *v1, const void *v2, void *v3);
|
||||||
int sort_by_salt (const void *v1, const void *v2);
|
int sort_by_salt (const void *v1, const void *v2);
|
||||||
int sort_by_salt_buf (const void *v1, const void *v2, MAYBE_UNUSED void * v3);
|
int sort_by_salt_buf (const void *v1, const void *v2, MAYBE_UNUSED void * v3);
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
|
|
||||||
typedef struct extra_info_straight
|
typedef struct extra_info_straight
|
||||||
{
|
{
|
||||||
|
u64 pos;
|
||||||
|
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
|
|
||||||
u64 rule_pos_prev;
|
u64 rule_pos_prev;
|
||||||
@ -23,6 +25,8 @@ typedef struct extra_info_straight
|
|||||||
|
|
||||||
typedef struct extra_info_combi
|
typedef struct extra_info_combi
|
||||||
{
|
{
|
||||||
|
u64 pos;
|
||||||
|
|
||||||
FILE *base_fp;
|
FILE *base_fp;
|
||||||
FILE *combs_fp;
|
FILE *combs_fp;
|
||||||
|
|
||||||
|
122
include/types.h
122
include/types.h
@ -609,91 +609,91 @@ typedef enum user_options_map
|
|||||||
IDX_BENCHMARK = 'b',
|
IDX_BENCHMARK = 'b',
|
||||||
IDX_BITMAP_MAX = 0xff02,
|
IDX_BITMAP_MAX = 0xff02,
|
||||||
IDX_BITMAP_MIN = 0xff03,
|
IDX_BITMAP_MIN = 0xff03,
|
||||||
IDX_CPU_AFFINITY = 0xff0a,
|
IDX_CPU_AFFINITY = 0xff0b,
|
||||||
IDX_CUSTOM_CHARSET_1 = '1',
|
IDX_CUSTOM_CHARSET_1 = '1',
|
||||||
IDX_CUSTOM_CHARSET_2 = '2',
|
IDX_CUSTOM_CHARSET_2 = '2',
|
||||||
IDX_CUSTOM_CHARSET_3 = '3',
|
IDX_CUSTOM_CHARSET_3 = '3',
|
||||||
IDX_CUSTOM_CHARSET_4 = '4',
|
IDX_CUSTOM_CHARSET_4 = '4',
|
||||||
IDX_DEBUG_FILE = 0xff0b,
|
IDX_DEBUG_FILE = 0xff0c,
|
||||||
IDX_DEBUG_MODE = 0xff0c,
|
IDX_DEBUG_MODE = 0xff0d,
|
||||||
IDX_ENCODING_FROM = 0xff0d,
|
IDX_ENCODING_FROM = 0xff0e,
|
||||||
IDX_ENCODING_TO = 0xff0e,
|
IDX_ENCODING_TO = 0xff0f,
|
||||||
IDX_EXAMPLE_HASHES = 0xff0f,
|
IDX_EXAMPLE_HASHES = 0xff10,
|
||||||
IDX_FORCE = 0xff10,
|
IDX_FORCE = 0xff11,
|
||||||
IDX_GPU_TEMP_ABORT = 0xff11,
|
IDX_GPU_TEMP_ABORT = 0xff12,
|
||||||
IDX_GPU_TEMP_DISABLE = 0xff12,
|
IDX_GPU_TEMP_DISABLE = 0xff13,
|
||||||
IDX_HASH_MODE = 'm',
|
IDX_HASH_MODE = 'm',
|
||||||
IDX_HCCAPX_MESSAGE_PAIR = 0xff13,
|
IDX_HCCAPX_MESSAGE_PAIR = 0xff14,
|
||||||
IDX_HELP = 'h',
|
IDX_HELP = 'h',
|
||||||
IDX_HEX_CHARSET = 0xff14,
|
IDX_HEX_CHARSET = 0xff15,
|
||||||
IDX_HEX_SALT = 0xff15,
|
IDX_HEX_SALT = 0xff16,
|
||||||
IDX_HEX_WORDLIST = 0xff16,
|
IDX_HEX_WORDLIST = 0xff17,
|
||||||
IDX_INCREMENT = 'i',
|
IDX_INCREMENT = 'i',
|
||||||
IDX_INCREMENT_MAX = 0xff17,
|
IDX_INCREMENT_MAX = 0xff18,
|
||||||
IDX_INCREMENT_MIN = 0xff18,
|
IDX_INCREMENT_MIN = 0xff19,
|
||||||
IDX_INDUCTION_DIR = 0xff19,
|
IDX_INDUCTION_DIR = 0xff1a,
|
||||||
IDX_KEEP_GUESSING = 0xff1a,
|
IDX_KEEP_GUESSING = 0xff1b,
|
||||||
IDX_KERNEL_ACCEL = 'n',
|
IDX_KERNEL_ACCEL = 'n',
|
||||||
IDX_KERNEL_LOOPS = 'u',
|
IDX_KERNEL_LOOPS = 'u',
|
||||||
IDX_KEYSPACE = 0xff1b,
|
IDX_KEYSPACE = 0xff1c,
|
||||||
IDX_LEFT = 0xff1c,
|
IDX_LEFT = 0xff1d,
|
||||||
IDX_LIMIT = 'l',
|
IDX_LIMIT = 'l',
|
||||||
IDX_LOGFILE_DISABLE = 0xff1d,
|
IDX_LOGFILE_DISABLE = 0xff1e,
|
||||||
IDX_LOOPBACK = 0xff1e,
|
IDX_LOOPBACK = 0xff1f,
|
||||||
IDX_MACHINE_READABLE = 0xff1f,
|
IDX_MACHINE_READABLE = 0xff20,
|
||||||
IDX_MARKOV_CLASSIC = 0xff20,
|
IDX_MARKOV_CLASSIC = 0xff21,
|
||||||
IDX_MARKOV_DISABLE = 0xff21,
|
IDX_MARKOV_DISABLE = 0xff22,
|
||||||
IDX_MARKOV_HCSTAT2 = 0xff22,
|
IDX_MARKOV_HCSTAT2 = 0xff23,
|
||||||
IDX_MARKOV_THRESHOLD = 't',
|
IDX_MARKOV_THRESHOLD = 't',
|
||||||
IDX_NONCE_ERROR_CORRECTIONS = 0xff23,
|
IDX_NONCE_ERROR_CORRECTIONS = 0xff24,
|
||||||
IDX_NVIDIA_SPIN_DAMP = 0xff24,
|
IDX_NVIDIA_SPIN_DAMP = 0xff25,
|
||||||
IDX_OPENCL_DEVICES = 'd',
|
IDX_OPENCL_DEVICES = 'd',
|
||||||
IDX_OPENCL_DEVICE_TYPES = 'D',
|
IDX_OPENCL_DEVICE_TYPES = 'D',
|
||||||
IDX_OPENCL_INFO = 'I',
|
IDX_OPENCL_INFO = 'I',
|
||||||
IDX_OPENCL_PLATFORMS = 0xff25,
|
IDX_OPENCL_PLATFORMS = 0xff26,
|
||||||
IDX_OPENCL_VECTOR_WIDTH = 0xff26,
|
IDX_OPENCL_VECTOR_WIDTH = 0xff27,
|
||||||
IDX_OPTIMIZED_KERNEL_ENABLE = 'O',
|
IDX_OPTIMIZED_KERNEL_ENABLE = 'O',
|
||||||
IDX_OUTFILE_AUTOHEX_DISABLE = 0xff27,
|
IDX_OUTFILE_AUTOHEX_DISABLE = 0xff28,
|
||||||
IDX_OUTFILE_CHECK_DIR = 0xff28,
|
IDX_OUTFILE_CHECK_DIR = 0xff29,
|
||||||
IDX_OUTFILE_CHECK_TIMER = 0xff29,
|
IDX_OUTFILE_CHECK_TIMER = 0xff2a,
|
||||||
IDX_OUTFILE_FORMAT = 0xff2a,
|
IDX_OUTFILE_FORMAT = 0xff2b,
|
||||||
IDX_OUTFILE = 'o',
|
IDX_OUTFILE = 'o',
|
||||||
IDX_POTFILE_DISABLE = 0xff2b,
|
IDX_POTFILE_DISABLE = 0xff2c,
|
||||||
IDX_POTFILE_PATH = 0xff2c,
|
IDX_POTFILE_PATH = 0xff2d,
|
||||||
IDX_PROGRESS_ONLY = 0xff2d,
|
IDX_PROGRESS_ONLY = 0xff2e,
|
||||||
IDX_QUIET = 0xff2e,
|
IDX_QUIET = 0xff2f,
|
||||||
IDX_REMOVE = 0xff2f,
|
IDX_REMOVE = 0xff30,
|
||||||
IDX_REMOVE_TIMER = 0xff30,
|
IDX_REMOVE_TIMER = 0xff31,
|
||||||
IDX_RESTORE = 0xff31,
|
IDX_RESTORE = 0xff32,
|
||||||
IDX_RESTORE_DISABLE = 0xff32,
|
IDX_RESTORE_DISABLE = 0xff33,
|
||||||
IDX_RESTORE_FILE_PATH = 0xff33,
|
IDX_RESTORE_FILE_PATH = 0xff34,
|
||||||
IDX_RP_FILE = 'r',
|
IDX_RP_FILE = 'r',
|
||||||
IDX_RP_GEN_FUNC_MAX = 0xff34,
|
IDX_RP_GEN_FUNC_MAX = 0xff35,
|
||||||
IDX_RP_GEN_FUNC_MIN = 0xff35,
|
IDX_RP_GEN_FUNC_MIN = 0xff36,
|
||||||
IDX_RP_GEN = 'g',
|
IDX_RP_GEN = 'g',
|
||||||
IDX_RP_GEN_SEED = 0xff36,
|
IDX_RP_GEN_SEED = 0xff37,
|
||||||
IDX_RULE_BUF_L = 'j',
|
IDX_RULE_BUF_L = 'j',
|
||||||
IDX_RULE_BUF_R = 'k',
|
IDX_RULE_BUF_R = 'k',
|
||||||
IDX_RUNTIME = 0xff37,
|
IDX_RUNTIME = 0xff38,
|
||||||
IDX_SCRYPT_TMTO = 0xff38,
|
IDX_SCRYPT_TMTO = 0xff39,
|
||||||
IDX_SEGMENT_SIZE = 'c',
|
IDX_SEGMENT_SIZE = 'c',
|
||||||
IDX_SELF_TEST_DISABLE = 0xff39,
|
IDX_SELF_TEST_DISABLE = 0xff3a,
|
||||||
IDX_SEPARATOR = 'p',
|
IDX_SEPARATOR = 'p',
|
||||||
IDX_SESSION = 0xff3a,
|
IDX_SESSION = 0xff3b,
|
||||||
IDX_SHOW = 0xff3b,
|
IDX_SHOW = 0xff3c,
|
||||||
IDX_SKIP = 's',
|
IDX_SKIP = 's',
|
||||||
IDX_SLOW_CANDIDATES = 'S',
|
IDX_SLOW_CANDIDATES = 'S',
|
||||||
IDX_SPEED_ONLY = 0xff3c,
|
IDX_SPEED_ONLY = 0xff3d,
|
||||||
IDX_STATUS = 0xff3d,
|
IDX_STATUS = 0xff3e,
|
||||||
IDX_STATUS_TIMER = 0xff3e,
|
IDX_STATUS_TIMER = 0xff3f,
|
||||||
IDX_STDOUT_FLAG = 0xff3f,
|
IDX_STDOUT_FLAG = 0xff40,
|
||||||
IDX_TRUECRYPT_KEYFILES = 0xff40,
|
IDX_TRUECRYPT_KEYFILES = 0xff41,
|
||||||
IDX_USERNAME = 0xff41,
|
IDX_USERNAME = 0xff42,
|
||||||
IDX_VERACRYPT_KEYFILES = 0xff42,
|
IDX_VERACRYPT_KEYFILES = 0xff43,
|
||||||
IDX_VERACRYPT_PIM = 0xff43,
|
IDX_VERACRYPT_PIM = 0xff44,
|
||||||
IDX_VERSION_LOWER = 'v',
|
IDX_VERSION_LOWER = 'v',
|
||||||
IDX_VERSION = 'V',
|
IDX_VERSION = 'V',
|
||||||
IDX_WORDLIST_AUTOHEX_DISABLE = 0xff44,
|
IDX_WORDLIST_AUTOHEX_DISABLE = 0xff45,
|
||||||
IDX_WORKLOAD_PROFILE = 'w',
|
IDX_WORKLOAD_PROFILE = 'w',
|
||||||
|
|
||||||
} user_options_map_t;
|
} user_options_map_t;
|
||||||
@ -1096,7 +1096,7 @@ typedef struct hc_device_param
|
|||||||
u32 *pws_comp;
|
u32 *pws_comp;
|
||||||
u64 pws_cnt;
|
u64 pws_cnt;
|
||||||
|
|
||||||
pw_pre_t *pws_pre_buf;
|
pw_pre_t *pws_pre_buf; // for slow candidates
|
||||||
u64 pws_pre_cnt;
|
u64 pws_pre_cnt;
|
||||||
|
|
||||||
pw_pre_t *pws_base_buf; // for debug mode
|
pw_pre_t *pws_base_buf; // for debug mode
|
||||||
@ -1633,6 +1633,8 @@ typedef struct user_options
|
|||||||
bool runtime_chgd;
|
bool runtime_chgd;
|
||||||
bool segment_size_chgd;
|
bool segment_size_chgd;
|
||||||
bool workload_profile_chgd;
|
bool workload_profile_chgd;
|
||||||
|
bool skip_chgd;
|
||||||
|
bool limit_chgd;
|
||||||
|
|
||||||
bool advice_disable;
|
bool advice_disable;
|
||||||
bool benchmark;
|
bool benchmark;
|
||||||
|
424
src/dispatch.c
424
src/dispatch.c
@ -16,8 +16,29 @@
|
|||||||
#include "rp.h"
|
#include "rp.h"
|
||||||
#include "rp_cpu.h"
|
#include "rp_cpu.h"
|
||||||
#include "slow_candidates.h"
|
#include "slow_candidates.h"
|
||||||
|
#include "user_options.h"
|
||||||
#include "dispatch.h"
|
#include "dispatch.h"
|
||||||
|
|
||||||
|
static u64 get_highest_words_done (const hashcat_ctx_t *hashcat_ctx)
|
||||||
|
{
|
||||||
|
const opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
|
||||||
|
|
||||||
|
u64 words_cur = 0;
|
||||||
|
|
||||||
|
for (u32 device_id = 0; device_id < opencl_ctx->devices_cnt; device_id++)
|
||||||
|
{
|
||||||
|
hc_device_param_t *device_param = &opencl_ctx->devices_param[device_id];
|
||||||
|
|
||||||
|
if (device_param->skipped == true) continue;
|
||||||
|
|
||||||
|
const u64 words_done = device_param->words_done;
|
||||||
|
|
||||||
|
if (words_done > words_cur) words_cur = words_done;
|
||||||
|
}
|
||||||
|
|
||||||
|
return words_cur;
|
||||||
|
}
|
||||||
|
|
||||||
static u64 get_lowest_words_done (const hashcat_ctx_t *hashcat_ctx)
|
static u64 get_lowest_words_done (const hashcat_ctx_t *hashcat_ctx)
|
||||||
{
|
{
|
||||||
const opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
|
const opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
|
||||||
@ -146,181 +167,6 @@ static int calc_stdin (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_par
|
|||||||
iconv_tmp = (char *) hcmalloc (HCBUFSIZ_TINY);
|
iconv_tmp = (char *) hcmalloc (HCBUFSIZ_TINY);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (user_options->slow_candidates == true)
|
|
||||||
{
|
|
||||||
while (status_ctx->run_thread_level1 == true)
|
|
||||||
{
|
|
||||||
hc_thread_mutex_lock (status_ctx->mux_dispatcher);
|
|
||||||
|
|
||||||
if (feof (stdin) != 0)
|
|
||||||
{
|
|
||||||
hc_thread_mutex_unlock (status_ctx->mux_dispatcher);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
u64 words_extra_total = 0;
|
|
||||||
|
|
||||||
memset (device_param->pws_comp, 0, device_param->size_pws_comp);
|
|
||||||
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
|
||||||
memset (device_param->pws_pre_buf, 0, device_param->size_pws_pre);
|
|
||||||
memset (device_param->pws_base_buf, 0, device_param->size_pws_base);
|
|
||||||
|
|
||||||
device_param->pws_pre_cnt = 0;
|
|
||||||
device_param->pws_base_cnt = 0;
|
|
||||||
|
|
||||||
while (device_param->pws_pre_cnt < device_param->kernel_power)
|
|
||||||
{
|
|
||||||
const int rc_select = select_read_timeout_console (1);
|
|
||||||
|
|
||||||
if (rc_select == -1) break;
|
|
||||||
|
|
||||||
if (rc_select == 0)
|
|
||||||
{
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
|
||||||
|
|
||||||
status_ctx->stdin_read_timeout_cnt++;
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
status_ctx->stdin_read_timeout_cnt = 0;
|
|
||||||
|
|
||||||
char *line_buf = fgets (buf, HCBUFSIZ_LARGE - 1, stdin);
|
|
||||||
|
|
||||||
if (line_buf == NULL) break;
|
|
||||||
|
|
||||||
size_t line_len = in_superchop (line_buf);
|
|
||||||
|
|
||||||
line_len = convert_from_hex (hashcat_ctx, line_buf, (u32) line_len);
|
|
||||||
|
|
||||||
// do the on-the-fly encoding
|
|
||||||
|
|
||||||
if (iconv_enabled == true)
|
|
||||||
{
|
|
||||||
char *iconv_ptr = iconv_tmp;
|
|
||||||
size_t iconv_sz = HCBUFSIZ_TINY;
|
|
||||||
|
|
||||||
const size_t iconv_rc = iconv (iconv_ctx, &line_buf, &line_len, &iconv_ptr, &iconv_sz);
|
|
||||||
|
|
||||||
if (iconv_rc == (size_t) -1) continue;
|
|
||||||
|
|
||||||
line_buf = iconv_tmp;
|
|
||||||
line_len = HCBUFSIZ_TINY - iconv_sz;
|
|
||||||
}
|
|
||||||
|
|
||||||
// post-process rule engine
|
|
||||||
|
|
||||||
char rule_buf_out[RP_PASSWORD_SIZE];
|
|
||||||
|
|
||||||
if (run_rule_engine ((int) user_options_extra->rule_len_l, user_options->rule_buf_l))
|
|
||||||
{
|
|
||||||
if (line_len >= RP_PASSWORD_SIZE) continue;
|
|
||||||
|
|
||||||
memset (rule_buf_out, 0, sizeof (rule_buf_out));
|
|
||||||
|
|
||||||
const int rule_len_out = _old_apply_rule (user_options->rule_buf_l, (int) user_options_extra->rule_len_l, line_buf, (int) line_len, rule_buf_out);
|
|
||||||
|
|
||||||
if (rule_len_out < 0) continue;
|
|
||||||
|
|
||||||
line_buf = rule_buf_out;
|
|
||||||
line_len = (size_t) rule_len_out;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (line_len >= PW_MAX) continue;
|
|
||||||
|
|
||||||
// hmm that's always the case, or?
|
|
||||||
|
|
||||||
const u32 attack_kern = user_options_extra->attack_kern;
|
|
||||||
|
|
||||||
if (attack_kern == ATTACK_KERN_STRAIGHT)
|
|
||||||
{
|
|
||||||
if ((line_len < hashconfig->pw_min) || (line_len > hashconfig->pw_max))
|
|
||||||
{
|
|
||||||
words_extra_total++;
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pw_pre_add (device_param, (u8 *) line_buf, (int) line_len, NULL, 0, 0);
|
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
|
||||||
}
|
|
||||||
|
|
||||||
hc_thread_mutex_unlock (status_ctx->mux_dispatcher);
|
|
||||||
|
|
||||||
u64 pre_rejects = 0;
|
|
||||||
|
|
||||||
if (0)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
|
||||||
|
|
||||||
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
|
||||||
{
|
|
||||||
pw_pre_t *pw_pre = device_param->pws_pre_buf + pws_pre_idx;
|
|
||||||
|
|
||||||
pw_base_add (device_param, pw_pre);
|
|
||||||
|
|
||||||
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
words_extra_total += pre_rejects;
|
|
||||||
|
|
||||||
if (words_extra_total > 0)
|
|
||||||
{
|
|
||||||
hc_thread_mutex_lock (status_ctx->mux_counter);
|
|
||||||
|
|
||||||
for (u32 salt_pos = 0; salt_pos < hashes->salts_cnt; salt_pos++)
|
|
||||||
{
|
|
||||||
status_ctx->words_progress_rejected[salt_pos] += words_extra_total * straight_ctx->kernel_rules_cnt;
|
|
||||||
}
|
|
||||||
|
|
||||||
hc_thread_mutex_unlock (status_ctx->mux_counter);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
|
||||||
|
|
||||||
if (device_param->pws_cnt)
|
|
||||||
{
|
|
||||||
// flush
|
|
||||||
|
|
||||||
int CL_rc;
|
|
||||||
|
|
||||||
CL_rc = run_copy (hashcat_ctx, device_param, device_param->pws_cnt);
|
|
||||||
|
|
||||||
if (CL_rc == -1)
|
|
||||||
{
|
|
||||||
hcfree (buf);
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
CL_rc = run_cracker (hashcat_ctx, device_param, device_param->pws_cnt);
|
|
||||||
|
|
||||||
if (CL_rc == -1)
|
|
||||||
{
|
|
||||||
hcfree (buf);
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
device_param->pws_cnt = 0;
|
|
||||||
|
|
||||||
device_param->pws_base_cnt = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
|
||||||
|
|
||||||
if (device_param->speed_only_finish == true) break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
while (status_ctx->run_thread_level1 == true)
|
while (status_ctx->run_thread_level1 == true)
|
||||||
{
|
{
|
||||||
hc_thread_mutex_lock (status_ctx->mux_dispatcher);
|
hc_thread_mutex_lock (status_ctx->mux_dispatcher);
|
||||||
@ -462,7 +308,6 @@ static int calc_stdin (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_par
|
|||||||
|
|
||||||
if (device_param->speed_only_finish == true) break;
|
if (device_param->speed_only_finish == true) break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
device_param->kernel_accel_prev = device_param->kernel_accel;
|
device_param->kernel_accel_prev = device_param->kernel_accel;
|
||||||
device_param->kernel_loops_prev = device_param->kernel_loops;
|
device_param->kernel_loops_prev = device_param->kernel_loops;
|
||||||
@ -517,6 +362,7 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
|
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
|
||||||
straight_ctx_t *straight_ctx = hashcat_ctx->straight_ctx;
|
straight_ctx_t *straight_ctx = hashcat_ctx->straight_ctx;
|
||||||
combinator_ctx_t *combinator_ctx = hashcat_ctx->combinator_ctx;
|
combinator_ctx_t *combinator_ctx = hashcat_ctx->combinator_ctx;
|
||||||
|
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
|
||||||
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
||||||
|
|
||||||
const u32 attack_mode = user_options->attack_mode;
|
const u32 attack_mode = user_options->attack_mode;
|
||||||
@ -526,13 +372,43 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
{
|
{
|
||||||
// attack modes from here
|
// attack modes from here
|
||||||
|
|
||||||
if (attack_mode == ATTACK_MODE_BF)
|
if (attack_mode == ATTACK_MODE_STRAIGHT)
|
||||||
{
|
{
|
||||||
extra_info_mask_t extra_info_mask;
|
char *dictfile = straight_ctx->dict;
|
||||||
|
|
||||||
memset (&extra_info_mask, 0, sizeof (extra_info_mask));
|
FILE *fp = fopen (dictfile, "rb");
|
||||||
|
|
||||||
extra_info_mask.out_len = mask_ctx->css_cnt;
|
if (fp == NULL)
|
||||||
|
{
|
||||||
|
event_log_error (hashcat_ctx, "%s: %s", dictfile, strerror (errno));
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
extra_info_straight_t extra_info_straight;
|
||||||
|
|
||||||
|
memset (&extra_info_straight, 0, sizeof (extra_info_straight));
|
||||||
|
|
||||||
|
extra_info_straight.fp = fp;
|
||||||
|
|
||||||
|
hashcat_ctx_t *hashcat_ctx_tmp = (hashcat_ctx_t *) hcmalloc (sizeof (hashcat_ctx_t));
|
||||||
|
|
||||||
|
memcpy (hashcat_ctx_tmp, hashcat_ctx, sizeof (hashcat_ctx_t)); // yes we actually want to copy these pointers
|
||||||
|
|
||||||
|
hashcat_ctx_tmp->wl_data = (wl_data_t *) hcmalloc (sizeof (wl_data_t));
|
||||||
|
|
||||||
|
const int rc_wl_data_init = wl_data_init (hashcat_ctx_tmp);
|
||||||
|
|
||||||
|
if (rc_wl_data_init == -1)
|
||||||
|
{
|
||||||
|
fclose (fp);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp->wl_data);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp);
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
u64 words_cur = 0;
|
u64 words_cur = 0;
|
||||||
|
|
||||||
@ -542,10 +418,15 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
memset (device_param->pws_comp, 0, device_param->size_pws_comp);
|
memset (device_param->pws_comp, 0, device_param->size_pws_comp);
|
||||||
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
||||||
|
memset (device_param->pws_base_buf, 0, device_param->size_pws_base);
|
||||||
|
|
||||||
u64 pre_rejects = -1u;
|
u64 pre_rejects = -1;
|
||||||
|
|
||||||
while (pre_rejects)
|
// this greatly reduces spam on hashcat console
|
||||||
|
|
||||||
|
const u64 pre_rejects_ignore = get_power (opencl_ctx, device_param) / 2;
|
||||||
|
|
||||||
|
while (pre_rejects > pre_rejects_ignore)
|
||||||
{
|
{
|
||||||
u64 words_extra_total = 0;
|
u64 words_extra_total = 0;
|
||||||
|
|
||||||
@ -559,25 +440,34 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
while (words_extra)
|
while (words_extra)
|
||||||
{
|
{
|
||||||
const u64 work = get_work (hashcat_ctx, device_param, words_extra);
|
u64 work = get_work (hashcat_ctx, device_param, words_extra);
|
||||||
|
|
||||||
if (work == 0) break;
|
if (work == 0) break;
|
||||||
|
|
||||||
words_extra = 0;
|
|
||||||
|
|
||||||
u64 words_off = device_param->words_off;
|
u64 words_off = device_param->words_off;
|
||||||
|
|
||||||
words_fin = words_off + work;
|
words_fin = words_off + work;
|
||||||
|
|
||||||
|
words_extra = 0;
|
||||||
|
|
||||||
|
slow_candidates_seek (hashcat_ctx_tmp, &extra_info_straight, words_cur, words_off);
|
||||||
|
|
||||||
words_cur = words_off;
|
words_cur = words_off;
|
||||||
|
|
||||||
for (u64 i = words_cur; i < words_fin; i++)
|
for (u64 i = words_cur; i < words_fin; i++)
|
||||||
{
|
{
|
||||||
extra_info_mask.pos = i;
|
extra_info_straight.pos = i;
|
||||||
|
|
||||||
slow_candidates_next (hashcat_ctx, &extra_info_mask);
|
slow_candidates_next (hashcat_ctx_tmp, &extra_info_straight);
|
||||||
|
|
||||||
pw_pre_add (device_param, extra_info_mask.out_buf, extra_info_mask.out_len, NULL, 0, 0);
|
if ((extra_info_straight.out_len < hashconfig->pw_min) || (extra_info_straight.out_len > hashconfig->pw_max))
|
||||||
|
{
|
||||||
|
pre_rejects++;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
pw_pre_add (device_param, extra_info_straight.out_buf, extra_info_straight.out_len, extra_info_straight.base_buf, extra_info_straight.base_len, extra_info_straight.rule_pos_prev);
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
}
|
}
|
||||||
@ -589,20 +479,16 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
||||||
|
|
||||||
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
||||||
{
|
{
|
||||||
pw_pre_t *pw_pre = device_param->pws_pre_buf + pws_pre_idx;
|
pw_pre_t *pw_pre = device_param->pws_pre_buf + pws_pre_idx;
|
||||||
|
|
||||||
|
pw_base_add (device_param, pw_pre);
|
||||||
|
|
||||||
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
words_extra_total += pre_rejects;
|
words_extra_total += pre_rejects;
|
||||||
|
|
||||||
@ -635,6 +521,12 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (CL_rc == -1)
|
if (CL_rc == -1)
|
||||||
{
|
{
|
||||||
|
fclose (fp);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp->wl_data);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp);
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -642,25 +534,41 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (CL_rc == -1)
|
if (CL_rc == -1)
|
||||||
{
|
{
|
||||||
|
fclose (fp);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp->wl_data);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp);
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
device_param->pws_cnt = 0;
|
device_param->pws_cnt = 0;
|
||||||
|
|
||||||
|
device_param->pws_base_cnt = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (device_param->speed_only_finish == true) break;
|
if (device_param->speed_only_finish == true) break;
|
||||||
|
|
||||||
if (status_ctx->run_thread_level2 == true)
|
if (status_ctx->run_thread_level2 == true)
|
||||||
{
|
{
|
||||||
device_param->words_done = words_fin;
|
device_param->words_done = MAX (device_param->words_done, words_fin);
|
||||||
|
|
||||||
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
status_ctx->words_cur = get_highest_words_done (hashcat_ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
|
|
||||||
if (words_fin == 0) break;
|
if (words_fin == 0) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fclose (fp);
|
||||||
|
|
||||||
|
wl_data_destroy (hashcat_ctx_tmp);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp->wl_data);
|
||||||
|
|
||||||
|
hcfree (hashcat_ctx_tmp);
|
||||||
}
|
}
|
||||||
else if (attack_mode == ATTACK_MODE_COMBI)
|
else if (attack_mode == ATTACK_MODE_COMBI)
|
||||||
{
|
{
|
||||||
@ -737,9 +645,13 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
||||||
memset (device_param->pws_base_buf, 0, device_param->size_pws_base);
|
memset (device_param->pws_base_buf, 0, device_param->size_pws_base);
|
||||||
|
|
||||||
u64 pre_rejects = -1u;
|
u64 pre_rejects = -1;
|
||||||
|
|
||||||
while (pre_rejects)
|
// this greatly reduces spam on hashcat console
|
||||||
|
|
||||||
|
const u64 pre_rejects_ignore = get_power (opencl_ctx, device_param) / 2;
|
||||||
|
|
||||||
|
while (pre_rejects > pre_rejects_ignore)
|
||||||
{
|
{
|
||||||
u64 words_extra_total = 0;
|
u64 words_extra_total = 0;
|
||||||
|
|
||||||
@ -753,7 +665,7 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
while (words_extra)
|
while (words_extra)
|
||||||
{
|
{
|
||||||
const u64 work = get_work (hashcat_ctx, device_param, words_extra);
|
u64 work = get_work (hashcat_ctx, device_param, words_extra);
|
||||||
|
|
||||||
if (work == 0) break;
|
if (work == 0) break;
|
||||||
|
|
||||||
@ -769,11 +681,13 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
for (u64 i = words_cur; i < words_fin; i++)
|
for (u64 i = words_cur; i < words_fin; i++)
|
||||||
{
|
{
|
||||||
|
extra_info_combi.pos = i;
|
||||||
|
|
||||||
slow_candidates_next (hashcat_ctx_tmp, &extra_info_combi);
|
slow_candidates_next (hashcat_ctx_tmp, &extra_info_combi);
|
||||||
|
|
||||||
if ((extra_info_combi.out_len < hashconfig->pw_min) || (extra_info_combi.out_len > hashconfig->pw_max))
|
if ((extra_info_combi.out_len < hashconfig->pw_min) || (extra_info_combi.out_len > hashconfig->pw_max))
|
||||||
{
|
{
|
||||||
words_extra++;
|
pre_rejects++;
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -790,11 +704,6 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
||||||
|
|
||||||
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
||||||
@ -805,7 +714,6 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
words_extra_total += pre_rejects;
|
words_extra_total += pre_rejects;
|
||||||
|
|
||||||
@ -873,9 +781,9 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (status_ctx->run_thread_level2 == true)
|
if (status_ctx->run_thread_level2 == true)
|
||||||
{
|
{
|
||||||
device_param->words_done = words_fin;
|
device_param->words_done = MAX (device_param->words_done, words_fin);
|
||||||
|
|
||||||
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
status_ctx->words_cur = get_highest_words_done (hashcat_ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
@ -893,43 +801,13 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
hcfree (hashcat_ctx_tmp);
|
hcfree (hashcat_ctx_tmp);
|
||||||
}
|
}
|
||||||
else if (attack_mode == ATTACK_MODE_STRAIGHT)
|
else if (attack_mode == ATTACK_MODE_BF)
|
||||||
{
|
{
|
||||||
char *dictfile = straight_ctx->dict;
|
extra_info_mask_t extra_info_mask;
|
||||||
|
|
||||||
FILE *fp = fopen (dictfile, "rb");
|
memset (&extra_info_mask, 0, sizeof (extra_info_mask));
|
||||||
|
|
||||||
if (fp == NULL)
|
extra_info_mask.out_len = mask_ctx->css_cnt;
|
||||||
{
|
|
||||||
event_log_error (hashcat_ctx, "%s: %s", dictfile, strerror (errno));
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
extra_info_straight_t extra_info_straight;
|
|
||||||
|
|
||||||
memset (&extra_info_straight, 0, sizeof (extra_info_straight));
|
|
||||||
|
|
||||||
extra_info_straight.fp = fp;
|
|
||||||
|
|
||||||
hashcat_ctx_t *hashcat_ctx_tmp = (hashcat_ctx_t *) hcmalloc (sizeof (hashcat_ctx_t));
|
|
||||||
|
|
||||||
memcpy (hashcat_ctx_tmp, hashcat_ctx, sizeof (hashcat_ctx_t)); // yes we actually want to copy these pointers
|
|
||||||
|
|
||||||
hashcat_ctx_tmp->wl_data = (wl_data_t *) hcmalloc (sizeof (wl_data_t));
|
|
||||||
|
|
||||||
const int rc_wl_data_init = wl_data_init (hashcat_ctx_tmp);
|
|
||||||
|
|
||||||
if (rc_wl_data_init == -1)
|
|
||||||
{
|
|
||||||
fclose (fp);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp->wl_data);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp);
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
u64 words_cur = 0;
|
u64 words_cur = 0;
|
||||||
|
|
||||||
@ -939,11 +817,14 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
memset (device_param->pws_comp, 0, device_param->size_pws_comp);
|
memset (device_param->pws_comp, 0, device_param->size_pws_comp);
|
||||||
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
memset (device_param->pws_idx, 0, device_param->size_pws_idx);
|
||||||
memset (device_param->pws_base_buf, 0, device_param->size_pws_base);
|
|
||||||
|
|
||||||
u64 pre_rejects = -1u;
|
u64 pre_rejects = -1;
|
||||||
|
|
||||||
while (pre_rejects)
|
// this greatly reduces spam on hashcat console
|
||||||
|
|
||||||
|
const u64 pre_rejects_ignore = get_power (opencl_ctx, device_param) / 2;
|
||||||
|
|
||||||
|
while (pre_rejects > pre_rejects_ignore)
|
||||||
{
|
{
|
||||||
u64 words_extra_total = 0;
|
u64 words_extra_total = 0;
|
||||||
|
|
||||||
@ -957,7 +838,7 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
while (words_extra)
|
while (words_extra)
|
||||||
{
|
{
|
||||||
const u64 work = get_work (hashcat_ctx, device_param, words_extra);
|
u64 work = get_work (hashcat_ctx, device_param, words_extra);
|
||||||
|
|
||||||
if (work == 0) break;
|
if (work == 0) break;
|
||||||
|
|
||||||
@ -967,22 +848,15 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
words_fin = words_off + work;
|
words_fin = words_off + work;
|
||||||
|
|
||||||
slow_candidates_seek (hashcat_ctx_tmp, &extra_info_straight, words_cur, words_off);
|
|
||||||
|
|
||||||
words_cur = words_off;
|
words_cur = words_off;
|
||||||
|
|
||||||
for (u64 i = words_cur; i < words_fin; i++)
|
for (u64 i = words_cur; i < words_fin; i++)
|
||||||
{
|
{
|
||||||
slow_candidates_next (hashcat_ctx_tmp, &extra_info_straight);
|
extra_info_mask.pos = i;
|
||||||
|
|
||||||
if ((extra_info_straight.out_len < hashconfig->pw_min) || (extra_info_straight.out_len > hashconfig->pw_max))
|
slow_candidates_next (hashcat_ctx, &extra_info_mask);
|
||||||
{
|
|
||||||
words_extra++;
|
|
||||||
|
|
||||||
continue;
|
pw_pre_add (device_param, extra_info_mask.out_buf, extra_info_mask.out_len, NULL, 0, 0);
|
||||||
}
|
|
||||||
|
|
||||||
pw_pre_add (device_param, extra_info_straight.out_buf, extra_info_straight.out_len, extra_info_straight.base_buf, extra_info_straight.base_len, extra_info_straight.rule_pos_prev);
|
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
}
|
}
|
||||||
@ -994,22 +868,14 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
u64 pws_pre_cnt = device_param->pws_pre_cnt;
|
||||||
|
|
||||||
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
for (u64 pws_pre_idx = 0; pws_pre_idx < pws_pre_cnt; pws_pre_idx++)
|
||||||
{
|
{
|
||||||
pw_pre_t *pw_pre = device_param->pws_pre_buf + pws_pre_idx;
|
pw_pre_t *pw_pre = device_param->pws_pre_buf + pws_pre_idx;
|
||||||
|
|
||||||
pw_base_add (device_param, pw_pre);
|
|
||||||
|
|
||||||
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
pw_add (device_param, (const u8 *) pw_pre->pw_buf, (const int) pw_pre->pw_len);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
words_extra_total += pre_rejects;
|
words_extra_total += pre_rejects;
|
||||||
|
|
||||||
@ -1042,12 +908,6 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (CL_rc == -1)
|
if (CL_rc == -1)
|
||||||
{
|
{
|
||||||
fclose (fp);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp->wl_data);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp);
|
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1055,41 +915,25 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (CL_rc == -1)
|
if (CL_rc == -1)
|
||||||
{
|
{
|
||||||
fclose (fp);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp->wl_data);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp);
|
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
device_param->pws_cnt = 0;
|
device_param->pws_cnt = 0;
|
||||||
|
|
||||||
device_param->pws_base_cnt = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (device_param->speed_only_finish == true) break;
|
if (device_param->speed_only_finish == true) break;
|
||||||
|
|
||||||
if (status_ctx->run_thread_level2 == true)
|
if (status_ctx->run_thread_level2 == true)
|
||||||
{
|
{
|
||||||
device_param->words_done = words_fin;
|
device_param->words_done = MAX (device_param->words_done, words_fin);
|
||||||
|
|
||||||
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
status_ctx->words_cur = get_highest_words_done (hashcat_ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status_ctx->run_thread_level1 == false) break;
|
if (status_ctx->run_thread_level1 == false) break;
|
||||||
|
|
||||||
if (words_fin == 0) break;
|
if (words_fin == 0) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
fclose (fp);
|
|
||||||
|
|
||||||
wl_data_destroy (hashcat_ctx_tmp);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp->wl_data);
|
|
||||||
|
|
||||||
hcfree (hashcat_ctx_tmp);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1139,7 +983,7 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (status_ctx->run_thread_level2 == true)
|
if (status_ctx->run_thread_level2 == true)
|
||||||
{
|
{
|
||||||
device_param->words_done = words_fin;
|
device_param->words_done = MAX (device_param->words_done, words_fin);
|
||||||
|
|
||||||
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
||||||
}
|
}
|
||||||
@ -1406,7 +1250,7 @@ static int calc (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param)
|
|||||||
|
|
||||||
if (status_ctx->run_thread_level2 == true)
|
if (status_ctx->run_thread_level2 == true)
|
||||||
{
|
{
|
||||||
device_param->words_done = words_fin;
|
device_param->words_done = MAX (device_param->words_done, words_fin);
|
||||||
|
|
||||||
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
status_ctx->words_cur = get_lowest_words_done (hashcat_ctx);
|
||||||
}
|
}
|
||||||
|
@ -27,6 +27,14 @@
|
|||||||
#include "timer.h"
|
#include "timer.h"
|
||||||
#include "locking.h"
|
#include "locking.h"
|
||||||
|
|
||||||
|
int sort_by_string (const void *p1, const void *p2)
|
||||||
|
{
|
||||||
|
const char *s1 = (const char *) p1;
|
||||||
|
const char *s2 = (const char *) p2;
|
||||||
|
|
||||||
|
return strcmp (s1, s2);
|
||||||
|
}
|
||||||
|
|
||||||
int sort_by_digest_p0p1 (const void *v1, const void *v2, void *v3)
|
int sort_by_digest_p0p1 (const void *v1, const void *v2, void *v3)
|
||||||
{
|
{
|
||||||
const u32 *d1 = (const u32 *) v1;
|
const u32 *d1 = (const u32 *) v1;
|
||||||
|
@ -27,19 +27,17 @@ void slow_candidates_seek (hashcat_ctx_t *hashcat_ctx, void *extra_info, const u
|
|||||||
{
|
{
|
||||||
extra_info_straight_t *extra_info_straight = (extra_info_straight_t *) extra_info;
|
extra_info_straight_t *extra_info_straight = (extra_info_straight_t *) extra_info;
|
||||||
|
|
||||||
FILE *fp = extra_info_straight->fp;
|
for (u64 i = cur; i < end; i++)
|
||||||
|
|
||||||
const u64 overlap = end % straight_ctx->kernel_rules_cnt;
|
|
||||||
|
|
||||||
const u64 init = end - overlap;
|
|
||||||
|
|
||||||
for (u64 i = cur; i < init; i += straight_ctx->kernel_rules_cnt)
|
|
||||||
{
|
{
|
||||||
char *line_buf;
|
if ((i % straight_ctx->kernel_rules_cnt) == 0)
|
||||||
u32 line_len;
|
{
|
||||||
|
char *line_buf = NULL;
|
||||||
|
u32 line_len = 0;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
|
FILE *fp = extra_info_straight->fp;
|
||||||
|
|
||||||
get_next_word (hashcat_ctx, fp, &line_buf, &line_len);
|
get_next_word (hashcat_ctx, fp, &line_buf, &line_len);
|
||||||
|
|
||||||
// post-process rule engine
|
// post-process rule engine
|
||||||
@ -67,9 +65,11 @@ void slow_candidates_seek (hashcat_ctx_t *hashcat_ctx, void *extra_info, const u
|
|||||||
|
|
||||||
extra_info_straight->base_len = line_len;
|
extra_info_straight->base_len = line_len;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
extra_info_straight->rule_pos_prev = overlap;
|
extra_info_straight->rule_pos_prev = end % straight_ctx->kernel_rules_cnt;
|
||||||
extra_info_straight->rule_pos = overlap;
|
|
||||||
|
extra_info_straight->rule_pos = extra_info_straight->rule_pos_prev;
|
||||||
}
|
}
|
||||||
else if (attack_mode == ATTACK_MODE_COMBI)
|
else if (attack_mode == ATTACK_MODE_COMBI)
|
||||||
{
|
{
|
||||||
@ -78,12 +78,9 @@ void slow_candidates_seek (hashcat_ctx_t *hashcat_ctx, void *extra_info, const u
|
|||||||
FILE *base_fp = extra_info_combi->base_fp;
|
FILE *base_fp = extra_info_combi->base_fp;
|
||||||
FILE *combs_fp = extra_info_combi->combs_fp;
|
FILE *combs_fp = extra_info_combi->combs_fp;
|
||||||
|
|
||||||
u64 overlap_cur = cur % combinator_ctx->combs_cnt;
|
for (u64 i = cur; i < end; i++)
|
||||||
const u64 overlap = end % combinator_ctx->combs_cnt;
|
{
|
||||||
|
if ((i % combinator_ctx->combs_cnt) == 0)
|
||||||
const u64 init = end - overlap;
|
|
||||||
|
|
||||||
for (u64 i = cur; i < init; i += combinator_ctx->combs_cnt)
|
|
||||||
{
|
{
|
||||||
char *line_buf = NULL;
|
char *line_buf = NULL;
|
||||||
u32 line_len = 0;
|
u32 line_len = 0;
|
||||||
@ -94,17 +91,20 @@ void slow_candidates_seek (hashcat_ctx_t *hashcat_ctx, void *extra_info, const u
|
|||||||
|
|
||||||
// post-process rule engine
|
// post-process rule engine
|
||||||
|
|
||||||
|
char rule_buf_out[RP_PASSWORD_SIZE];
|
||||||
|
|
||||||
if (run_rule_engine ((int) user_options_extra->rule_len_l, user_options->rule_buf_l))
|
if (run_rule_engine ((int) user_options_extra->rule_len_l, user_options->rule_buf_l))
|
||||||
{
|
{
|
||||||
if (line_len >= RP_PASSWORD_SIZE) continue;
|
if (line_len >= RP_PASSWORD_SIZE) continue;
|
||||||
|
|
||||||
char rule_buf_out[RP_PASSWORD_SIZE];
|
|
||||||
|
|
||||||
memset (rule_buf_out, 0, sizeof (rule_buf_out));
|
memset (rule_buf_out, 0, sizeof (rule_buf_out));
|
||||||
|
|
||||||
const int rule_len_out = _old_apply_rule (user_options->rule_buf_l, (int) user_options_extra->rule_len_l, line_buf, (int) line_len, rule_buf_out);
|
const int rule_len_out = _old_apply_rule (user_options->rule_buf_l, (int) user_options_extra->rule_len_l, line_buf, (int) line_len, rule_buf_out);
|
||||||
|
|
||||||
if (rule_len_out < 0) continue;
|
if (rule_len_out < 0) continue;
|
||||||
|
|
||||||
|
line_buf = rule_buf_out;
|
||||||
|
line_len = (u32) rule_len_out;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@ -115,12 +115,8 @@ void slow_candidates_seek (hashcat_ctx_t *hashcat_ctx, void *extra_info, const u
|
|||||||
extra_info_combi->base_len = line_len;
|
extra_info_combi->base_len = line_len;
|
||||||
|
|
||||||
rewind (combs_fp);
|
rewind (combs_fp);
|
||||||
|
|
||||||
overlap_cur = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (u64 i = overlap_cur; i < overlap; i++)
|
|
||||||
{
|
|
||||||
char *line_buf = extra_info_combi->scratch_buf;
|
char *line_buf = extra_info_combi->scratch_buf;
|
||||||
u32 line_len = 0;
|
u32 line_len = 0;
|
||||||
|
|
||||||
@ -147,8 +143,9 @@ void slow_candidates_seek (hashcat_ctx_t *hashcat_ctx, void *extra_info, const u
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extra_info_combi->comb_pos_prev = overlap;
|
extra_info_combi->comb_pos_prev = end % combinator_ctx->combs_cnt;
|
||||||
extra_info_combi->comb_pos = overlap;
|
|
||||||
|
extra_info_combi->comb_pos = extra_info_combi->comb_pos_prev;
|
||||||
}
|
}
|
||||||
else if (attack_mode == ATTACK_MODE_BF)
|
else if (attack_mode == ATTACK_MODE_BF)
|
||||||
{
|
{
|
||||||
@ -171,15 +168,15 @@ void slow_candidates_next (hashcat_ctx_t *hashcat_ctx, void *extra_info)
|
|||||||
{
|
{
|
||||||
extra_info_straight_t *extra_info_straight = (extra_info_straight_t *) extra_info;
|
extra_info_straight_t *extra_info_straight = (extra_info_straight_t *) extra_info;
|
||||||
|
|
||||||
FILE *fp = extra_info_straight->fp;
|
if ((extra_info_straight->pos % straight_ctx->kernel_rules_cnt) == 0)
|
||||||
|
|
||||||
if (extra_info_straight->rule_pos == 0)
|
|
||||||
{
|
{
|
||||||
char *line_buf;
|
char *line_buf = NULL;
|
||||||
u32 line_len;
|
u32 line_len = 0;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
|
FILE *fp = extra_info_straight->fp;
|
||||||
|
|
||||||
get_next_word (hashcat_ctx, fp, &line_buf, &line_len);
|
get_next_word (hashcat_ctx, fp, &line_buf, &line_len);
|
||||||
|
|
||||||
line_len = (u32) convert_from_hex (hashcat_ctx, line_buf, line_len);
|
line_len = (u32) convert_from_hex (hashcat_ctx, line_buf, line_len);
|
||||||
@ -243,10 +240,10 @@ void slow_candidates_next (hashcat_ctx_t *hashcat_ctx, void *extra_info)
|
|||||||
FILE *base_fp = extra_info_combi->base_fp;
|
FILE *base_fp = extra_info_combi->base_fp;
|
||||||
FILE *combs_fp = extra_info_combi->combs_fp;
|
FILE *combs_fp = extra_info_combi->combs_fp;
|
||||||
|
|
||||||
if (extra_info_combi->comb_pos == 0)
|
if ((extra_info_combi->pos % combinator_ctx->combs_cnt) == 0)
|
||||||
{
|
{
|
||||||
char *line_buf;
|
char *line_buf = NULL;
|
||||||
u32 line_len;
|
u32 line_len = 0;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
@ -284,7 +281,6 @@ void slow_candidates_next (hashcat_ctx_t *hashcat_ctx, void *extra_info)
|
|||||||
extra_info_combi->out_len = extra_info_combi->base_len;
|
extra_info_combi->out_len = extra_info_combi->base_len;
|
||||||
|
|
||||||
char *line_buf = extra_info_combi->scratch_buf;
|
char *line_buf = extra_info_combi->scratch_buf;
|
||||||
|
|
||||||
u32 line_len = 0;
|
u32 line_len = 0;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
|
@ -334,8 +334,10 @@ int user_options_getopt (hashcat_ctx_t *hashcat_ctx, int argc, char **argv)
|
|||||||
case IDX_EXAMPLE_HASHES: user_options->example_hashes = true; break;
|
case IDX_EXAMPLE_HASHES: user_options->example_hashes = true; break;
|
||||||
case IDX_FORCE: user_options->force = true; break;
|
case IDX_FORCE: user_options->force = true; break;
|
||||||
case IDX_SELF_TEST_DISABLE: user_options->self_test_disable = true; break;
|
case IDX_SELF_TEST_DISABLE: user_options->self_test_disable = true; break;
|
||||||
case IDX_SKIP: user_options->skip = hc_strtoull (optarg, NULL, 10); break;
|
case IDX_SKIP: user_options->skip = hc_strtoull (optarg, NULL, 10);
|
||||||
case IDX_LIMIT: user_options->limit = hc_strtoull (optarg, NULL, 10); break;
|
user_options->skip_chgd = true; break;
|
||||||
|
case IDX_LIMIT: user_options->limit = hc_strtoull (optarg, NULL, 10);
|
||||||
|
user_options->limit_chgd = true; break;
|
||||||
case IDX_KEEP_GUESSING: user_options->keep_guessing = true; break;
|
case IDX_KEEP_GUESSING: user_options->keep_guessing = true; break;
|
||||||
case IDX_KEYSPACE: user_options->keyspace = true; break;
|
case IDX_KEYSPACE: user_options->keyspace = true; break;
|
||||||
case IDX_BENCHMARK: user_options->benchmark = true; break;
|
case IDX_BENCHMARK: user_options->benchmark = true; break;
|
||||||
@ -491,6 +493,22 @@ int user_options_sanity (hashcat_ctx_t *hashcat_ctx)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
if (user_options->skip_chgd == true && user_options->skip == 0)
|
||||||
|
{
|
||||||
|
event_log_error (hashcat_ctx, "Invalid --skip value specified.");
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (user_options->limit_chgd == true && user_options->limit == 0)
|
||||||
|
{
|
||||||
|
event_log_error (hashcat_ctx, "Invalid --limit value specified.");
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
if (user_options->runtime_chgd == true && user_options->runtime == 0)
|
if (user_options->runtime_chgd == true && user_options->runtime == 0)
|
||||||
{
|
{
|
||||||
event_log_error (hashcat_ctx, "Invalid --runtime value specified.");
|
event_log_error (hashcat_ctx, "Invalid --runtime value specified.");
|
||||||
@ -1130,6 +1148,18 @@ int user_options_sanity (hashcat_ctx_t *hashcat_ctx)
|
|||||||
{
|
{
|
||||||
show_error = false;
|
show_error = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (user_options->hc_argc == 1)
|
||||||
|
{
|
||||||
|
// stdin mode
|
||||||
|
|
||||||
|
if (user_options->slow_candidates == true)
|
||||||
|
{
|
||||||
|
event_log_error (hashcat_ctx, "Use of --slow-candidates is not possible in stdin mode.");
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (user_options->attack_mode == ATTACK_MODE_COMBI)
|
else if (user_options->attack_mode == ATTACK_MODE_COMBI)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user