1
0
mirror of https://github.com/hashcat/hashcat.git synced 2024-11-15 20:39:17 +00:00
hashcat/src/shared.c

370 lines
6.4 KiB
C
Raw Normal View History

2015-12-04 14:47:52 +00:00
/**
* Author......: See docs/credits.txt
2015-12-04 14:47:52 +00:00
* License.....: MIT
*/
#include "common.h"
2016-09-16 15:01:18 +00:00
#include "types.h"
#include "shared.h"
2015-12-04 14:47:52 +00:00
2016-09-20 15:04:31 +00:00
bool is_power_of_2 (const u32 v)
{
return (v && !(v & (v - 1)));
}
2016-09-08 08:01:49 +00:00
u32 mydivc32 (const u32 dividend, const u32 divisor)
{
2016-09-08 08:01:49 +00:00
u32 quotient = dividend / divisor;
2016-09-08 08:01:49 +00:00
if (dividend % divisor) quotient++;
2016-09-08 08:01:49 +00:00
return quotient;
}
2016-09-08 08:01:49 +00:00
u64 mydivc64 (const u64 dividend, const u64 divisor)
{
u64 quotient = dividend / divisor;
2016-09-08 08:01:49 +00:00
if (dividend % divisor) quotient++;
return quotient;
}
char *filename_from_filepath (char *filepath)
{
char *ptr = NULL;
if ((ptr = strrchr (filepath, '/')) != NULL)
{
ptr++;
}
else if ((ptr = strrchr (filepath, '\\')) != NULL)
{
ptr++;
}
else
{
ptr = filepath;
}
return ptr;
}
2016-09-30 15:41:40 +00:00
void naive_replace (char *s, const char key_char, const char replace_char)
2016-09-08 08:01:49 +00:00
{
const size_t len = strlen (s);
for (size_t in = 0; in < len; in++)
{
2016-09-30 15:41:40 +00:00
const char c = s[in];
2016-09-08 08:01:49 +00:00
if (c == key_char)
{
2016-09-08 08:01:49 +00:00
s[in] = replace_char;
}
}
2016-09-08 08:01:49 +00:00
}
2016-09-30 15:41:40 +00:00
void naive_escape (char *s, size_t s_max, const char key_char, const char escape_char)
2016-09-08 08:01:49 +00:00
{
char s_escaped[1024] = { 0 };
2016-09-08 08:01:49 +00:00
size_t s_escaped_max = sizeof (s_escaped);
2016-09-08 08:01:49 +00:00
const size_t len = strlen (s);
2016-09-08 08:01:49 +00:00
for (size_t in = 0, out = 0; in < len; in++, out++)
{
2016-09-30 15:41:40 +00:00
const char c = s[in];
2016-09-08 08:01:49 +00:00
if (c == key_char)
{
s_escaped[out] = escape_char;
2015-12-04 14:47:52 +00:00
2016-09-08 08:01:49 +00:00
out++;
}
2015-12-04 14:47:52 +00:00
2016-09-08 08:01:49 +00:00
if (out == s_escaped_max - 2) break;
2015-12-04 14:47:52 +00:00
2016-09-08 08:01:49 +00:00
s_escaped[out] = c;
}
strncpy (s, s_escaped, s_max - 1);
}
2015-12-04 14:47:52 +00:00
2016-12-23 23:40:40 +00:00
void hc_asprintf (char **strp, const char *fmt, ...)
{
va_list args;
va_start (args, fmt);
int rc __attribute__((unused));
2016-12-23 23:57:38 +00:00
rc = vasprintf (strp, fmt, args);
2016-12-23 23:40:40 +00:00
va_end (args);
}
#if defined (_POSIX)
int hc_stat (const char *pathname, hc_stat_t *buf)
{
return stat (pathname, buf);
}
int hc_fstat (int fd, hc_stat_t *buf)
{
return fstat (fd, buf);
}
#endif
#if defined (_WIN)
int hc_stat (const char *pathname, hc_stat_t *buf)
{
return stat64 (pathname, buf);
}
int hc_fstat (int fd, hc_stat_t *buf)
{
return fstat64 (fd, buf);
}
#endif
void hc_sleep_msec (const u32 msec)
2016-09-08 08:48:38 +00:00
{
#if defined (_WIN)
Sleep (msec);
#else
usleep (msec * 1000);
2016-09-08 08:48:38 +00:00
#endif
}
2016-09-08 08:01:49 +00:00
2016-09-30 15:41:40 +00:00
void hc_sleep (const u32 sec)
{
#if defined (_WIN)
Sleep (sec * 1000);
#else
2016-09-08 08:48:38 +00:00
sleep (sec);
#endif
2016-09-08 08:48:38 +00:00
}
2016-09-28 21:53:46 +00:00
#if defined (_WIN)
#define __WINDOWS__
#endif
#include "sort_r.h"
#if defined (_WIN)
#undef __WINDOWS__
#endif
void hc_qsort_r (void *base, size_t nmemb, size_t size, int (*compar) (const void *, const void *, void *), void *arg)
{
sort_r (base, nmemb, size, compar, arg);
}
void *hc_bsearch_r (const void *key, const void *base, size_t nmemb, size_t size, int (*compar) (const void *, const void *, void *), void *arg)
{
for (size_t l = 0, r = nmemb; r; r >>= 1)
{
const size_t m = r >> 1;
const size_t c = l + m;
const char *next = (char *) base + (c * size);
const int cmp = (*compar) (key, next, arg);
if (cmp > 0)
{
l += m + 1;
r--;
}
if (cmp == 0) return ((void *) next);
}
return (NULL);
}
bool hc_path_is_file (const char *path)
{
hc_stat_t s;
if (hc_stat (path, &s) == -1) return false;
if (S_ISREG (s.st_mode)) return true;
return false;
}
bool hc_path_is_directory (const char *path)
{
hc_stat_t s;
if (hc_stat (path, &s) == -1) return false;
if (S_ISDIR (s.st_mode)) return true;
return false;
}
bool hc_path_is_empty (const char *path)
{
hc_stat_t s;
if (hc_stat (path, &s) == -1) return false;
if (s.st_size == 0) return true;
return false;
}
bool hc_path_exist (const char *path)
{
if (access (path, F_OK) == -1) return false;
return true;
}
bool hc_path_read (const char *path)
{
if (access (path, R_OK) == -1) return false;
return true;
}
bool hc_path_write (const char *path)
{
if (access (path, W_OK) == -1) return false;
return true;
}
bool hc_path_create (const char *path)
{
if (hc_path_exist (path) == true) return false;
const int fd = creat (path, S_IRUSR | S_IWUSR);
if (fd == -1) return false;
close (fd);
unlink (path);
return true;
}
2016-09-28 21:53:46 +00:00
void setup_environment_variables ()
{
char *compute = getenv ("COMPUTE");
if (compute)
{
static char display[100];
u32 compute_len_max = sizeof (display);
2016-09-28 21:53:46 +00:00
// we only use this check to avoid "tainted string" warnings
u32 compute_len = strnlen (compute, compute_len_max);
if (compute_len > 0) // should be always true
{
if (compute_len < compute_len_max) // some upper bound is always good
{
snprintf (display, compute_len_max, "DISPLAY=%s", compute);
putenv (display);
}
}
2016-09-28 21:53:46 +00:00
}
else
{
if (getenv ("DISPLAY") == NULL)
putenv ((char *) "DISPLAY=:0");
}
if (getenv ("GPU_FORCE_64BIT_PTR") == NULL)
putenv ((char *) "GPU_FORCE_64BIT_PTR=1");
2016-09-28 21:53:46 +00:00
if (getenv ("GPU_MAX_ALLOC_PERCENT") == NULL)
putenv ((char *) "GPU_MAX_ALLOC_PERCENT=100");
if (getenv ("GPU_SINGLE_ALLOC_PERCENT") == NULL)
putenv ((char *) "GPU_SINGLE_ALLOC_PERCENT=100");
if (getenv ("GPU_MAX_HEAP_SIZE") == NULL)
putenv ((char *) "GPU_MAX_HEAP_SIZE=100");
if (getenv ("CPU_FORCE_64BIT_PTR") == NULL)
putenv ((char *) "CPU_FORCE_64BIT_PTR=1");
2016-09-28 21:53:46 +00:00
if (getenv ("CPU_MAX_ALLOC_PERCENT") == NULL)
putenv ((char *) "CPU_MAX_ALLOC_PERCENT=100");
if (getenv ("CPU_SINGLE_ALLOC_PERCENT") == NULL)
putenv ((char *) "CPU_SINGLE_ALLOC_PERCENT=100");
if (getenv ("CPU_MAX_HEAP_SIZE") == NULL)
putenv ((char *) "CPU_MAX_HEAP_SIZE=100");
2016-09-28 21:53:46 +00:00
if (getenv ("GPU_USE_SYNC_OBJECTS") == NULL)
putenv ((char *) "GPU_USE_SYNC_OBJECTS=1");
if (getenv ("CUDA_CACHE_DISABLE") == NULL)
putenv ((char *) "CUDA_CACHE_DISABLE=1");
if (getenv ("POCL_KERNEL_CACHE") == NULL)
putenv ((char *) "POCL_KERNEL_CACHE=0");
}
void setup_umask ()
{
umask (077);
}
void setup_seeding (const bool rp_gen_seed_chgd, const u32 rp_gen_seed)
{
if (rp_gen_seed_chgd == true)
{
srand (rp_gen_seed);
}
else
{
time_t ts;
time (&ts);
srand (ts);
}
2017-02-15 11:36:03 +00:00
}
u32 get_random_num (const u32 min, const u32 max)
{
if (min == max) return (min);
2017-02-15 12:26:02 +00:00
const u32 low = max - min;
2017-02-15 11:36:03 +00:00
if (low == 0) return (0);
#if defined (__linux__)
u32 data;
FILE *fp = fopen ("/dev/urandom", "rb");
if (fp == NULL) return (0);
const int nread = fread (&data, sizeof (u32), 1, fp);
fclose (fp);
if (nread != 1) return 0;
u64 r = data % low; r += min;
return (u32) r;
#else
return (((u32) rand () % (max - min)) + min);
#endif
}