/** * Author......: Jens Steube * License.....: MIT */ #ifndef SHARED_H #define SHARED_H #include #include /** * 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 /** * temperature management */ #ifdef LINUX #include #include #endif #ifdef WIN #include #include #endif #ifdef OSX #include #include #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 "hashcat.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 #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 16 #define GPU_ACCEL_NV_9000 2 #define GPU_ACCEL_NV_9100 8 #define GPU_ACCEL_NV_9200 2 #define GPU_ACCEL_NV_9300 2 #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 16 #define GPU_ACCEL_AMD_9000 2 #define GPU_ACCEL_AMD_9100 8 #define GPU_ACCEL_AMD_9200 2 #define GPU_ACCEL_AMD_9300 2 #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_exec_path (); char *get_install_dir (const char *progname); char *get_profile_dir (const char *homedir); char *get_session_dir (const char *profile_dir); 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