1
0
mirror of https://github.com/hashcat/hashcat.git synced 2024-11-15 12:29:35 +00:00
hashcat/include/shared.h

2301 lines
91 KiB
C

/**
* Author......: Jens Steube <jens.steube@gmail.com>
* License.....: MIT
*/
#ifndef SHARED_H
#define SHARED_H
#include <common.h>
#include <constants.h>
/**
* thread management
*/
#ifdef _WIN
#define hc_timer_get(a,r) { hc_timer_t hr_freq; QueryPerformanceFrequency (&hr_freq); hc_timer_t hr_tmp; hc_timer_set (&hr_tmp); (r) = (double) ((double) (hr_tmp.QuadPart - (a).QuadPart) / (double) (hr_freq.QuadPart / 1000)); }
#define hc_timer_set(a) { QueryPerformanceCounter ((a)); }
#elif _POSIX
#define hc_timer_get(a,r) { hc_timer_t hr_tmp; hc_timer_set (&hr_tmp); (r) = (double) (((hr_tmp.tv_sec - (a).tv_sec) * 1000) + ((double) (hr_tmp.tv_usec - (a).tv_usec) / 1000)); }
#define hc_timer_set(a) { gettimeofday ((a), NULL); }
#endif
#ifdef _WIN
#define hc_thread_create(t,f,a) t = CreateThread (NULL, 0, (LPTHREAD_START_ROUTINE) &f, a, 0, NULL)
#define hc_thread_wait(n,a) for (uint i = 0; i < n; i++) WaitForSingleObject ((a)[i], INFINITE)
#define hc_thread_exit(t) ExitThread (t)
#define hc_thread_mutex_lock(m) EnterCriticalSection (&m)
#define hc_thread_mutex_unlock(m) LeaveCriticalSection (&m)
#define hc_thread_mutex_init(m) InitializeCriticalSection (&m)
#define hc_thread_mutex_delete(m) DeleteCriticalSection (&m)
#elif _POSIX
#define hc_thread_create(t,f,a) pthread_create (&t, NULL, f, a)
#define hc_thread_wait(n,a) for (uint i = 0; i < n; i++) pthread_join ((a)[i], NULL)
#define hc_thread_exit(t) pthread_exit (&t)
#define hc_thread_mutex_lock(m) pthread_mutex_lock (&m)
#define hc_thread_mutex_unlock(m) pthread_mutex_unlock (&m)
#define hc_thread_mutex_init(m) pthread_mutex_init (&m, NULL)
#define hc_thread_mutex_delete(m) pthread_mutex_destroy (&m)
#endif
/**
* system stuff
*/
#ifdef _WIN
#define hc_sleep(x) Sleep ((x) * 1000);
#elif _POSIX
#define hc_sleep(x) sleep ((x));
#endif
#include <ext_OpenCL.h>
/**
* temperature management
*/
#ifdef LINUX
#include <ext_nvml.h>
#include <ext_ADL.h>
#endif
#ifdef WIN
#include <ext_nvapi.h>
#include <ext_ADL.h>
#endif
#ifdef OSX
#include <ext_smi.h>
#include <ext_dummy.h>
#endif
/**
* shared stuff
*/
#define ETC_MAX (60 * 60 * 24 * 365 * 10)
#define DEVICES_MAX 128
#define CL_PLATFORMS_MAX 16
#define CL_VENDOR_NV "NVIDIA Corporation"
#define CL_VENDOR_AMD "Advanced Micro Devices, Inc."
#define CL_VENDOR_SDS "Shiloh Distributed Solutions"
#define CL_VENDOR_APPLE "Apple"
#define VENDOR_ID_AMD 4098
#define VENDOR_ID_NV 4318
#define VENDOR_ID_UNKNOWN 0
#define BLOCK_SIZE 64
#define CHARSIZ 0x100
#define INFOSZ CHARSIZ
#define SP_HCSTAT "hashcat.hcstat"
#define SP_PW_MIN 2
#define SP_PW_MAX 64
#define SP_ROOT_CNT (SP_PW_MAX * CHARSIZ)
#define SP_MARKOV_CNT (SP_PW_MAX * CHARSIZ * CHARSIZ)
#define INDUCT_DIR "induct"
#define OUTFILES_DIR "outfiles"
#define LOOPBACK_FILE "loopback"
/**
* types
*/
#ifdef _WIN
typedef LARGE_INTEGER hc_timer_t;
typedef HANDLE hc_thread_t;
typedef CRITICAL_SECTION hc_thread_mutex_t;
#elif _POSIX
typedef struct timeval hc_timer_t;
typedef pthread_t hc_thread_t;
typedef pthread_mutex_t hc_thread_mutex_t;
#endif
#include <types.h>
#include "rp_cpu.h"
#include "rp_gpu.h"
/**
* valid project specific global stuff
*/
extern const char *PROGNAME;
extern const char *VERSION_TXT;
extern const uint VERSION_BIN;
extern const uint RESTORE_MIN;
extern const char *EULA_TXT[];
extern const char *USAGE_MINI[];
extern const char *USAGE_BIG[];
extern const char *PROMPT;
extern int SUPPRESS_OUTPUT;
extern hc_thread_mutex_t mux_adl;
extern hc_thread_mutex_t mux_counter;
extern hc_thread_mutex_t mux_dispatcher;
extern hc_thread_mutex_t mux_display;
/**
* password lengths supported
*/
#define PW_LENGTH_MIN_0 0
#define PW_LENGTH_MAX_0 55
#define PW_LENGTH_MIN_400 0
#define PW_LENGTH_MAX_400 40
#define PW_LENGTH_MIN_500 0
#define PW_LENGTH_MAX_500 15
#define PW_LENGTH_MIN_1600 0
#define PW_LENGTH_MAX_1600 15
#define PW_LENGTH_MIN_1800 0
#define PW_LENGTH_MAX_1800 15
#define PW_LENGTH_MIN_2500 0
#define PW_LENGTH_MAX_2500 64
#define PW_LENGTH_MIN_6300 0
#define PW_LENGTH_MAX_6300 15
#define PW_LENGTH_MIN_7400 0
#define PW_LENGTH_MAX_7400 15
/**
* gpu accel / loops macro
*/
#define GPU_ACCEL_NV_0 128
#define GPU_ACCEL_NV_10 128
#define GPU_ACCEL_NV_11 128
#define GPU_ACCEL_NV_12 128
#define GPU_ACCEL_NV_20 64
#define GPU_ACCEL_NV_21 64
#define GPU_ACCEL_NV_22 64
#define GPU_ACCEL_NV_23 64
#define GPU_ACCEL_NV_30 128
#define GPU_ACCEL_NV_40 64
#define GPU_ACCEL_NV_50 64
#define GPU_ACCEL_NV_60 64
#define GPU_ACCEL_NV_100 64
#define GPU_ACCEL_NV_101 64
#define GPU_ACCEL_NV_110 64
#define GPU_ACCEL_NV_111 64
#define GPU_ACCEL_NV_112 64
#define GPU_ACCEL_NV_120 64
#define GPU_ACCEL_NV_121 64
#define GPU_ACCEL_NV_122 64
#define GPU_ACCEL_NV_124 64
#define GPU_ACCEL_NV_130 64
#define GPU_ACCEL_NV_131 64
#define GPU_ACCEL_NV_132 64
#define GPU_ACCEL_NV_133 64
#define GPU_ACCEL_NV_140 64
#define GPU_ACCEL_NV_141 64
#define GPU_ACCEL_NV_150 64
#define GPU_ACCEL_NV_160 64
#define GPU_ACCEL_NV_190 64
#define GPU_ACCEL_NV_200 64
#define GPU_ACCEL_NV_300 64
#define GPU_ACCEL_NV_400 8
#define GPU_ACCEL_NV_500 8
#define GPU_ACCEL_NV_501 8
#define GPU_ACCEL_NV_900 128
#define GPU_ACCEL_NV_910 128
#define GPU_ACCEL_NV_1000 128
#define GPU_ACCEL_NV_1100 64
#define GPU_ACCEL_NV_1400 64
#define GPU_ACCEL_NV_1410 64
#define GPU_ACCEL_NV_1420 64
#define GPU_ACCEL_NV_1421 64
#define GPU_ACCEL_NV_1430 64
#define GPU_ACCEL_NV_1440 64
#define GPU_ACCEL_NV_1441 64
#define GPU_ACCEL_NV_1450 32
#define GPU_ACCEL_NV_1460 32
#define GPU_ACCEL_NV_1500 16
#define GPU_ACCEL_NV_1600 8
#define GPU_ACCEL_NV_1700 64
#define GPU_ACCEL_NV_1710 64
#define GPU_ACCEL_NV_1711 64
#define GPU_ACCEL_NV_1720 64
#define GPU_ACCEL_NV_1722 64
#define GPU_ACCEL_NV_1730 64
#define GPU_ACCEL_NV_1731 64
#define GPU_ACCEL_NV_1740 64
#define GPU_ACCEL_NV_1750 32
#define GPU_ACCEL_NV_1760 32
#define GPU_ACCEL_NV_1800 2
#define GPU_ACCEL_NV_2100 8
#define GPU_ACCEL_NV_2400 64
#define GPU_ACCEL_NV_2410 64
#define GPU_ACCEL_NV_2500 8
#define GPU_ACCEL_NV_2600 64
#define GPU_ACCEL_NV_2611 64
#define GPU_ACCEL_NV_2612 64
#define GPU_ACCEL_NV_2711 64
#define GPU_ACCEL_NV_2811 64
#define GPU_ACCEL_NV_3000 64
#define GPU_ACCEL_NV_3100 16
#define GPU_ACCEL_NV_3200 2
#define GPU_ACCEL_NV_3710 64
#define GPU_ACCEL_NV_3711 64
#define GPU_ACCEL_NV_3800 128
#define GPU_ACCEL_NV_4300 64
#define GPU_ACCEL_NV_4400 64
#define GPU_ACCEL_NV_4500 64
#define GPU_ACCEL_NV_4700 64
#define GPU_ACCEL_NV_4800 128
#define GPU_ACCEL_NV_4900 64
#define GPU_ACCEL_NV_5000 64
#define GPU_ACCEL_NV_5100 64
#define GPU_ACCEL_NV_5200 8
#define GPU_ACCEL_NV_5300 32
#define GPU_ACCEL_NV_5400 32
#define GPU_ACCEL_NV_5500 64
#define GPU_ACCEL_NV_5600 8
#define GPU_ACCEL_NV_5700 64
#define GPU_ACCEL_NV_5800 8
#define GPU_ACCEL_NV_6000 64
#define GPU_ACCEL_NV_6100 8
#define GPU_ACCEL_NV_6211 16
#define GPU_ACCEL_NV_6212 8
#define GPU_ACCEL_NV_6213 8
#define GPU_ACCEL_NV_6221 4
#define GPU_ACCEL_NV_6222 4
#define GPU_ACCEL_NV_6223 4
#define GPU_ACCEL_NV_6231 4
#define GPU_ACCEL_NV_6232 4
#define GPU_ACCEL_NV_6233 4
#define GPU_ACCEL_NV_6241 32
#define GPU_ACCEL_NV_6242 16
#define GPU_ACCEL_NV_6243 16
#define GPU_ACCEL_NV_6300 8
#define GPU_ACCEL_NV_6400 8
#define GPU_ACCEL_NV_6500 8
#define GPU_ACCEL_NV_6600 8
#define GPU_ACCEL_NV_6700 8
#define GPU_ACCEL_NV_6800 8
#define GPU_ACCEL_NV_6900 16
#define GPU_ACCEL_NV_7100 2
#define GPU_ACCEL_NV_7200 2
#define GPU_ACCEL_NV_7300 64
#define GPU_ACCEL_NV_7400 2
#define GPU_ACCEL_NV_7500 8
#define GPU_ACCEL_NV_7600 64
#define GPU_ACCEL_NV_7700 16
#define GPU_ACCEL_NV_7800 8
#define GPU_ACCEL_NV_7900 2
#define GPU_ACCEL_NV_8000 8
#define GPU_ACCEL_NV_8100 64
#define GPU_ACCEL_NV_8200 2
#define GPU_ACCEL_NV_8300 64
#define GPU_ACCEL_NV_8400 64
#define GPU_ACCEL_NV_8500 64
#define GPU_ACCEL_NV_8600 8
#define GPU_ACCEL_NV_8700 8
#define GPU_ACCEL_NV_8800 8
#define GPU_ACCEL_NV_8900 4
#define GPU_ACCEL_NV_9000 2
#define GPU_ACCEL_NV_9100 8
#define GPU_ACCEL_NV_9200 2
#define GPU_ACCEL_NV_9300 4
#define GPU_ACCEL_NV_9400 8
#define GPU_ACCEL_NV_9500 8
#define GPU_ACCEL_NV_9600 2
#define GPU_ACCEL_NV_9700 8
#define GPU_ACCEL_NV_9710 8
#define GPU_ACCEL_NV_9720 8
#define GPU_ACCEL_NV_9800 8
#define GPU_ACCEL_NV_9810 8
#define GPU_ACCEL_NV_9820 8
#define GPU_ACCEL_NV_9900 64
#define GPU_ACCEL_NV_10000 2
#define GPU_ACCEL_NV_10100 128
#define GPU_ACCEL_NV_10200 64
#define GPU_ACCEL_NV_10300 8
#define GPU_ACCEL_NV_10400 8
#define GPU_ACCEL_NV_10410 8
#define GPU_ACCEL_NV_10420 8
#define GPU_ACCEL_NV_10500 64
#define GPU_ACCEL_NV_10600 64
#define GPU_ACCEL_NV_10700 1
#define GPU_ACCEL_NV_10800 64
#define GPU_ACCEL_NV_10900 2
#define GPU_ACCEL_NV_11000 64
#define GPU_ACCEL_NV_11100 64
#define GPU_ACCEL_NV_11200 64
#define GPU_ACCEL_NV_11300 2
#define GPU_ACCEL_NV_11400 8
#define GPU_ACCEL_NV_11500 128
#define GPU_ACCEL_NV_11600 2
#define GPU_ACCEL_NV_11700 4
#define GPU_ACCEL_NV_11800 4
#define GPU_ACCEL_NV_11900 2
#define GPU_ACCEL_NV_12000 2
#define GPU_ACCEL_NV_12100 2
#define GPU_ACCEL_NV_12200 2
#define GPU_ACCEL_NV_12300 2
#define GPU_ACCEL_NV_12400 64
#define GPU_ACCEL_NV_12500 8
#define GPU_ACCEL_NV_12600 32
#define GPU_ACCEL_NV_12700 64
#define GPU_ACCEL_NV_12800 64
#define GPU_ACCEL_AMD_0 128
#define GPU_ACCEL_AMD_10 128
#define GPU_ACCEL_AMD_11 128
#define GPU_ACCEL_AMD_12 128
#define GPU_ACCEL_AMD_20 64
#define GPU_ACCEL_AMD_21 64
#define GPU_ACCEL_AMD_22 64
#define GPU_ACCEL_AMD_23 64
#define GPU_ACCEL_AMD_30 128
#define GPU_ACCEL_AMD_40 64
#define GPU_ACCEL_AMD_50 64
#define GPU_ACCEL_AMD_60 64
#define GPU_ACCEL_AMD_100 64
#define GPU_ACCEL_AMD_101 64
#define GPU_ACCEL_AMD_110 64
#define GPU_ACCEL_AMD_111 64
#define GPU_ACCEL_AMD_112 64
#define GPU_ACCEL_AMD_120 64
#define GPU_ACCEL_AMD_121 64
#define GPU_ACCEL_AMD_122 64
#define GPU_ACCEL_AMD_124 64
#define GPU_ACCEL_AMD_130 64
#define GPU_ACCEL_AMD_131 64
#define GPU_ACCEL_AMD_132 64
#define GPU_ACCEL_AMD_133 64
#define GPU_ACCEL_AMD_140 64
#define GPU_ACCEL_AMD_141 64
#define GPU_ACCEL_AMD_150 64
#define GPU_ACCEL_AMD_160 64
#define GPU_ACCEL_AMD_190 64
#define GPU_ACCEL_AMD_200 64
#define GPU_ACCEL_AMD_300 64
#define GPU_ACCEL_AMD_400 8
#define GPU_ACCEL_AMD_500 8
#define GPU_ACCEL_AMD_501 8
#define GPU_ACCEL_AMD_900 128
#define GPU_ACCEL_AMD_910 128
#define GPU_ACCEL_AMD_1000 128
#define GPU_ACCEL_AMD_1100 64
#define GPU_ACCEL_AMD_1400 64
#define GPU_ACCEL_AMD_1410 64
#define GPU_ACCEL_AMD_1420 64
#define GPU_ACCEL_AMD_1421 64
#define GPU_ACCEL_AMD_1430 64
#define GPU_ACCEL_AMD_1440 64
#define GPU_ACCEL_AMD_1441 64
#define GPU_ACCEL_AMD_1450 32
#define GPU_ACCEL_AMD_1460 32
#define GPU_ACCEL_AMD_1500 16
#define GPU_ACCEL_AMD_1600 8
#define GPU_ACCEL_AMD_1700 64
#define GPU_ACCEL_AMD_1710 64
#define GPU_ACCEL_AMD_1711 64
#define GPU_ACCEL_AMD_1720 64
#define GPU_ACCEL_AMD_1722 64
#define GPU_ACCEL_AMD_1730 64
#define GPU_ACCEL_AMD_1731 64
#define GPU_ACCEL_AMD_1740 64
#define GPU_ACCEL_AMD_1750 32
#define GPU_ACCEL_AMD_1760 32
#define GPU_ACCEL_AMD_1800 2
#define GPU_ACCEL_AMD_2100 8
#define GPU_ACCEL_AMD_2400 64
#define GPU_ACCEL_AMD_2410 64
#define GPU_ACCEL_AMD_2500 8
#define GPU_ACCEL_AMD_2600 64
#define GPU_ACCEL_AMD_2611 64
#define GPU_ACCEL_AMD_2612 64
#define GPU_ACCEL_AMD_2711 64
#define GPU_ACCEL_AMD_2811 64
#define GPU_ACCEL_AMD_3000 128
#define GPU_ACCEL_AMD_3100 16
#define GPU_ACCEL_AMD_3200 2
#define GPU_ACCEL_AMD_3710 64
#define GPU_ACCEL_AMD_3711 64
#define GPU_ACCEL_AMD_3800 128
#define GPU_ACCEL_AMD_4300 64
#define GPU_ACCEL_AMD_4400 64
#define GPU_ACCEL_AMD_4500 64
#define GPU_ACCEL_AMD_4700 64
#define GPU_ACCEL_AMD_4800 128
#define GPU_ACCEL_AMD_4900 64
#define GPU_ACCEL_AMD_5000 64
#define GPU_ACCEL_AMD_5100 64
#define GPU_ACCEL_AMD_5200 8
#define GPU_ACCEL_AMD_5300 32
#define GPU_ACCEL_AMD_5400 32
#define GPU_ACCEL_AMD_5500 64
#define GPU_ACCEL_AMD_5600 64
#define GPU_ACCEL_AMD_5700 64
#define GPU_ACCEL_AMD_5800 8
#define GPU_ACCEL_AMD_6000 64
#define GPU_ACCEL_AMD_6100 8
#define GPU_ACCEL_AMD_6211 16
#define GPU_ACCEL_AMD_6212 8
#define GPU_ACCEL_AMD_6213 8
#define GPU_ACCEL_AMD_6221 4
#define GPU_ACCEL_AMD_6222 4
#define GPU_ACCEL_AMD_6223 4
#define GPU_ACCEL_AMD_6231 4
#define GPU_ACCEL_AMD_6232 4
#define GPU_ACCEL_AMD_6233 4
#define GPU_ACCEL_AMD_6241 32
#define GPU_ACCEL_AMD_6242 16
#define GPU_ACCEL_AMD_6243 16
#define GPU_ACCEL_AMD_6300 8
#define GPU_ACCEL_AMD_6400 8
#define GPU_ACCEL_AMD_6500 8
#define GPU_ACCEL_AMD_6600 8
#define GPU_ACCEL_AMD_6700 8
#define GPU_ACCEL_AMD_6800 8
#define GPU_ACCEL_AMD_6900 16
#define GPU_ACCEL_AMD_7100 2
#define GPU_ACCEL_AMD_7200 2
#define GPU_ACCEL_AMD_7300 64
#define GPU_ACCEL_AMD_7400 2
#define GPU_ACCEL_AMD_7500 8
#define GPU_ACCEL_AMD_7600 64
#define GPU_ACCEL_AMD_7700 16
#define GPU_ACCEL_AMD_7800 8
#define GPU_ACCEL_AMD_7900 2
#define GPU_ACCEL_AMD_8000 8
#define GPU_ACCEL_AMD_8100 64
#define GPU_ACCEL_AMD_8200 2
#define GPU_ACCEL_AMD_8300 64
#define GPU_ACCEL_AMD_8400 64
#define GPU_ACCEL_AMD_8500 64
#define GPU_ACCEL_AMD_8600 8
#define GPU_ACCEL_AMD_8700 8
#define GPU_ACCEL_AMD_8800 8
#define GPU_ACCEL_AMD_8900 4
#define GPU_ACCEL_AMD_9000 2
#define GPU_ACCEL_AMD_9100 8
#define GPU_ACCEL_AMD_9200 2
#define GPU_ACCEL_AMD_9300 4
#define GPU_ACCEL_AMD_9400 8
#define GPU_ACCEL_AMD_9500 8
#define GPU_ACCEL_AMD_9600 2
#define GPU_ACCEL_AMD_9700 8
#define GPU_ACCEL_AMD_9710 8
#define GPU_ACCEL_AMD_9720 8
#define GPU_ACCEL_AMD_9800 8
#define GPU_ACCEL_AMD_9810 8
#define GPU_ACCEL_AMD_9820 8
#define GPU_ACCEL_AMD_9900 64
#define GPU_ACCEL_AMD_10000 2
#define GPU_ACCEL_AMD_10100 128
#define GPU_ACCEL_AMD_10200 64
#define GPU_ACCEL_AMD_10300 8
#define GPU_ACCEL_AMD_10400 8
#define GPU_ACCEL_AMD_10410 8
#define GPU_ACCEL_AMD_10420 8
#define GPU_ACCEL_AMD_10500 64
#define GPU_ACCEL_AMD_10600 64
#define GPU_ACCEL_AMD_10700 1
#define GPU_ACCEL_AMD_10800 64
#define GPU_ACCEL_AMD_10900 2
#define GPU_ACCEL_AMD_11000 64
#define GPU_ACCEL_AMD_11100 64
#define GPU_ACCEL_AMD_11200 64
#define GPU_ACCEL_AMD_11300 2
#define GPU_ACCEL_AMD_11400 8
#define GPU_ACCEL_AMD_11500 128
#define GPU_ACCEL_AMD_11600 2
#define GPU_ACCEL_AMD_11700 4
#define GPU_ACCEL_AMD_11800 4
#define GPU_ACCEL_AMD_11900 2
#define GPU_ACCEL_AMD_12000 2
#define GPU_ACCEL_AMD_12100 2
#define GPU_ACCEL_AMD_12200 2
#define GPU_ACCEL_AMD_12300 2
#define GPU_ACCEL_AMD_12400 64
#define GPU_ACCEL_AMD_12500 8
#define GPU_ACCEL_AMD_12600 32
#define GPU_ACCEL_AMD_12700 64
#define GPU_ACCEL_AMD_12800 64
#define GPU_LOOPS_NV_0 512
#define GPU_LOOPS_NV_10 512
#define GPU_LOOPS_NV_11 512
#define GPU_LOOPS_NV_12 512
#define GPU_LOOPS_NV_20 128
#define GPU_LOOPS_NV_21 128
#define GPU_LOOPS_NV_22 128
#define GPU_LOOPS_NV_23 128
#define GPU_LOOPS_NV_30 512
#define GPU_LOOPS_NV_40 128
#define GPU_LOOPS_NV_50 64
#define GPU_LOOPS_NV_60 64
#define GPU_LOOPS_NV_100 128
#define GPU_LOOPS_NV_101 128
#define GPU_LOOPS_NV_110 128
#define GPU_LOOPS_NV_111 128
#define GPU_LOOPS_NV_112 128
#define GPU_LOOPS_NV_120 64
#define GPU_LOOPS_NV_121 64
#define GPU_LOOPS_NV_122 64
#define GPU_LOOPS_NV_124 64
#define GPU_LOOPS_NV_130 64
#define GPU_LOOPS_NV_131 64
#define GPU_LOOPS_NV_132 64
#define GPU_LOOPS_NV_133 64
#define GPU_LOOPS_NV_140 64
#define GPU_LOOPS_NV_141 64
#define GPU_LOOPS_NV_150 32
#define GPU_LOOPS_NV_160 32
#define GPU_LOOPS_NV_190 64
#define GPU_LOOPS_NV_200 64
#define GPU_LOOPS_NV_300 64
#define GPU_LOOPS_NV_400 256
#define GPU_LOOPS_NV_500 200
#define GPU_LOOPS_NV_501 200
#define GPU_LOOPS_NV_900 512
#define GPU_LOOPS_NV_910 512
#define GPU_LOOPS_NV_1000 512
#define GPU_LOOPS_NV_1100 256
#define GPU_LOOPS_NV_1400 128
#define GPU_LOOPS_NV_1410 128
#define GPU_LOOPS_NV_1420 64
#define GPU_LOOPS_NV_1421 64
#define GPU_LOOPS_NV_1430 128
#define GPU_LOOPS_NV_1440 64
#define GPU_LOOPS_NV_1441 64
#define GPU_LOOPS_NV_1450 16
#define GPU_LOOPS_NV_1460 16
#define GPU_LOOPS_NV_1500 512
#define GPU_LOOPS_NV_1600 256
#define GPU_LOOPS_NV_1700 32
#define GPU_LOOPS_NV_1710 32
#define GPU_LOOPS_NV_1711 32
#define GPU_LOOPS_NV_1720 16
#define GPU_LOOPS_NV_1722 16
#define GPU_LOOPS_NV_1730 32
#define GPU_LOOPS_NV_1731 32
#define GPU_LOOPS_NV_1740 16
#define GPU_LOOPS_NV_1750 16
#define GPU_LOOPS_NV_1760 16
#define GPU_LOOPS_NV_1800 200
#define GPU_LOOPS_NV_2100 256
#define GPU_LOOPS_NV_2400 512
#define GPU_LOOPS_NV_2410 512
#define GPU_LOOPS_NV_2500 256
#define GPU_LOOPS_NV_2600 256
#define GPU_LOOPS_NV_2611 256
#define GPU_LOOPS_NV_2612 256
#define GPU_LOOPS_NV_2711 128
#define GPU_LOOPS_NV_2811 128
#define GPU_LOOPS_NV_3000 512
#define GPU_LOOPS_NV_3100 64
#define GPU_LOOPS_NV_3200 16
#define GPU_LOOPS_NV_3710 128
#define GPU_LOOPS_NV_3711 128
#define GPU_LOOPS_NV_3800 512
#define GPU_LOOPS_NV_4300 256
#define GPU_LOOPS_NV_4400 128
#define GPU_LOOPS_NV_4500 128
#define GPU_LOOPS_NV_4700 128
#define GPU_LOOPS_NV_4800 512
#define GPU_LOOPS_NV_4900 128
#define GPU_LOOPS_NV_5000 16
#define GPU_LOOPS_NV_5100 512
#define GPU_LOOPS_NV_5200 256
#define GPU_LOOPS_NV_5300 64
#define GPU_LOOPS_NV_5400 64
#define GPU_LOOPS_NV_5500 128
#define GPU_LOOPS_NV_5600 128
#define GPU_LOOPS_NV_5700 256
#define GPU_LOOPS_NV_5800 256
#define GPU_LOOPS_NV_6000 128
#define GPU_LOOPS_NV_6100 64
#define GPU_LOOPS_NV_6211 200
#define GPU_LOOPS_NV_6212 200
#define GPU_LOOPS_NV_6213 200
#define GPU_LOOPS_NV_6221 200
#define GPU_LOOPS_NV_6222 200
#define GPU_LOOPS_NV_6223 200
#define GPU_LOOPS_NV_6231 200
#define GPU_LOOPS_NV_6232 200
#define GPU_LOOPS_NV_6233 200
#define GPU_LOOPS_NV_6241 200
#define GPU_LOOPS_NV_6242 200
#define GPU_LOOPS_NV_6243 200
#define GPU_LOOPS_NV_6300 256
#define GPU_LOOPS_NV_6400 256
#define GPU_LOOPS_NV_6500 256
#define GPU_LOOPS_NV_6600 200
#define GPU_LOOPS_NV_6700 256
#define GPU_LOOPS_NV_6800 200
#define GPU_LOOPS_NV_6900 64
#define GPU_LOOPS_NV_7100 256
#define GPU_LOOPS_NV_7200 200
#define GPU_LOOPS_NV_7300 32
#define GPU_LOOPS_NV_7400 200
#define GPU_LOOPS_NV_7500 32
#define GPU_LOOPS_NV_7600 128
#define GPU_LOOPS_NV_7700 128
#define GPU_LOOPS_NV_7800 256
#define GPU_LOOPS_NV_7900 128
#define GPU_LOOPS_NV_8000 64
#define GPU_LOOPS_NV_8100 64
#define GPU_LOOPS_NV_8200 200
#define GPU_LOOPS_NV_8300 64
#define GPU_LOOPS_NV_8400 32
#define GPU_LOOPS_NV_8500 128
#define GPU_LOOPS_NV_8600 32
#define GPU_LOOPS_NV_8700 32
#define GPU_LOOPS_NV_8800 256
#define GPU_LOOPS_NV_8900 1
#define GPU_LOOPS_NV_9000 16
#define GPU_LOOPS_NV_9100 256
#define GPU_LOOPS_NV_9200 200
#define GPU_LOOPS_NV_9300 1
#define GPU_LOOPS_NV_9400 200
#define GPU_LOOPS_NV_9500 200
#define GPU_LOOPS_NV_9600 200
#define GPU_LOOPS_NV_9700 200
#define GPU_LOOPS_NV_9710 200
#define GPU_LOOPS_NV_9720 200
#define GPU_LOOPS_NV_9800 200
#define GPU_LOOPS_NV_9810 200
#define GPU_LOOPS_NV_9820 200
#define GPU_LOOPS_NV_9900 512
#define GPU_LOOPS_NV_10000 200
#define GPU_LOOPS_NV_10100 512
#define GPU_LOOPS_NV_10200 64
#define GPU_LOOPS_NV_10300 128
#define GPU_LOOPS_NV_10400 256
#define GPU_LOOPS_NV_10410 256
#define GPU_LOOPS_NV_10420 256
#define GPU_LOOPS_NV_10500 64
#define GPU_LOOPS_NV_10600 128
#define GPU_LOOPS_NV_10700 64
#define GPU_LOOPS_NV_10800 32
#define GPU_LOOPS_NV_10900 200
#define GPU_LOOPS_NV_11000 128
#define GPU_LOOPS_NV_11100 128
#define GPU_LOOPS_NV_11200 128
#define GPU_LOOPS_NV_11300 256
#define GPU_LOOPS_NV_11400 256
#define GPU_LOOPS_NV_11500 512
#define GPU_LOOPS_NV_11600 512
#define GPU_LOOPS_NV_11700 64
#define GPU_LOOPS_NV_11800 64
#define GPU_LOOPS_NV_11900 200
#define GPU_LOOPS_NV_12000 200
#define GPU_LOOPS_NV_12100 200
#define GPU_LOOPS_NV_12200 256
#define GPU_LOOPS_NV_12300 256
#define GPU_LOOPS_NV_12400 256
#define GPU_LOOPS_NV_12500 256
#define GPU_LOOPS_NV_12600 16
#define GPU_LOOPS_NV_12700 10
#define GPU_LOOPS_NV_12800 100
#define GPU_LOOPS_AMD_0 256
#define GPU_LOOPS_AMD_10 256
#define GPU_LOOPS_AMD_11 256
#define GPU_LOOPS_AMD_12 256
#define GPU_LOOPS_AMD_20 256
#define GPU_LOOPS_AMD_21 256
#define GPU_LOOPS_AMD_22 256
#define GPU_LOOPS_AMD_23 256
#define GPU_LOOPS_AMD_30 256
#define GPU_LOOPS_AMD_40 256
#define GPU_LOOPS_AMD_50 64
#define GPU_LOOPS_AMD_60 64
#define GPU_LOOPS_AMD_100 128
#define GPU_LOOPS_AMD_101 128
#define GPU_LOOPS_AMD_110 128
#define GPU_LOOPS_AMD_111 128
#define GPU_LOOPS_AMD_112 128
#define GPU_LOOPS_AMD_120 128
#define GPU_LOOPS_AMD_121 128
#define GPU_LOOPS_AMD_122 128
#define GPU_LOOPS_AMD_124 128
#define GPU_LOOPS_AMD_130 128
#define GPU_LOOPS_AMD_131 128
#define GPU_LOOPS_AMD_132 128
#define GPU_LOOPS_AMD_133 128
#define GPU_LOOPS_AMD_140 128
#define GPU_LOOPS_AMD_141 128
#define GPU_LOOPS_AMD_150 64
#define GPU_LOOPS_AMD_160 64
#define GPU_LOOPS_AMD_190 128
#define GPU_LOOPS_AMD_200 128
#define GPU_LOOPS_AMD_300 64
#define GPU_LOOPS_AMD_400 256
#define GPU_LOOPS_AMD_500 256
#define GPU_LOOPS_AMD_501 256
#define GPU_LOOPS_AMD_900 256
#define GPU_LOOPS_AMD_910 256
#define GPU_LOOPS_AMD_1000 256
#define GPU_LOOPS_AMD_1100 128
#define GPU_LOOPS_AMD_1400 64
#define GPU_LOOPS_AMD_1410 64
#define GPU_LOOPS_AMD_1420 64
#define GPU_LOOPS_AMD_1421 64
#define GPU_LOOPS_AMD_1430 64
#define GPU_LOOPS_AMD_1440 64
#define GPU_LOOPS_AMD_1441 64
#define GPU_LOOPS_AMD_1450 32
#define GPU_LOOPS_AMD_1460 32
#define GPU_LOOPS_AMD_1500 256
#define GPU_LOOPS_AMD_1600 256
#define GPU_LOOPS_AMD_1700 32
#define GPU_LOOPS_AMD_1710 32
#define GPU_LOOPS_AMD_1711 32
#define GPU_LOOPS_AMD_1720 32
#define GPU_LOOPS_AMD_1722 32
#define GPU_LOOPS_AMD_1730 32
#define GPU_LOOPS_AMD_1731 32
#define GPU_LOOPS_AMD_1740 32
#define GPU_LOOPS_AMD_1750 16
#define GPU_LOOPS_AMD_1760 16
#define GPU_LOOPS_AMD_1800 16
#define GPU_LOOPS_AMD_2100 256
#define GPU_LOOPS_AMD_2400 256
#define GPU_LOOPS_AMD_2410 256
#define GPU_LOOPS_AMD_2500 256
#define GPU_LOOPS_AMD_2600 128
#define GPU_LOOPS_AMD_2611 128
#define GPU_LOOPS_AMD_2612 128
#define GPU_LOOPS_AMD_2711 64
#define GPU_LOOPS_AMD_2811 64
#define GPU_LOOPS_AMD_3000 256
#define GPU_LOOPS_AMD_3100 16
#define GPU_LOOPS_AMD_3200 16
#define GPU_LOOPS_AMD_3710 128
#define GPU_LOOPS_AMD_3711 128
#define GPU_LOOPS_AMD_3800 256
#define GPU_LOOPS_AMD_4300 128
#define GPU_LOOPS_AMD_4400 128
#define GPU_LOOPS_AMD_4500 128
#define GPU_LOOPS_AMD_4700 128
#define GPU_LOOPS_AMD_4800 256
#define GPU_LOOPS_AMD_4900 128
#define GPU_LOOPS_AMD_5000 64
#define GPU_LOOPS_AMD_5100 256
#define GPU_LOOPS_AMD_5200 256
#define GPU_LOOPS_AMD_5300 32
#define GPU_LOOPS_AMD_5400 32
#define GPU_LOOPS_AMD_5500 128
#define GPU_LOOPS_AMD_5600 64
#define GPU_LOOPS_AMD_5700 64
#define GPU_LOOPS_AMD_5800 256
#define GPU_LOOPS_AMD_6000 64
#define GPU_LOOPS_AMD_6100 64
#define GPU_LOOPS_AMD_6211 200
#define GPU_LOOPS_AMD_6212 200
#define GPU_LOOPS_AMD_6213 200
#define GPU_LOOPS_AMD_6221 200
#define GPU_LOOPS_AMD_6222 200
#define GPU_LOOPS_AMD_6223 200
#define GPU_LOOPS_AMD_6231 200
#define GPU_LOOPS_AMD_6232 200
#define GPU_LOOPS_AMD_6233 200
#define GPU_LOOPS_AMD_6241 200
#define GPU_LOOPS_AMD_6242 200
#define GPU_LOOPS_AMD_6243 200
#define GPU_LOOPS_AMD_6300 256
#define GPU_LOOPS_AMD_6400 256
#define GPU_LOOPS_AMD_6500 256
#define GPU_LOOPS_AMD_6600 200
#define GPU_LOOPS_AMD_6700 256
#define GPU_LOOPS_AMD_6800 200
#define GPU_LOOPS_AMD_6900 64
#define GPU_LOOPS_AMD_7100 256
#define GPU_LOOPS_AMD_7200 200
#define GPU_LOOPS_AMD_7300 64
#define GPU_LOOPS_AMD_7400 200
#define GPU_LOOPS_AMD_7500 16
#define GPU_LOOPS_AMD_7600 128
#define GPU_LOOPS_AMD_7700 128
#define GPU_LOOPS_AMD_7800 64
#define GPU_LOOPS_AMD_7900 256
#define GPU_LOOPS_AMD_8000 64
#define GPU_LOOPS_AMD_8100 128
#define GPU_LOOPS_AMD_8200 200
#define GPU_LOOPS_AMD_8300 64
#define GPU_LOOPS_AMD_8400 64
#define GPU_LOOPS_AMD_8500 16
#define GPU_LOOPS_AMD_8600 16
#define GPU_LOOPS_AMD_8700 16
#define GPU_LOOPS_AMD_8800 256
#define GPU_LOOPS_AMD_8900 1
#define GPU_LOOPS_AMD_9000 16
#define GPU_LOOPS_AMD_9100 256
#define GPU_LOOPS_AMD_9200 200
#define GPU_LOOPS_AMD_9300 1
#define GPU_LOOPS_AMD_9400 200
#define GPU_LOOPS_AMD_9500 200
#define GPU_LOOPS_AMD_9600 200
#define GPU_LOOPS_AMD_9700 200
#define GPU_LOOPS_AMD_9710 200
#define GPU_LOOPS_AMD_9720 200
#define GPU_LOOPS_AMD_9800 200
#define GPU_LOOPS_AMD_9810 200
#define GPU_LOOPS_AMD_9820 200
#define GPU_LOOPS_AMD_9900 256
#define GPU_LOOPS_AMD_10000 200
#define GPU_LOOPS_AMD_10100 512
#define GPU_LOOPS_AMD_10200 64
#define GPU_LOOPS_AMD_10300 128
#define GPU_LOOPS_AMD_10400 256
#define GPU_LOOPS_AMD_10410 256
#define GPU_LOOPS_AMD_10420 256
#define GPU_LOOPS_AMD_10500 64
#define GPU_LOOPS_AMD_10600 64
#define GPU_LOOPS_AMD_10700 64
#define GPU_LOOPS_AMD_10800 32
#define GPU_LOOPS_AMD_10900 200
#define GPU_LOOPS_AMD_11000 256
#define GPU_LOOPS_AMD_11100 128
#define GPU_LOOPS_AMD_11200 128
#define GPU_LOOPS_AMD_11300 256
#define GPU_LOOPS_AMD_11400 128
#define GPU_LOOPS_AMD_11500 256
#define GPU_LOOPS_AMD_11600 512
#define GPU_LOOPS_AMD_11700 64
#define GPU_LOOPS_AMD_11800 64
#define GPU_LOOPS_AMD_11900 200
#define GPU_LOOPS_AMD_12000 200
#define GPU_LOOPS_AMD_12100 200
#define GPU_LOOPS_AMD_12200 256
#define GPU_LOOPS_AMD_12300 256
#define GPU_LOOPS_AMD_12400 256
#define GPU_LOOPS_AMD_12500 256
#define GPU_LOOPS_AMD_12600 32
#define GPU_LOOPS_AMD_12700 10
#define GPU_LOOPS_AMD_12800 100
/**
* Strings
*/
#define HT_00000 "MD5"
#define HT_00010 "md5($pass.$salt)"
#define HT_00020 "md5($salt.$pass)"
#define HT_00030 "md5(unicode($pass).$salt)"
#define HT_00040 "md5($salt.unicode($pass))"
#define HT_00050 "HMAC-MD5 (key = $pass)"
#define HT_00060 "HMAC-MD5 (key = $salt)"
#define HT_00100 "SHA1"
#define HT_00110 "sha1($pass.$salt)"
#define HT_00120 "sha1($salt.$pass)"
#define HT_00130 "sha1(unicode($pass).$salt)"
#define HT_00140 "sha1($salt.unicode($pass))"
#define HT_00150 "HMAC-SHA1 (key = $pass)"
#define HT_00160 "HMAC-SHA1 (key = $salt)"
#define HT_00190 "sha1(LinkedIn)"
#define HT_00200 "MySQL323"
#define HT_00300 "MySQL4.1/MySQL5"
#define HT_00400 "phpass, MD5(Wordpress), MD5(phpBB3), MD5(Joomla)"
#define HT_00500 "md5crypt, MD5(Unix), FreeBSD MD5, Cisco-IOS MD5"
#define HT_00501 "Juniper IVE"
#define HT_00900 "MD4"
#define HT_00910 "md4($pass.$salt)"
#define HT_01000 "NTLM"
#define HT_01100 "Domain Cached Credentials (DCC), MS Cache"
#define HT_01400 "SHA256"
#define HT_01410 "sha256($pass.$salt)"
#define HT_01420 "sha256($salt.$pass)"
#define HT_01430 "sha256(unicode($pass).$salt)"
#define HT_01440 "sha256($salt.$pass)"
#define HT_01450 "HMAC-SHA256 (key = $pass)"
#define HT_01460 "HMAC-SHA256 (key = $salt)"
#define HT_01500 "descrypt, DES(Unix), Traditional DES"
#define HT_01600 "md5apr1, MD5(APR), Apache MD5"
#define HT_01700 "SHA512"
#define HT_01710 "sha512($pass.$salt)"
#define HT_01720 "sha512($salt.$pass)"
#define HT_01730 "sha512(unicode($pass).$salt)"
#define HT_01740 "sha512($salt.unicode($pass))"
#define HT_01750 "HMAC-SHA512 (key = $pass)"
#define HT_01760 "HMAC-SHA512 (key = $salt)"
#define HT_01800 "sha512crypt, SHA512(Unix)"
#define HT_02100 "Domain Cached Credentials 2 (DCC2), MS Cache 2"
#define HT_02400 "Cisco-PIX MD5"
#define HT_02410 "Cisco-ASA MD5"
#define HT_02500 "WPA/WPA2"
#define HT_02600 "Double MD5"
#define HT_03000 "LM"
#define HT_03100 "Oracle H: Type (Oracle 7+)"
#define HT_03200 "bcrypt, Blowfish(OpenBSD)"
#define HT_03710 "md5($salt.md5($pass))"
#define HT_03711 "Mediawiki B type"
#define HT_03800 "md5($salt.$pass.$salt)"
#define HT_04300 "md5(strtoupper(md5($pass)))"
#define HT_04400 "md5(sha1($pass))"
#define HT_04500 "Double SHA1"
#define HT_04700 "sha1(md5($pass))"
#define HT_04800 "MD5(Chap), iSCSI CHAP authentication"
#define HT_04900 "sha1($salt.$pass.$salt)"
#define HT_05000 "SHA-3(Keccak)"
#define HT_05100 "Half MD5"
#define HT_05200 "Password Safe v3"
#define HT_05300 "IKE-PSK MD5"
#define HT_05400 "IKE-PSK SHA1"
#define HT_05500 "NetNTLMv1-VANILLA / NetNTLMv1+ESS"
#define HT_05600 "NetNTLMv2"
#define HT_05700 "Cisco-IOS SHA256"
#define HT_05800 "Android PIN"
#define HT_06000 "RipeMD160"
#define HT_06100 "Whirlpool"
#define HT_06300 "AIX {smd5}"
#define HT_06400 "AIX {ssha256}"
#define HT_06500 "AIX {ssha512}"
#define HT_06600 "1Password, agilekeychain"
#define HT_06700 "AIX {ssha1}"
#define HT_06800 "Lastpass"
#define HT_06900 "GOST R 34.11-94"
#define HT_07100 "OSX v10.8+"
#define HT_07200 "GRUB 2"
#define HT_07300 "IPMI2 RAKP HMAC-SHA1"
#define HT_07400 "sha256crypt, SHA256(Unix)"
#define HT_07500 "Kerberos 5 AS-REQ Pre-Auth etype 23"
#define HT_07600 "Redmine Project Management Web App"
#define HT_07700 "SAP CODVN B (BCODE)"
#define HT_07800 "SAP CODVN F/G (PASSCODE)"
#define HT_07900 "Drupal7"
#define HT_08000 "Sybase ASE"
#define HT_08100 "Citrix NetScaler"
#define HT_08200 "1Password, cloudkeychain"
#define HT_08300 "DNSSEC (NSEC3)"
#define HT_08400 "WBB3, Woltlab Burning Board 3"
#define HT_08500 "RACF"
#define HT_08600 "Lotus Notes/Domino 5"
#define HT_08700 "Lotus Notes/Domino 6"
#define HT_08800 "Android FDE <= 4.3"
#define HT_08900 "scrypt"
#define HT_09000 "Password Safe v2"
#define HT_09100 "Lotus Notes/Domino 8"
#define HT_09200 "Cisco $8$"
#define HT_09300 "Cisco $9$"
#define HT_09400 "Office 2007"
#define HT_09500 "Office 2010"
#define HT_09600 "Office 2013"
#define HT_09700 "MS Office <= 2003 MD5 + RC4, oldoffice$0, oldoffice$1"
#define HT_09710 "MS Office <= 2003 MD5 + RC4, collision-mode #1"
#define HT_09720 "MS Office <= 2003 MD5 + RC4, collision-mode #2"
#define HT_09800 "MS Office <= 2003 SHA1 + RC4, oldoffice$3, oldoffice$4"
#define HT_09810 "MS Office <= 2003 SHA1 + RC4, collision-mode #1"
#define HT_09820 "MS Office <= 2003 SHA1 + RC4, collision-mode #2"
#define HT_09900 "Radmin2"
#define HT_10000 "Django (PBKDF2-SHA256)"
#define HT_10100 "SipHash"
#define HT_10200 "Cram MD5"
#define HT_10300 "SAP CODVN H (PWDSALTEDHASH) iSSHA-1"
#define HT_10400 "PDF 1.1 - 1.3 (Acrobat 2 - 4)"
#define HT_10410 "PDF 1.1 - 1.3 (Acrobat 2 - 4) + collider-mode #1"
#define HT_10420 "PDF 1.1 - 1.3 (Acrobat 2 - 4) + collider-mode #2"
#define HT_10500 "PDF 1.4 - 1.6 (Acrobat 5 - 8)"
#define HT_10600 "PDF 1.7 Level 3 (Acrobat 9)"
#define HT_10700 "PDF 1.7 Level 8 (Acrobat 10 - 11)"
#define HT_10800 "SHA384"
#define HT_10900 "PBKDF2-HMAC-SHA256"
#define HT_11000 "PrestaShop"
#define HT_11100 "PostgreSQL Challenge-Response Authentication (MD5)"
#define HT_11200 "MySQL Challenge-Response Authentication (SHA1)"
#define HT_11300 "Bitcoin/Litecoin wallet.dat"
#define HT_11400 "SIP digest authentication (MD5)"
#define HT_11500 "CRC32"
#define HT_11600 "7-Zip"
#define HT_11700 "GOST R 34.11-2012 (Streebog) 256-bit"
#define HT_11800 "GOST R 34.11-2012 (Streebog) 512-bit"
#define HT_11900 "PBKDF2-HMAC-MD5"
#define HT_12000 "PBKDF2-HMAC-SHA1"
#define HT_12100 "PBKDF2-HMAC-SHA512"
#define HT_12200 "eCryptfs"
#define HT_12300 "Oracle T: Type (Oracle 12+)"
#define HT_12400 "BSDiCrypt, Extended DES"
#define HT_12500 "RAR3-hp"
#define HT_12600 "ColdFusion 10+"
#define HT_12700 "Blockchain, My Wallet"
#define HT_12800 "MS-AzureSync PBKDF2-HMAC-SHA256"
#define HT_00011 "Joomla < 2.5.18"
#define HT_00012 "PostgreSQL"
#define HT_00021 "osCommerce, xt:Commerce"
#define HT_00022 "Juniper Netscreen/SSG (ScreenOS)"
#define HT_00023 "Skype"
#define HT_00101 "SHA-1(Base64), nsldap, Netscape LDAP SHA"
#define HT_00111 "SSHA-1(Base64), nsldaps, Netscape LDAP SSHA"
#define HT_00112 "Oracle S: Type (Oracle 11+)"
#define HT_00121 "SMF > v1.1"
#define HT_00122 "OSX v10.4, v10.5, v10.6"
#define HT_00124 "Django (SHA-1)"
#define HT_00131 "MSSQL(2000)"
#define HT_00132 "MSSQL(2005)"
#define HT_00133 "PeopleSoft"
#define HT_00141 "EPiServer 6.x < v4"
#define HT_01421 "hMailServer"
#define HT_01441 "EPiServer 6.x > v4"
#define HT_01711 "SSHA-512(Base64), LDAP {SSHA512}"
#define HT_01722 "OSX v10.7"
#define HT_01731 "MSSQL(2012)"
#define HT_02611 "vBulletin < v3.8.5"
#define HT_02612 "PHPS"
#define HT_02711 "vBulletin > v3.8.5"
#define HT_02811 "IPB2+, MyBB1.2+"
#define HT_06211 "TrueCrypt 5.0+ PBKDF2-HMAC-RipeMD160 + XTS 512 bit"
#define HT_06212 "TrueCrypt 5.0+ PBKDF2-HMAC-RipeMD160 + XTS 1024 bit"
#define HT_06213 "TrueCrypt 5.0+ PBKDF2-HMAC-RipeMD160 + XTS 1536 bit"
#define HT_06221 "TrueCrypt 5.0+ PBKDF2-HMAC-SHA512 + XTS 512 bit"
#define HT_06222 "TrueCrypt 5.0+ PBKDF2-HMAC-SHA512 + XTS 1024 bit"
#define HT_06223 "TrueCrypt 5.0+ PBKDF2-HMAC-SHA512 + XTS 1536 bit"
#define HT_06231 "TrueCrypt 5.0+ PBKDF2-HMAC-Whirlpool + XTS 512 bit"
#define HT_06232 "TrueCrypt 5.0+ PBKDF2-HMAC-Whirlpool + XTS 1024 bit"
#define HT_06233 "TrueCrypt 5.0+ PBKDF2-HMAC-Whirlpool + XTS 1536 bit"
#define HT_06241 "TrueCrypt 5.0+ PBKDF2-HMAC-RipeMD160 + XTS 512 bit + boot-mode"
#define HT_06242 "TrueCrypt 5.0+ PBKDF2-HMAC-RipeMD160 + XTS 1024 bit + boot-mode"
#define HT_06243 "TrueCrypt 5.0+ PBKDF2-HMAC-RipeMD160 + XTS 1536 bit + boot-mode"
/**
* Outfile formats
*/
#define OUTFILE_FMT_HASH (1 << 0)
#define OUTFILE_FMT_PLAIN (1 << 1)
#define OUTFILE_FMT_HEXPLAIN (1 << 2)
#define OUTFILE_FMT_CRACKPOS (1 << 3)
/**
* algo specific
*/
#define DISPLAY_LEN_MIN_0 32
#define DISPLAY_LEN_MAX_0 32
#define DISPLAY_LEN_MIN_10 32 + 1 + 0
#define DISPLAY_LEN_MAX_10 32 + 1 + 51
#define DISPLAY_LEN_MIN_10H 32 + 1 + 0
#define DISPLAY_LEN_MAX_10H 32 + 1 + 102
#define DISPLAY_LEN_MIN_20 32 + 1 + 0
#define DISPLAY_LEN_MAX_20 32 + 1 + 31
#define DISPLAY_LEN_MIN_20H 32 + 1 + 0
#define DISPLAY_LEN_MAX_20H 32 + 1 + 62
#define DISPLAY_LEN_MIN_50 32 + 1 + 0
#define DISPLAY_LEN_MAX_50 32 + 1 + 51
#define DISPLAY_LEN_MIN_50H 32 + 1 + 0
#define DISPLAY_LEN_MAX_50H 32 + 1 + 102
#define DISPLAY_LEN_MIN_100 40
#define DISPLAY_LEN_MAX_100 40
#define DISPLAY_LEN_MIN_110 40 + 1 + 0
#define DISPLAY_LEN_MAX_110 40 + 1 + 51
#define DISPLAY_LEN_MIN_110H 40 + 1 + 0
#define DISPLAY_LEN_MAX_110H 40 + 1 + 102
#define DISPLAY_LEN_MIN_120 40 + 1 + 0
#define DISPLAY_LEN_MAX_120 40 + 1 + 31
#define DISPLAY_LEN_MIN_120H 40 + 1 + 0
#define DISPLAY_LEN_MAX_120H 40 + 1 + 62
#define DISPLAY_LEN_MIN_150 40 + 1 + 0
#define DISPLAY_LEN_MAX_150 40 + 1 + 51
#define DISPLAY_LEN_MIN_150H 40 + 1 + 0
#define DISPLAY_LEN_MAX_150H 40 + 1 + 102
#define DISPLAY_LEN_MIN_190 40
#define DISPLAY_LEN_MAX_190 40
#define DISPLAY_LEN_MIN_200 16
#define DISPLAY_LEN_MAX_200 16
#define DISPLAY_LEN_MIN_300 40
#define DISPLAY_LEN_MAX_300 40
#define DISPLAY_LEN_MIN_400 34
#define DISPLAY_LEN_MAX_400 34
#define DISPLAY_LEN_MIN_500 3 + 1 + 0 + 22
#define DISPLAY_LEN_MIN_501 104
#define DISPLAY_LEN_MAX_500 3 + 1 + 8 + 22
#define DISPLAY_LEN_MAX_501 104
#define DISPLAY_LEN_MIN_900 32
#define DISPLAY_LEN_MAX_900 32
#define DISPLAY_LEN_MIN_910 32 + 1 + 0
#define DISPLAY_LEN_MAX_910 32 + 1 + 51
#define DISPLAY_LEN_MIN_910H 32 + 1 + 0
#define DISPLAY_LEN_MAX_910H 32 + 1 + 102
#define DISPLAY_LEN_MIN_1000 32
#define DISPLAY_LEN_MAX_1000 32
#define DISPLAY_LEN_MIN_1100 32 + 1 + 0
#define DISPLAY_LEN_MAX_1100 32 + 1 + 19
#define DISPLAY_LEN_MIN_1100H 32 + 1 + 0
#define DISPLAY_LEN_MAX_1100H 32 + 1 + 38
#define DISPLAY_LEN_MIN_1400 64
#define DISPLAY_LEN_MAX_1400 64
#define DISPLAY_LEN_MIN_1410 64 + 1 + 0
#define DISPLAY_LEN_MAX_1410 64 + 1 + 51
#define DISPLAY_LEN_MIN_1410H 64 + 1 + 0
#define DISPLAY_LEN_MAX_1410H 64 + 1 + 102
#define DISPLAY_LEN_MIN_1420 64 + 1 + 0
#define DISPLAY_LEN_MAX_1420 64 + 1 + 16
#define DISPLAY_LEN_MIN_1420H 64 + 1 + 0
#define DISPLAY_LEN_MAX_1420H 64 + 1 + 32
#define DISPLAY_LEN_MIN_1421 70
#define DISPLAY_LEN_MAX_1421 70
#define DISPLAY_LEN_MIN_1450 64 + 1 + 0
#define DISPLAY_LEN_MAX_1450 64 + 1 + 51
#define DISPLAY_LEN_MIN_1450H 64 + 1 + 0
#define DISPLAY_LEN_MAX_1450H 64 + 1 + 102
#define DISPLAY_LEN_MIN_1500 13
#define DISPLAY_LEN_MAX_1500 13
#define DISPLAY_LEN_MIN_1600 29 + 0
#define DISPLAY_LEN_MAX_1600 29 + 8
#define DISPLAY_LEN_MIN_1700 128
#define DISPLAY_LEN_MAX_1700 128
#define DISPLAY_LEN_MIN_1710 128 + 1 + 0
#define DISPLAY_LEN_MAX_1710 128 + 1 + 51
#define DISPLAY_LEN_MIN_1710H 128 + 1 + 0
#define DISPLAY_LEN_MAX_1710H 128 + 1 + 102
#define DISPLAY_LEN_MIN_1720 128 + 1 + 0
#define DISPLAY_LEN_MAX_1720 128 + 1 + 16
#define DISPLAY_LEN_MIN_1720H 128 + 1 + 0
#define DISPLAY_LEN_MAX_1720H 128 + 1 + 32
#define DISPLAY_LEN_MIN_1730 128 + 1 + 0
#define DISPLAY_LEN_MAX_1730 128 + 1 + 16
#define DISPLAY_LEN_MIN_1731 128 + 6 + 0
#define DISPLAY_LEN_MAX_1731 128 + 6 + 16
#define DISPLAY_LEN_MIN_1740 128 + 1 + 0
#define DISPLAY_LEN_MAX_1740 128 + 1 + 16
#define DISPLAY_LEN_MIN_1750 128 + 1 + 0
#define DISPLAY_LEN_MAX_1750 128 + 1 + 51
#define DISPLAY_LEN_MIN_1750H 128 + 1 + 0
#define DISPLAY_LEN_MAX_1750H 128 + 1 + 102
#define DISPLAY_LEN_MIN_1800 90 + 0
#define DISPLAY_LEN_MAX_1800 90 + 16
#define DISPLAY_LEN_MIN_2100 6 + 1 + 1 + 32 + 1 + 0
#define DISPLAY_LEN_MAX_2100 6 + 5 + 1 + 32 + 1 + 19
#define DISPLAY_LEN_MIN_2100H 6 + 1 + 1 + 32 + 1 + 0
#define DISPLAY_LEN_MAX_2100H 6 + 5 + 1 + 32 + 1 + 38
#define DISPLAY_LEN_MIN_2400 16
#define DISPLAY_LEN_MAX_2400 16
#define DISPLAY_LEN_MIN_2410 16 + 1 + 0
#define DISPLAY_LEN_MAX_2410 16 + 1 + 16
#define DISPLAY_LEN_MIN_2410H 16 + 1 + 0
#define DISPLAY_LEN_MAX_2410H 16 + 1 + 32
#define DISPLAY_LEN_MIN_2500 64 + 1 + 0
#define DISPLAY_LEN_MAX_2500 64 + 1 + 15
#define DISPLAY_LEN_MIN_2600 32
#define DISPLAY_LEN_MAX_2600 32
#define DISPLAY_LEN_MIN_3000 16
#define DISPLAY_LEN_MAX_3000 16
#define DISPLAY_LEN_MIN_3100 16 + 1 + 0
#define DISPLAY_LEN_MAX_3100 16 + 1 + 30
#define DISPLAY_LEN_MIN_3100H 16 + 1 + 0
#define DISPLAY_LEN_MAX_3100H 16 + 1 + 60
#define DISPLAY_LEN_MIN_3200 60
#define DISPLAY_LEN_MAX_3200 60
#define DISPLAY_LEN_MIN_3711 3 + 0 + 1 + 32
#define DISPLAY_LEN_MAX_3711 3 + 31 + 1 + 32
#define DISPLAY_LEN_MIN_4300 32
#define DISPLAY_LEN_MAX_4300 32
#define DISPLAY_LEN_MIN_4800 32 + 1 + 32 + 1 + 2
#define DISPLAY_LEN_MAX_4800 32 + 1 + 32 + 1 + 2
#define DISPLAY_LEN_MIN_5000 16
#define DISPLAY_LEN_MAX_5000 400
#define DISPLAY_LEN_MIN_5100 16
#define DISPLAY_LEN_MAX_5100 16
#define DISPLAY_LEN_MIN_5300 48
#define DISPLAY_LEN_MAX_5300 1024
#define DISPLAY_LEN_MIN_5400 56
#define DISPLAY_LEN_MAX_5400 1024
#define DISPLAY_LEN_MIN_5500 1 + 1 + 0 + 1 + 1 + 1 + 0 + 1 + 48 + 1 + 16
#define DISPLAY_LEN_MAX_5500 60 + 1 + 0 + 1 + 45 + 1 + 48 + 1 + 48 + 1 + 16
#define DISPLAY_LEN_MIN_5600 1 + 1 + 0 + 1 + 1 + 1 + 16 + 1 + 32 + 1 + 1
#define DISPLAY_LEN_MAX_5600 60 + 1 + 0 + 1 + 45 + 1 + 16 + 1 + 32 + 1 + 1024
#define DISPLAY_LEN_MIN_5700 43
#define DISPLAY_LEN_MAX_5700 43
#define DISPLAY_LEN_MIN_5800 40 + 1 + 1
#define DISPLAY_LEN_MAX_5800 40 + 1 + 16
#define DISPLAY_LEN_MIN_6000 40
#define DISPLAY_LEN_MAX_6000 40
#define DISPLAY_LEN_MIN_6100 128
#define DISPLAY_LEN_MAX_6100 128
#define DISPLAY_LEN_MIN_6300 6 + 1 + 8 + 22
#define DISPLAY_LEN_MAX_6300 6 + 1 + 48 + 22
#define DISPLAY_LEN_MIN_6400 9 + 2 + 1 + 16 + 1 + 43
#define DISPLAY_LEN_MAX_6400 9 + 2 + 1 + 48 + 1 + 43
#define DISPLAY_LEN_MIN_6500 9 + 2 + 1 + 16 + 1 + 86
#define DISPLAY_LEN_MAX_6500 9 + 2 + 1 + 48 + 1 + 86
#define DISPLAY_LEN_MIN_6600 1 + 1 + 16 + 1 + 2080
#define DISPLAY_LEN_MAX_6600 6 + 1 + 16 + 1 + 2080
#define DISPLAY_LEN_MIN_6700 7 + 2 + 1 + 16 + 1 + 27
#define DISPLAY_LEN_MAX_6700 7 + 2 + 1 + 48 + 1 + 27
#define DISPLAY_LEN_MIN_6800 32 + 1 + 1 + 1 + 0
#define DISPLAY_LEN_MAX_6800 32 + 1 + 5 + 1 + 32
#define DISPLAY_LEN_MIN_6900 64
#define DISPLAY_LEN_MAX_6900 64
#define DISPLAY_LEN_MIN_7100 4 + 2 + 1 + 64 + 1 + 128
#define DISPLAY_LEN_MAX_7100 4 + 5 + 1 + 64 + 1 + 128
#define DISPLAY_LEN_MIN_7200 19 + 1 + 1 + 1 + 128
#define DISPLAY_LEN_MAX_7200 19 + 5 + 1 + 224 + 128
#define DISPLAY_LEN_MIN_7300 64 + 1 + 40
#define DISPLAY_LEN_MAX_7300 512 + 1 + 40
#define DISPLAY_LEN_MIN_7400 47 + 0
#define DISPLAY_LEN_MAX_7400 47 + 16
#define DISPLAY_LEN_MIN_7500 1 + 6 + 1 + 2 + 1 + 0 + 1 + 0 + 1 + 0 + 1 + 72 + 32
#define DISPLAY_LEN_MAX_7500 1 + 6 + 1 + 2 + 1 + 64 + 1 + 64 + 1 + 128 + 1 + 72 + 32
#define DISPLAY_LEN_MIN_7700 1 + 1 + 16
#define DISPLAY_LEN_MAX_7700 40 + 1 + 16
#define DISPLAY_LEN_MIN_7800 1 + 1 + 40
#define DISPLAY_LEN_MAX_7800 40 + 1 + 40
#define DISPLAY_LEN_MIN_7900 3 + 1 + 8 + 43
#define DISPLAY_LEN_MAX_7900 3 + 1 + 8 + 43
#define DISPLAY_LEN_MIN_8000 2 + 4 + 16 + 64
#define DISPLAY_LEN_MAX_8000 2 + 4 + 16 + 64
#define DISPLAY_LEN_MIN_8100 1 + 8 + 40
#define DISPLAY_LEN_MAX_8100 1 + 8 + 40
#define DISPLAY_LEN_MIN_8200 64 + 1 + 32 + 1 + 1 + 1 + 1
#define DISPLAY_LEN_MAX_8200 64 + 1 + 32 + 1 + 8 + 1 + 2048
#define DISPLAY_LEN_MIN_8300 32 + 1 + 1 + 1 + 1 + 1 + 1
#define DISPLAY_LEN_MAX_8300 32 + 1 + 32 + 1 + 32 + 1 + 5
#define DISPLAY_LEN_MIN_8400 40 + 1 + 40
#define DISPLAY_LEN_MAX_8400 40 + 1 + 40
#define DISPLAY_LEN_MIN_8500 6 + 1 + 1 + 1 + 1
#define DISPLAY_LEN_MAX_8500 6 + 1 + 8 + 1 + 16
#define DISPLAY_LEN_MIN_8600 32
#define DISPLAY_LEN_MAX_8600 32
#define DISPLAY_LEN_MIN_8700 22
#define DISPLAY_LEN_MAX_8700 22
#define DISPLAY_LEN_MIN_8800 1 + 3 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 32 + 1 + 3072
#define DISPLAY_LEN_MAX_8800 1 + 3 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 32 + 1 + 3072
#define DISPLAY_LEN_MIN_8900 6 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 1 + 44
#define DISPLAY_LEN_MAX_8900 6 + 1 + 6 + 1 + 2 + 1 + 2 + 1 + 45 + 1 + 44
#define DISPLAY_LEN_MIN_9100 51
#define DISPLAY_LEN_MAX_9100 51
#define DISPLAY_LEN_MIN_9200 3 + 14 + 1 + 43
#define DISPLAY_LEN_MAX_9200 3 + 14 + 1 + 43
#define DISPLAY_LEN_MIN_9300 3 + 14 + 1 + 43
#define DISPLAY_LEN_MAX_9300 3 + 14 + 1 + 43
#define DISPLAY_LEN_MIN_9400 8 + 1 + 4 + 1 + 2 + 1 + 3 + 1 + 2 + 1 + 32 + 1 + 32 + 1 + 40
#define DISPLAY_LEN_MAX_9400 8 + 1 + 4 + 1 + 2 + 1 + 3 + 1 + 2 + 1 + 32 + 1 + 32 + 1 + 40
#define DISPLAY_LEN_MIN_9500 8 + 1 + 4 + 1 + 6 + 1 + 3 + 1 + 2 + 1 + 32 + 1 + 32 + 1 + 64
#define DISPLAY_LEN_MAX_9500 8 + 1 + 4 + 1 + 6 + 1 + 3 + 1 + 2 + 1 + 32 + 1 + 32 + 1 + 64
#define DISPLAY_LEN_MIN_9600 8 + 1 + 4 + 1 + 6 + 1 + 3 + 1 + 2 + 1 + 32 + 1 + 32 + 1 + 64
#define DISPLAY_LEN_MAX_9600 8 + 1 + 4 + 1 + 6 + 1 + 3 + 1 + 2 + 1 + 32 + 1 + 32 + 1 + 64
#define DISPLAY_LEN_MIN_9700 12 + 1 + 32 + 1 + 32 + 1 + 32
#define DISPLAY_LEN_MAX_9700 12 + 1 + 32 + 1 + 32 + 1 + 32
#define DISPLAY_LEN_MIN_9720 12 + 1 + 32 + 1 + 32 + 1 + 32 + 1 + 10
#define DISPLAY_LEN_MAX_9720 12 + 1 + 32 + 1 + 32 + 1 + 32 + 1 + 10
#define DISPLAY_LEN_MIN_9800 12 + 1 + 32 + 1 + 32 + 1 + 40
#define DISPLAY_LEN_MAX_9800 12 + 1 + 32 + 1 + 32 + 1 + 40
#define DISPLAY_LEN_MIN_9820 12 + 1 + 32 + 1 + 32 + 1 + 40 + 1 + 10
#define DISPLAY_LEN_MAX_9820 12 + 1 + 32 + 1 + 32 + 1 + 40 + 1 + 10
#define DISPLAY_LEN_MIN_9900 32
#define DISPLAY_LEN_MAX_9900 32
#define DISPLAY_LEN_MIN_10000 13 + 1 + 1 + 1 + 0 + 44
#define DISPLAY_LEN_MAX_10000 13 + 1 + 6 + 1 + 15 + 44
#define DISPLAY_LEN_MIN_10100 16 + 1 + 1 + 1 + 1 + 1 + 32
#define DISPLAY_LEN_MAX_10100 16 + 1 + 1 + 1 + 1 + 1 + 32
#define DISPLAY_LEN_MIN_10200 10 + 12 + 1 + 44
#define DISPLAY_LEN_MAX_10200 10 + 76 + 1 + 132
#define DISPLAY_LEN_MIN_10300 10 + 1 + 1 + 33
#define DISPLAY_LEN_MAX_10300 10 + 5 + 1 + 49
#define DISPLAY_LEN_MIN_10400 5 + 1 + 1 + 1 + 1 + 2 + 1 + 1 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64
#define DISPLAY_LEN_MAX_10400 5 + 1 + 1 + 1 + 1 + 2 + 1 + 5 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64
#define DISPLAY_LEN_MIN_10410 5 + 1 + 1 + 1 + 1 + 3 + 1 + 1 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64
#define DISPLAY_LEN_MAX_10410 5 + 1 + 1 + 1 + 1 + 3 + 1 + 5 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64
#define DISPLAY_LEN_MIN_10420 5 + 1 + 1 + 1 + 1 + 3 + 1 + 1 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64 + 1 + 10
#define DISPLAY_LEN_MAX_10420 5 + 1 + 1 + 1 + 1 + 3 + 1 + 5 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64 + 1 + 10
#define DISPLAY_LEN_MIN_10500 5 + 1 + 1 + 1 + 1 + 3 + 1 + 1 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64
#define DISPLAY_LEN_MAX_10500 5 + 1 + 1 + 1 + 1 + 3 + 1 + 5 + 1 + 1 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64 + 1 + 2 + 1 + 64
#define DISPLAY_LEN_MIN_10600 5 + 1 + 1 + 1 + 1 + 3 + 1 + 1 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 1
#define DISPLAY_LEN_MAX_10600 5 + 1 + 1 + 1 + 1 + 3 + 1 + 5 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 1000
#define DISPLAY_LEN_MIN_10700 5 + 1 + 1 + 1 + 1 + 3 + 1 + 1 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 1
#define DISPLAY_LEN_MAX_10700 5 + 1 + 1 + 1 + 1 + 3 + 1 + 5 + 1 + 1 + 1 + 2 + 1 + 32 + 1 + 1000
#define DISPLAY_LEN_MIN_10800 96
#define DISPLAY_LEN_MAX_10800 96
#define DISPLAY_LEN_MIN_10900 7 + 1 + 1 + 0 + 1 + 24
#define DISPLAY_LEN_MAX_10900 7 + 6 + 1 + 64 + 1 + 88
#define DISPLAY_LEN_MIN_11000 32 + 1 + 56
#define DISPLAY_LEN_MAX_11000 32 + 1 + 56
#define DISPLAY_LEN_MIN_11100 10 + 0 + 1 + 8 + 1 + 32
#define DISPLAY_LEN_MAX_11100 10 + 32 + 1 + 8 + 1 + 32
#define DISPLAY_LEN_MIN_11200 9 + 40 + 1 + 40
#define DISPLAY_LEN_MAX_11200 9 + 40 + 1 + 40
#define DISPLAY_LEN_MIN_11300 1 + 7 + 1 + 2 + 1 + 96 + 1 + 2 + 1 + 16 + 1 + 1 + 1 + 2 + 1 + 96 + 1 + 2 + 1 + 66
#define DISPLAY_LEN_MAX_11300 1 + 7 + 1 + 2 + 1 + 96 + 1 + 2 + 1 + 16 + 1 + 6 + 1 + 2 + 1 + 96 + 1 + 2 + 1 + 66
#define DISPLAY_LEN_MIN_11400 6 + 0 + 1 + 0 + 1 + 0 + 1 + 0 + 1 + 0 + 1 + 0 + 1 + 1 + 1 + 0 + 1 + 1 + 1 + 0 + 1 + 0 + 1 + 0 + 1 + 3 + 1 + 32
#define DISPLAY_LEN_MAX_11400 6 + 512 + 1 + 512 + 1 + 116 + 1 + 116 + 1 + 246 + 1 + 245 + 1 + 246 + 1 + 245 + 1 + 50 + 1 + 50 + 1 + 50 + 1 + 50 + 1 + 3 + 1 + 32
#define DISPLAY_LEN_MIN_11500 8 + 1 + 8
#define DISPLAY_LEN_MAX_11500 8 + 1 + 8
#define DISPLAY_LEN_MIN_11600 1 + 2 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 1 + 1 + 1 + 32 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 2
#define DISPLAY_LEN_MAX_11600 1 + 2 + 1 + 1 + 1 + 2 + 1 + 1 + 1 + 64 + 1 + 1 + 1 + 32 + 1 + 10 + 1 + 3 + 1 + 3 + 1 + 768
#define DISPLAY_LEN_MIN_11700 64
#define DISPLAY_LEN_MAX_11700 64
#define DISPLAY_LEN_MIN_11800 128
#define DISPLAY_LEN_MAX_11800 128
#define DISPLAY_LEN_MIN_11900 3 + 1 + 1 + 0 + 1 + 12
#define DISPLAY_LEN_MAX_11900 3 + 6 + 1 + 64 + 1 + 88
#define DISPLAY_LEN_MIN_12000 4 + 1 + 1 + 0 + 1 + 16
#define DISPLAY_LEN_MAX_12000 4 + 6 + 1 + 64 + 1 + 88
#define DISPLAY_LEN_MIN_12100 6 + 1 + 1 + 0 + 1 + 16
#define DISPLAY_LEN_MAX_12100 6 + 6 + 1 + 64 + 1 + 88
#define DISPLAY_LEN_MIN_12100 6 + 1 + 1 + 0 + 1 + 16
#define DISPLAY_LEN_MAX_12100 6 + 6 + 1 + 64 + 1 + 88
#define DISPLAY_LEN_MIN_12200 1 + 8 + 1 + 1 + 1 + 1 + 1 + 16 + 1 + 16
#define DISPLAY_LEN_MAX_12200 1 + 8 + 1 + 1 + 1 + 1 + 1 + 16 + 1 + 16
#define DISPLAY_LEN_MIN_12300 160
#define DISPLAY_LEN_MAX_12300 160
#define DISPLAY_LEN_MIN_12400 1 + 4 + 4 + 11
#define DISPLAY_LEN_MAX_12400 1 + 4 + 4 + 11
#define DISPLAY_LEN_MIN_12500 6 + 1 + 1 + 1 + 16 + 1 + 32
#define DISPLAY_LEN_MAX_12500 6 + 1 + 1 + 1 + 16 + 1 + 32
#define DISPLAY_LEN_MIN_12600 64 + 1 + 64
#define DISPLAY_LEN_MAX_12600 64 + 1 + 64
#define DISPLAY_LEN_MIN_12700 1 + 10 + 1 + 1 + 1 + 64
#define DISPLAY_LEN_MAX_12700 1 + 10 + 1 + 5 + 1 + 20000
#define DISPLAY_LEN_MIN_12800 11 + 1 + 20 + 1 + 1 + 1 + 64
#define DISPLAY_LEN_MAX_12800 11 + 1 + 20 + 1 + 5 + 1 + 64
#define DISPLAY_LEN_MIN_11 32 + 1 + 16
#define DISPLAY_LEN_MAX_11 32 + 1 + 32
#define DISPLAY_LEN_MIN_11H 32 + 1 + 32
#define DISPLAY_LEN_MAX_11H 32 + 1 + 64
#define DISPLAY_LEN_MIN_12 32 + 1 + 1
#define DISPLAY_LEN_MAX_12 32 + 1 + 32
#define DISPLAY_LEN_MIN_12H 32 + 1 + 2
#define DISPLAY_LEN_MAX_12H 32 + 1 + 64
#define DISPLAY_LEN_MIN_21 32 + 1 + 1
#define DISPLAY_LEN_MAX_21 32 + 1 + 15
#define DISPLAY_LEN_MIN_21H 32 + 1 + 2
#define DISPLAY_LEN_MAX_21H 32 + 1 + 30
#define DISPLAY_LEN_MIN_22 30 + 1 + 1
#define DISPLAY_LEN_MAX_22 30 + 1 + 15
#define DISPLAY_LEN_MIN_22H 30 + 1 + 2
#define DISPLAY_LEN_MAX_22H 30 + 1 + 30
#define DISPLAY_LEN_MIN_23 32 + 1 + 0
#define DISPLAY_LEN_MAX_23 32 + 1 + 23
#define DISPLAY_LEN_MIN_101 5 + 28
#define DISPLAY_LEN_MAX_101 5 + 28
#define DISPLAY_LEN_MIN_111 6 + 28 + 0
#define DISPLAY_LEN_MAX_111 6 + 28 + 40
#define DISPLAY_LEN_MIN_112 40 + 1 + 20
#define DISPLAY_LEN_MAX_112 40 + 1 + 20
#define DISPLAY_LEN_MIN_121 40 + 1 + 1
#define DISPLAY_LEN_MAX_121 40 + 1 + 32
#define DISPLAY_LEN_MIN_121H 40 + 1 + 2
#define DISPLAY_LEN_MAX_121H 40 + 1 + 64
#define DISPLAY_LEN_MIN_122 8 + 40
#define DISPLAY_LEN_MAX_122 8 + 40
#define DISPLAY_LEN_MIN_124 4 + 1 + 0 + 1 + 40
#define DISPLAY_LEN_MAX_124 4 + 1 + 32 + 1 + 40
#define DISPLAY_LEN_MIN_131 6 + 8 + 80
#define DISPLAY_LEN_MAX_131 6 + 8 + 80
#define DISPLAY_LEN_MIN_132 6 + 8 + 40
#define DISPLAY_LEN_MAX_132 6 + 8 + 40
#define DISPLAY_LEN_MIN_133 28
#define DISPLAY_LEN_MAX_133 28
#define DISPLAY_LEN_MIN_141 14 + 0 + 1 + 28
#define DISPLAY_LEN_MAX_141 14 + 44 + 1 + 28
#define DISPLAY_LEN_MIN_1441 14 + 0 + 1 + 43
#define DISPLAY_LEN_MAX_1441 14 + 24 + 1 + 43
#define DISPLAY_LEN_MIN_1711 9 + 86 + 0
#define DISPLAY_LEN_MAX_1711 9 + 86 + 68
#define DISPLAY_LEN_MIN_1722 8 + 128
#define DISPLAY_LEN_MAX_1722 8 + 128
#define DISPLAY_LEN_MIN_2611 32 + 1 + 0
#define DISPLAY_LEN_MAX_2611 32 + 1 + 23
#define DISPLAY_LEN_MIN_2611H 32 + 1 + 0
#define DISPLAY_LEN_MIN_2612 6 + 0 + 1 + 32
#define DISPLAY_LEN_MAX_2611H 32 + 1 + 46
#define DISPLAY_LEN_MAX_2612 6 + 46 + 1 + 32
#define DISPLAY_LEN_MIN_2711 32 + 1 + 23
#define DISPLAY_LEN_MAX_2711 32 + 1 + 31
#define DISPLAY_LEN_MIN_2711H 32 + 1 + 46
#define DISPLAY_LEN_MAX_2711H 32 + 1 + 62
#define DISPLAY_LEN_MIN_2811 32 + 1 + 0
#define DISPLAY_LEN_MAX_2811 32 + 1 + 31
#define DISPLAY_LEN_MIN_2811H 32 + 1 + 0
#define DISPLAY_LEN_MAX_2811H 32 + 1 + 62
#define DISPLAY_LEN_MIN_7600 40 + 1 + 32
#define DISPLAY_LEN_MAX_7600 40 + 1 + 32
#define HASH_TYPE_MD4 1
#define HASH_TYPE_MD5 2
#define HASH_TYPE_MD5H 3
#define HASH_TYPE_SHA1 4
#define HASH_TYPE_SHA256 5
#define HASH_TYPE_SHA384 6
#define HASH_TYPE_SHA512 7
#define HASH_TYPE_DCC2 8
#define HASH_TYPE_WPA 9
#define HASH_TYPE_LM 10
#define HASH_TYPE_DESCRYPT 11
#define HASH_TYPE_ORACLEH 12
#define HASH_TYPE_DESRACF 13
#define HASH_TYPE_BCRYPT 14
#define HASH_TYPE_KECCAK 15
#define HASH_TYPE_NETNTLM 16
#define HASH_TYPE_RIPEMD160 17
#define HASH_TYPE_WHIRLPOOL 18
#define HASH_TYPE_AES 19
#define HASH_TYPE_GOST 20
#define HASH_TYPE_KRB5PA 21
#define HASH_TYPE_SAPB 22
#define HASH_TYPE_SAPG 23
#define HASH_TYPE_MYSQL 24
#define HASH_TYPE_LOTUS5 25
#define HASH_TYPE_LOTUS6 26
#define HASH_TYPE_ANDROIDFDE 27
#define HASH_TYPE_SCRYPT 28
#define HASH_TYPE_LOTUS8 29
#define HASH_TYPE_OFFICE2007 30
#define HASH_TYPE_OFFICE2010 31
#define HASH_TYPE_OFFICE2013 32
#define HASH_TYPE_OLDOFFICE01 33
#define HASH_TYPE_OLDOFFICE34 34
#define HASH_TYPE_SIPHASH 35
#define HASH_TYPE_PDFU16 36
#define HASH_TYPE_PDFU32 37
#define HASH_TYPE_PBKDF2_SHA256 38
#define HASH_TYPE_BITCOIN_WALLET 39
#define HASH_TYPE_CRC32 40
#define HASH_TYPE_GOST_2012SBOG_256 41
#define HASH_TYPE_GOST_2012SBOG_512 42
#define HASH_TYPE_PBKDF2_MD5 43
#define HASH_TYPE_PBKDF2_SHA1 44
#define HASH_TYPE_PBKDF2_SHA512 45
#define HASH_TYPE_ECRYPTFS 46
#define HASH_TYPE_ORACLET 47
#define HASH_TYPE_BSDICRYPT 48
#define HASH_TYPE_RAR3HP 49
#define KERN_TYPE_MD5 0
#define KERN_TYPE_MD5_PWSLT 10
#define KERN_TYPE_MD5_SLTPW 20
#define KERN_TYPE_MD5_PWUSLT 30
#define KERN_TYPE_MD5_SLTPWU 40
#define KERN_TYPE_HMACMD5_PW 50
#define KERN_TYPE_HMACMD5_SLT 60
#define KERN_TYPE_SHA1 100
#define KERN_TYPE_SHA1_PWSLT 110
#define KERN_TYPE_SHA1_SLTPW 120
#define KERN_TYPE_SHA1_PWUSLT 130
#define KERN_TYPE_SHA1_SLTPWU 140
#define KERN_TYPE_HMACSHA1_PW 150
#define KERN_TYPE_HMACSHA1_SLT 160
#define KERN_TYPE_SHA1_LINKEDIN 190
#define KERN_TYPE_MYSQL 200
#define KERN_TYPE_MYSQL41 300
#define KERN_TYPE_PHPASS 400
#define KERN_TYPE_MD5CRYPT 500
#define KERN_TYPE_MD4 900
#define KERN_TYPE_MD4_PWU 1000
#define KERN_TYPE_MD44_PWUSLT 1100
#define KERN_TYPE_SHA256 1400
#define KERN_TYPE_SHA256_PWSLT 1410
#define KERN_TYPE_SHA256_SLTPW 1420
#define KERN_TYPE_SHA256_PWUSLT 1430
#define KERN_TYPE_SHA256_SLTPWU 1440
#define KERN_TYPE_HMACSHA256_PW 1450
#define KERN_TYPE_HMACSHA256_SLT 1460
#define KERN_TYPE_DESCRYPT 1500
#define KERN_TYPE_APR1CRYPT 1600
#define KERN_TYPE_SHA512 1700
#define KERN_TYPE_SHA512_PWSLT 1710
#define KERN_TYPE_SHA512_SLTPW 1720
#define KERN_TYPE_SHA512_PWSLTU 1730
#define KERN_TYPE_SHA512_SLTPWU 1740
#define KERN_TYPE_HMACSHA512_PW 1750
#define KERN_TYPE_HMACSHA512_SLT 1760
#define KERN_TYPE_SHA512CRYPT 1800
#define KERN_TYPE_DCC2 2100
#define KERN_TYPE_MD5PIX 2400
#define KERN_TYPE_MD5ASA 2410
#define KERN_TYPE_WPA 2500
#define KERN_TYPE_MD55 2600
#define KERN_TYPE_MD55_PWSLT1 2610
#define KERN_TYPE_MD55_PWSLT2 2710
#define KERN_TYPE_MD55_SLTPW 2810
#define KERN_TYPE_LM 3000
#define KERN_TYPE_ORACLEH 3100
#define KERN_TYPE_BCRYPT 3200
#define KERN_TYPE_MD5_SLT_MD5_PW 3710
#define KERN_TYPE_MD5_SLT_PW_SLT 3800
#define KERN_TYPE_MD5U5 4300
#define KERN_TYPE_MD5U5_PWSLT1 4310
#define KERN_TYPE_MD5_SHA1 4400
#define KERN_TYPE_SHA11 4500
#define KERN_TYPE_SHA1_MD5 4700
#define KERN_TYPE_MD5_CHAP 4800
#define KERN_TYPE_SHA1_SLT_PW_SLT 4900
#define KERN_TYPE_KECCAK 5000
#define KERN_TYPE_MD5H 5100
#define KERN_TYPE_PSAFE3 5200
#define KERN_TYPE_IKEPSK_MD5 5300
#define KERN_TYPE_IKEPSK_SHA1 5400
#define KERN_TYPE_NETNTLMv1 5500
#define KERN_TYPE_NETNTLMv2 5600
#define KERN_TYPE_ANDROIDPIN 5800
#define KERN_TYPE_RIPEMD160 6000
#define KERN_TYPE_WHIRLPOOL 6100
#define KERN_TYPE_TCRIPEMD160_XTS512 6211
#define KERN_TYPE_TCRIPEMD160_XTS1024 6212
#define KERN_TYPE_TCRIPEMD160_XTS1536 6213
#define KERN_TYPE_TCSHA512_XTS512 6221
#define KERN_TYPE_TCSHA512_XTS1024 6222
#define KERN_TYPE_TCSHA512_XTS1536 6223
#define KERN_TYPE_TCWHIRLPOOL_XTS512 6231
#define KERN_TYPE_TCWHIRLPOOL_XTS1024 6232
#define KERN_TYPE_TCWHIRLPOOL_XTS1536 6233
#define KERN_TYPE_MD5AIX 6300
#define KERN_TYPE_SHA256AIX 6400
#define KERN_TYPE_SHA512AIX 6500
#define KERN_TYPE_AGILEKEY 6600
#define KERN_TYPE_SHA1AIX 6700
#define KERN_TYPE_LASTPASS 6800
#define KERN_TYPE_GOST 6900
#define KERN_TYPE_PBKDF2_SHA512 7100
#define KERN_TYPE_RAKP 7300
#define KERN_TYPE_SHA256CRYPT 7400
#define KERN_TYPE_KRB5PA 7500
#define KERN_TYPE_SHA1_SLT_SHA1_PW 7600
#define KERN_TYPE_SAPB 7700
#define KERN_TYPE_SAPG 7800
#define KERN_TYPE_DRUPAL7 7900
#define KERN_TYPE_SYBASEASE 8000
#define KERN_TYPE_NETSCALER 8100
#define KERN_TYPE_CLOUDKEY 8200
#define KERN_TYPE_NSEC3 8300
#define KERN_TYPE_WBB3 8400
#define KERN_TYPE_RACF 8500
#define KERN_TYPE_LOTUS5 8600
#define KERN_TYPE_LOTUS6 8700
#define KERN_TYPE_ANDROIDFDE 8800
#define KERN_TYPE_SCRYPT 8900
#define KERN_TYPE_PSAFE2 9000
#define KERN_TYPE_LOTUS8 9100
#define KERN_TYPE_OFFICE2007 9400
#define KERN_TYPE_OFFICE2010 9500
#define KERN_TYPE_OFFICE2013 9600
#define KERN_TYPE_OLDOFFICE01 9700
#define KERN_TYPE_OLDOFFICE01CM1 9710
#define KERN_TYPE_OLDOFFICE01CM2 9720
#define KERN_TYPE_OLDOFFICE34 9800
#define KERN_TYPE_OLDOFFICE34CM1 9810
#define KERN_TYPE_OLDOFFICE34CM2 9820
#define KERN_TYPE_RADMIN2 9900
#define KERN_TYPE_SIPHASH 10100
#define KERN_TYPE_SAPH_SHA1 10300
#define KERN_TYPE_PDF11 10400
#define KERN_TYPE_PDF11CM1 10410
#define KERN_TYPE_PDF11CM2 10420
#define KERN_TYPE_PDF14 10500
#define KERN_TYPE_PDF17L8 10700
#define KERN_TYPE_SHA384 10800
#define KERN_TYPE_PBKDF2_SHA256 10900
#define KERN_TYPE_PRESTASHOP 11000
#define KERN_TYPE_POSTGRESQL_AUTH 11100
#define KERN_TYPE_MYSQL_AUTH 11200
#define KERN_TYPE_BITCOIN_WALLET 11300
#define KERN_TYPE_SIP_AUTH 11400
#define KERN_TYPE_CRC32 11500
#define KERN_TYPE_SEVEN_ZIP 11600
#define KERN_TYPE_GOST_2012SBOG_256 11700
#define KERN_TYPE_GOST_2012SBOG_512 11800
#define KERN_TYPE_PBKDF2_MD5 11900
#define KERN_TYPE_PBKDF2_SHA1 12000
#define KERN_TYPE_ECRYPTFS 12200
#define KERN_TYPE_ORACLET 12300
#define KERN_TYPE_BSDICRYPT 12400
#define KERN_TYPE_RAR3 12500
#define KERN_TYPE_CF10 12600
#define KERN_TYPE_MYWALLET 12700
#define KERN_TYPE_MS_DRSR 12800
/**
* signatures
*/
#define SIGNATURE_PHPASS1 "$P$"
#define SIGNATURE_PHPASS2 "$H$"
#define SIGNATURE_MD5CRYPT "$1$"
#define SIGNATURE_BCRYPT1 "$2a$"
#define SIGNATURE_BCRYPT2 "$2x$"
#define SIGNATURE_BCRYPT3 "$2y$"
#define SIGNATURE_SHA512CRYPT "$6$"
#define SIGNATURE_MD5APR1 "$apr1$"
#define SIGNATURE_MSSQL "0x0100"
#define SIGNATURE_MSSQL2012 "0x0200"
#define SIGNATURE_SHA1B64 "{SHA}"
#define SIGNATURE_SSHA1B64_lower "{ssha}"
#define SIGNATURE_SSHA1B64_upper "{SSHA}"
#define SIGNATURE_EPISERVER "$episerver$*0*"
#define SIGNATURE_EPISERVER4 "$episerver$*1*"
#define SIGNATURE_PSAFE3 "PWS3"
#define SIGNATURE_TRUECRYPT "TRUE"
#define SIGNATURE_MD5AIX "{smd5}"
#define SIGNATURE_SHA1AIX "{ssha1}"
#define SIGNATURE_SHA256AIX "{ssha256}"
#define SIGNATURE_SHA512AIX "{ssha512}"
#define SIGNATURE_SHA256CRYPT "$5$"
#define SIGNATURE_SHA512OSX "$ml$"
#define SIGNATURE_SHA512GRUB "grub.pbkdf2.sha512."
#define SIGNATURE_SHA512B64S "{SSHA512}"
#define SIGNATURE_KRB5PA "$krb5pa$23"
#define SIGNATURE_DRUPAL7 "$S$"
#define SIGNATURE_SYBASEASE "0xc007"
#define SIGNATURE_NETSCALER "1"
#define SIGNATURE_DCC2 "$DCC2$"
#define SIGNATURE_RACF "$racf$"
#define SIGNATURE_PHPS "$PHPS$"
#define SIGNATURE_MEDIAWIKI_B "$B$"
#define SIGNATURE_ANDROIDFDE "$fde$"
#define SIGNATURE_SCRYPT "SCRYPT"
#define SIGNATURE_CISCO8 "$8$"
#define SIGNATURE_CISCO9 "$9$"
#define SIGNATURE_OFFICE2007 "$office$"
#define SIGNATURE_OFFICE2010 "$office$"
#define SIGNATURE_OFFICE2013 "$office$"
#define SIGNATURE_OLDOFFICE0 "$oldoffice$0"
#define SIGNATURE_OLDOFFICE1 "$oldoffice$1"
#define SIGNATURE_OLDOFFICE3 "$oldoffice$3"
#define SIGNATURE_OLDOFFICE4 "$oldoffice$4"
#define SIGNATURE_DJANGOSHA1 "sha1$"
#define SIGNATURE_DJANGOPBKDF2 "pbkdf2_sha256$"
#define SIGNATURE_CRAM_MD5 "$cram_md5$"
#define SIGNATURE_SAPH_SHA1 "{x-issha, "
#define SIGNATURE_PDF "$pdf$"
#define SIGNATURE_PBKDF2_SHA256 "sha256:"
#define SIGNATURE_POSTGRESQL_AUTH "$postgres$"
#define SIGNATURE_MYSQL_AUTH "$mysqlna$"
#define SIGNATURE_BITCOIN_WALLET "$bitcoin$"
#define SIGNATURE_SIP_AUTH "$sip$*"
#define SIGNATURE_SEVEN_ZIP "$7z$"
#define SIGNATURE_PBKDF2_MD5 "md5:"
#define SIGNATURE_PBKDF2_SHA1 "sha1:"
#define SIGNATURE_PBKDF2_SHA512 "sha512:"
#define SIGNATURE_ECRYPTFS "$ecryptfs$"
#define SIGNATURE_BSDICRYPT "_"
#define SIGNATURE_RAR3 "$RAR3$"
#define SIGNATURE_MYWALLET "$blockchain$"
#define SIGNATURE_MS_DRSR "v1;PPH1_MD4"
/**
* Default iteration numbers
*/
#define ROUNDS_PHPASS (1 << 11) // $P$B
#define ROUNDS_DCC2 10240
#define ROUNDS_WPA2 4096
#define ROUNDS_BCRYPT (1 << 5)
#define ROUNDS_PSAFE3 2048
#define ROUNDS_ANDROIDPIN 1024
#define ROUNDS_TRUECRYPT_1K 1000
#define ROUNDS_TRUECRYPT_2K 2000
#define ROUNDS_SHA1AIX (1 << 6)
#define ROUNDS_SHA256AIX (1 << 6)
#define ROUNDS_SHA512AIX (1 << 6)
#define ROUNDS_MD5CRYPT 1000
#define ROUNDS_SHA256CRYPT 5000
#define ROUNDS_SHA512CRYPT 5000
#define ROUNDS_GRUB 10000
#define ROUNDS_SHA512OSX 35000
#define ROUNDS_AGILEKEY 1000
#define ROUNDS_LASTPASS 500
#define ROUNDS_DRUPAL7 (1 << 14) // $S$C
#define ROUNDS_CLOUDKEY 40000
#define ROUNDS_NSEC3 1
#define ROUNDS_ANDROIDFDE 2000
#define ROUNDS_PSAFE2 1000
#define ROUNDS_LOTUS8 5000
#define ROUNDS_CISCO8 20000
#define ROUNDS_OFFICE2007 50000
#define ROUNDS_OFFICE2010 100000
#define ROUNDS_OFFICE2013 100000
#define ROUNDS_DJANGOPBKDF2 20000
#define ROUNDS_SAPH_SHA1 1024
#define ROUNDS_PDF14 (50 + 20)
#define ROUNDS_PDF17L8 64
#define ROUNDS_PBKDF2_SHA256 1000
#define ROUNDS_BITCOIN_WALLET 200000
#define ROUNDS_SEVEN_ZIP (1 << 19)
#define ROUNDS_PBKDF2_MD5 1000
#define ROUNDS_PBKDF2_SHA1 1000
#define ROUNDS_PBKDF2_SHA512 1000
#define ROUNDS_ECRYPTFS 65536
#define ROUNDS_ORACLET 4096
#define ROUNDS_BSDICRYPT 2900
#define ROUNDS_RAR3 262144
#define ROUNDS_MYWALLET 10
#define ROUNDS_MS_DRSR 100
/**
* salt types
*/
#define SALT_TYPE_NONE 1
#define SALT_TYPE_EMBEDDED 2
#define SALT_TYPE_INTERN 3
#define SALT_TYPE_EXTERN 4
#define SALT_TYPE_VIRTUAL 5
/**
* optimizer options
*/
#define OPTI_TYPE_ZERO_BYTE (1 << 1)
#define OPTI_TYPE_PRECOMPUTE_INIT (1 << 2)
#define OPTI_TYPE_PRECOMPUTE_MERKLE (1 << 3)
#define OPTI_TYPE_PRECOMPUTE_PERMUT (1 << 4)
#define OPTI_TYPE_MEET_IN_MIDDLE (1 << 5)
#define OPTI_TYPE_EARLY_SKIP (1 << 6)
#define OPTI_TYPE_NOT_SALTED (1 << 7)
#define OPTI_TYPE_NOT_ITERATED (1 << 8)
#define OPTI_TYPE_PREPENDED_SALT (1 << 9)
#define OPTI_TYPE_APPENDED_SALT (1 << 10)
#define OPTI_TYPE_SINGLE_HASH (1 << 11)
#define OPTI_TYPE_SINGLE_SALT (1 << 12)
#define OPTI_TYPE_BRUTE_FORCE (1 << 13)
#define OPTI_TYPE_RAW_HASH (1 << 15)
#define OPTI_STR_ZERO_BYTE "Zero-Byte"
#define OPTI_STR_PRECOMPUTE_INIT "Precompute-Init"
#define OPTI_STR_PRECOMPUTE_MERKLE "Precompute-Merkle-Demgard"
#define OPTI_STR_PRECOMPUTE_PERMUT "Precompute-Final-Permutation"
#define OPTI_STR_MEET_IN_MIDDLE "Meet-In-The-Middle"
#define OPTI_STR_EARLY_SKIP "Early-Skip"
#define OPTI_STR_NOT_SALTED "Not-Salted"
#define OPTI_STR_NOT_ITERATED "Not-Iterated"
#define OPTI_STR_PREPENDED_SALT "Prepended-Salt"
#define OPTI_STR_APPENDED_SALT "Appended-Salt"
#define OPTI_STR_SINGLE_HASH "Single-Hash"
#define OPTI_STR_SINGLE_SALT "Single-Salt"
#define OPTI_STR_BRUTE_FORCE "Brute-Force"
#define OPTI_STR_RAW_HASH "Raw-Hash"
/**
* hash options
*/
#define OPTS_TYPE_PT_UNICODE (1 << 0)
#define OPTS_TYPE_PT_UPPER (1 << 1)
#define OPTS_TYPE_PT_LOWER (1 << 2)
#define OPTS_TYPE_PT_ADD01 (1 << 3)
#define OPTS_TYPE_PT_ADD02 (1 << 4)
#define OPTS_TYPE_PT_ADD80 (1 << 5)
#define OPTS_TYPE_PT_ADDBITS14 (1 << 6)
#define OPTS_TYPE_PT_ADDBITS15 (1 << 7)
#define OPTS_TYPE_PT_GENERATE_LE (1 << 8)
#define OPTS_TYPE_PT_GENERATE_BE (1 << 9)
#define OPTS_TYPE_PT_NEVERCRACK (1 << 10) // if we want all possible results
#define OPTS_TYPE_PT_BITSLICE (1 << 11)
#define OPTS_TYPE_ST_UNICODE (1 << 12)
#define OPTS_TYPE_ST_UPPER (1 << 13)
#define OPTS_TYPE_ST_LOWER (1 << 14)
#define OPTS_TYPE_ST_ADD01 (1 << 15)
#define OPTS_TYPE_ST_ADD02 (1 << 16)
#define OPTS_TYPE_ST_ADD80 (1 << 17)
#define OPTS_TYPE_ST_ADDBITS14 (1 << 18)
#define OPTS_TYPE_ST_ADDBITS15 (1 << 19)
#define OPTS_TYPE_ST_GENERATE_LE (1 << 20)
#define OPTS_TYPE_ST_GENERATE_BE (1 << 21)
#define OPTS_TYPE_ST_HEX (1 << 22)
#define OPTS_TYPE_ST_BASE64 (1 << 23)
#define OPTS_TYPE_HASH_COPY (1 << 24)
#define OPTS_TYPE_HOOK12 (1 << 25)
#define OPTS_TYPE_HOOK23 (1 << 26)
/**
* digests
*/
#define DGST_SIZE_0 0
#define DGST_SIZE_4_2 (2 * sizeof (uint)) // 8
#define DGST_SIZE_4_4 (4 * sizeof (uint)) // 16
#define DGST_SIZE_4_5 (5 * sizeof (uint)) // 20
#define DGST_SIZE_4_6 (6 * sizeof (uint)) // 24
#define DGST_SIZE_4_8 (8 * sizeof (uint)) // 32
#define DGST_SIZE_4_16 (16 * sizeof (uint)) // 64 !!!
#define DGST_SIZE_4_32 (32 * sizeof (uint)) // 128 !!!
#define DGST_SIZE_4_64 (64 * sizeof (uint)) // 256
#define DGST_SIZE_8_8 (8 * sizeof (uint64_t)) // 64 !!!
#define DGST_SIZE_8_16 (16 * sizeof (uint64_t)) // 128 !!!
#define DGST_SIZE_8_25 (25 * sizeof (uint64_t)) // 200
/**
* parser
*/
#define PARSER_OK 0
#define PARSER_COMMENT -1
#define PARSER_GLOBAL_ZERO -2
#define PARSER_GLOBAL_LENGTH -3
#define PARSER_HASH_LENGTH -4
#define PARSER_HASH_VALUE -5
#define PARSER_SALT_LENGTH -6
#define PARSER_SALT_VALUE -7
#define PARSER_SALT_ITERATION -8
#define PARSER_SEPARATOR_UNMATCHED -9
#define PARSER_SIGNATURE_UNMATCHED -10
#define PARSER_HCCAP_FILE_SIZE -11
#define PARSER_HCCAP_EAPOL_SIZE -12
#define PARSER_PSAFE2_FILE_SIZE -13
#define PARSER_PSAFE3_FILE_SIZE -14
#define PARSER_TC_FILE_SIZE -15
#define PARSER_SIP_AUTH_DIRECTIVE -16
#define PARSER_UNKNOWN_ERROR -255
#define PA_000 "OK"
#define PA_001 "Ignored due to comment"
#define PA_002 "Ignored due to zero length"
#define PA_003 "Line-length exception"
#define PA_004 "Hash-length exception"
#define PA_005 "Hash-value exception"
#define PA_006 "Salt-length exception"
#define PA_007 "Salt-value exception"
#define PA_008 "Salt-iteration count exception"
#define PA_009 "Separator unmatched"
#define PA_010 "Signature unmatched"
#define PA_011 "Invalid hccap filesize"
#define PA_012 "Invalid eapol size"
#define PA_013 "Invalid psafe2 filesize"
#define PA_014 "Invalid psafe3 filesize"
#define PA_015 "Invalid truecrypt filesize"
#define PA_016 "Invalid SIP directive, only MD5 is supported"
#define PA_255 "Unknown error"
/**
* status
*/
#define STATUS_STARTING 0
#define STATUS_INIT 1
#define STATUS_RUNNING 2
#define STATUS_PAUSED 3
#define STATUS_EXHAUSTED 4
#define STATUS_CRACKED 5
#define STATUS_ABORTED 6
#define STATUS_QUIT 7
#define STATUS_BYPASS 8
#define STATUS_STOP_AT_CHECKPOINT 9
#define ST_0000 "Initializing"
#define ST_0001 "Starting"
#define ST_0002 "Running"
#define ST_0003 "Paused"
#define ST_0004 "Exhausted"
#define ST_0005 "Cracked"
#define ST_0006 "Aborted"
#define ST_0007 "Quit"
#define ST_0008 "Bypass"
#define ST_0009 "Running (stop at checkpoint)"
/**
* kernel types
*/
#define KERN_RUN_MP 101
#define KERN_RUN_MP_L 102
#define KERN_RUN_MP_R 103
#define KERN_RUN_1 1000
#define KERN_RUN_12 1500
#define KERN_RUN_2 2000
#define KERN_RUN_23 2500
#define KERN_RUN_3 3000
/*
* functions
*/
#define ROTATE_LEFT(a,n) rotl32 ((a), (n))
#define ROTATE_RIGHT(a,n) rotr32 ((a), (n))
uint32_t rotl32 (const uint32_t a, const uint n);
uint32_t rotr32 (const uint32_t a, const uint n);
uint64_t rotl64 (const uint64_t a, const uint n);
uint64_t rotr64 (const uint64_t a, const uint n);
void dump_hex (const char *s, size_t size);
void truecrypt_crc32 (char *file, unsigned char keytab[64]);
char *get_install_dir (const char *progname);
char *get_profile_dir (const char *homedir);
char *get_session_dir (const char *profile_dir, const char *session);
uint get_vliw_by_compute_capability (const uint major, const uint minor);
uint get_vliw_by_device_name (const char *device_name);
void *rulefind (const void *key, void *base, int nmemb, size_t size, int (*compar) (const void *, const void *));
int sort_by_mtime (const void *p1, const void *p2);
int sort_by_cpu_rule (const void *p1, const void *p2);
int sort_by_gpu_rule (const void *p1, const void *p2);
int sort_by_stringptr (const void *p1, const void *p2);
int sort_by_dictstat (const void *s1, const void *s2);
int sort_by_bitmap (const void *s1, const void *s2);
int sort_by_pot (const void *v1, const void *v2);
int sort_by_hash (const void *v1, const void *v2);
int sort_by_hash_no_salt(const void *v1, const void *v2);
int sort_by_salt (const void *v1, const void *v2);
int sort_by_salt_buf (const void *v1, const void *v2);
int sort_by_hash_t_salt (const void *v1, const void *v2);
int sort_by_digest_4_2 (const void *v1, const void *v2);
int sort_by_digest_4_4 (const void *v1, const void *v2);
int sort_by_digest_4_5 (const void *v1, const void *v2);
int sort_by_digest_4_6 (const void *v1, const void *v2);
int sort_by_digest_4_8 (const void *v1, const void *v2);
int sort_by_digest_4_16 (const void *v1, const void *v2);
int sort_by_digest_4_32 (const void *v1, const void *v2);
int sort_by_digest_4_64 (const void *v1, const void *v2);
int sort_by_digest_8_8 (const void *v1, const void *v2);
int sort_by_digest_8_16 (const void *v1, const void *v2);
int sort_by_digest_8_25 (const void *v1, const void *v2);
int sort_by_digest_p0p1 (const void *v1, const void *v2);
// special version for hccap (last 2 uints should be skipped where the digest is located)
int sort_by_hash_t_salt_hccap (const void *v1, const void *v2);
char hex_convert (const char c);
char hex_to_char (const char hex[2]);
uint hex_to_uint (const char hex[8]);
uint64_t hex_to_uint64_t (const char hex[16]);
void format_debug (char * debug_file, uint debug_mode, unsigned char *orig_plain_ptr, uint orig_plain_len, unsigned char *mod_plain_ptr, uint mod_plain_len, char *rule_buf, int rule_len);
void format_plain (FILE *fp, unsigned char *plain_ptr, uint plain_len, uint outfile_autohex);
void format_output (FILE *out_fp, char *out_buf, unsigned char *plain_ptr, const uint plain_len, const uint64_t crackpos, unsigned char *username, const uint user_len);
void handle_show_request (pot_t *pot, uint pot_cnt, char *input_buf, int input_len, hash_t *hashes_buf, int (*sort_by_pot) (const void *, const void *), FILE *out_fp);
void handle_left_request (pot_t *pot, uint pot_cnt, char *input_buf, int input_len, hash_t *hashes_buf, int (*sort_by_pot) (const void *, const void *), FILE *out_fp);
void handle_show_request_lm (pot_t *pot, uint pot_cnt, char *input_buf, int input_len, hash_t *hash_left, hash_t *hash_right, int (*sort_by_pot) (const void *, const void *), FILE *out_fp);
void handle_left_request_lm (pot_t *pot, uint pot_cnt, char *input_buf, int input_len, hash_t *hash_left, hash_t *hash_right, int (*sort_by_pot) (const void *, const void *), FILE *out_fp);
uint devices_to_devicemask (char *gpu_devices);
uint get_random_num (uint min, uint max);
uint32_t mydivc32 (const uint32_t dividend, const uint32_t divisor);
uint64_t mydivc64 (const uint64_t dividend, const uint64_t divisor);
void ascii_digest (char out_buf[1024], uint salt_pos, uint digest_pos);
void to_hccap_t (hccap_t *hccap, uint salt_pos, uint digest_pos);
void format_speed_display (float val, char *buf, size_t len);
void format_timer_display (struct tm *tm, char *buf, size_t len);
void lowercase (char *buf, int len);
void uppercase (char *buf, int len);
int fgetl (FILE *fp, char *line_buf);
int in_superchop (char *buf);
char **scan_directory (const char *path);
int count_dictionaries (char **dictionary_files);
char *strparser (const uint parser_status);
char *stroptitype (const uint opti_type);
char *strhashtype (const uint hash_mode);
char *strstatus (const uint threads_status);
void status ();
void *mycalloc (size_t nmemb, size_t size);
void myfree (void *ptr);
void *mymalloc (size_t size);
void *myrealloc (void *ptr, size_t oldsz, size_t add);
char *mystrdup (const char *s);
char *logfile_generate_topid ();
char *logfile_generate_subid ();
void logfile_append (const char *fmt, ...);
#ifdef _WIN
void fsync (int fd);
#endif
int hm_get_adapter_index_nv (HM_ADAPTER_NV nvGPUHandle[DEVICES_MAX]);
int get_adapters_num_amd (HM_LIB hm_dll, int *iNumberAdapters);
int hm_get_device_num (HM_LIB hm_dll, HM_ADAPTER_AMD hm_adapter_index, int *hm_device_num);
// void hm_get_opencl_busid_devid (hm_attrs_t *hm_device, uint opencl_num_devices, cl_device_id *devices);
int hm_get_adapter_index_amd (hm_attrs_t *hm_device, uint32_t *valid_adl_device_list, int num_adl_adapters, LPAdapterInfo lpAdapterInfo);
LPAdapterInfo hm_get_adapter_info_amd (HM_LIB hm_dll, int iNumberAdapters);
uint32_t *hm_get_list_valid_adl_adapters (int iNumberAdapters, int *num_adl_adapters, LPAdapterInfo lpAdapterInfo);
int hm_get_overdrive_version (HM_LIB hm_dll, hm_attrs_t *hm_device, uint32_t *valid_adl_device_list, int num_adl_adapters, LPAdapterInfo lpAdapterInfo);
int hm_check_fanspeed_control (HM_LIB hm_dll, hm_attrs_t *hm_device, uint32_t *valid_adl_device_list, int num_adl_adapters, LPAdapterInfo lpAdapterInfo);
void hm_close (HM_LIB hm_dll);
HM_LIB hm_init ();
int hm_get_temperature_with_device_id (const uint device_id);
int hm_get_fanspeed_with_device_id (const uint device_id);
int hm_get_utilization_with_device_id (const uint device_id);
int hm_set_fanspeed_with_device_id_amd (const uint device_id, const int fanspeed);
void myabort ();
void myquit ();
uint set_gpu_accel (uint hash_mode);
uint set_gpu_loops (uint hash_mode);
void set_cpu_affinity (char *cpu_affinity);
void eula_print (const char *progname);
void usage_mini_print (const char *progname);
void usage_big_print (const char *progname);
void mp_css_to_uniq_tbl (uint css_cnt, cs_t *css, uint uniq_tbls[SP_PW_MAX][CHARSIZ]);
void mp_cut_at (char *mask, uint max);
void mp_exec (uint64_t val, char *buf, cs_t *css, int css_cnt);
cs_t *mp_gen_css (char *mask_buf, size_t mask_len, cs_t *mp_sys, cs_t *mp_usr, uint *css_cnt);
uint64_t mp_get_sum (uint css_cnt, cs_t *css);
void mp_setup_sys (cs_t *mp_sys);
void mp_setup_usr (cs_t *mp_sys, cs_t *mp_usr, char *buf, uint index);
void mp_reset_usr (cs_t *mp_usr, uint index);
char *mp_get_truncated_mask (char *mask_buf, size_t mask_len, uint len);
uint64_t sp_get_sum (uint start, uint stop, cs_t *root_css_buf);
void sp_exec (uint64_t ctx, char *pw_buf, cs_t *root_css_buf, cs_t *markov_css_buf, uint start, uint stop);
int sp_comp_val (const void *p1, const void *p2);
void sp_setup_tbl (const char *install_dir, char *hcstat, uint disable, uint classic, hcstat_table_t *root_table_buf, hcstat_table_t *markov_table_buf);
void sp_tbl_to_css (hcstat_table_t *root_table_buf, hcstat_table_t *markov_table_buf, cs_t *root_css_buf, cs_t *markov_css_buf, uint threshold, uint uniq_tbls[SP_PW_MAX][CHARSIZ]);
void sp_stretch_markov (hcstat_table_t *in, hcstat_table_t *out);
void sp_stretch_root (hcstat_table_t *in, hcstat_table_t *out);
uint byte_swap_32 (const uint n);
uint64_t byte_swap_64 (const uint64_t n);
char hex_convert (const char c);
int bcrypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int cisco4_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int dcc_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int dcc2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int descrypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int episerver_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int ipb2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int joomla_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int postgresql_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int netscreen_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int keccak_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int lm_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md4_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md4s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5half_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5md5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5pix_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5asa_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5apr1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int md5crypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mssql2000_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mssql2005_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int netntlmv1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int netntlmv2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oracleh_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oracles_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oraclet_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int osc_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int osx1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int osx512_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int phpass_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha1linkedin_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha1b64_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha1b64s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha1s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha256_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha256s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha384_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512crypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int smf_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int vb3_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int vb30_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int wpa_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int psafe2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int psafe3_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int ikepsk_md5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int ikepsk_sha1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int androidpin_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int ripemd160_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int whirlpool_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int truecrypt_parse_hash_1k (char *input_buf, uint input_len, hash_t *hash_buf);
int truecrypt_parse_hash_2k (char *input_buf, uint input_len, hash_t *hash_buf);
int md5aix_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha256aix_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512aix_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int agilekey_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha1aix_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int lastpass_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int gost_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha256crypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mssql2012_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512osx_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int episerver4_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512grub_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sha512b64s_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int hmacsha1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int hmacsha256_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int hmacsha512_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int hmacmd5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int krb5pa_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sapb_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sapg_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int drupal7_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sybasease_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mysql323_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int rakp_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int netscaler_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int chap_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int cloudkey_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int nsec3_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int wbb3_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int racf_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int lotus5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int lotus6_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int lotus8_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int hmailserver_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int phps_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mediawiki_b_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int peoplesoft_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int skype_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int androidfde_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int scrypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int juniper_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int cisco8_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int cisco9_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int office2007_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int office2010_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int office2013_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oldoffice01_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oldoffice01cm1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oldoffice01cm2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oldoffice34_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oldoffice34cm1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int oldoffice34cm2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int radmin2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int djangosha1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int djangopbkdf2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int siphash_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int crammd5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int saph_sha1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int redmine_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pdf11_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pdf11cm1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pdf11cm2_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pdf14_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pdf17l3_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pdf17l8_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pbkdf2_sha256_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int prestashop_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int postgresql_auth_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mysql_auth_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int bitcoin_wallet_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int sip_auth_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int crc32_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int seven_zip_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int gost2012sbog_256_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int gost2012sbog_512_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pbkdf2_md5_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pbkdf2_sha1_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int pbkdf2_sha512_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int ecryptfs_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int bsdicrypt_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int rar3hp_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int cf10_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int mywallet_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
int ms_drsr_parse_hash (char *input_buf, uint input_len, hash_t *hash_buf);
void load_kernel (const char *kernel_file, int num_devices, size_t *kernel_lengths, const unsigned char **kernel_sources);
void writeProgramBin (char *dst, unsigned char *binary, size_t binary_size);
uint64_t get_lowest_words_done ();
restore_data_t *init_restore (int argc, char **argv);
void read_restore (const char *eff_restore_file, restore_data_t *rd);
void write_restore (const char *new_restore_file, restore_data_t *rd);
void cycle_restore ();
void check_checkpoint ();
#ifdef WIN
BOOL WINAPI sigHandler_default (DWORD sig);
BOOL WINAPI sigHandler_benchmark (DWORD sig);
void hc_signal (BOOL WINAPI (callback) (DWORD sig));
#else
void sigHandler_default (int sig);
void sigHandler_benchmark (int sig);
void hc_signal (void c (int));
#endif
typedef int bool;
bool class_num (char c);
bool class_lower (char c);
bool class_upper (char c);
bool class_alpha (char c);
int mangle_lrest (char arr[BLOCK_SIZE], int arr_len);
int mangle_urest (char arr[BLOCK_SIZE], int arr_len);
int mangle_trest (char arr[BLOCK_SIZE], int arr_len);
int mangle_reverse (char arr[BLOCK_SIZE], int arr_len);
int mangle_double (char arr[BLOCK_SIZE], int arr_len);
int mangle_double_times (char arr[BLOCK_SIZE], int arr_len, int times);
int mangle_reflect (char arr[BLOCK_SIZE], int arr_len);
int mangle_rotate_left (char arr[BLOCK_SIZE], int arr_len);
int mangle_rotate_right (char arr[BLOCK_SIZE], int arr_len);
int mangle_append (char arr[BLOCK_SIZE], int arr_len, char c);
int mangle_prepend (char arr[BLOCK_SIZE], int arr_len, char c);
int mangle_delete_at (char arr[BLOCK_SIZE], int arr_len, int upos);
int mangle_extract (char arr[BLOCK_SIZE], int arr_len, int upos, int ulen);
int mangle_omit (char arr[BLOCK_SIZE], int arr_len, int upos, int ulen);
int mangle_insert (char arr[BLOCK_SIZE], int arr_len, int upos, char c);
int mangle_overstrike (char arr[BLOCK_SIZE], int arr_len, int upos, char c);
int mangle_truncate_at (char arr[BLOCK_SIZE], int arr_len, int upos);
int mangle_replace (char arr[BLOCK_SIZE], int arr_len, char oldc, char newc);
int mangle_purgechar (char arr[BLOCK_SIZE], int arr_len, char c);
int mangle_dupeblock_prepend (char arr[BLOCK_SIZE], int arr_len, int ulen);
int mangle_dupeblock_append (char arr[BLOCK_SIZE], int arr_len, int ulen);
int mangle_dupechar_at (char arr[BLOCK_SIZE], int arr_len, int upos, int ulen);
int mangle_dupechar (char arr[BLOCK_SIZE], int arr_len);
int mangle_switch_at_check (char arr[BLOCK_SIZE], int arr_len, int upos, int upos2);
int mangle_switch_at (char arr[BLOCK_SIZE], int arr_len, int upos, int upos2);
int mangle_chr_shiftl (uint8_t arr[BLOCK_SIZE], int arr_len, int upos);
int mangle_chr_shiftr (uint8_t arr[BLOCK_SIZE], int arr_len, int upos);
int mangle_chr_incr (uint8_t arr[BLOCK_SIZE], int arr_len, int upos);
int mangle_chr_decr (uint8_t arr[BLOCK_SIZE], int arr_len, int upos);
int mangle_title (char arr[BLOCK_SIZE], int arr_len);
int generate_random_rule (char rule_buf[RP_RULE_BUFSIZ], uint32_t rp_gen_func_min, uint32_t rp_gen_func_max);
int _old_apply_rule (char *rule, int rule_len, char in[BLOCK_SIZE], int in_len, char out[BLOCK_SIZE]);
int cpu_rule_to_gpu_rule (char rule_buf[BUFSIZ], uint rule_len, gpu_rule_t *rule);
int gpu_rule_to_cpu_rule (char rule_buf[BUFSIZ], gpu_rule_t *rule);
void *thread_gpu_watch (void *p);
void *thread_keypress (void *p);
void *thread_runtime (void *p);
/**
* checksum for use on cpu
*/
#include "cpu-crc32.h"
/**
* ciphers for use on cpu
*/
#include "cpu-aes.h"
#endif