mirror of
https://github.com/hashcat/hashcat.git
synced 2024-12-23 15:18:16 +00:00
Workaround OpenCL runtimes that do not accept -I parameter in the OpenCL kernel build options even if this is an OpenCL standard option
This commit is contained in:
parent
e2dbaa6efa
commit
e56a4e9c60
@ -15,6 +15,7 @@
|
|||||||
- Allow the use of enc_id == 0 in hash-mode 10600 and 10700 as it takes no part in the actual computation
|
- Allow the use of enc_id == 0 in hash-mode 10600 and 10700 as it takes no part in the actual computation
|
||||||
- Get rid of exit() calls in OpenCL wrapper library with the goal to have a better control which error can be ignored under special circumstances
|
- Get rid of exit() calls in OpenCL wrapper library with the goal to have a better control which error can be ignored under special circumstances
|
||||||
- Do not error and exit if an OpenCL platform has no devices, just print a warning and continue with the next platform
|
- Do not error and exit if an OpenCL platform has no devices, just print a warning and continue with the next platform
|
||||||
|
- Workaround OpenCL runtimes that do not accept -I parameter in the OpenCL kernel build options even if this is an OpenCL standard option
|
||||||
|
|
||||||
##
|
##
|
||||||
## Bugs
|
## Bugs
|
||||||
|
@ -6147,6 +6147,22 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
umask (077);
|
umask (077);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* There's some buggy OpenCL runtime that do not support -I.
|
||||||
|
* A workaround is to chdir() to the OpenCL folder,
|
||||||
|
* then compile the kernels,
|
||||||
|
* then chdir() back to where we came from so we need to save it first
|
||||||
|
*/
|
||||||
|
|
||||||
|
char cwd[1024];
|
||||||
|
|
||||||
|
if (getcwd (cwd, sizeof (cwd) - 1) == NULL)
|
||||||
|
{
|
||||||
|
log_error ("ERROR: getcwd(): %s", strerror (errno));
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Real init
|
* Real init
|
||||||
*/
|
*/
|
||||||
@ -16140,17 +16156,20 @@ int main (int argc, char **argv)
|
|||||||
"inc_vendor.cl",
|
"inc_vendor.cl",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (chdir (cpath_real) == -1)
|
||||||
|
{
|
||||||
|
log_error ("ERROR: %s: %s", cpath_real, strerror (errno));
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
for (int i = 0; i < files_cnt; i++)
|
for (int i = 0; i < files_cnt; i++)
|
||||||
{
|
{
|
||||||
char path[1024] = { 0 };
|
FILE *fd = fopen (files_names[i], "r");
|
||||||
|
|
||||||
snprintf (path, sizeof (path) - 1, "%s/%s", cpath_real, files_names[i]);
|
|
||||||
|
|
||||||
FILE *fd = fopen (path, "r");
|
|
||||||
|
|
||||||
if (fd == NULL)
|
if (fd == NULL)
|
||||||
{
|
{
|
||||||
log_error ("ERROR: %s: fopen(): %s", path, strerror (errno));
|
log_error ("ERROR: %s: fopen(): %s", files_names[i], strerror (errno));
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -16161,7 +16180,7 @@ int main (int argc, char **argv)
|
|||||||
|
|
||||||
if (n != 1)
|
if (n != 1)
|
||||||
{
|
{
|
||||||
log_error ("ERROR: %s: fread(): %s", path, strerror (errno));
|
log_error ("ERROR: %s: fread(): %s", files_names[i], strerror (errno));
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -16718,6 +16737,15 @@ int main (int argc, char **argv)
|
|||||||
local_free (kernel_sources);
|
local_free (kernel_sources);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// return back to the folder we came from initially (workaround)
|
||||||
|
|
||||||
|
if (chdir (cwd) == -1)
|
||||||
|
{
|
||||||
|
log_error ("ERROR: %s: %s", cwd, strerror (errno));
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
// some algorithm collide too fast, make that impossible
|
// some algorithm collide too fast, make that impossible
|
||||||
|
|
||||||
if (benchmark == 1)
|
if (benchmark == 1)
|
||||||
|
Loading…
Reference in New Issue
Block a user