1
0
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:
jsteube 2016-09-30 12:58:06 +02:00
parent 1585768044
commit eb6dffd52a
4 changed files with 58 additions and 44 deletions

View File

@ -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

View File

@ -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;

View File

@ -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

View File

@ -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)