mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-22 05:31:11 +00:00
Make tuning_db support modular
This commit is contained in:
parent
1585768044
commit
eb6dffd52a
@ -11,9 +11,9 @@
|
|||||||
|
|
||||||
#define TUNING_DB_FILE "hashcat.hctune"
|
#define TUNING_DB_FILE "hashcat.hctune"
|
||||||
|
|
||||||
|
int tuning_db_init (tuning_db_t *tuning_db, const user_options_t *user_options, const folder_config_t *folder_config);
|
||||||
void tuning_db_destroy (tuning_db_t *tuning_db);
|
void tuning_db_destroy (tuning_db_t *tuning_db);
|
||||||
tuning_db_t *tuning_db_alloc (FILE *fp);
|
|
||||||
tuning_db_t *tuning_db_init (const char *tuning_db_file);
|
|
||||||
tuning_db_entry_t *tuning_db_search (const tuning_db_t *tuning_db, const char *device_name, const cl_device_type device_type, int attack_mode, const int hash_type);
|
tuning_db_entry_t *tuning_db_search (const tuning_db_t *tuning_db, const char *device_name, const cl_device_type device_type, int attack_mode, const int hash_type);
|
||||||
|
|
||||||
#endif // _TUNINGDB_H
|
#endif // _TUNINGDB_H
|
||||||
|
@ -991,6 +991,8 @@ typedef struct
|
|||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
|
bool enabled;
|
||||||
|
|
||||||
tuning_db_alias_t *alias_buf;
|
tuning_db_alias_t *alias_buf;
|
||||||
int alias_cnt;
|
int alias_cnt;
|
||||||
|
|
||||||
@ -1353,6 +1355,7 @@ typedef struct
|
|||||||
status_ctx_t *status_ctx;
|
status_ctx_t *status_ctx;
|
||||||
session_ctx_t *session_ctx;
|
session_ctx_t *session_ctx;
|
||||||
straight_ctx_t *straight_ctx;
|
straight_ctx_t *straight_ctx;
|
||||||
|
tuning_db_t *tuning_db;
|
||||||
user_options_extra_t *user_options_extra;
|
user_options_extra_t *user_options_extra;
|
||||||
user_options_t *user_options;
|
user_options_t *user_options;
|
||||||
|
|
||||||
|
@ -1777,11 +1777,13 @@ int main (int argc, char **argv)
|
|||||||
* tuning db
|
* tuning db
|
||||||
*/
|
*/
|
||||||
|
|
||||||
char tuning_db_file[256] = { 0 };
|
tuning_db_t *tuning_db = (tuning_db_t *) mymalloc (sizeof (tuning_db_t));
|
||||||
|
|
||||||
snprintf (tuning_db_file, sizeof (tuning_db_file) - 1, "%s/%s", folder_config->shared_dir, TUNING_DB_FILE);
|
const int rc_tuning_db = tuning_db_init (tuning_db, user_options, folder_config);
|
||||||
|
|
||||||
tuning_db_t *tuning_db = tuning_db_init (tuning_db_file);
|
data.tuning_db = tuning_db;
|
||||||
|
|
||||||
|
if (rc_tuning_db == -1) return -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* induction directory
|
* induction directory
|
||||||
|
@ -50,34 +50,32 @@ static int sort_by_tuning_db_entry (const void *v1, const void *v2)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void tuning_db_destroy (tuning_db_t *tuning_db)
|
int tuning_db_init (tuning_db_t *tuning_db, const user_options_t *user_options, const folder_config_t *folder_config)
|
||||||
{
|
{
|
||||||
int i;
|
tuning_db->enabled = false;
|
||||||
|
|
||||||
for (i = 0; i < tuning_db->alias_cnt; i++)
|
if (user_options->keyspace == true) return 0;
|
||||||
|
if (user_options->left == true) return 0;
|
||||||
|
if (user_options->show == true) return 0;
|
||||||
|
if (user_options->usage == true) return 0;
|
||||||
|
if (user_options->version == true) return 0;
|
||||||
|
|
||||||
|
tuning_db->enabled = true;
|
||||||
|
|
||||||
|
char *tuning_db_file = (char *) mymalloc (HCBUFSIZ_TINY);
|
||||||
|
|
||||||
|
snprintf (tuning_db_file, HCBUFSIZ_TINY - 1, "%s/%s", folder_config->shared_dir, TUNING_DB_FILE);
|
||||||
|
|
||||||
|
FILE *fp = fopen (tuning_db_file, "rb");
|
||||||
|
|
||||||
|
if (fp == NULL)
|
||||||
{
|
{
|
||||||
tuning_db_alias_t *alias = &tuning_db->alias_buf[i];
|
log_error ("%s: %s", tuning_db_file, strerror (errno));
|
||||||
|
|
||||||
myfree (alias->device_name);
|
return -1;
|
||||||
myfree (alias->alias_name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < tuning_db->entry_cnt; i++)
|
myfree (tuning_db_file);
|
||||||
{
|
|
||||||
tuning_db_entry_t *entry = &tuning_db->entry_buf[i];
|
|
||||||
|
|
||||||
myfree (entry->device_name);
|
|
||||||
}
|
|
||||||
|
|
||||||
myfree (tuning_db->alias_buf);
|
|
||||||
myfree (tuning_db->entry_buf);
|
|
||||||
|
|
||||||
myfree (tuning_db);
|
|
||||||
}
|
|
||||||
|
|
||||||
tuning_db_t *tuning_db_alloc (FILE *fp)
|
|
||||||
{
|
|
||||||
tuning_db_t *tuning_db = (tuning_db_t *) mymalloc (sizeof (tuning_db_t));
|
|
||||||
|
|
||||||
int num_lines = count_lines (fp);
|
int num_lines = count_lines (fp);
|
||||||
|
|
||||||
@ -89,22 +87,6 @@ tuning_db_t *tuning_db_alloc (FILE *fp)
|
|||||||
tuning_db->entry_buf = (tuning_db_entry_t *) mycalloc (num_lines + 1, sizeof (tuning_db_entry_t));
|
tuning_db->entry_buf = (tuning_db_entry_t *) mycalloc (num_lines + 1, sizeof (tuning_db_entry_t));
|
||||||
tuning_db->entry_cnt = 0;
|
tuning_db->entry_cnt = 0;
|
||||||
|
|
||||||
return tuning_db;
|
|
||||||
}
|
|
||||||
|
|
||||||
tuning_db_t *tuning_db_init (const char *tuning_db_file)
|
|
||||||
{
|
|
||||||
FILE *fp = fopen (tuning_db_file, "rb");
|
|
||||||
|
|
||||||
if (fp == NULL)
|
|
||||||
{
|
|
||||||
log_error ("%s: %s", tuning_db_file, strerror (errno));
|
|
||||||
|
|
||||||
exit (-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
tuning_db_t *tuning_db = tuning_db_alloc (fp);
|
|
||||||
|
|
||||||
rewind (fp);
|
rewind (fp);
|
||||||
|
|
||||||
int line_num = 0;
|
int line_num = 0;
|
||||||
@ -253,7 +235,34 @@ tuning_db_t *tuning_db_init (const char *tuning_db_file)
|
|||||||
qsort (tuning_db->alias_buf, tuning_db->alias_cnt, sizeof (tuning_db_alias_t), sort_by_tuning_db_alias);
|
qsort (tuning_db->alias_buf, tuning_db->alias_cnt, sizeof (tuning_db_alias_t), sort_by_tuning_db_alias);
|
||||||
qsort (tuning_db->entry_buf, tuning_db->entry_cnt, sizeof (tuning_db_entry_t), sort_by_tuning_db_entry);
|
qsort (tuning_db->entry_buf, tuning_db->entry_cnt, sizeof (tuning_db_entry_t), sort_by_tuning_db_entry);
|
||||||
|
|
||||||
return tuning_db;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void tuning_db_destroy (tuning_db_t *tuning_db)
|
||||||
|
{
|
||||||
|
if (tuning_db->enabled == false) return;
|
||||||
|
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < tuning_db->alias_cnt; i++)
|
||||||
|
{
|
||||||
|
tuning_db_alias_t *alias = &tuning_db->alias_buf[i];
|
||||||
|
|
||||||
|
myfree (alias->device_name);
|
||||||
|
myfree (alias->alias_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < tuning_db->entry_cnt; i++)
|
||||||
|
{
|
||||||
|
tuning_db_entry_t *entry = &tuning_db->entry_buf[i];
|
||||||
|
|
||||||
|
myfree (entry->device_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
myfree (tuning_db->alias_buf);
|
||||||
|
myfree (tuning_db->entry_buf);
|
||||||
|
|
||||||
|
myfree (tuning_db);
|
||||||
}
|
}
|
||||||
|
|
||||||
tuning_db_entry_t *tuning_db_search (const tuning_db_t *tuning_db, const char *device_name, const cl_device_type device_type, int attack_mode, const int hash_type)
|
tuning_db_entry_t *tuning_db_search (const tuning_db_t *tuning_db, const char *device_name, const cl_device_type device_type, int attack_mode, const int hash_type)
|
||||||
|
Loading…
Reference in New Issue
Block a user