mirror of
https://github.com/hashcat/hashcat
synced 2025-01-25 05:17:27 +01:00
OpenCL Kernels: Improve performance preview accuracy in --benchmark, --speed-only and --progress-only mode
This commit is contained in:
parent
fd89cac052
commit
a7a15df911
@ -42,6 +42,7 @@
|
|||||||
##
|
##
|
||||||
|
|
||||||
- OpenCL Kernels: Add a decompressing kernel and a compressing host code in order to reduce PCIe transfer time
|
- OpenCL Kernels: Add a decompressing kernel and a compressing host code in order to reduce PCIe transfer time
|
||||||
|
- OpenCL Kernels: Improve performance preview accuracy in --benchmark, --speed-only and --progress-only mode
|
||||||
- OpenCL Kernels: Remove password length restriction to 16 for Cisco-PIX and Cisco-ASA hashes
|
- OpenCL Kernels: Remove password length restriction to 16 for Cisco-PIX and Cisco-ASA hashes
|
||||||
- Terminal: Display Set Cost/Rounds During Benchmarking
|
- Terminal: Display Set Cost/Rounds During Benchmarking
|
||||||
- Terminal: Show [r]esume in prompt only in pause mode, and show [p]ause in prompt only in resume mode
|
- Terminal: Show [r]esume in prompt only in pause mode, and show [p]ause in prompt only in resume mode
|
||||||
|
@ -110,7 +110,7 @@ but this is nededed for VS compiler which doesn't have inline keyword but has __
|
|||||||
#define PARAMCNT 64
|
#define PARAMCNT 64
|
||||||
#define DEVICES_MAX 128
|
#define DEVICES_MAX 128
|
||||||
#define EXEC_CACHE 128
|
#define EXEC_CACHE 128
|
||||||
#define SPEED_CACHE 128
|
#define SPEED_CACHE 4096
|
||||||
#define SPEED_MAXAGE 4096
|
#define SPEED_MAXAGE 4096
|
||||||
#define EXPECTED_ITERATIONS 10000
|
#define EXPECTED_ITERATIONS 10000
|
||||||
|
|
||||||
|
17
src/hashes.c
17
src/hashes.c
@ -330,10 +330,11 @@ void check_hash (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param, pl
|
|||||||
|
|
||||||
int check_cracked (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param, const u32 salt_pos)
|
int check_cracked (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param, const u32 salt_pos)
|
||||||
{
|
{
|
||||||
cpt_ctx_t *cpt_ctx = hashcat_ctx->cpt_ctx;
|
cpt_ctx_t *cpt_ctx = hashcat_ctx->cpt_ctx;
|
||||||
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
hashconfig_t *hashconfig = hashcat_ctx->hashconfig;
|
||||||
hashes_t *hashes = hashcat_ctx->hashes;
|
hashes_t *hashes = hashcat_ctx->hashes;
|
||||||
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
status_ctx_t *status_ctx = hashcat_ctx->status_ctx;
|
||||||
|
user_options_t *user_options = hashcat_ctx->user_options;
|
||||||
|
|
||||||
salt_t *salt_buf = &hashes->salts_buf[salt_pos];
|
salt_t *salt_buf = &hashes->salts_buf[salt_pos];
|
||||||
|
|
||||||
@ -350,6 +351,14 @@ int check_cracked (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// we want the hc_clEnqueueReadBuffer to run in benchmark mode because it has an influence in performance
|
||||||
|
// but sometimes, when a benchmark kernel run cracks a kernel, we don't want to see that!
|
||||||
|
|
||||||
|
if (user_options->speed_only == true)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (num_cracked)
|
if (num_cracked)
|
||||||
{
|
{
|
||||||
plain_t *cracked = (plain_t *) hccalloc (num_cracked, sizeof (plain_t));
|
plain_t *cracked = (plain_t *) hccalloc (num_cracked, sizeof (plain_t));
|
||||||
|
63
src/opencl.c
63
src/opencl.c
@ -1318,7 +1318,7 @@ int choose_kernel (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param,
|
|||||||
|
|
||||||
if (user_options->speed_only == true)
|
if (user_options->speed_only == true)
|
||||||
{
|
{
|
||||||
if (speed_msec > 4096) return -2; // special RC
|
if (speed_msec > 4000) return -2; // special RC
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2460,27 +2460,12 @@ int run_cracker (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param, co
|
|||||||
if (CL_rc == -1) return -1;
|
if (CL_rc == -1) return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
// this writes speed cache, we dont want it
|
|
||||||
if (user_options->speed_only == true)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < 16; i++)
|
|
||||||
{
|
|
||||||
const int rc = choose_kernel (hashcat_ctx, device_param, highest_pw_len, pws_cnt, fast_iteration, salt_pos);
|
|
||||||
|
|
||||||
if (rc == -1) return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
hc_timer_set (&device_param->timer_speed);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
const int rc = choose_kernel (hashcat_ctx, device_param, highest_pw_len, pws_cnt, fast_iteration, salt_pos);
|
const int rc = choose_kernel (hashcat_ctx, device_param, highest_pw_len, pws_cnt, fast_iteration, salt_pos);
|
||||||
|
|
||||||
if (rc == -1) return -1;
|
if (rc == -1) return -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* benchmark, part1
|
* benchmark was aborted because too long kernel runtime (slow hashes only)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (user_options->speed_only == true)
|
if (user_options->speed_only == true)
|
||||||
@ -2530,7 +2515,43 @@ int run_cracker (hashcat_ctx_t *hashcat_ctx, hc_device_param_t *device_param, co
|
|||||||
* benchmark, part2
|
* benchmark, part2
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (user_options->speed_only == true) break;
|
if (user_options->speed_only == true)
|
||||||
|
{
|
||||||
|
double total = device_param->speed_msec[0];
|
||||||
|
|
||||||
|
for (u32 speed_pos = 1; speed_pos < device_param->speed_pos; speed_pos++)
|
||||||
|
{
|
||||||
|
total += device_param->speed_msec[speed_pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
// it's unclear if 4s is enough to turn on boost mode for all opencl device
|
||||||
|
|
||||||
|
if ((total > 4000) || (device_param->speed_pos == SPEED_CACHE - 1))
|
||||||
|
{
|
||||||
|
u32 q = device_param->speed_pos / 10; // only use the last 10% of the recording
|
||||||
|
|
||||||
|
if (q == 0) q = 1;
|
||||||
|
|
||||||
|
u64 cnt = 0;
|
||||||
|
double msec = 0;
|
||||||
|
|
||||||
|
for (u32 speed_pos = device_param->speed_pos - q; speed_pos < device_param->speed_pos; speed_pos++)
|
||||||
|
{
|
||||||
|
cnt += device_param->speed_cnt[speed_pos];
|
||||||
|
msec += device_param->speed_msec[speed_pos];
|
||||||
|
}
|
||||||
|
|
||||||
|
memset (device_param->speed_cnt, 0, SPEED_CACHE * sizeof (u64));
|
||||||
|
memset (device_param->speed_msec, 0, SPEED_CACHE * sizeof (double));
|
||||||
|
|
||||||
|
device_param->speed_cnt[0] = cnt / q;
|
||||||
|
device_param->speed_msec[0] = msec / q;
|
||||||
|
|
||||||
|
device_param->speed_pos = 1;
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* result
|
* result
|
||||||
@ -6050,6 +6071,12 @@ void opencl_session_reset (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
device_param->words_off = 0;
|
device_param->words_off = 0;
|
||||||
device_param->words_done = 0;
|
device_param->words_done = 0;
|
||||||
|
|
||||||
|
#if defined (_WIN)
|
||||||
|
device_param->timer_speed.QuadPart = 0;
|
||||||
|
#else
|
||||||
|
device_param->timer_speed.tv_sec = 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
opencl_ctx->kernel_power_all = 0;
|
opencl_ctx->kernel_power_all = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user