1
0
mirror of https://github.com/hashcat/hashcat.git synced 2025-01-03 04:11:06 +00:00

Added option --gpu-platform to select a single OpenCL platform in case multiple OpenCL platforms are present

This commit is contained in:
jsteube 2015-12-23 18:02:01 +01:00
parent c17bf5e865
commit f1cdf15540
2 changed files with 36 additions and 3 deletions

View File

@ -10,6 +10,10 @@ File.: Host
Desc.: Implemented a new feature that allows to quit at next restore point update (and disable it) Desc.: Implemented a new feature that allows to quit at next restore point update (and disable it)
Issue: 10 Issue: 10
Type.: Feature
File.: Host
Desc.: Added option --gpu-platform to select a single OpenCL platform in case multiple OpenCL platforms are present
Type.: Bug Type.: Bug
File.: Host File.: Host
Desc.: Fixed a bug in combination of --restore and a user immediately aborting the session after restart Desc.: Fixed a bug in combination of --restore and a user immediately aborting the session after restart

View File

@ -383,7 +383,8 @@ const char *USAGE_BIG[] =
" --bitmap-min=NUM Minimum number of bits allowed for bitmaps", " --bitmap-min=NUM Minimum number of bits allowed for bitmaps",
" --bitmap-max=NUM Maximum number of bits allowed for bitmaps", " --bitmap-max=NUM Maximum number of bits allowed for bitmaps",
" --cpu-affinity=STR Locks to CPU devices, seperate with comma", " --cpu-affinity=STR Locks to CPU devices, seperate with comma",
" -d, --gpu-devices=STR Devices to use, separate with comma", " -d, --gpu-devices=STR OpenCL devices to use, separate with comma",
" --gpu-platform=STR OpenCL platform to use, in case multiple OpenCL platforms are present",
" -w, --workload-profile=NUM Enable a specific workload profile, see references below", " -w, --workload-profile=NUM Enable a specific workload profile, see references below",
" -n, --gpu-accel=NUM Workload tuning: 1, 8, 40, 80, 160", " -n, --gpu-accel=NUM Workload tuning: 1, 8, 40, 80, 160",
" -u, --gpu-loops=NUM Workload fine-tuning: 8 - 1024", " -u, --gpu-loops=NUM Workload fine-tuning: 8 - 1024",
@ -5070,6 +5071,7 @@ int main (int argc, char **argv)
uint increment_max = INCREMENT_MAX; uint increment_max = INCREMENT_MAX;
char *cpu_affinity = NULL; char *cpu_affinity = NULL;
char *gpu_devices = NULL; char *gpu_devices = NULL;
char *gpu_platform = NULL;
char *truecrypt_keyfiles = NULL; char *truecrypt_keyfiles = NULL;
uint workload_profile = WORKLOAD_PROFILE; uint workload_profile = WORKLOAD_PROFILE;
uint gpu_accel = GPU_ACCEL; uint gpu_accel = GPU_ACCEL;
@ -5143,6 +5145,7 @@ int main (int argc, char **argv)
#define IDX_MARKOV_HCSTAT 0xff24 #define IDX_MARKOV_HCSTAT 0xff24
#define IDX_CPU_AFFINITY 0xff25 #define IDX_CPU_AFFINITY 0xff25
#define IDX_GPU_DEVICES 'd' #define IDX_GPU_DEVICES 'd'
#define IDX_GPU_PLATFORM 0xff72
#define IDX_WORKLOAD_PROFILE 'w' #define IDX_WORKLOAD_PROFILE 'w'
#define IDX_GPU_ACCEL 'n' #define IDX_GPU_ACCEL 'n'
#define IDX_GPU_LOOPS 'u' #define IDX_GPU_LOOPS 'u'
@ -5222,6 +5225,7 @@ int main (int argc, char **argv)
{"markov-hcstat", required_argument, 0, IDX_MARKOV_HCSTAT}, {"markov-hcstat", required_argument, 0, IDX_MARKOV_HCSTAT},
{"cpu-affinity", required_argument, 0, IDX_CPU_AFFINITY}, {"cpu-affinity", required_argument, 0, IDX_CPU_AFFINITY},
{"gpu-devices", required_argument, 0, IDX_GPU_DEVICES}, {"gpu-devices", required_argument, 0, IDX_GPU_DEVICES},
{"gpu-platform", required_argument, 0, IDX_GPU_PLATFORM},
{"workload-profile", required_argument, 0, IDX_WORKLOAD_PROFILE}, {"workload-profile", required_argument, 0, IDX_WORKLOAD_PROFILE},
{"gpu-accel", required_argument, 0, IDX_GPU_ACCEL}, {"gpu-accel", required_argument, 0, IDX_GPU_ACCEL},
{"gpu-loops", required_argument, 0, IDX_GPU_LOOPS}, {"gpu-loops", required_argument, 0, IDX_GPU_LOOPS},
@ -5450,6 +5454,7 @@ int main (int argc, char **argv)
case IDX_HEX_WORDLIST: hex_wordlist = 1; break; case IDX_HEX_WORDLIST: hex_wordlist = 1; break;
case IDX_CPU_AFFINITY: cpu_affinity = optarg; break; case IDX_CPU_AFFINITY: cpu_affinity = optarg; break;
case IDX_GPU_DEVICES: gpu_devices = optarg; break; case IDX_GPU_DEVICES: gpu_devices = optarg; break;
case IDX_GPU_PLATFORM: gpu_platform = optarg; break;
case IDX_WORKLOAD_PROFILE: workload_profile = atoi (optarg); break; case IDX_WORKLOAD_PROFILE: workload_profile = atoi (optarg); break;
case IDX_GPU_ACCEL: gpu_accel = atoi (optarg); case IDX_GPU_ACCEL: gpu_accel = atoi (optarg);
gpu_accel_chgd = 1; break; gpu_accel_chgd = 1; break;
@ -6331,6 +6336,7 @@ int main (int argc, char **argv)
logfile_top_string (custom_charset_4); logfile_top_string (custom_charset_4);
logfile_top_string (debug_file); logfile_top_string (debug_file);
logfile_top_string (gpu_devices); logfile_top_string (gpu_devices);
logfile_top_string (gpu_platform);
logfile_top_string (induction_dir); logfile_top_string (induction_dir);
logfile_top_string (markov_hcstat); logfile_top_string (markov_hcstat);
logfile_top_string (outfile); logfile_top_string (outfile);
@ -12254,14 +12260,37 @@ int main (int argc, char **argv)
return (-1); return (-1);
} }
uint CL_platform_sel = 0;
if (CL_platforms_cnt > 1) if (CL_platforms_cnt > 1)
{ {
log_error ("ERROR: Too many OpenCL compatible platforms found"); if (gpu_platform == NULL)
{
log_error ("ERROR: Too many OpenCL compatible platforms found");
log_error (" Please select a single platform using the --gpu-platform option");
log_error ("");
log_error ("Available OpenCL platforms:");
for (uint i = 0; i < CL_platforms_cnt; i++)
{
char CL_platform_vendor[INFOSZ];
memset (CL_platform_vendor, 0, sizeof (CL_platform_vendor));
hc_clGetPlatformInfo (CL_platforms[i], CL_PLATFORM_VENDOR, sizeof (CL_platform_vendor), CL_platform_vendor, NULL);
printf ("* %d = %s\n", i + 1, CL_platform_vendor);
}
}
else
{
CL_platform_sel = atoi (gpu_platform);
}
return (-1); return (-1);
} }
cl_platform_id CL_platform = CL_platforms[0]; cl_platform_id CL_platform = CL_platforms[CL_platform_sel];
char CL_platform_vendor[INFOSZ]; char CL_platform_vendor[INFOSZ];