mirror of
https://github.com/hashcat/hashcat
synced 2025-01-17 23:17:27 +01:00
Replace "#if defined (HAVE_HWMON)" with "user_options->powertune_enable = false" which give a more easy to read sourcecode
This commit is contained in:
parent
458d6b37f9
commit
2215174c2e
@ -802,11 +802,9 @@ typedef struct
|
||||
u32 kernel_loops;
|
||||
u32 nvidia_spin_damp;
|
||||
bool gpu_temp_disable;
|
||||
#if defined (HAVE_HWMON)
|
||||
u32 gpu_temp_abort;
|
||||
u32 gpu_temp_retain;
|
||||
bool powertune_enable;
|
||||
#endif
|
||||
bool logfile_disable;
|
||||
u32 segment_size;
|
||||
u32 scrypt_tmto;
|
||||
@ -940,13 +938,11 @@ typedef struct
|
||||
* hardware watchdog
|
||||
*/
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
void *hm_adl;
|
||||
void *hm_nvml;
|
||||
void *hm_nvapi;
|
||||
void *hm_xnvctrl;
|
||||
hm_attrs_t hm_device[DEVICES_MAX];
|
||||
#endif
|
||||
|
||||
/**
|
||||
* logging
|
||||
@ -1028,11 +1024,9 @@ typedef struct
|
||||
debugfile_ctx_t *debugfile_ctx;
|
||||
session_ctx_t *session_ctx;
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
u32 gpu_temp_disable;
|
||||
u32 gpu_temp_abort;
|
||||
u32 gpu_temp_retain;
|
||||
#endif
|
||||
|
||||
char **rp_files;
|
||||
u32 rp_files_cnt;
|
||||
|
@ -220,11 +220,9 @@ static const struct option long_options[] =
|
||||
{"kernel-loops", required_argument, 0, IDX_KERNEL_LOOPS},
|
||||
{"nvidia-spin-damp", required_argument, 0, IDX_NVIDIA_SPIN_DAMP},
|
||||
{"gpu-temp-disable", no_argument, 0, IDX_GPU_TEMP_DISABLE},
|
||||
#if defined (HAVE_HWMON)
|
||||
{"gpu-temp-abort", required_argument, 0, IDX_GPU_TEMP_ABORT},
|
||||
{"gpu-temp-retain", required_argument, 0, IDX_GPU_TEMP_RETAIN},
|
||||
{"powertune-enable", no_argument, 0, IDX_POWERTUNE_ENABLE},
|
||||
#endif // HAVE_HWMON
|
||||
{"logfile-disable", no_argument, 0, IDX_LOGFILE_DISABLE},
|
||||
{"truecrypt-keyfiles", required_argument, 0, IDX_TRUECRYPT_KEYFILES},
|
||||
{"veracrypt-keyfiles", required_argument, 0, IDX_VERACRYPT_KEYFILES},
|
||||
|
118
src/hashcat.c
118
src/hashcat.c
@ -561,9 +561,7 @@ int main (int argc, char **argv)
|
||||
logfile_top_uint (user_options->outfile_format);
|
||||
logfile_top_uint (user_options->potfile_disable);
|
||||
logfile_top_string (user_options->potfile_path);
|
||||
#if defined(HAVE_HWMON)
|
||||
logfile_top_uint (user_options->powertune_enable);
|
||||
#endif
|
||||
logfile_top_uint (user_options->scrypt_tmto);
|
||||
logfile_top_uint (user_options->quiet);
|
||||
logfile_top_uint (user_options->remove);
|
||||
@ -1251,7 +1249,6 @@ int main (int argc, char **argv)
|
||||
* HM devices: init
|
||||
*/
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
hm_attrs_t hm_adapters_adl[DEVICES_MAX];
|
||||
hm_attrs_t hm_adapters_nvapi[DEVICES_MAX];
|
||||
hm_attrs_t hm_adapters_nvml[DEVICES_MAX];
|
||||
@ -1428,7 +1425,6 @@ int main (int argc, char **argv)
|
||||
data.gpu_temp_disable = user_options->gpu_temp_disable;
|
||||
data.gpu_temp_abort = user_options->gpu_temp_abort;
|
||||
data.gpu_temp_retain = user_options->gpu_temp_retain;
|
||||
#endif
|
||||
|
||||
/**
|
||||
* enable custom signal handler(s)
|
||||
@ -1474,7 +1470,6 @@ int main (int argc, char **argv)
|
||||
* Watchdog and Temperature balance
|
||||
*/
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
if (user_options->gpu_temp_disable == false && data.hm_adl == NULL && data.hm_nvml == NULL && data.hm_xnvctrl == NULL)
|
||||
{
|
||||
log_info ("Watchdog: Hardware Monitoring Interface not found on your system");
|
||||
@ -1499,11 +1494,8 @@ int main (int argc, char **argv)
|
||||
}
|
||||
|
||||
if (user_options->quiet == false) log_info ("");
|
||||
#endif
|
||||
}
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
|
||||
/**
|
||||
* HM devices: copy
|
||||
*/
|
||||
@ -1737,8 +1729,6 @@ int main (int argc, char **argv)
|
||||
hc_thread_mutex_unlock (mux_hwmon);
|
||||
}
|
||||
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
#if defined (DEBUG)
|
||||
if (user_options->benchmark == true) log_info ("Hashmode: %d", hashconfig->hash_mode);
|
||||
#endif
|
||||
@ -1759,71 +1749,69 @@ int main (int argc, char **argv)
|
||||
* Store initial fanspeed if gpu_temp_retain is enabled
|
||||
*/
|
||||
|
||||
#if defined(HAVE_HWMON)
|
||||
|
||||
for (uint device_id = 0; device_id < opencl_ctx->devices_cnt; device_id++)
|
||||
if (user_options->gpu_temp_disable == false)
|
||||
{
|
||||
hc_device_param_t *device_param = &opencl_ctx->devices_param[device_id];
|
||||
|
||||
if (device_param->skipped) continue;
|
||||
|
||||
if (user_options->gpu_temp_disable == true) continue;
|
||||
|
||||
if (user_options->gpu_temp_retain == 0) continue;
|
||||
|
||||
hc_thread_mutex_lock (mux_hwmon);
|
||||
|
||||
if (data.hm_device[device_id].fan_get_supported == 1)
|
||||
if (user_options->gpu_temp_retain)
|
||||
{
|
||||
const int fanspeed = hm_get_fanspeed_with_device_id (opencl_ctx, device_id);
|
||||
const int fanpolicy = hm_get_fanpolicy_with_device_id (opencl_ctx, device_id);
|
||||
|
||||
// we also set it to tell the OS we take control over the fan and it's automatic controller
|
||||
// if it was set to automatic. we do not control user-defined fanspeeds.
|
||||
|
||||
if (fanpolicy == 1)
|
||||
for (uint device_id = 0; device_id < opencl_ctx->devices_cnt; device_id++)
|
||||
{
|
||||
data.hm_device[device_id].fan_set_supported = 1;
|
||||
hc_device_param_t *device_param = &opencl_ctx->devices_param[device_id];
|
||||
|
||||
int rc = -1;
|
||||
if (device_param->skipped) continue;
|
||||
|
||||
if (device_param->device_vendor_id == VENDOR_ID_AMD)
|
||||
hc_thread_mutex_lock (mux_hwmon);
|
||||
|
||||
if (data.hm_device[device_id].fan_get_supported == 1)
|
||||
{
|
||||
rc = hm_set_fanspeed_with_device_id_adl (device_id, fanspeed, 1);
|
||||
}
|
||||
else if (device_param->device_vendor_id == VENDOR_ID_NV)
|
||||
{
|
||||
#if defined (__linux__)
|
||||
rc = set_fan_control (data.hm_xnvctrl, data.hm_device[device_id].xnvctrl, NV_CTRL_GPU_COOLER_MANUAL_CONTROL_TRUE);
|
||||
#endif
|
||||
const int fanspeed = hm_get_fanspeed_with_device_id (opencl_ctx, device_id);
|
||||
const int fanpolicy = hm_get_fanpolicy_with_device_id (opencl_ctx, device_id);
|
||||
|
||||
#if defined (_WIN)
|
||||
rc = hm_set_fanspeed_with_device_id_nvapi (device_id, fanspeed, 1);
|
||||
#endif
|
||||
// we also set it to tell the OS we take control over the fan and it's automatic controller
|
||||
// if it was set to automatic. we do not control user-defined fanspeeds.
|
||||
|
||||
if (fanpolicy == 1)
|
||||
{
|
||||
data.hm_device[device_id].fan_set_supported = 1;
|
||||
|
||||
int rc = -1;
|
||||
|
||||
if (device_param->device_vendor_id == VENDOR_ID_AMD)
|
||||
{
|
||||
rc = hm_set_fanspeed_with_device_id_adl (device_id, fanspeed, 1);
|
||||
}
|
||||
else if (device_param->device_vendor_id == VENDOR_ID_NV)
|
||||
{
|
||||
#if defined (__linux__)
|
||||
rc = set_fan_control (data.hm_xnvctrl, data.hm_device[device_id].xnvctrl, NV_CTRL_GPU_COOLER_MANUAL_CONTROL_TRUE);
|
||||
#endif
|
||||
|
||||
#if defined (_WIN)
|
||||
rc = hm_set_fanspeed_with_device_id_nvapi (device_id, fanspeed, 1);
|
||||
#endif
|
||||
}
|
||||
|
||||
if (rc == 0)
|
||||
{
|
||||
data.hm_device[device_id].fan_set_supported = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
log_info ("WARNING: Failed to set initial fan speed for device #%u", device_id + 1);
|
||||
|
||||
data.hm_device[device_id].fan_set_supported = 0;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
data.hm_device[device_id].fan_set_supported = 0;
|
||||
}
|
||||
}
|
||||
|
||||
if (rc == 0)
|
||||
{
|
||||
data.hm_device[device_id].fan_set_supported = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
log_info ("WARNING: Failed to set initial fan speed for device #%u", device_id + 1);
|
||||
|
||||
data.hm_device[device_id].fan_set_supported = 0;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
data.hm_device[device_id].fan_set_supported = 0;
|
||||
hc_thread_mutex_unlock (mux_hwmon);
|
||||
}
|
||||
}
|
||||
|
||||
hc_thread_mutex_unlock (mux_hwmon);
|
||||
}
|
||||
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
/**
|
||||
* In benchmark-mode, inform user which algorithm is checked
|
||||
*/
|
||||
@ -3906,10 +3894,9 @@ int main (int argc, char **argv)
|
||||
|
||||
// reset default fan speed
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
if (user_options->gpu_temp_disable == false)
|
||||
{
|
||||
if (user_options->gpu_temp_retain != 0)
|
||||
if (user_options->gpu_temp_retain)
|
||||
{
|
||||
hc_thread_mutex_lock (mux_hwmon);
|
||||
|
||||
@ -4059,7 +4046,6 @@ int main (int argc, char **argv)
|
||||
data.hm_adl = NULL;
|
||||
}
|
||||
}
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
if (opencl_ctx->run_main_level1 == false) break;
|
||||
|
||||
@ -4098,11 +4084,9 @@ int main (int argc, char **argv)
|
||||
local_free (bitmap_s2_c);
|
||||
local_free (bitmap_s2_d);
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
local_free (od_clock_mem_status);
|
||||
local_free (od_power_control_status);
|
||||
local_free (nvml_power_limit);
|
||||
#endif
|
||||
|
||||
global_free (kernel_rules_buf);
|
||||
|
||||
|
@ -30,8 +30,6 @@
|
||||
|
||||
hc_thread_mutex_t mux_hwmon;
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
|
||||
extern hc_global_data_t data;
|
||||
|
||||
int get_adapters_num_adl (void *adl, int *iNumberAdapters)
|
||||
@ -871,5 +869,3 @@ int hm_set_fanspeed_with_device_id_xnvctrl (const uint device_id, const int fans
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
#endif // HAVE_HWMON
|
||||
|
@ -52,7 +52,6 @@ void *thread_monitor (void *p)
|
||||
hashconfig_t *hashconfig = data.hashconfig;
|
||||
hashes_t *hashes = data.hashes;
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
uint hwmon_check = 0;
|
||||
|
||||
int slowdown_warnings = 0;
|
||||
@ -72,7 +71,6 @@ void *thread_monitor (void *p)
|
||||
int fan_speed_max = 100;
|
||||
|
||||
time_t last_temp_check_time;
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
uint sleep_time = 1;
|
||||
|
||||
@ -96,20 +94,17 @@ void *thread_monitor (void *p)
|
||||
status_check = 1;
|
||||
}
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
if (data.gpu_temp_disable == 0)
|
||||
{
|
||||
time (&last_temp_check_time);
|
||||
|
||||
hwmon_check = 1;
|
||||
}
|
||||
#endif
|
||||
|
||||
if ((runtime_check == 0) && (remove_check == 0) && (status_check == 0) && (restore_check == 0))
|
||||
{
|
||||
#if defined (HAVE_HWMON)
|
||||
if (hwmon_check == 0)
|
||||
#endif
|
||||
|
||||
return (p);
|
||||
}
|
||||
|
||||
@ -119,8 +114,6 @@ void *thread_monitor (void *p)
|
||||
|
||||
if (opencl_ctx->devices_status == STATUS_INIT) continue;
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
|
||||
if (hwmon_check == 1)
|
||||
{
|
||||
hc_thread_mutex_lock (mux_hwmon);
|
||||
@ -281,7 +274,6 @@ void *thread_monitor (void *p)
|
||||
|
||||
hc_thread_mutex_unlock (mux_hwmon);
|
||||
}
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
if (restore_check == 1)
|
||||
{
|
||||
@ -365,12 +357,10 @@ void *thread_monitor (void *p)
|
||||
}
|
||||
}
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
myfree (fan_speed_chgd);
|
||||
|
||||
myfree (temp_diff_old);
|
||||
myfree (temp_diff_sum);
|
||||
#endif
|
||||
|
||||
p = NULL;
|
||||
|
||||
|
@ -258,7 +258,6 @@ void status_display_machine_readable (opencl_ctx_t *opencl_ctx, const hashes_t *
|
||||
* temperature
|
||||
*/
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
if (data.gpu_temp_disable == 0)
|
||||
{
|
||||
fprintf (out, "TEMP\t");
|
||||
@ -278,7 +277,6 @@ void status_display_machine_readable (opencl_ctx_t *opencl_ctx, const hashes_t *
|
||||
|
||||
hc_thread_mutex_unlock (mux_hwmon);
|
||||
}
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
/**
|
||||
* flush
|
||||
@ -1031,8 +1029,6 @@ void status_display (opencl_ctx_t *opencl_ctx, const hashconfig_t *hashconfig, c
|
||||
}
|
||||
}
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
|
||||
if (opencl_ctx->run_main_level1 == false) return;
|
||||
|
||||
if (data.gpu_temp_disable == 0)
|
||||
@ -1118,8 +1114,6 @@ void status_display (opencl_ctx_t *opencl_ctx, const hashconfig_t *hashconfig, c
|
||||
|
||||
hc_thread_mutex_unlock (mux_hwmon);
|
||||
}
|
||||
|
||||
#endif // HAVE_HWMON
|
||||
}
|
||||
|
||||
void status_benchmark_automate (opencl_ctx_t *opencl_ctx, const hashconfig_t *hashconfig)
|
||||
|
@ -83,11 +83,9 @@ static const char *USAGE_BIG[] =
|
||||
" -u, --kernel-loops | Num | Manual workload tuning, set innerloop step size to X | -u 256",
|
||||
" --nvidia-spin-damp | Num | Workaround NVidias CPU burning loop bug, in percent | --nvidia-spin-damp=50",
|
||||
" --gpu-temp-disable | | Disable temperature and fanspeed reads and triggers |",
|
||||
#if defined (HAVE_HWMON)
|
||||
" --gpu-temp-abort | Num | Abort if GPU temperature reaches X degrees celsius | --gpu-temp-abort=100",
|
||||
" --gpu-temp-retain | Num | Try to retain GPU temperature at X degrees celsius | --gpu-temp-retain=95",
|
||||
" --powertune-enable | | Enable power tuning, restores settings when finished |",
|
||||
#endif
|
||||
" --scrypt-tmto | Num | Manually override TMTO value for scrypt to X | --scrypt-tmto=3",
|
||||
" -s, --skip | Num | Skip X words from the start | -s 1000000",
|
||||
" -l, --limit | Num | Limit X words from the start + skipped words | -l 1000000",
|
||||
|
@ -193,11 +193,9 @@ int user_options_parse (user_options_t *user_options, int myargc, char **myargv)
|
||||
case IDX_NVIDIA_SPIN_DAMP: user_options->nvidia_spin_damp = atoi (optarg);
|
||||
user_options->nvidia_spin_damp_chgd = true; break;
|
||||
case IDX_GPU_TEMP_DISABLE: user_options->gpu_temp_disable = true; break;
|
||||
#if defined (HAVE_HWMON)
|
||||
case IDX_GPU_TEMP_ABORT: user_options->gpu_temp_abort = atoi (optarg); break;
|
||||
case IDX_GPU_TEMP_RETAIN: user_options->gpu_temp_retain = atoi (optarg); break;
|
||||
case IDX_POWERTUNE_ENABLE: user_options->powertune_enable = true; break;
|
||||
#endif // HAVE_HWMON
|
||||
case IDX_LOGFILE_DISABLE: user_options->logfile_disable = true; break;
|
||||
case IDX_TRUECRYPT_KEYFILES: user_options->truecrypt_keyfiles = optarg; break;
|
||||
case IDX_VERACRYPT_KEYFILES: user_options->veracrypt_keyfiles = optarg; break;
|
||||
@ -234,6 +232,13 @@ int user_options_parse (user_options_t *user_options, int myargc, char **myargv)
|
||||
return -1;
|
||||
}
|
||||
|
||||
#if !defined (HAVE_HWMON)
|
||||
user_options->powertune_enable = false;
|
||||
user_options->gpu_temp_disable = true;
|
||||
user_options->gpu_temp_abort = 0;
|
||||
user_options->gpu_temp_retain = 0;
|
||||
#endif // HAVE_HWMON
|
||||
|
||||
// some options can influence or overwrite other options
|
||||
|
||||
if (user_options->opencl_info == true
|
||||
@ -268,12 +273,10 @@ int user_options_parse (user_options_t *user_options, int myargc, char **myargv)
|
||||
user_options->workload_profile = 3;
|
||||
}
|
||||
|
||||
#if defined (HAVE_HWMON)
|
||||
if (user_options->powertune_enable == true)
|
||||
{
|
||||
user_options->gpu_temp_disable = false;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
if (user_options->keyspace == true)
|
||||
|
Loading…
Reference in New Issue
Block a user