mirror of
https://github.com/hashcat/hashcat.git
synced 2024-11-23 00:28:11 +00:00
Fix for 0H/s issue on different algorithms
This commit is contained in:
parent
50ea3a88dd
commit
42c83df959
@ -955,21 +955,12 @@ struct __hc_device_param
|
|||||||
uint exec_pos;
|
uint exec_pos;
|
||||||
double exec_ms[EXEC_CACHE];
|
double exec_ms[EXEC_CACHE];
|
||||||
|
|
||||||
// this is "average" speed, we'll use this for benchmark and final status screen
|
|
||||||
|
|
||||||
u64 speed_cnt_total;
|
|
||||||
double speed_ms_total;
|
|
||||||
|
|
||||||
// this is "current" speed
|
// this is "current" speed
|
||||||
|
|
||||||
uint speed_pos;
|
uint speed_pos;
|
||||||
u64 speed_cnt[SPEED_CACHE];
|
u64 speed_cnt[SPEED_CACHE];
|
||||||
double speed_ms[SPEED_CACHE];
|
double speed_ms[SPEED_CACHE];
|
||||||
|
|
||||||
// speed_rec is what additionally limits the "current" speed in time, not array elements
|
|
||||||
|
|
||||||
hc_timer_t speed_rec[SPEED_CACHE];
|
|
||||||
|
|
||||||
hc_timer_t timer_speed;
|
hc_timer_t timer_speed;
|
||||||
|
|
||||||
// device specific attributes starting
|
// device specific attributes starting
|
||||||
|
@ -805,12 +805,6 @@ void status_display_automat ()
|
|||||||
|
|
||||||
for (int i = 0; i < SPEED_CACHE; i++)
|
for (int i = 0; i < SPEED_CACHE; i++)
|
||||||
{
|
{
|
||||||
double rec_ms;
|
|
||||||
|
|
||||||
hc_timer_get (device_param->speed_rec[i], rec_ms);
|
|
||||||
|
|
||||||
if (rec_ms > SPEED_MAXAGE) continue;
|
|
||||||
|
|
||||||
speed_cnt += device_param->speed_cnt[i];
|
speed_cnt += device_param->speed_cnt[i];
|
||||||
speed_ms += device_param->speed_ms[i];
|
speed_ms += device_param->speed_ms[i];
|
||||||
}
|
}
|
||||||
@ -1149,25 +1143,11 @@ void status_display ()
|
|||||||
|
|
||||||
if (device_param->skipped) continue;
|
if (device_param->skipped) continue;
|
||||||
|
|
||||||
// we need to clear values (set to 0) because in case the device does
|
|
||||||
// not get new candidates it idles around but speed display would
|
|
||||||
// show it as working.
|
|
||||||
// if we instantly set it to 0 after reading it happens that the
|
|
||||||
// speed can be shown as zero if the users refreshes too fast.
|
|
||||||
// therefore, we add a timestamp when a stat was recorded and if its
|
|
||||||
// too old we will not use it
|
|
||||||
|
|
||||||
speed_cnt[device_id] = 0;
|
speed_cnt[device_id] = 0;
|
||||||
speed_ms[device_id] = 0;
|
speed_ms[device_id] = 0;
|
||||||
|
|
||||||
for (int i = 0; i < SPEED_CACHE; i++)
|
for (int i = 0; i < SPEED_CACHE; i++)
|
||||||
{
|
{
|
||||||
double rec_ms;
|
|
||||||
|
|
||||||
hc_timer_get (device_param->speed_rec[i], rec_ms);
|
|
||||||
|
|
||||||
if (rec_ms > SPEED_MAXAGE) continue;
|
|
||||||
|
|
||||||
speed_cnt[device_id] += device_param->speed_cnt[i];
|
speed_cnt[device_id] += device_param->speed_cnt[i];
|
||||||
speed_ms[device_id] += device_param->speed_ms[i];
|
speed_ms[device_id] += device_param->speed_ms[i];
|
||||||
}
|
}
|
||||||
@ -2694,6 +2674,24 @@ static void choose_kernel (hc_device_param_t *device_param, const uint attack_ex
|
|||||||
if (data.devices_status == STATUS_CRACKED) break;
|
if (data.devices_status == STATUS_CRACKED) break;
|
||||||
if (data.devices_status == STATUS_ABORTED) break;
|
if (data.devices_status == STATUS_ABORTED) break;
|
||||||
if (data.devices_status == STATUS_QUIT) break;
|
if (data.devices_status == STATUS_QUIT) break;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* speed
|
||||||
|
*/
|
||||||
|
|
||||||
|
const float iter_part = (float) (loop_pos + loop_left) / iter;
|
||||||
|
|
||||||
|
const u64 perf_sum_all = pws_cnt * iter_part;
|
||||||
|
|
||||||
|
double speed_ms;
|
||||||
|
|
||||||
|
hc_timer_get (device_param->timer_speed, speed_ms);
|
||||||
|
|
||||||
|
const u32 speed_pos = device_param->speed_pos;
|
||||||
|
|
||||||
|
device_param->speed_cnt[speed_pos] = perf_sum_all;
|
||||||
|
|
||||||
|
device_param->speed_ms[speed_pos] = speed_ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (opts_type & OPTS_TYPE_HOOK23)
|
if (opts_type & OPTS_TYPE_HOOK23)
|
||||||
@ -3371,8 +3369,6 @@ static void run_cracker (hc_device_param_t *device_param, const uint pws_cnt)
|
|||||||
|
|
||||||
device_param->speed_ms[speed_pos] = speed_ms;
|
device_param->speed_ms[speed_pos] = speed_ms;
|
||||||
|
|
||||||
device_param->speed_rec[speed_pos] = device_param->timer_speed;
|
|
||||||
|
|
||||||
hc_thread_mutex_unlock (mux_display);
|
hc_thread_mutex_unlock (mux_display);
|
||||||
|
|
||||||
speed_pos++;
|
speed_pos++;
|
||||||
@ -3382,12 +3378,6 @@ static void run_cracker (hc_device_param_t *device_param, const uint pws_cnt)
|
|||||||
speed_pos = 0;
|
speed_pos = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// average speed
|
|
||||||
|
|
||||||
device_param->speed_cnt_total += perf_sum_all;
|
|
||||||
|
|
||||||
device_param->speed_ms_total += speed_ms;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* benchmark
|
* benchmark
|
||||||
*/
|
*/
|
||||||
@ -16033,10 +16023,6 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
memset (device_param->speed_cnt, 0, SPEED_CACHE * sizeof (u64));
|
memset (device_param->speed_cnt, 0, SPEED_CACHE * sizeof (u64));
|
||||||
memset (device_param->speed_ms, 0, SPEED_CACHE * sizeof (double));
|
memset (device_param->speed_ms, 0, SPEED_CACHE * sizeof (double));
|
||||||
memset (device_param->speed_rec, 0, SPEED_CACHE * sizeof (hc_timer_t));
|
|
||||||
|
|
||||||
device_param->speed_cnt_total = 0;
|
|
||||||
device_param->speed_ms_total = 0;
|
|
||||||
|
|
||||||
device_param->exec_pos = 0;
|
device_param->exec_pos = 0;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user