mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-05 13:21:13 +00:00
Fix final autotune balancing
This commit is contained in:
parent
f05944395a
commit
a83622faaf
@ -2949,7 +2949,7 @@ static void autotune (hc_device_param_t *device_param)
|
|||||||
|
|
||||||
e_best = 0;
|
e_best = 0;
|
||||||
|
|
||||||
for (int i = 0; i < STEPS_LOOPS_CNT; i++)
|
for (int i = 0; i < STEPS_LOOPS_CNT - 1; i++)
|
||||||
{
|
{
|
||||||
const u32 kernel_loops_try = steps_loops[i];
|
const u32 kernel_loops_try = steps_loops[i];
|
||||||
|
|
||||||
@ -2974,7 +2974,12 @@ static void autotune (hc_device_param_t *device_param)
|
|||||||
|
|
||||||
const double exec_ms = try_run (device_param, kernel_accel, kernel_loops, 1);
|
const double exec_ms = try_run (device_param, kernel_accel, kernel_loops, 1);
|
||||||
|
|
||||||
e_best = exec_ms;
|
u32 kernel_accel_best = kernel_accel;
|
||||||
|
u32 kernel_loops_best = kernel_loops;
|
||||||
|
|
||||||
|
u32 exec_best = exec_ms;
|
||||||
|
|
||||||
|
// reset
|
||||||
|
|
||||||
u32 kernel_accel_try = kernel_accel;
|
u32 kernel_accel_try = kernel_accel;
|
||||||
u32 kernel_loops_try = kernel_loops;
|
u32 kernel_loops_try = kernel_loops;
|
||||||
@ -2989,14 +2994,17 @@ static void autotune (hc_device_param_t *device_param)
|
|||||||
|
|
||||||
const double exec_ms = try_run (device_param, kernel_accel_try, kernel_loops_try, 1);
|
const double exec_ms = try_run (device_param, kernel_accel_try, kernel_loops_try, 1);
|
||||||
|
|
||||||
if (exec_ms > e_best) break;
|
if (exec_ms < exec_best)
|
||||||
|
{
|
||||||
|
kernel_accel_best = kernel_accel_try;
|
||||||
|
kernel_loops_best = kernel_loops_try;
|
||||||
|
|
||||||
kernel_accel = kernel_accel_try;
|
exec_best = exec_ms;
|
||||||
kernel_loops = kernel_loops_try;
|
}
|
||||||
|
|
||||||
e_best = exec_ms;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// reset
|
||||||
|
|
||||||
kernel_accel_try = kernel_accel;
|
kernel_accel_try = kernel_accel;
|
||||||
kernel_loops_try = kernel_loops;
|
kernel_loops_try = kernel_loops;
|
||||||
|
|
||||||
@ -3010,14 +3018,18 @@ static void autotune (hc_device_param_t *device_param)
|
|||||||
|
|
||||||
const double exec_ms = try_run (device_param, kernel_accel_try, kernel_loops_try, 1);
|
const double exec_ms = try_run (device_param, kernel_accel_try, kernel_loops_try, 1);
|
||||||
|
|
||||||
if (exec_ms > e_best) break;
|
if (exec_ms < exec_best)
|
||||||
|
{
|
||||||
|
kernel_accel_best = kernel_accel_try;
|
||||||
|
kernel_loops_best = kernel_loops_try;
|
||||||
|
|
||||||
kernel_accel = kernel_accel_try;
|
exec_best = exec_ms;
|
||||||
kernel_loops = kernel_loops_try;
|
}
|
||||||
|
|
||||||
e_best = exec_ms;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
kernel_accel = kernel_accel_best;
|
||||||
|
kernel_loops = kernel_loops_best;
|
||||||
|
|
||||||
// reset timer
|
// reset timer
|
||||||
|
|
||||||
device_param->exec_pos = 0;
|
device_param->exec_pos = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user