1
0
mirror of https://github.com/hashcat/hashcat.git synced 2024-11-15 20:39:17 +00:00
hashcat/src/hashcat.c

1559 lines
40 KiB
C
Raw Normal View History

/**
* Author......: See docs/credits.txt
2015-12-04 14:47:52 +00:00
* License.....: MIT
*/
#if defined (__APPLE__)
#include <stdio.h>
#endif // __APPLE__
#include "common.h"
2016-09-28 21:33:44 +00:00
// basic tools
2016-09-06 20:25:54 +00:00
#include "types.h"
2016-09-28 22:23:24 +00:00
#include "folder.h"
#include "locking.h"
2016-09-28 21:33:44 +00:00
#include "logging.h"
2016-09-28 22:23:24 +00:00
#include "memory.h"
#include "shared.h"
#include "thread.h"
#include "timer.h"
2016-09-28 21:33:44 +00:00
// features
#include "affinity.h"
#include "autotune.h"
#include "bitmap.h"
2016-09-28 21:33:44 +00:00
#include "combinator.h"
2016-09-29 13:19:12 +00:00
#include "cpt.h"
#include "debugfile.h"
#include "dictstat.h"
#include "dispatch.h"
2016-09-30 07:25:51 +00:00
#include "hashes.h"
#include "hwmon.h"
#include "induct.h"
#include "interface.h"
#include "logfile.h"
#include "loopback.h"
#include "monitor.h"
#include "mpsp.h"
#include "opencl.h"
#include "outfile_check.h"
#include "outfile.h"
#include "potfile.h"
#include "restore.h"
#include "rp.h"
#include "status.h"
2016-09-28 21:33:44 +00:00
#include "straight.h"
#include "terminal.h"
#include "tuningdb.h"
#include "usage.h"
#include "user_options.h"
#include "weak_hash.h"
#include "wordlist.h"
2016-09-30 15:41:40 +00:00
extern const u32 DEFAULT_BENCHMARK_ALGORITHMS_CNT;
extern const u32 DEFAULT_BENCHMARK_ALGORITHMS_BUF[];
2016-10-02 23:27:55 +00:00
void hashcat_ctx_init (hashcat_ctx_t *hashcat_ctx)
{
hashcat_ctx->bitmap_ctx = (bitmap_ctx_t *) mymalloc (sizeof (bitmap_ctx_t));
hashcat_ctx->combinator_ctx = (combinator_ctx_t *) mymalloc (sizeof (combinator_ctx_t));
hashcat_ctx->cpt_ctx = (cpt_ctx_t *) mymalloc (sizeof (cpt_ctx_t));
hashcat_ctx->debugfile_ctx = (debugfile_ctx_t *) mymalloc (sizeof (debugfile_ctx_t));
hashcat_ctx->dictstat_ctx = (dictstat_ctx_t *) mymalloc (sizeof (dictstat_ctx_t));
hashcat_ctx->folder_config = (folder_config_t *) mymalloc (sizeof (folder_config_t));
hashcat_ctx->hashconfig = (hashconfig_t *) mymalloc (sizeof (hashconfig_t));
hashcat_ctx->hashes = (hashes_t *) mymalloc (sizeof (hashes_t));
hashcat_ctx->hwmon_ctx = (hwmon_ctx_t *) mymalloc (sizeof (hwmon_ctx_t));
hashcat_ctx->induct_ctx = (induct_ctx_t *) mymalloc (sizeof (induct_ctx_t));
hashcat_ctx->logfile_ctx = (logfile_ctx_t *) mymalloc (sizeof (logfile_ctx_t));
hashcat_ctx->loopback_ctx = (loopback_ctx_t *) mymalloc (sizeof (loopback_ctx_t));
hashcat_ctx->mask_ctx = (mask_ctx_t *) mymalloc (sizeof (mask_ctx_t));
hashcat_ctx->opencl_ctx = (opencl_ctx_t *) mymalloc (sizeof (opencl_ctx_t));
hashcat_ctx->outcheck_ctx = (outcheck_ctx_t *) mymalloc (sizeof (outcheck_ctx_t));
hashcat_ctx->outfile_ctx = (outfile_ctx_t *) mymalloc (sizeof (outfile_ctx_t));
hashcat_ctx->potfile_ctx = (potfile_ctx_t *) mymalloc (sizeof (potfile_ctx_t));
hashcat_ctx->restore_ctx = (restore_ctx_t *) mymalloc (sizeof (restore_ctx_t));
hashcat_ctx->status_ctx = (status_ctx_t *) mymalloc (sizeof (status_ctx_t));
hashcat_ctx->straight_ctx = (straight_ctx_t *) mymalloc (sizeof (straight_ctx_t));
hashcat_ctx->tuning_db = (tuning_db_t *) mymalloc (sizeof (tuning_db_t));
hashcat_ctx->user_options_extra = (user_options_extra_t *) mymalloc (sizeof (user_options_extra_t));
hashcat_ctx->user_options = (user_options_t *) mymalloc (sizeof (user_options_t));
hashcat_ctx->wl_data = (wl_data_t *) mymalloc (sizeof (wl_data_t));
}
2016-10-02 23:27:55 +00:00
void hashcat_ctx_destroy (hashcat_ctx_t *hashcat_ctx)
{
myfree (hashcat_ctx->bitmap_ctx);
myfree (hashcat_ctx->combinator_ctx);
myfree (hashcat_ctx->cpt_ctx);
myfree (hashcat_ctx->debugfile_ctx);
myfree (hashcat_ctx->dictstat_ctx);
myfree (hashcat_ctx->folder_config);
myfree (hashcat_ctx->hashconfig);
myfree (hashcat_ctx->hashes);
myfree (hashcat_ctx->hwmon_ctx);
myfree (hashcat_ctx->induct_ctx);
myfree (hashcat_ctx->logfile_ctx);
myfree (hashcat_ctx->loopback_ctx);
myfree (hashcat_ctx->mask_ctx);
myfree (hashcat_ctx->opencl_ctx);
myfree (hashcat_ctx->outcheck_ctx);
myfree (hashcat_ctx->outfile_ctx);
myfree (hashcat_ctx->potfile_ctx);
myfree (hashcat_ctx->restore_ctx);
myfree (hashcat_ctx->status_ctx);
myfree (hashcat_ctx->straight_ctx);
myfree (hashcat_ctx->tuning_db);
myfree (hashcat_ctx->user_options_extra);
myfree (hashcat_ctx->user_options);
myfree (hashcat_ctx->wl_data);
}
2016-09-29 12:46:51 +00:00
// inner2_loop iterates through wordlists, then calls kernel execution
static int inner2_loop (hashcat_ctx_t *hashcat_ctx)
2016-09-23 20:51:42 +00:00
{
combinator_ctx_t *combinator_ctx = hashcat_ctx->combinator_ctx;
dictstat_ctx_t *dictstat_ctx = hashcat_ctx->dictstat_ctx;
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
hashes_t *hashes = hashcat_ctx->hashes;
induct_ctx_t *induct_ctx = hashcat_ctx->induct_ctx;
logfile_ctx_t *logfile_ctx = hashcat_ctx->logfile_ctx;
loopback_ctx_t *loopback_ctx = hashcat_ctx->loopback_ctx;
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
restore_ctx_t *restore_ctx = hashcat_ctx->restore_ctx;
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
straight_ctx_t *straight_ctx = hashcat_ctx->straight_ctx;
user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
user_options_t *user_options = hashcat_ctx->user_options;
wl_data_t *wl_data = hashcat_ctx->wl_data;
2016-09-29 21:25:29 +00:00
//status_ctx->run_main_level1 = true;
//status_ctx->run_main_level2 = true;
//status_ctx->run_main_level3 = true;
status_ctx->run_thread_level1 = true;
status_ctx->run_thread_level2 = true;
2016-09-23 20:51:42 +00:00
status_ctx->devices_status = STATUS_INIT;
2016-09-29 12:46:51 +00:00
logfile_generate_subid (logfile_ctx);
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
logfile_sub_msg ("START");
2015-12-04 14:47:52 +00:00
2016-10-06 07:47:34 +00:00
status_progress_reset (hashcat_ctx);
2016-09-24 10:05:56 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->words_cur = 0;
2016-09-27 16:32:09 +00:00
2016-09-29 12:46:51 +00:00
restore_data_t *rd = restore_ctx->rd;
2016-09-16 15:31:31 +00:00
2016-09-29 12:46:51 +00:00
if (rd->words_cur)
{
2016-09-29 21:49:33 +00:00
status_ctx->words_cur = rd->words_cur;
2016-09-16 15:31:31 +00:00
2016-09-29 12:46:51 +00:00
user_options->skip = 0;
}
2016-09-16 15:31:31 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->skip)
{
2016-09-29 21:49:33 +00:00
status_ctx->words_cur = user_options->skip;
2016-09-16 15:31:31 +00:00
2016-09-29 12:46:51 +00:00
user_options->skip = 0;
}
2016-09-16 15:31:31 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->ms_paused = 0;
2016-09-16 15:31:31 +00:00
2016-09-29 12:46:51 +00:00
opencl_session_reset (opencl_ctx);
2016-09-27 16:32:09 +00:00
2016-10-06 08:26:47 +00:00
cpt_ctx_reset (hashcat_ctx);
2016-09-29 13:19:12 +00:00
2016-09-29 12:46:51 +00:00
// figure out wordlist based workload
2016-09-27 16:32:09 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->attack_mode == ATTACK_MODE_STRAIGHT)
2016-09-27 16:32:09 +00:00
{
2016-09-29 12:46:51 +00:00
if (user_options_extra->wordlist_mode == WL_MODE_FILE)
{
2016-09-29 12:46:51 +00:00
if (induct_ctx->induction_dictionaries_cnt)
{
2016-09-29 12:46:51 +00:00
straight_ctx->dict = induct_ctx->induction_dictionaries[induct_ctx->induction_dictionaries_pos];
}
else
{
straight_ctx->dict = straight_ctx->dicts[straight_ctx->dicts_pos];
}
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
logfile_sub_string (straight_ctx->dict);
2016-09-23 20:51:42 +00:00
for (u32 i = 0; i < user_options->rp_files_cnt; i++)
{
2016-09-29 12:46:51 +00:00
logfile_sub_var_string ("rulefile", user_options->rp_files[i]);
}
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
FILE *fd2 = fopen (straight_ctx->dict, "rb");
if (fd2 == NULL)
{
2016-09-29 12:46:51 +00:00
log_error ("ERROR: %s: %s", straight_ctx->dict, strerror (errno));
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
return -1;
}
2016-09-23 20:51:42 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->words_cnt = count_words (wl_data, user_options, user_options_extra, straight_ctx, combinator_ctx, fd2, straight_ctx->dict, dictstat_ctx);
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
fclose (fd2);
2016-09-29 21:49:33 +00:00
if (status_ctx->words_cnt == 0)
2016-09-29 12:46:51 +00:00
{
logfile_sub_msg ("STOP");
2016-09-24 12:00:59 +00:00
return 0;
}
2016-09-29 12:46:51 +00:00
}
}
else if (user_options->attack_mode == ATTACK_MODE_COMBI)
{
logfile_sub_string (combinator_ctx->dict1);
logfile_sub_string (combinator_ctx->dict2);
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
if (combinator_ctx->combs_mode == COMBINATOR_MODE_BASE_LEFT)
{
FILE *fd2 = fopen (combinator_ctx->dict1, "rb");
2016-09-29 12:46:51 +00:00
if (fd2 == NULL)
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
log_error ("ERROR: %s: %s", combinator_ctx->dict1, strerror (errno));
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
return -1;
}
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->words_cnt = count_words (wl_data, user_options, user_options_extra, straight_ctx, combinator_ctx, fd2, combinator_ctx->dict1, dictstat_ctx);
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
fclose (fd2);
}
else if (combinator_ctx->combs_mode == COMBINATOR_MODE_BASE_RIGHT)
{
FILE *fd2 = fopen (combinator_ctx->dict2, "rb");
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
if (fd2 == NULL)
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
log_error ("ERROR: %s: %s", combinator_ctx->dict2, strerror (errno));
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
return -1;
}
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->words_cnt = count_words (wl_data, user_options, user_options_extra, straight_ctx, combinator_ctx, fd2, combinator_ctx->dict2, dictstat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
fclose (fd2);
}
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
if (status_ctx->words_cnt == 0)
2016-09-29 12:46:51 +00:00
{
logfile_sub_msg ("STOP");
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
return 0;
}
}
else if (user_options->attack_mode == ATTACK_MODE_BF)
{
logfile_sub_string (mask_ctx->mask);
}
2016-09-29 12:46:51 +00:00
else if ((user_options->attack_mode == ATTACK_MODE_HYBRID1) || (user_options->attack_mode == ATTACK_MODE_HYBRID2))
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
if (induct_ctx->induction_dictionaries_cnt)
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
straight_ctx->dict = induct_ctx->induction_dictionaries[induct_ctx->induction_dictionaries_pos];
}
else
{
straight_ctx->dict = straight_ctx->dicts[straight_ctx->dicts_pos];
}
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
logfile_sub_string (straight_ctx->dict);
logfile_sub_string (mask_ctx->mask);
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
FILE *fd2 = fopen (straight_ctx->dict, "rb");
2016-09-29 12:46:51 +00:00
if (fd2 == NULL)
{
log_error ("ERROR: %s: %s", straight_ctx->dict, strerror (errno));
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
return -1;
}
2016-09-29 21:49:33 +00:00
status_ctx->words_cnt = count_words (wl_data, user_options, user_options_extra, straight_ctx, combinator_ctx, fd2, straight_ctx->dict, dictstat_ctx);
2016-09-29 12:46:51 +00:00
fclose (fd2);
2016-09-29 21:49:33 +00:00
if (status_ctx->words_cnt == 0)
2016-09-29 12:46:51 +00:00
{
logfile_sub_msg ("STOP");
2016-09-29 12:46:51 +00:00
return 0;
}
}
2016-09-29 21:49:33 +00:00
u64 words_base = status_ctx->words_cnt;
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
if (user_options_extra->attack_kern == ATTACK_KERN_STRAIGHT)
{
if (straight_ctx->kernel_rules_cnt)
{
words_base /= straight_ctx->kernel_rules_cnt;
}
2016-09-29 12:46:51 +00:00
}
else if (user_options_extra->attack_kern == ATTACK_KERN_COMBI)
{
if (combinator_ctx->combs_cnt)
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
words_base /= combinator_ctx->combs_cnt;
2016-09-23 20:51:42 +00:00
}
}
2016-09-29 12:46:51 +00:00
else if (user_options_extra->attack_kern == ATTACK_KERN_BF)
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
if (mask_ctx->bfs_cnt)
{
2016-09-29 12:46:51 +00:00
words_base /= mask_ctx->bfs_cnt;
2016-09-23 20:51:42 +00:00
}
2016-09-29 12:46:51 +00:00
}
2016-05-30 08:29:18 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->words_base = words_base;
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->keyspace == true)
{
log_info ("%" PRIu64 "", words_base);
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
return 0;
}
2016-09-23 20:51:42 +00:00
2016-09-29 21:49:33 +00:00
if (status_ctx->words_cur > status_ctx->words_base)
2016-09-29 12:46:51 +00:00
{
log_error ("ERROR: Restore value greater keyspace");
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
return -1;
}
2016-09-23 20:51:42 +00:00
2016-09-29 21:49:33 +00:00
if (status_ctx->words_cur)
2016-09-29 12:46:51 +00:00
{
if (user_options_extra->attack_kern == ATTACK_KERN_STRAIGHT)
{
for (u32 i = 0; i < hashes->salts_cnt; i++)
2016-09-29 12:46:51 +00:00
{
2016-09-29 21:49:33 +00:00
status_ctx->words_progress_restored[i] = status_ctx->words_cur * straight_ctx->kernel_rules_cnt;
2016-09-29 12:46:51 +00:00
}
2016-05-30 08:29:18 +00:00
}
2016-09-29 12:46:51 +00:00
else if (user_options_extra->attack_kern == ATTACK_KERN_COMBI)
2016-09-23 20:51:42 +00:00
{
for (u32 i = 0; i < hashes->salts_cnt; i++)
2016-09-29 12:46:51 +00:00
{
2016-09-29 21:49:33 +00:00
status_ctx->words_progress_restored[i] = status_ctx->words_cur * combinator_ctx->combs_cnt;
2016-09-29 12:46:51 +00:00
}
2016-09-23 20:51:42 +00:00
}
2016-09-29 12:46:51 +00:00
else if (user_options_extra->attack_kern == ATTACK_KERN_BF)
{
for (u32 i = 0; i < hashes->salts_cnt; i++)
2016-09-29 12:46:51 +00:00
{
2016-09-29 21:49:33 +00:00
status_ctx->words_progress_restored[i] = status_ctx->words_cur * mask_ctx->bfs_cnt;
2016-09-29 12:46:51 +00:00
}
2016-09-23 20:51:42 +00:00
}
2016-09-29 12:46:51 +00:00
}
2016-09-29 12:46:51 +00:00
/**
* limit kernel loops by the amplification count we have from:
* - straight_ctx, combinator_ctx or mask_ctx for fast hashes
* - hash iteration count for slow hashes
*/
2016-09-29 12:46:51 +00:00
opencl_ctx_devices_kernel_loops (opencl_ctx, user_options_extra, hashconfig, hashes, straight_ctx, combinator_ctx, mask_ctx);
2016-09-29 12:46:51 +00:00
/**
* create autotune threads
*/
thread_param_t *threads_param = (thread_param_t *) mycalloc (opencl_ctx->devices_cnt, sizeof (thread_param_t));
2016-09-29 12:46:51 +00:00
hc_thread_t *c_threads = (hc_thread_t *) mycalloc (opencl_ctx->devices_cnt, sizeof (hc_thread_t));
2016-09-29 21:25:29 +00:00
status_ctx->devices_status = STATUS_AUTOTUNE;
for (u32 device_id = 0; device_id < opencl_ctx->devices_cnt; device_id++)
2016-09-29 12:46:51 +00:00
{
thread_param_t *thread_param = threads_param + device_id;
thread_param->hashcat_ctx = hashcat_ctx;
thread_param->tid = device_id;
hc_thread_create (c_threads[device_id], thread_autotune, thread_param);
2016-09-29 12:46:51 +00:00
}
2016-09-23 20:51:42 +00:00
2016-09-29 12:46:51 +00:00
hc_thread_wait (opencl_ctx->devices_cnt, c_threads);
2016-09-29 12:46:51 +00:00
/**
* autotune modified kernel_accel, which modifies opencl_ctx->kernel_power_all
*/
2016-09-29 21:49:33 +00:00
opencl_ctx_devices_update_power (opencl_ctx, user_options, user_options_extra, status_ctx);
2016-09-29 12:46:51 +00:00
/**
* Begin loopback recording
*/
2016-01-15 16:23:07 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->loopback == true)
{
2016-09-30 10:07:49 +00:00
loopback_write_open (loopback_ctx, induct_ctx);
2016-09-29 12:46:51 +00:00
}
2016-09-29 12:46:51 +00:00
/**
* Tell user we're about to start
*/
2016-09-29 12:46:51 +00:00
if ((user_options_extra->wordlist_mode == WL_MODE_FILE) || (user_options_extra->wordlist_mode == WL_MODE_MASK))
{
if ((user_options->quiet == false) && (user_options->status == false) && (user_options->benchmark == false))
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
if (user_options->quiet == false) send_prompt ();
2016-09-23 20:51:42 +00:00
}
2016-09-29 12:46:51 +00:00
}
else if (user_options_extra->wordlist_mode == WL_MODE_STDIN)
{
if (user_options->quiet == false) log_info ("Starting attack in stdin mode...");
if (user_options->quiet == false) log_info ("");
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
/**
* Prepare cracking stats
*/
2016-01-15 16:23:07 +00:00
2016-09-29 21:49:33 +00:00
hc_timer_set (&status_ctx->timer_running);
2016-01-15 16:23:07 +00:00
2016-09-29 12:46:51 +00:00
time_t runtime_start;
2016-09-29 12:46:51 +00:00
time (&runtime_start);
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->runtime_start = runtime_start;
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->prepare_time = runtime_start - status_ctx->prepare_start;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
/**
* create cracker threads
*/
2016-09-27 16:32:09 +00:00
2016-09-29 21:25:29 +00:00
status_ctx->devices_status = STATUS_RUNNING;
2016-09-27 16:32:09 +00:00
for (u32 device_id = 0; device_id < opencl_ctx->devices_cnt; device_id++)
2016-09-23 20:51:42 +00:00
{
thread_param_t *thread_param = threads_param + device_id;
thread_param->hashcat_ctx = hashcat_ctx;
thread_param->tid = device_id;
2016-09-29 12:46:51 +00:00
if (user_options_extra->wordlist_mode == WL_MODE_STDIN)
2016-09-23 20:51:42 +00:00
{
hc_thread_create (c_threads[device_id], thread_calc_stdin, thread_param);
2015-12-04 14:47:52 +00:00
}
2016-09-29 12:46:51 +00:00
else
2016-09-23 20:51:42 +00:00
{
hc_thread_create (c_threads[device_id], thread_calc, thread_param);
2016-09-23 20:51:42 +00:00
}
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
hc_thread_wait (opencl_ctx->devices_cnt, c_threads);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
myfree (c_threads);
2015-12-04 14:47:52 +00:00
myfree (threads_param);
2016-09-29 12:46:51 +00:00
// calculate final status
2015-12-04 14:47:52 +00:00
2016-09-29 21:25:29 +00:00
if ((status_ctx->devices_status != STATUS_CRACKED)
&& (status_ctx->devices_status != STATUS_ABORTED)
&& (status_ctx->devices_status != STATUS_QUIT)
&& (status_ctx->devices_status != STATUS_BYPASS))
2016-09-29 12:46:51 +00:00
{
2016-09-29 21:25:29 +00:00
status_ctx->devices_status = STATUS_EXHAUSTED;
2016-09-29 12:46:51 +00:00
}
2015-12-04 14:47:52 +00:00
2016-09-29 21:25:29 +00:00
logfile_sub_var_uint ("status-after-work", status_ctx->devices_status);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// update some timer
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
time_t runtime_stop;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
time (&runtime_stop);
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
status_ctx->runtime_stop = runtime_stop;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
logfile_sub_uint (runtime_start);
logfile_sub_uint (runtime_stop);
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
time (&status_ctx->prepare_start);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
logfile_sub_msg ("STOP");
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// no more skip and restore from here
2015-12-04 14:47:52 +00:00
2016-09-29 21:25:29 +00:00
if (status_ctx->devices_status == STATUS_EXHAUSTED)
2016-09-29 12:46:51 +00:00
{
rd->words_cur = 0;
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// stop loopback recording
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->loopback == true)
{
loopback_write_close (loopback_ctx);
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// print final status
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->benchmark == true)
{
status_benchmark (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->machine_readable == false)
{
log_info ("");
}
}
else
{
if (user_options->quiet == false)
{
clear_prompt ();
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (hashes->digests_saved != hashes->digests_done) log_info ("");
2015-12-04 14:47:52 +00:00
status_display (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
log_info ("");
2015-12-04 14:47:52 +00:00
}
2016-09-29 12:46:51 +00:00
else
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
if (user_options->status == true)
{
status_display (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
log_info ("");
}
2016-09-23 20:51:42 +00:00
}
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// New induction folder check
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (induct_ctx->induction_dictionaries_cnt == 0)
{
induct_ctx_scan (induct_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
while (induct_ctx->induction_dictionaries_cnt)
2015-12-04 14:47:52 +00:00
{
2016-09-29 12:46:51 +00:00
for (induct_ctx->induction_dictionaries_pos = 0; induct_ctx->induction_dictionaries_pos < induct_ctx->induction_dictionaries_cnt; induct_ctx->induction_dictionaries_pos++)
{
const int rc_inner2_loop = inner2_loop (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (rc_inner2_loop == -1) return -1;
2015-12-04 14:47:52 +00:00
2016-09-29 21:25:29 +00:00
if (status_ctx->run_main_level3 == false) break;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
unlink (induct_ctx->induction_dictionaries[induct_ctx->induction_dictionaries_pos]);
2016-09-23 20:51:42 +00:00
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
myfree (induct_ctx->induction_dictionaries);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
induct_ctx_scan (induct_ctx);
}
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
return 0;
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// inner1_loop iterates through masks, then calls inner2_loop
2015-12-04 14:47:52 +00:00
static int inner1_loop (hashcat_ctx_t *hashcat_ctx)
2016-09-29 12:46:51 +00:00
{
combinator_ctx_t *combinator_ctx = hashcat_ctx->combinator_ctx;
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
hashes_t *hashes = hashcat_ctx->hashes;
logfile_ctx_t *logfile_ctx = hashcat_ctx->logfile_ctx;
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
restore_ctx_t *restore_ctx = hashcat_ctx->restore_ctx;
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
straight_ctx_t *straight_ctx = hashcat_ctx->straight_ctx;
user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
user_options_t *user_options = hashcat_ctx->user_options;
2016-09-29 21:25:29 +00:00
//status_ctx->run_main_level1 = true;
//status_ctx->run_main_level2 = true;
status_ctx->run_main_level3 = true;
status_ctx->run_thread_level1 = true;
status_ctx->run_thread_level2 = true;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
/**
* Update pw_min and pw_max according to next mask
2016-09-29 12:46:51 +00:00
*/
2015-12-04 14:47:52 +00:00
u32 pw_min = hashconfig->pw_min;
u32 pw_max = hashconfig->pw_max;
2015-12-04 14:47:52 +00:00
if (user_options->benchmark == true)
2016-09-29 12:46:51 +00:00
{
pw_min = mp_get_length (mask_ctx->mask);
pw_max = pw_min;
2016-09-29 12:46:51 +00:00
}
2015-12-04 14:47:52 +00:00
hashconfig->pw_min = pw_min;
hashconfig->pw_max = pw_max;
2016-09-29 12:46:51 +00:00
/**
* Update mask in attack-mode specific stuff
2016-09-29 12:46:51 +00:00
*/
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (user_options_extra->attack_kern == ATTACK_KERN_COMBI)
{
if (user_options->attack_mode == ATTACK_MODE_COMBI)
{
2016-09-29 12:46:51 +00:00
}
else if ((user_options->attack_mode == ATTACK_MODE_HYBRID1) || (user_options->attack_mode == ATTACK_MODE_HYBRID2))
{
mask_ctx->mask = mask_ctx->masks[mask_ctx->masks_pos];
2015-12-04 14:47:52 +00:00
2016-10-06 08:14:19 +00:00
const int rc_mask_file = mask_ctx_parse_maskfile (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (rc_mask_file == -1) return -1;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
mask_ctx->css_buf = mp_gen_css (mask_ctx->mask, strlen (mask_ctx->mask), mask_ctx->mp_sys, mask_ctx->mp_usr, &mask_ctx->css_cnt, hashconfig, user_options);
2015-12-04 14:47:52 +00:00
u32 uniq_tbls[SP_PW_MAX][CHARSIZ] = { { 0 } };
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
mp_css_to_uniq_tbl (mask_ctx->css_cnt, mask_ctx->css_buf, uniq_tbls);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
sp_tbl_to_css (mask_ctx->root_table_buf, mask_ctx->markov_table_buf, mask_ctx->root_css_buf, mask_ctx->markov_css_buf, user_options->markov_threshold, uniq_tbls);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
combinator_ctx->combs_cnt = sp_get_sum (0, mask_ctx->css_cnt, mask_ctx->root_css_buf);
const int rc_update_mp = opencl_session_update_mp (opencl_ctx, mask_ctx);
if (rc_update_mp == -1) return -1;
2016-09-23 20:51:42 +00:00
}
2016-09-27 16:32:09 +00:00
const int rc_update_combinator = opencl_session_update_combinator (opencl_ctx, hashconfig, combinator_ctx);
2016-09-27 16:32:09 +00:00
if (rc_update_combinator == -1) return -1;
2016-09-23 20:51:42 +00:00
}
2016-09-29 12:46:51 +00:00
else if (user_options_extra->attack_kern == ATTACK_KERN_BF)
{
mask_ctx->mask = mask_ctx->masks[mask_ctx->masks_pos];
2015-12-04 14:47:52 +00:00
2016-10-06 08:14:19 +00:00
const int rc_mask_file = mask_ctx_parse_maskfile (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (rc_mask_file == -1) return -1;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (user_options->attack_mode == ATTACK_MODE_BF) // always true
2016-09-23 20:51:42 +00:00
{
2016-09-29 12:46:51 +00:00
mask_ctx->css_buf = mp_gen_css (mask_ctx->mask, strlen (mask_ctx->mask), mask_ctx->mp_sys, mask_ctx->mp_usr, &mask_ctx->css_cnt, hashconfig, user_options);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// check if mask is not too large or too small for pw_min/pw_max (*2 if unicode)
2015-12-04 14:47:52 +00:00
u32 mask_min = hashconfig->pw_min;
u32 mask_max = hashconfig->pw_max;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if ((mask_ctx->css_cnt < mask_min) || (mask_ctx->css_cnt > mask_max))
{
if (mask_ctx->css_cnt < mask_min)
{
log_info ("WARNING: Skipping mask '%s' because it is smaller than the minimum password length", mask_ctx->mask);
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (mask_ctx->css_cnt > mask_max)
{
log_info ("WARNING: Skipping mask '%s' because it is larger than the maximum password length", mask_ctx->mask);
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// skip to next mask
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
logfile_sub_msg ("STOP");
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
return 0;
}
2015-12-04 14:47:52 +00:00
if (hashconfig->opts_type & OPTS_TYPE_PT_UNICODE)
{
mask_min *= 2;
mask_max *= 2;
}
if (hashconfig->opts_type & OPTS_TYPE_PT_UNICODE)
{
mp_css_unicode_expand (mask_ctx);
}
2016-09-29 12:46:51 +00:00
u32 css_cnt_orig = mask_ctx->css_cnt;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (hashconfig->opti_type & OPTI_TYPE_SINGLE_HASH)
{
if (hashconfig->opti_type & OPTI_TYPE_APPENDED_SALT)
{
mp_css_append_salt (mask_ctx, &hashes->salts_buf[0]);
2016-09-29 12:46:51 +00:00
}
}
2015-12-04 14:47:52 +00:00
u32 uniq_tbls[SP_PW_MAX][CHARSIZ] = { { 0 } };
2016-09-29 12:46:51 +00:00
mp_css_to_uniq_tbl (mask_ctx->css_cnt, mask_ctx->css_buf, uniq_tbls);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
sp_tbl_to_css (mask_ctx->root_table_buf, mask_ctx->markov_table_buf, mask_ctx->root_css_buf, mask_ctx->markov_css_buf, user_options->markov_threshold, uniq_tbls);
2016-09-29 21:49:33 +00:00
status_ctx->words_cnt = sp_get_sum (0, mask_ctx->css_cnt, mask_ctx->root_css_buf);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
// copy + args
2015-12-04 14:47:52 +00:00
u32 css_cnt_lr[2];
mp_css_split_cnt (mask_ctx, hashconfig, css_cnt_orig, css_cnt_lr);
2015-12-04 14:47:52 +00:00
mask_ctx->bfs_cnt = sp_get_sum (0, css_cnt_lr[1], mask_ctx->root_css_buf);
const int rc_update_mp_rl = opencl_session_update_mp_rl (opencl_ctx, mask_ctx, css_cnt_lr[0], css_cnt_lr[1]);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (rc_update_mp_rl == -1) return -1;
}
2016-09-29 12:46:51 +00:00
}
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
/**
* loop through wordlists
2016-09-29 12:46:51 +00:00
*/
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
restore_data_t *rd = restore_ctx->rd;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (straight_ctx->dicts_cnt)
{
2016-10-02 22:01:37 +00:00
for (u32 dicts_pos = rd->dicts_pos; dicts_pos < straight_ctx->dicts_cnt; dicts_pos++)
2016-09-29 12:46:51 +00:00
{
2016-10-02 22:01:37 +00:00
rd->dicts_pos = dicts_pos;
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
straight_ctx->dicts_pos = dicts_pos;
2015-12-04 14:47:52 +00:00
const int rc_inner2_loop = inner2_loop (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (rc_inner2_loop == -1) return -1;
2015-12-04 14:47:52 +00:00
2016-09-29 21:25:29 +00:00
if (status_ctx->run_main_level3 == false) break;
2016-09-29 12:46:51 +00:00
}
}
2016-09-29 12:46:51 +00:00
else
{
const int rc_inner2_loop = inner2_loop (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 12:46:51 +00:00
if (rc_inner2_loop == -1) return -1;
}
2016-09-24 23:02:44 +00:00
return 0;
}
2016-09-24 23:02:44 +00:00
2016-09-29 12:46:51 +00:00
// outer_loop iterates through hash_modes (in benchmark mode)
// also initializes stuff that depend on hash mode
2016-09-29 12:46:51 +00:00
static int outer_loop (hashcat_ctx_t *hashcat_ctx)
{
bitmap_ctx_t *bitmap_ctx = hashcat_ctx->bitmap_ctx;
folder_config_t *folder_config = hashcat_ctx->folder_config;
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
hashes_t *hashes = hashcat_ctx->hashes;
hwmon_ctx_t *hwmon_ctx = hashcat_ctx->hwmon_ctx;
mask_ctx_t *mask_ctx = hashcat_ctx->mask_ctx;
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
outcheck_ctx_t *outcheck_ctx = hashcat_ctx->outcheck_ctx;
outfile_ctx_t *outfile_ctx = hashcat_ctx->outfile_ctx;
potfile_ctx_t *potfile_ctx = hashcat_ctx->potfile_ctx;
restore_ctx_t *restore_ctx = hashcat_ctx->restore_ctx;
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
straight_ctx_t *straight_ctx = hashcat_ctx->straight_ctx;
tuning_db_t *tuning_db = hashcat_ctx->tuning_db;
user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
user_options_t *user_options = hashcat_ctx->user_options;
wl_data_t *wl_data = hashcat_ctx->wl_data;
2016-09-29 21:25:29 +00:00
status_ctx->devices_status = STATUS_INIT;
2016-09-24 23:02:44 +00:00
2016-09-29 21:25:29 +00:00
//status_ctx->run_main_level1 = true;
status_ctx->run_main_level2 = true;
status_ctx->run_main_level3 = true;
status_ctx->run_thread_level1 = true;
status_ctx->run_thread_level2 = true;
2015-12-04 14:47:52 +00:00
/**
* setup prepare timer
*/
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
time (&status_ctx->prepare_start);
2015-12-04 14:47:52 +00:00
/**
* setup variables and buffers depending on hash_mode
*/
2015-12-04 14:47:52 +00:00
const int rc_hashconfig = hashconfig_init (hashconfig, user_options);
2015-12-04 14:47:52 +00:00
if (rc_hashconfig == -1) return -1;
2016-02-05 14:27:09 +00:00
/**
* potfile show/left depends on hash_mode, so it's called here first time
*/
if (user_options->show == true || user_options->left == true)
{
outfile_write_open (outfile_ctx);
potfile_read_open (potfile_ctx);
2015-12-04 14:47:52 +00:00
potfile_read_parse (potfile_ctx, hashconfig);
2015-12-04 14:47:52 +00:00
potfile_read_close (potfile_ctx);
}
2015-12-04 14:47:52 +00:00
/**
* load hashes, stage 1
*/
2015-12-04 14:47:52 +00:00
const int rc_hashes_init_stage1 = hashes_init_stage1 (hashcat_ctx);
if (rc_hashes_init_stage1 == -1) return -1;
if ((user_options->keyspace == false) && (user_options->stdout_flag == false) && (user_options->opencl_info == false))
{
if (hashes->hashes_cnt == 0)
{
log_error ("ERROR: No hashes loaded");
2015-12-04 14:47:52 +00:00
return -1;
}
}
2015-12-04 14:47:52 +00:00
/**
* potfile show/left final
*/
2015-12-04 14:47:52 +00:00
if (user_options->show == true || user_options->left == true)
{
outfile_write_close (outfile_ctx);
2015-12-04 14:47:52 +00:00
potfile_hash_free (potfile_ctx, hashconfig);
2015-12-04 14:47:52 +00:00
return 0;
}
2015-12-04 14:47:52 +00:00
/**
* Potfile removes
*/
2015-12-04 14:47:52 +00:00
int potfile_remove_cracks = 0;
2015-12-04 14:47:52 +00:00
if (user_options->potfile_disable == 0)
{
if (user_options->quiet == false) log_info_nn ("Comparing hashes with potfile entries...");
2015-12-04 14:47:52 +00:00
potfile_remove_cracks = potfile_remove_parse (potfile_ctx, hashconfig, hashes);
}
2016-09-23 20:51:42 +00:00
/**
* load hashes, stage 2, remove duplicates, build base structure
*/
2015-12-04 14:47:52 +00:00
const u32 hashes_cnt_orig = hashes->hashes_cnt;
2015-12-04 14:47:52 +00:00
const int rc_hashes_init_stage2 = hashes_init_stage2 (hashcat_ctx);
2015-12-04 14:47:52 +00:00
if (rc_hashes_init_stage2 == -1) return -1;
2015-12-04 14:47:52 +00:00
/**
* load hashes, stage 2: at this point we can check for all hashes cracked (by potfile)
*/
if (status_ctx->devices_status == STATUS_CRACKED)
{
if (user_options->quiet == false)
{
log_info ("INFO: All hashes found in potfile! You can use --show to display them.");
log_info ("");
log_info ("INFO: No more hashes left to crack, exiting...");
log_info ("");
}
hashes_destroy (hashcat_ctx);
hashconfig_destroy (hashconfig);
potfile_destroy (potfile_ctx);
return 0;
}
/**
* load hashes, stage 3, automatic Optimizers
*/
2015-12-04 14:47:52 +00:00
const int rc_hashes_init_stage3 = hashes_init_stage3 (hashcat_ctx);
2015-12-04 14:47:52 +00:00
if (rc_hashes_init_stage3 == -1) return -1;
2015-12-04 14:47:52 +00:00
hashes_logger (hashcat_ctx);
2015-12-04 14:47:52 +00:00
/**
* bitmaps
*/
2015-12-04 14:47:52 +00:00
bitmap_ctx_init (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 13:19:12 +00:00
/**
* cracks-per-time allocate buffer
*/
2016-10-06 08:26:47 +00:00
cpt_ctx_init (hashcat_ctx);
2016-09-29 13:19:12 +00:00
/**
* Wordlist allocate buffer
*/
2015-12-04 14:47:52 +00:00
wl_data_init (wl_data, user_options, hashconfig);
/**
* straight mode init
*/
2016-10-06 08:21:39 +00:00
const int rc_straight_init = straight_ctx_init (hashcat_ctx);
if (rc_straight_init == -1) return -1;
2016-09-27 16:32:09 +00:00
/**
* straight mode init
*/
const int rc_combinator_init = combinator_ctx_init (hashcat_ctx);
2016-09-27 16:32:09 +00:00
if (rc_combinator_init == -1) return -1;
/**
* charsets : keep them together for more easy maintainnce
*/
2016-10-06 08:14:19 +00:00
const int rc_mask_init = mask_ctx_init (hashcat_ctx);
if (rc_mask_init == -1) return -1;
/**
* prevent the user from using --skip/--limit together w/ maskfile and or dictfile
*/
if (user_options->skip != 0 || user_options->limit != 0)
{
if ((mask_ctx->masks_cnt > 1) || (straight_ctx->dicts_cnt > 1))
{
log_error ("ERROR: --skip/--limit are not supported with --increment or mask files");
return -1;
}
}
/**
* prevent the user from using --keyspace together w/ maskfile and or dictfile
*/
if (user_options->keyspace == true)
{
if ((mask_ctx->masks_cnt > 1) || (straight_ctx->dicts_cnt > 1))
{
log_error ("ERROR: --keyspace is not supported with --increment or mask files");
return -1;
}
}
2016-09-29 20:27:04 +00:00
/**
2016-09-29 21:25:29 +00:00
* status progress init; needs hashes that's why we have to do it here and separate from status_ctx_init
2016-09-29 20:27:04 +00:00
*/
2016-10-06 07:47:34 +00:00
const int rc_status_init = status_progress_init (hashcat_ctx);
2016-09-29 20:27:04 +00:00
if (rc_status_init == -1) return -1;
/**
* enable custom signal handler(s)
* currently disabled, because man page says:
* The effects of signal() in a multithreaded process are unspecified.
*/
/*
if (user_options->benchmark == false)
{
hc_signal (sigHandler_default);
}
else
{
hc_signal (sigHandler_benchmark);
}
*/
/**
* inform the user
*/
if (user_options->quiet == false)
{
log_info ("Hashes: %u digests; %u unique digests, %u unique salts", hashes_cnt_orig, hashes->digests_cnt, hashes->salts_cnt);
log_info ("Bitmaps: %u bits, %u entries, 0x%08x mask, %u bytes, %u/%u rotates", bitmap_ctx->bitmap_bits, bitmap_ctx->bitmap_nums, bitmap_ctx->bitmap_mask, bitmap_ctx->bitmap_size, bitmap_ctx->bitmap_shift1, bitmap_ctx->bitmap_shift2);
if (user_options->attack_mode == ATTACK_MODE_STRAIGHT)
{
log_info ("Rules: %u", straight_ctx->kernel_rules_cnt);
}
if (user_options->quiet == false) log_info ("");
if (hashconfig->opti_type)
{
log_info ("Applicable Optimizers:");
for (u32 i = 0; i < 32; i++)
2016-09-23 20:51:42 +00:00
{
const u32 opti_bit = 1u << i;
2015-12-04 14:47:52 +00:00
if (hashconfig->opti_type & opti_bit) log_info ("* %s", stroptitype (opti_bit));
2016-09-23 20:51:42 +00:00
}
}
if (user_options->quiet == false) log_info ("");
/**
* Watchdog and Temperature balance
*/
2016-09-28 20:28:44 +00:00
if (hwmon_ctx->enabled == false && user_options->gpu_temp_disable == false)
{
log_info ("Watchdog: Hardware Monitoring Interface not found on your system");
}
2016-09-28 20:28:44 +00:00
if (hwmon_ctx->enabled == true && user_options->gpu_temp_abort > 0)
{
2016-09-28 20:28:44 +00:00
log_info ("Watchdog: Temperature abort trigger set to %uc", user_options->gpu_temp_abort);
}
else
{
2016-09-28 20:28:44 +00:00
log_info ("Watchdog: Temperature abort trigger disabled");
}
2015-12-04 14:47:52 +00:00
2016-09-28 20:28:44 +00:00
if (hwmon_ctx->enabled == true && user_options->gpu_temp_retain > 0)
{
2016-09-28 20:28:44 +00:00
log_info ("Watchdog: Temperature retain trigger set to %uc", user_options->gpu_temp_retain);
}
else
{
2016-09-28 20:28:44 +00:00
log_info ("Watchdog: Temperature retain trigger disabled");
}
if (user_options->quiet == false) log_info ("");
}
#if defined (DEBUG)
if (user_options->benchmark == true) log_info ("Hashmode: %d", hashconfig->hash_mode);
#endif
if (user_options->quiet == false) log_info_nn ("Initializing device kernels and memory...");
opencl_session_begin (opencl_ctx, hashconfig, hashes, straight_ctx, user_options, user_options_extra, folder_config, bitmap_ctx, tuning_db);
2015-12-04 14:47:52 +00:00
if (user_options->quiet == false) log_info_nn ("");
/**
* In benchmark-mode, inform user which algorithm is checked
*/
if (user_options->benchmark == true)
{
if (user_options->machine_readable == false)
{
char *hash_type = strhashtype (hashconfig->hash_mode); // not a bug
log_info ("Hashtype: %s", hash_type);
log_info ("");
}
}
/**
* weak hash check is the first to write to potfile, so open it for writing from here
*/
2016-10-04 21:00:20 +00:00
const int rc_potfile_write = potfile_write_open (potfile_ctx);
if (rc_potfile_write == -1) return -1;
/**
* weak hash check
*/
if (user_options->weak_hash_threshold >= hashes->salts_cnt)
{
hc_device_param_t *device_param = NULL;
for (u32 device_id = 0; device_id < opencl_ctx->devices_cnt; device_id++)
{
device_param = &opencl_ctx->devices_param[device_id];
2015-12-04 14:47:52 +00:00
if (device_param->skipped) continue;
break;
}
if (user_options->quiet == false) log_info_nn ("Checking for weak hashes...");
for (u32 salt_pos = 0; salt_pos < hashes->salts_cnt; salt_pos++)
{
weak_hash_check (hashcat_ctx, device_param, salt_pos);
}
}
/**
* status and monitor threads
*/
int inner_threads_cnt = 0;
hc_thread_t *inner_threads = (hc_thread_t *) mycalloc (10, sizeof (hc_thread_t));
2016-09-29 21:49:33 +00:00
status_ctx->shutdown_inner = false;
/**
* Outfile remove
*/
if (user_options->keyspace == false && user_options->benchmark == false && user_options->stdout_flag == false)
{
hc_thread_create (inner_threads[inner_threads_cnt], thread_monitor, hashcat_ctx);
inner_threads_cnt++;
if (outcheck_ctx->enabled == true)
{
hc_thread_create (inner_threads[inner_threads_cnt], thread_outfile_remove, hashcat_ctx);
inner_threads_cnt++;
}
}
/**
2016-09-29 20:27:04 +00:00
* Tell user about cracked hashes by potfile
*/
if (user_options->quiet == false)
{
if (potfile_remove_cracks > 0)
{
if (potfile_remove_cracks == 1)
{
log_info ("INFO: Removed 1 hash found in potfile");
log_info ("");
}
else
{
log_info ("INFO: Removed %d hashes found in potfile", potfile_remove_cracks);
log_info ("");
}
}
}
2016-09-29 20:27:04 +00:00
// main call
if (mask_ctx->masks_cnt)
{
2016-09-29 20:27:04 +00:00
restore_data_t *rd = restore_ctx->rd;
for (u32 masks_pos = rd->masks_pos; masks_pos < mask_ctx->masks_cnt; masks_pos++)
{
if (masks_pos > rd->masks_pos)
{
2016-10-02 22:01:37 +00:00
rd->dicts_pos = 0;
}
rd->masks_pos = masks_pos;
mask_ctx->masks_pos = masks_pos;
const int rc_inner1_loop = inner1_loop (hashcat_ctx);
if (rc_inner1_loop == -1) return -1;
2016-09-29 21:25:29 +00:00
if (status_ctx->run_main_level2 == false) break;
}
}
else
{
const int rc_inner1_loop = inner1_loop (hashcat_ctx);
if (rc_inner1_loop == -1) return -1;
}
// wait for inner threads
2016-09-29 21:49:33 +00:00
status_ctx->shutdown_inner = true;
for (int thread_idx = 0; thread_idx < inner_threads_cnt; thread_idx++)
{
hc_thread_wait (1, &inner_threads[thread_idx]);
}
myfree (inner_threads);
/**
* Clean up
*/
2016-10-06 07:47:34 +00:00
status_progress_destroy (hashcat_ctx);
2016-09-27 09:03:45 +00:00
opencl_session_destroy (opencl_ctx);
2015-12-04 14:47:52 +00:00
potfile_write_close (potfile_ctx);
2015-12-04 14:47:52 +00:00
bitmap_ctx_destroy (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-10-06 08:14:19 +00:00
mask_ctx_destroy (hashcat_ctx);
2015-12-04 14:47:52 +00:00
combinator_ctx_destroy (hashcat_ctx);
2016-09-27 16:32:09 +00:00
2016-10-06 08:21:39 +00:00
straight_ctx_destroy (hashcat_ctx);
hashes_destroy (hashcat_ctx);
2015-12-04 14:47:52 +00:00
hashconfig_destroy (hashconfig);
2015-12-04 14:47:52 +00:00
wl_data_destroy (wl_data);
2015-12-04 14:47:52 +00:00
2016-10-06 08:26:47 +00:00
cpt_ctx_destroy (hashcat_ctx);
2016-09-29 13:19:12 +00:00
return 0;
}
2015-12-04 14:47:52 +00:00
2016-10-02 23:27:55 +00:00
int hashcat (hashcat_ctx_t *hashcat_ctx, char *install_folder, char *shared_folder, int argc, char **argv, const int comptime)
{
/**
* To help users a bit
*/
2015-12-04 14:47:52 +00:00
setup_environment_variables ();
setup_umask ();
2015-12-04 14:47:52 +00:00
2016-09-29 21:25:29 +00:00
/**
* main init
2016-09-29 21:25:29 +00:00
*/
dictstat_ctx_t *dictstat_ctx = hashcat_ctx->dictstat_ctx;
folder_config_t *folder_config = hashcat_ctx->folder_config;
induct_ctx_t *induct_ctx = hashcat_ctx->induct_ctx;
logfile_ctx_t *logfile_ctx = hashcat_ctx->logfile_ctx;
loopback_ctx_t *loopback_ctx = hashcat_ctx->loopback_ctx;
opencl_ctx_t *opencl_ctx = hashcat_ctx->opencl_ctx;
outcheck_ctx_t *outcheck_ctx = hashcat_ctx->outcheck_ctx;
outfile_ctx_t *outfile_ctx = hashcat_ctx->outfile_ctx;
potfile_ctx_t *potfile_ctx = hashcat_ctx->potfile_ctx;
restore_ctx_t *restore_ctx = hashcat_ctx->restore_ctx;
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
tuning_db_t *tuning_db = hashcat_ctx->tuning_db;
user_options_extra_t *user_options_extra = hashcat_ctx->user_options_extra;
user_options_t *user_options = hashcat_ctx->user_options;
2016-09-29 21:25:29 +00:00
/**
* status init
*/
2016-09-29 21:25:29 +00:00
2016-10-06 07:47:34 +00:00
const int rc_status_init = status_ctx_init (hashcat_ctx);
2016-09-29 21:25:29 +00:00
if (rc_status_init == -1) return -1;
/**
* folder
*/
folder_config_init (folder_config, install_folder, shared_folder);
2015-12-04 14:47:52 +00:00
/**
* restore
*/
2015-12-04 14:47:52 +00:00
const int rc_restore_init = restore_ctx_init (restore_ctx, user_options, folder_config, argc, argv);
if (rc_restore_init == -1) return -1;
2015-12-04 14:47:52 +00:00
/**
* process user input
*/
2015-12-04 14:47:52 +00:00
2016-10-02 21:30:31 +00:00
user_options_preprocess (user_options);
2016-10-02 21:30:31 +00:00
user_options_extra_init (user_options, user_options_extra);
2015-12-04 14:47:52 +00:00
/**
* prepare seeding for random number generator, required by logfile and rules generator
*/
2016-09-28 21:53:46 +00:00
setup_seeding (user_options->rp_gen_seed_chgd, user_options->rp_gen_seed);
2015-12-04 14:47:52 +00:00
/**
* logfile init
*/
2015-12-04 14:47:52 +00:00
logfile_init (logfile_ctx, user_options, folder_config);
2015-12-04 14:47:52 +00:00
logfile_generate_topid (logfile_ctx);
2015-12-04 14:47:52 +00:00
logfile_top_msg ("START");
2015-12-04 14:47:52 +00:00
user_options_logger (user_options, logfile_ctx);
2015-12-04 14:47:52 +00:00
/**
* tuning db
*/
2015-12-04 14:47:52 +00:00
2016-09-30 11:02:15 +00:00
const int rc_tuning_db = tuning_db_init (tuning_db, user_options, folder_config);
2016-09-30 10:58:06 +00:00
if (rc_tuning_db == -1) return -1;
2015-12-04 14:47:52 +00:00
/**
* induction directory
*/
2016-01-15 16:23:07 +00:00
2016-09-29 21:49:33 +00:00
const int rc_induct_ctx_init = induct_ctx_init (induct_ctx, user_options, folder_config, status_ctx);
2015-12-04 14:47:52 +00:00
if (rc_induct_ctx_init == -1) return -1;
2015-12-04 14:47:52 +00:00
/**
* outfile-check directory
*/
2015-12-04 14:47:52 +00:00
const int rc_outcheck_ctx_init = outcheck_ctx_init (outcheck_ctx, user_options, folder_config);
if (rc_outcheck_ctx_init == -1) return -1;
2015-12-04 14:47:52 +00:00
2016-09-23 20:51:42 +00:00
/**
* outfile itself
2016-09-23 20:51:42 +00:00
*/
outfile_init (outfile_ctx, user_options);
2015-12-04 14:47:52 +00:00
/**
* Sanity check for hashfile vs outfile (should not point to the same physical file)
*/
2015-12-04 14:47:52 +00:00
2016-10-02 21:30:31 +00:00
const int rc_outfile_and_hashfile = outfile_and_hashfile (outfile_ctx, user_options_extra->hc_hash);
2016-09-23 20:51:42 +00:00
if (rc_outfile_and_hashfile == -1) return -1;
2016-09-23 20:51:42 +00:00
/**
* potfile init
* this is only setting path because potfile can be used in read and write mode depending on user options
* plus it depends on hash_mode, so we continue using it in outer_loop
*/
2016-09-23 20:51:42 +00:00
2016-09-30 10:37:29 +00:00
potfile_init (potfile_ctx, user_options, folder_config);
2015-12-04 14:47:52 +00:00
/**
* dictstat init
*/
2015-12-04 14:47:52 +00:00
dictstat_init (dictstat_ctx, user_options, folder_config);
2015-12-04 14:47:52 +00:00
dictstat_read (dictstat_ctx);
/**
* loopback init
*/
2016-09-23 20:51:42 +00:00
2016-09-30 10:07:49 +00:00
loopback_init (loopback_ctx, user_options);
2016-09-23 20:51:42 +00:00
/**
* debugfile init
*/
2016-09-23 20:51:42 +00:00
debugfile_init (hashcat_ctx);
2016-09-23 20:51:42 +00:00
/**
* cpu affinity
*/
2015-12-04 14:47:52 +00:00
if (user_options->cpu_affinity)
{
set_cpu_affinity (user_options->cpu_affinity);
}
2015-12-04 14:47:52 +00:00
/**
* Init OpenCL library loader
*/
2015-12-04 14:47:52 +00:00
const int rc_opencl_init = opencl_ctx_init (opencl_ctx, user_options);
if (rc_opencl_init == -1)
2016-09-23 20:51:42 +00:00
{
log_error ("ERROR: opencl_ctx_init() failed");
return -1;
}
/**
* Init OpenCL devices
*/
2015-12-04 14:47:52 +00:00
2016-10-02 23:27:55 +00:00
const int rc_devices_init = opencl_ctx_devices_init (opencl_ctx, user_options, comptime);
2015-12-04 14:47:52 +00:00
if (rc_devices_init == -1)
{
log_error ("ERROR: opencl_ctx_devices_init() failed");
return -1;
}
/**
* HM devices: init
*/
2016-10-06 09:10:00 +00:00
const int rc_hwmon_init = hwmon_ctx_init (hashcat_ctx);
2016-09-28 13:26:56 +00:00
if (rc_hwmon_init == -1)
{
log_error ("ERROR: hwmon_ctx_init() failed");
return -1;
}
2016-09-23 20:51:42 +00:00
/**
2016-09-24 10:19:56 +00:00
* keypress thread
2016-09-23 20:51:42 +00:00
*/
int outer_threads_cnt = 0;
2016-09-23 20:51:42 +00:00
hc_thread_t *outer_threads = (hc_thread_t *) mycalloc (10, sizeof (hc_thread_t));
2016-09-29 21:49:33 +00:00
status_ctx->shutdown_outer = false;
2016-09-23 20:51:42 +00:00
if (user_options->keyspace == false && user_options->benchmark == false && user_options->stdout_flag == false)
{
if ((user_options_extra->wordlist_mode == WL_MODE_FILE) || (user_options_extra->wordlist_mode == WL_MODE_MASK))
{
hc_thread_create (outer_threads[outer_threads_cnt], thread_keypress, hashcat_ctx);
2016-09-23 20:51:42 +00:00
outer_threads_cnt++;
}
}
2016-09-23 20:51:42 +00:00
/**
* outer loop
*/
2016-09-22 15:11:17 +00:00
2016-09-23 20:51:42 +00:00
if (user_options->benchmark == true)
{
user_options->quiet = true;
2016-09-23 20:51:42 +00:00
if (user_options->hash_mode_chgd == true)
{
const int rc = outer_loop (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-23 20:51:42 +00:00
if (rc == -1) return -1;
}
else
{
2016-09-30 15:41:40 +00:00
for (u32 algorithm_pos = 0; algorithm_pos < DEFAULT_BENCHMARK_ALGORITHMS_CNT; algorithm_pos++)
2016-09-23 20:51:42 +00:00
{
user_options->hash_mode = DEFAULT_BENCHMARK_ALGORITHMS_BUF[algorithm_pos];
2015-12-04 14:47:52 +00:00
const int rc = outer_loop (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-23 20:51:42 +00:00
if (rc == -1) return -1;
2016-09-29 21:25:29 +00:00
if (status_ctx->run_main_level1 == false) break;
2016-09-23 20:51:42 +00:00
}
}
}
else
{
const int rc = outer_loop (hashcat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-23 20:51:42 +00:00
if (rc == -1) return -1;
2015-12-04 14:47:52 +00:00
}
// wait for outer threads
2016-09-29 21:49:33 +00:00
status_ctx->shutdown_outer = true;
for (int thread_idx = 0; thread_idx < outer_threads_cnt; thread_idx++)
{
2016-06-26 14:09:05 +00:00
hc_thread_wait (1, &outer_threads[thread_idx]);
}
myfree (outer_threads);
2016-09-24 12:00:59 +00:00
if (user_options->benchmark == true)
{
user_options->quiet = false;
}
2016-10-04 09:03:20 +00:00
// if exhausted or cracked, unlink the restore file
unlink_restore (restore_ctx, status_ctx);
// final update dictionary cache
dictstat_write (dictstat_ctx);
2015-12-04 14:47:52 +00:00
// free memory
debugfile_destroy (hashcat_ctx);
tuning_db_destroy (tuning_db);
2016-09-24 11:05:09 +00:00
loopback_destroy (loopback_ctx);
dictstat_destroy (dictstat_ctx);
2015-12-04 14:47:52 +00:00
2016-09-24 10:41:56 +00:00
potfile_destroy (potfile_ctx);
induct_ctx_destroy (induct_ctx);
2016-09-24 10:19:56 +00:00
outfile_destroy (outfile_ctx);
outcheck_ctx_destroy (outcheck_ctx);
2015-12-04 14:47:52 +00:00
folder_config_destroy (folder_config);
user_options_extra_destroy (user_options_extra);
2016-10-06 09:10:00 +00:00
hwmon_ctx_destroy (hashcat_ctx);
2016-09-28 20:28:44 +00:00
opencl_ctx_devices_destroy (opencl_ctx);
2016-09-28 13:26:56 +00:00
2016-09-29 21:49:33 +00:00
opencl_ctx_destroy (opencl_ctx);
2016-09-24 23:02:44 +00:00
2016-09-29 21:49:33 +00:00
restore_ctx_destroy (restore_ctx);
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
time (&status_ctx->proc_stop);
2015-12-04 14:47:52 +00:00
2016-09-29 21:49:33 +00:00
logfile_top_uint (status_ctx->proc_start);
logfile_top_uint (status_ctx->proc_stop);
2015-12-04 14:47:52 +00:00
logfile_top_msg ("STOP");
2016-09-23 19:41:05 +00:00
logfile_destroy (logfile_ctx);
user_options_destroy (user_options);
2016-09-30 15:41:40 +00:00
int rc_final = -1;
2016-09-29 21:25:29 +00:00
if (status_ctx->devices_status == STATUS_ABORTED) rc_final = 2;
if (status_ctx->devices_status == STATUS_QUIT) rc_final = 2;
if (status_ctx->devices_status == STATUS_EXHAUSTED) rc_final = 1;
if (status_ctx->devices_status == STATUS_CRACKED) rc_final = 0;
2016-01-26 20:40:49 +00:00
2016-10-06 07:47:34 +00:00
status_ctx_destroy (hashcat_ctx);
2016-09-29 21:25:29 +00:00
return rc_final;
2015-12-04 14:47:52 +00:00
}