1
mirror of https://github.com/hashcat/hashcat synced 2025-01-10 17:16:22 +01:00

file locking: check return value of fcntl ()

This commit is contained in:
philsmd 2017-02-14 15:15:50 +01:00
parent cdfabe333f
commit c440dec867
No known key found for this signature in database
GPG Key ID: 4F25D016D9D6A8AF
5 changed files with 19 additions and 7 deletions

View File

@ -74,6 +74,7 @@
- OpenCL Kernel: Renumbered hash-mode 7600 to 4521
- OpenCL Device: Do a check on available constant memory size and abort if it's less than 64kB
- File Reads: Improved error detection on file reads, especially when getting the file stats
- File Locking: Improved error detection on file locks
- Sessions: Move out handling of multiple instance from restore file into separate pidfile
- Threads: Restored strerror as %m is unsupported by the BSDs
- Wordlists: Disable dictstat handling for hash-mode 3000 as it virtually creates words in the wordlist which is not the case for other modes

View File

@ -13,7 +13,7 @@
#include <errno.h>
#include <fcntl.h>
int lock_file (FILE *fp);
void unlock_file (FILE *fp);
int lock_file (FILE *fp);
int unlock_file (FILE *fp);
#endif // _LOCKING_H

View File

@ -27,7 +27,7 @@ int lock_file (FILE *fp)
return 0;
}
void unlock_file (FILE *fp)
int unlock_file (FILE *fp)
{
struct flock lock;
@ -35,7 +35,12 @@ void unlock_file (FILE *fp)
lock.l_type = F_UNLCK;
fcntl (fileno (fp), F_SETLK, &lock);
if (fcntl (fileno (fp), F_SETLK, &lock))
{
return -1;
}
return 0;
}
#else
@ -47,7 +52,7 @@ int lock_file (MAYBE_UNUSED FILE *fp)
return 0;
}
void unlock_file (MAYBE_UNUSED FILE *fp)
int unlock_file (MAYBE_UNUSED FILE *fp)
{
// we should put windows specific code here
}

View File

@ -163,7 +163,10 @@ void loopback_write_append (hashcat_ctx_t *hashcat_ctx, const u8 *plain_ptr, con
fflush (fp);
unlock_file (fp);
if (unlock_file (fp))
{
event_log_error (hashcat_ctx, "%s: Failed to unlock file", loopback_ctx->filename);
}
loopback_ctx->unused = false;
}

View File

@ -271,7 +271,10 @@ void potfile_write_append (hashcat_ctx_t *hashcat_ctx, const char *out_buf, u8 *
fflush (potfile_ctx->fp);
unlock_file (potfile_ctx->fp);
if (unlock_file (potfile_ctx->fp))
{
event_log_error (hashcat_ctx, "%s: Failed to unlock file", potfile_ctx->filename);
}
}
void potfile_update_hash (hashcat_ctx_t *hashcat_ctx, hash_t *found, char *line_pw_buf, int line_pw_len)