projects
/
hashcat.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Workaround memory allocation limit from OpenCL by using multiple buffers for scrypt
[hashcat.git]
/
include
/
types.h
diff --git
a/include/types.h
b/include/types.h
index
0083cc6
..
02df8ea
100644
(file)
--- a/
include/types.h
+++ b/
include/types.h
@@
-6,6
+6,12
@@
#ifndef TYPES_H
#define TYPES_H
#ifndef TYPES_H
#define TYPES_H
+#ifdef _WIN
+#define EOL "\r\n"
+#else
+#define EOL "\n"
+#endif
+
typedef struct
{
uint salt_buf[16];
typedef struct
{
uint salt_buf[16];
@@
-26,8
+32,6
@@
typedef struct
uint scrypt_N;
uint scrypt_r;
uint scrypt_p;
uint scrypt_N;
uint scrypt_r;
uint scrypt_p;
- uint scrypt_tmto;
- uint scrypt_phy;
} salt_t;
} salt_t;
@@
-168,6
+172,7
@@
typedef struct
uint salt_buf[16];
uint data_buf[112];
uint keyfile_buf[16];
uint salt_buf[16];
uint data_buf[112];
uint keyfile_buf[16];
+ uint signature;
} tc_t;
} tc_t;
@@
-268,9
+273,25
@@
typedef struct
typedef struct
{
typedef struct
{
- uint P[256];
+ u32 type;
+ u32 mode;
+ u32 magic;
+ u32 salt_len;
+ u32 salt_buf[4];
+ u32 verify_bytes;
+ u32 compress_length;
+ u32 data_len;
+ u32 data_buf[2048];
+ u32 auth_len;
+ u32 auth_buf[4];
+
+} zip2_t;
+
+typedef struct
+{
+ uint salt_buf[32];
-} scrypt_tmp_t;
+} win8phone_t;
typedef struct
{
typedef struct
{
@@
-626,8
+647,7
@@
typedef struct
typedef struct
{
typedef struct
{
- u32 KEK[5];
-
+ u32 KEK[4];
u32 lsb[4];
u32 cipher[4];
u32 lsb[4];
u32 cipher[4];
@@
-842,6
+862,9
@@
typedef struct
typedef struct
{
typedef struct
{
+ uint salt_pos;
+ uint digest_pos;
+ uint hash_pos;
uint gidvid;
uint il_pos;
uint gidvid;
uint il_pos;
@@
-894,7
+917,7
@@
typedef struct
#define PW_MAX1 (PW_MAX + 1)
#define PW_DICTMAX 31
#define PW_DICTMAX1 (PW_DICTMAX + 1)
#define PW_MAX1 (PW_MAX + 1)
#define PW_DICTMAX 31
#define PW_DICTMAX1 (PW_DICTMAX + 1)
-#define PARAMCNT 32
+#define PARAMCNT 64
struct __hc_device_param
{
struct __hc_device_param
{
@@
-911,7
+934,6
@@
struct __hc_device_param
uint kernel_exec_timeout;
uint device_processors;
uint kernel_exec_timeout;
uint device_processors;
- uint device_processor_cores;
u64 device_maxmem_alloc;
u64 device_global_mem;
u32 device_maxclock_frequency;
u64 device_maxmem_alloc;
u64 device_global_mem;
u32 device_maxclock_frequency;
@@
-927,7
+949,7
@@
struct __hc_device_param
uint kernel_accel_min;
uint kernel_accel_max;
uint kernel_power;
uint kernel_accel_min;
uint kernel_accel_max;
uint kernel_power;
- uint kernel_power_user;
+ uint hardware_power;
size_t size_pws;
size_t size_tmps;
size_t size_pws;
size_t size_tmps;
@@
-955,8
+977,6
@@
struct __hc_device_param
u64 words_off;
u64 words_done;
u64 words_off;
u64 words_done;
- uint *result;
-
uint outerloop_pos;
uint outerloop_left;
uint outerloop_pos;
uint outerloop_left;
@@
-966,6
+986,12
@@
struct __hc_device_param
uint exec_pos;
double exec_ms[EXEC_CACHE];
uint exec_pos;
double exec_ms[EXEC_CACHE];
+ // workaround cpu spinning
+
+ double exec_us_prev1[EXPECTED_ITERATIONS];
+ double exec_us_prev2[EXPECTED_ITERATIONS];
+ double exec_us_prev3[EXPECTED_ITERATIONS];
+
// this is "current" speed
uint speed_pos;
// this is "current" speed
uint speed_pos;
@@
-977,13
+1003,17
@@
struct __hc_device_param
// device specific attributes starting
char *device_name;
// device specific attributes starting
char *device_name;
+ char *device_vendor;
char *device_name_chksum;
char *device_version;
char *driver_version;
bool opencl_v12;
char *device_name_chksum;
char *device_version;
char *driver_version;
bool opencl_v12;
- cl_uint vendor_id;
+ double nvidia_spin_damp;
+
+ cl_uint device_vendor_id;
+ cl_uint platform_vendor_id;
cl_kernel kernel1;
cl_kernel kernel12;
cl_kernel kernel1;
cl_kernel kernel12;
@@
-996,13
+1026,13
@@
struct __hc_device_param
cl_kernel kernel_amp;
cl_kernel kernel_tm;
cl_kernel kernel_weak;
cl_kernel kernel_amp;
cl_kernel kernel_tm;
cl_kernel kernel_weak;
+ cl_kernel kernel_memset;
cl_context context;
cl_program program;
cl_program program_mp;
cl_program program_amp;
cl_context context;
cl_program program;
cl_program program_mp;
cl_program program_amp;
- cl_program program_weak;
cl_command_queue command_queue;
cl_command_queue command_queue;
@@
-1034,7
+1064,10
@@
struct __hc_device_param
cl_mem d_tmps;
cl_mem d_hooks;
cl_mem d_result;
cl_mem d_tmps;
cl_mem d_hooks;
cl_mem d_result;
- cl_mem d_scryptV_buf;
+ cl_mem d_scryptV0_buf;
+ cl_mem d_scryptV1_buf;
+ cl_mem d_scryptV2_buf;
+ cl_mem d_scryptV3_buf;
cl_mem d_root_css_buf;
cl_mem d_markov_css_buf;
cl_mem d_root_css_buf;
cl_mem d_markov_css_buf;
@@
-1044,6
+1077,7
@@
struct __hc_device_param
void *kernel_params_mp_l[PARAMCNT];
void *kernel_params_amp[PARAMCNT];
void *kernel_params_tm[PARAMCNT];
void *kernel_params_mp_l[PARAMCNT];
void *kernel_params_amp[PARAMCNT];
void *kernel_params_tm[PARAMCNT];
+ void *kernel_params_memset[PARAMCNT];
u32 kernel_params_buf32[PARAMCNT];
u32 kernel_params_buf32[PARAMCNT];
@@
-1057,6
+1091,7
@@
struct __hc_device_param
u64 kernel_params_mp_l_buf64[PARAMCNT];
u32 kernel_params_amp_buf32[PARAMCNT];
u64 kernel_params_mp_l_buf64[PARAMCNT];
u32 kernel_params_amp_buf32[PARAMCNT];
+ u32 kernel_params_memset_buf32[PARAMCNT];
};
typedef struct __hc_device_param hc_device_param_t;
};
typedef struct __hc_device_param hc_device_param_t;
@@
-1064,23
+1099,15
@@
typedef struct __hc_device_param hc_device_param_t;
#ifdef HAVE_HWMON
typedef struct
{
#ifdef HAVE_HWMON
typedef struct
{
- union
- {
- #ifdef HAVE_ADL
- HM_ADAPTER_AMD amd;
- #endif
+ HM_ADAPTER_ADL adl;
+ HM_ADAPTER_NVML nvml;
+ HM_ADAPTER_NVAPI nvapi;
+ HM_ADAPTER_XNVCTRL xnvctrl;
- #if defined(HAVE_NVML) || defined(HAVE_NVAPI)
- HM_ADAPTER_NV nv;
- #endif
+ int od_version;
- } adapter_index;
-
- int od_version;
- int fan_supported;
-
- // int busid; // used for CL_DEVICE_TOPOLOGY_AMD but broken for dual GPUs
- // int devid; // used for CL_DEVICE_TOPOLOGY_AMD but broken for dual GPUs
+ int fan_get_supported;
+ int fan_set_supported;
} hm_attrs_t;
#endif // HAVE_HWMON
} hm_attrs_t;
#endif // HAVE_HWMON
@@
-1097,12
+1124,16
@@
typedef struct
hc_device_param_t *devices_param;
hc_device_param_t *devices_param;
+ uint shutdown_inner;
+ uint shutdown_outer;
+
/**
* workload specific
*/
/**
* workload specific
*/
+ uint hardware_power_all;
uint kernel_power_all;
uint kernel_power_all;
- float kernel_power_div;
+ u64 kernel_power_final; // we save that so that all divisions are done from the same base
/**
* attack specific
/**
* attack specific
@@
-1147,8
+1178,10
@@
typedef struct
*/
#ifdef HAVE_HWMON
*/
#ifdef HAVE_HWMON
- void *hm_nv;
- void *hm_amd;
+ void *hm_adl;
+ void *hm_nvml;
+ void *hm_nvapi;
+ void *hm_xnvctrl;
hm_attrs_t hm_device[DEVICES_MAX];
#endif
hm_attrs_t hm_device[DEVICES_MAX];
#endif
@@
-1172,6
+1205,9
@@
typedef struct
void *esalts_buf;
void *esalts_buf;
+ uint scrypt_tmp_size;
+ uint scrypt_tmto_final;
+
/**
* logging
*/
/**
* logging
*/
@@
-1222,11
+1258,10
@@
typedef struct
uint restore_disable;
uint status;
uint status_timer;
uint restore_disable;
uint status;
uint status_timer;
- uint status_automat;
+ uint machine_readable;
uint quiet;
uint force;
uint benchmark;
uint quiet;
uint force;
uint benchmark;
- uint benchmark_repeats;
uint runtime;
uint remove;
uint remove_timer;
uint runtime;
uint remove;
uint remove_timer;
@@
-1241,6
+1276,8
@@
typedef struct
uint scrypt_tmto;
uint segment_size;
char *truecrypt_keyfiles;
uint scrypt_tmto;
uint segment_size;
char *truecrypt_keyfiles;
+ char *veracrypt_keyfiles;
+ uint veracrypt_pim;
uint workload_profile;
uint hash_mode;
uint workload_profile;
uint hash_mode;
@@
-1320,3
+1357,4
@@
typedef struct
extern hc_global_data_t data;
#endif
extern hc_global_data_t data;
#endif
+