mirror of
https://github.com/hashcat/hashcat.git
synced 2025-01-03 04:11:06 +00:00
2313 lines
91 KiB
C
2313 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
|
|
|
|
#ifdef _CUDA
|
|
#include <ext_cuda.h>
|
|
#elif _OCL
|
|
#include <ext_OpenCL.h>
|
|
#endif
|
|
|
|
/**
|
|
* temperature management
|
|
*/
|
|
|
|
#ifdef LINUX
|
|
#ifdef _CUDA
|
|
#include <ext_nvml.h>
|
|
#elif _OCL
|
|
#include <ext_ADL.h>
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef WIN
|
|
#ifdef _CUDA
|
|
#include <ext_nvapi.h>
|
|
#elif _OCL
|
|
#include <ext_ADL.h>
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef OSX
|
|
#ifdef _CUDA
|
|
#include <ext_smi.h>
|
|
#elif _OCL
|
|
#include <ext_dummy.h>
|
|
#endif
|
|
#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 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"
|
|
|
|
#define VENDOR_ID_AMD 4098
|
|
#define VENDOR_ID_NV 4318
|
|
|
|
/**
|
|
* 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_SCALAR_MODE (1 << 14)
|
|
#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_SCALAR_MODE "Scalar-Mode"
|
|
#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 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"
|
|
|
|
/**
|
|
* 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);
|
|
|
|
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
|
|
|
|
#ifdef _CUDA
|
|
int hm_get_adapter_index (HM_ADAPTER nvGPUHandle[DEVICES_MAX]);
|
|
#endif
|
|
|
|
#ifdef _OCL
|
|
int get_adapters_num (HM_LIB hm_dll, int *iNumberAdapters);
|
|
|
|
int hm_get_device_num (HM_LIB hm_dll, HM_ADAPTER 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 (hm_attrs_t *hm_device, uint32_t *valid_adl_device_list, int num_adl_adapters, LPAdapterInfo lpAdapterInfo);
|
|
|
|
LPAdapterInfo hm_get_adapter_info (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 ();
|
|
#endif
|
|
|
|
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 (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 ();
|
|
|
|
#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
|