1
0
mirror of https://github.com/hashcat/hashcat.git synced 2025-01-25 23:21:05 +00:00

Fixed mask length check in hybrid attack-modes: Do not include hash-mode dependant mask length checks

This commit is contained in:
jsteube 2016-12-18 16:01:23 +01:00
parent 4b9cb7bbcf
commit 24a3aff5ea
2 changed files with 10 additions and 5 deletions

View File

@ -22,6 +22,7 @@
- Fixed kernel loops in --increment mode leading to slower performance - Fixed kernel loops in --increment mode leading to slower performance
- Fixed custom char parsing code in maskfiles in --increment mode: Custom charset wasn't used - Fixed custom char parsing code in maskfiles in --increment mode: Custom charset wasn't used
- Fixed hex output of plaintext in case --outfile-format 4, 5, 6 or 7 was used - Fixed hex output of plaintext in case --outfile-format 4, 5, 6 or 7 was used
- Fixed mask length check in hybrid attack-modes: Do not include hash-mode dependant mask length checks
- Removed access to readlink() on FreeBSD: Causes problem building hashcat - Removed access to readlink() on FreeBSD: Causes problem building hashcat
## ##

View File

@ -936,15 +936,19 @@ static int mask_append (hashcat_ctx_t *hashcat_ctx, const char *mask, const char
{ {
const u32 mask_length = mp_get_length (mask); const u32 mask_length = mp_get_length (mask);
const u32 pw_min = hashconfig->pw_min;
const u32 pw_max = hashconfig->pw_max;
u32 increment_min = user_options->increment_min; u32 increment_min = user_options->increment_min;
u32 increment_max = user_options->increment_max; u32 increment_max = user_options->increment_max;
increment_max = MIN (increment_max, mask_length);
if (user_options->attack_mode == ATTACK_MODE_BF)
{
const u32 pw_min = hashconfig->pw_min;
const u32 pw_max = hashconfig->pw_max;
increment_min = MAX (increment_min, pw_min); increment_min = MAX (increment_min, pw_min);
increment_max = MIN (increment_max, pw_max); increment_max = MIN (increment_max, pw_max);
increment_max = MIN (increment_max, mask_length); }
for (u32 increment_len = increment_min; increment_len <= increment_max; increment_len++) for (u32 increment_len = increment_min; increment_len <= increment_max; increment_len++)
{ {