mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-28 00:21:18 +00:00
Merge pull request #2846 from jtojanen/master
Fix access violation in hashconfig_destroy if hashcat_ctx_t is only p…
This commit is contained in:
commit
6c670136c4
@ -495,6 +495,8 @@ void hashconfig_destroy (hashcat_ctx_t *hashcat_ctx)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (module_ctx->hook_extra_params)
|
||||||
|
{
|
||||||
if (hashconfig->hook_extra_param_size)
|
if (hashconfig->hook_extra_param_size)
|
||||||
{
|
{
|
||||||
const int hook_threads = (int) user_options->hook_threads;
|
const int hook_threads = (int) user_options->hook_threads;
|
||||||
@ -503,12 +505,11 @@ void hashconfig_destroy (hashcat_ctx_t *hashcat_ctx)
|
|||||||
{
|
{
|
||||||
hcfree (module_ctx->hook_extra_params[i]);
|
hcfree (module_ctx->hook_extra_params[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
hcfree (module_ctx->hook_extra_params);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
hcfree (module_ctx->hook_extra_params[0]);
|
hcfree (module_ctx->hook_extra_params[0]);
|
||||||
|
}
|
||||||
|
|
||||||
hcfree (module_ctx->hook_extra_params);
|
hcfree (module_ctx->hook_extra_params);
|
||||||
}
|
}
|
||||||
|
@ -2845,27 +2845,6 @@ int user_options_check_files (hashcat_ctx_t *hashcat_ctx)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// single kernel and module existence check to detect "7z e" errors
|
|
||||||
|
|
||||||
char *modulefile = (char *) hcmalloc (HCBUFSIZ_TINY);
|
|
||||||
|
|
||||||
module_filename (folder_config, 0, modulefile, HCBUFSIZ_TINY);
|
|
||||||
|
|
||||||
if (hc_path_exist (modulefile) == false)
|
|
||||||
{
|
|
||||||
event_log_error (hashcat_ctx, "%s: %s", modulefile, strerror (errno));
|
|
||||||
|
|
||||||
event_log_warning (hashcat_ctx, "If you are using the hashcat binary package, this may be an extraction issue.");
|
|
||||||
event_log_warning (hashcat_ctx, "For example, using \"7z e\" instead of using \"7z x\".");
|
|
||||||
event_log_warning (hashcat_ctx, NULL);
|
|
||||||
|
|
||||||
hcfree (modulefile);
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
hcfree (modulefile);
|
|
||||||
|
|
||||||
const bool quiet_save = user_options->quiet;
|
const bool quiet_save = user_options->quiet;
|
||||||
|
|
||||||
user_options->quiet = true;
|
user_options->quiet = true;
|
||||||
@ -2874,30 +2853,46 @@ int user_options_check_files (hashcat_ctx_t *hashcat_ctx)
|
|||||||
|
|
||||||
user_options->quiet = quiet_save;
|
user_options->quiet = quiet_save;
|
||||||
|
|
||||||
if (rc == -1) return -1;
|
if (rc == -1)
|
||||||
|
{
|
||||||
|
// module existence check to detect "7z e" errors
|
||||||
|
|
||||||
|
const module_ctx_t* module_ctx = hashcat_ctx->module_ctx;
|
||||||
|
|
||||||
|
if (module_ctx->module_handle == NULL)
|
||||||
|
{
|
||||||
|
event_log_warning (hashcat_ctx, "If you are using the hashcat binary package, this may be an extraction issue.");
|
||||||
|
event_log_warning (hashcat_ctx, "For example, using \"7z e\" instead of using \"7z x\".");
|
||||||
|
event_log_warning (hashcat_ctx, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
hashconfig_destroy (hashcat_ctx);
|
hashconfig_destroy (hashcat_ctx);
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// same check but for an backend kernel
|
// same check but for an backend kernel
|
||||||
|
|
||||||
char *kernelfile = (char *) hcmalloc (HCBUFSIZ_TINY);
|
const hashconfig_t* hashconfig = hashcat_ctx->hashconfig;
|
||||||
|
|
||||||
generate_source_kernel_filename (false, ATTACK_EXEC_OUTSIDE_KERNEL, ATTACK_KERN_STRAIGHT, 400, 0, folder_config->shared_dir, kernelfile);
|
char kernelfile[HCBUFSIZ_TINY] = { 0 };
|
||||||
|
|
||||||
|
generate_source_kernel_filename (user_options->slow_candidates, hashconfig->attack_exec, user_options_extra->attack_kern, hashconfig->kern_type, hashconfig->opti_type & OPTI_TYPE_OPTIMIZED_KERNEL, folder_config->shared_dir, kernelfile);
|
||||||
|
|
||||||
|
hashconfig_destroy (hashcat_ctx);
|
||||||
|
|
||||||
if (hc_path_read (kernelfile) == false)
|
if (hc_path_read (kernelfile) == false)
|
||||||
{
|
{
|
||||||
event_log_error (hashcat_ctx, "%s: %s", kernelfile, strerror (errno));
|
event_log_error (hashcat_ctx, "%s: %s", kernelfile, strerror(errno));
|
||||||
|
|
||||||
event_log_warning (hashcat_ctx, "If you are using the hashcat binary package, this may be an extraction issue.");
|
event_log_warning (hashcat_ctx, "If you are using the hashcat binary package, this may be an extraction issue.");
|
||||||
event_log_warning (hashcat_ctx, "For example, using \"7z e\" instead of using \"7z x\".");
|
event_log_warning (hashcat_ctx, "For example, using \"7z e\" instead of using \"7z x\".");
|
||||||
event_log_warning (hashcat_ctx, NULL);
|
event_log_warning (hashcat_ctx, NULL);
|
||||||
|
|
||||||
hcfree (kernelfile);
|
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
hcfree (kernelfile);
|
|
||||||
|
|
||||||
// loopback - can't check at this point
|
// loopback - can't check at this point
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user