2015-12-04 14:47:52 +00:00
|
|
|
/**
|
2016-09-11 20:20:15 +00:00
|
|
|
* Author......: See docs/credits.txt
|
2015-12-04 14:47:52 +00:00
|
|
|
* License.....: MIT
|
|
|
|
*/
|
|
|
|
|
2016-09-06 16:44:05 +00:00
|
|
|
#ifndef _EXT_OPENCL_H
|
|
|
|
#define _EXT_OPENCL_H
|
2015-12-04 14:47:52 +00:00
|
|
|
|
2018-10-14 10:39:11 +00:00
|
|
|
#define CL_TARGET_OPENCL_VERSION 120
|
|
|
|
|
2016-09-06 17:44:27 +00:00
|
|
|
#define CL_USE_DEPRECATED_OPENCL_1_2_APIS
|
|
|
|
#define CL_USE_DEPRECATED_OPENCL_2_0_APIS
|
|
|
|
|
2016-09-07 20:29:57 +00:00
|
|
|
#if defined (__APPLE__)
|
2016-09-06 17:44:27 +00:00
|
|
|
#include <OpenCL/cl.h>
|
2017-03-05 02:28:50 +00:00
|
|
|
#else
|
2016-11-29 21:39:22 +00:00
|
|
|
#include <CL/cl.h>
|
|
|
|
#endif
|
|
|
|
|
2016-11-05 19:23:05 +00:00
|
|
|
// NVIDIA extras
|
|
|
|
|
|
|
|
#define CL_DEVICE_COMPUTE_CAPABILITY_MAJOR_NV 0x4000
|
|
|
|
#define CL_DEVICE_COMPUTE_CAPABILITY_MINOR_NV 0x4001
|
|
|
|
#define CL_DEVICE_KERNEL_EXEC_TIMEOUT_NV 0x4005
|
|
|
|
#define CL_DEVICE_PCI_BUS_ID_NV 0x4008
|
|
|
|
#define CL_DEVICE_PCI_SLOT_ID_NV 0x4009
|
|
|
|
|
|
|
|
// AMD extras
|
|
|
|
|
|
|
|
#define CL_DEVICE_TOPOLOGY_AMD 0x4037
|
2021-05-26 17:09:50 +00:00
|
|
|
#define CL_DEVICE_BOARD_NAME_AMD 0x4038
|
2016-11-05 19:23:05 +00:00
|
|
|
|
|
|
|
typedef union
|
|
|
|
{
|
2022-01-03 01:41:12 +00:00
|
|
|
struct { cl_uint type; cl_uint data[5]; } raw;
|
|
|
|
struct { cl_uint type; cl_char unused[17]; cl_char bus; cl_char device; cl_char function; } pcie;
|
|
|
|
|
2016-11-05 19:23:05 +00:00
|
|
|
} cl_device_topology_amd;
|
|
|
|
|
2016-09-06 13:28:56 +00:00
|
|
|
#define CL_PLATFORMS_MAX 16
|
2016-09-05 19:47:26 +00:00
|
|
|
|
2016-07-10 11:23:06 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLBUILDPROGRAM) (cl_program, cl_uint, const cl_device_id *, const char *, void (CL_CALLBACK *)(cl_program, void *), void *);
|
2021-04-11 11:35:40 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLCOMPILEPROGRAM) (cl_program, cl_uint, const cl_device_id *, const char *, cl_uint, const cl_program *, const char **, void (CL_CALLBACK *)(cl_program, void *), void *);
|
2016-07-10 11:23:06 +00:00
|
|
|
typedef cl_mem (CL_API_CALL *OCL_CLCREATEBUFFER) (cl_context, cl_mem_flags, size_t, void *, cl_int *);
|
|
|
|
typedef cl_command_queue (CL_API_CALL *OCL_CLCREATECOMMANDQUEUE) (cl_context, cl_device_id, cl_command_queue_properties, cl_int *);
|
|
|
|
typedef cl_context (CL_API_CALL *OCL_CLCREATECONTEXT) (const cl_context_properties *, cl_uint, const cl_device_id *, void (CL_CALLBACK *)(const char *, const void *, size_t, void *), void *, cl_int *);
|
|
|
|
typedef cl_kernel (CL_API_CALL *OCL_CLCREATEKERNEL) (cl_program, const char *, cl_int *);
|
|
|
|
typedef cl_program (CL_API_CALL *OCL_CLCREATEPROGRAMWITHBINARY) (cl_context, cl_uint, const cl_device_id *, const size_t *, const unsigned char **, cl_int *, cl_int *);
|
|
|
|
typedef cl_program (CL_API_CALL *OCL_CLCREATEPROGRAMWITHSOURCE) (cl_context, cl_uint, const char **, const size_t *, cl_int *);
|
2021-07-27 15:56:59 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLENQUEUEFILLBUFFER) (cl_command_queue, cl_mem, const void *, size_t, size_t, size_t, cl_uint, const cl_event *, cl_event *);
|
2016-07-10 11:23:06 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLENQUEUECOPYBUFFER) (cl_command_queue, cl_mem, cl_mem, size_t, size_t, size_t, cl_uint, const cl_event *, cl_event *);
|
|
|
|
typedef void * (CL_API_CALL *OCL_CLENQUEUEMAPBUFFER) (cl_command_queue, cl_mem, cl_bool, cl_map_flags, size_t, size_t, cl_uint, const cl_event *, cl_event *, cl_int *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLENQUEUENDRANGEKERNEL) (cl_command_queue, cl_kernel, cl_uint, const size_t *, const size_t *, const size_t *, cl_uint, const cl_event *, cl_event *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLENQUEUEREADBUFFER) (cl_command_queue, cl_mem, cl_bool, size_t, size_t, const void *, cl_uint, const cl_event *, cl_event *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLENQUEUEUNMAPMEMOBJECT) (cl_command_queue, cl_mem, void *, cl_uint, const cl_event *, cl_event *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLENQUEUEWRITEBUFFER) (cl_command_queue, cl_mem, cl_bool, size_t, size_t, const void *, cl_uint, const cl_event *, cl_event *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLFINISH) (cl_command_queue);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLFLUSH) (cl_command_queue);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETDEVICEIDS) (cl_platform_id, cl_device_type, cl_uint, cl_device_id *, cl_uint *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETDEVICEINFO) (cl_device_id, cl_device_info, size_t, void *, size_t *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETEVENTINFO) (cl_event, cl_event_info, size_t, void *, size_t *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETEVENTPROFILINGINFO) (cl_event, cl_profiling_info, size_t, void *, size_t *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETKERNELWORKGROUPINFO) (cl_kernel, cl_device_id, cl_kernel_work_group_info, size_t, void *, size_t *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETPLATFORMIDS) (cl_uint, cl_platform_id *, cl_uint *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETPLATFORMINFO) (cl_platform_id, cl_platform_info, size_t, void *, size_t *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETPROGRAMBUILDINFO) (cl_program, cl_device_id, cl_program_build_info, size_t, void *, size_t *);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLGETPROGRAMINFO) (cl_program, cl_program_info, size_t, void *, size_t *);
|
2021-04-11 11:35:40 +00:00
|
|
|
typedef cl_program (CL_API_CALL *OCL_CLLINKPROGRAM) (cl_context, cl_uint, const cl_device_id *, const char *, cl_uint, const cl_program *, void (CL_CALLBACK *) (cl_program, void *), void *, cl_int *);
|
2016-07-10 11:23:06 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLRELEASECOMMANDQUEUE) (cl_command_queue);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLRELEASECONTEXT) (cl_context);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLRELEASEEVENT) (cl_event);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLRELEASEKERNEL) (cl_kernel);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLRELEASEMEMOBJECT) (cl_mem);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLRELEASEPROGRAM) (cl_program);
|
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLSETKERNELARG) (cl_kernel, cl_uint, size_t, const void *);
|
2021-05-02 08:15:25 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLUNLOADPLATFORMCOMPILER) (cl_platform_id);
|
2016-07-10 11:23:06 +00:00
|
|
|
typedef cl_int (CL_API_CALL *OCL_CLWAITFOREVENTS) (cl_uint, const cl_event *);
|
2016-01-26 20:40:49 +00:00
|
|
|
|
2016-10-01 09:54:00 +00:00
|
|
|
typedef struct hc_opencl_lib
|
2016-01-26 20:40:49 +00:00
|
|
|
{
|
2019-01-14 09:11:23 +00:00
|
|
|
hc_dynlib_t lib;
|
2016-01-26 20:40:49 +00:00
|
|
|
|
2022-01-03 01:41:12 +00:00
|
|
|
OCL_CLBUILDPROGRAM clBuildProgram;
|
|
|
|
OCL_CLCOMPILEPROGRAM clCompileProgram;
|
|
|
|
OCL_CLCREATEBUFFER clCreateBuffer;
|
|
|
|
OCL_CLCREATECOMMANDQUEUE clCreateCommandQueue;
|
|
|
|
OCL_CLCREATECONTEXT clCreateContext;
|
|
|
|
OCL_CLCREATEKERNEL clCreateKernel;
|
|
|
|
OCL_CLCREATEPROGRAMWITHBINARY clCreateProgramWithBinary;
|
|
|
|
OCL_CLCREATEPROGRAMWITHSOURCE clCreateProgramWithSource;
|
|
|
|
OCL_CLENQUEUECOPYBUFFER clEnqueueCopyBuffer;
|
|
|
|
OCL_CLENQUEUEFILLBUFFER clEnqueueFillBuffer;
|
|
|
|
OCL_CLENQUEUEMAPBUFFER clEnqueueMapBuffer;
|
|
|
|
OCL_CLENQUEUENDRANGEKERNEL clEnqueueNDRangeKernel;
|
|
|
|
OCL_CLENQUEUEREADBUFFER clEnqueueReadBuffer;
|
|
|
|
OCL_CLENQUEUEUNMAPMEMOBJECT clEnqueueUnmapMemObject;
|
|
|
|
OCL_CLENQUEUEWRITEBUFFER clEnqueueWriteBuffer;
|
|
|
|
OCL_CLFINISH clFinish;
|
|
|
|
OCL_CLFLUSH clFlush;
|
|
|
|
OCL_CLGETDEVICEIDS clGetDeviceIDs;
|
|
|
|
OCL_CLGETDEVICEINFO clGetDeviceInfo;
|
|
|
|
OCL_CLGETEVENTINFO clGetEventInfo;
|
|
|
|
OCL_CLGETEVENTPROFILINGINFO clGetEventProfilingInfo;
|
|
|
|
OCL_CLGETKERNELWORKGROUPINFO clGetKernelWorkGroupInfo;
|
|
|
|
OCL_CLGETPLATFORMIDS clGetPlatformIDs;
|
|
|
|
OCL_CLGETPLATFORMINFO clGetPlatformInfo;
|
|
|
|
OCL_CLGETPROGRAMBUILDINFO clGetProgramBuildInfo;
|
|
|
|
OCL_CLGETPROGRAMINFO clGetProgramInfo;
|
|
|
|
OCL_CLLINKPROGRAM clLinkProgram;
|
|
|
|
OCL_CLRELEASECOMMANDQUEUE clReleaseCommandQueue;
|
|
|
|
OCL_CLRELEASECONTEXT clReleaseContext;
|
|
|
|
OCL_CLRELEASEEVENT clReleaseEvent;
|
|
|
|
OCL_CLRELEASEKERNEL clReleaseKernel;
|
|
|
|
OCL_CLRELEASEMEMOBJECT clReleaseMemObject;
|
|
|
|
OCL_CLRELEASEPROGRAM clReleaseProgram;
|
|
|
|
OCL_CLSETKERNELARG clSetKernelArg;
|
|
|
|
OCL_CLUNLOADPLATFORMCOMPILER clUnloadPlatformCompiler;
|
|
|
|
OCL_CLWAITFOREVENTS clWaitForEvents;
|
2015-12-04 14:47:52 +00:00
|
|
|
|
2016-01-26 20:40:49 +00:00
|
|
|
} hc_opencl_lib_t;
|
|
|
|
|
2016-09-05 19:47:26 +00:00
|
|
|
typedef hc_opencl_lib_t OCL_PTR;
|
2016-01-26 20:40:49 +00:00
|
|
|
|
2022-01-03 01:41:12 +00:00
|
|
|
const char *val2cstr_cl (cl_int CL_err);
|
|
|
|
|
|
|
|
int ocl_init (void *hashcat_ctx);
|
|
|
|
void ocl_close (void *hashcat_ctx);
|
|
|
|
|
|
|
|
int hc_clEnqueueNDRangeKernel (void *hashcat_ctx, cl_command_queue command_queue, cl_kernel kernel, cl_uint work_dim, const size_t *global_work_offset, const size_t *global_work_size, const size_t *local_work_size, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event);
|
|
|
|
int hc_clGetEventInfo (void *hashcat_ctx, cl_event event, cl_event_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clFlush (void *hashcat_ctx, cl_command_queue command_queue);
|
|
|
|
int hc_clFinish (void *hashcat_ctx, cl_command_queue command_queue);
|
|
|
|
int hc_clSetKernelArg (void *hashcat_ctx, cl_kernel kernel, cl_uint arg_index, size_t arg_size, const void *arg_value);
|
|
|
|
int hc_clEnqueueWriteBuffer (void *hashcat_ctx, cl_command_queue command_queue, cl_mem buffer, cl_bool blocking_write, size_t offset, size_t size, const void *ptr, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event);
|
|
|
|
int hc_clEnqueueCopyBuffer (void *hashcat_ctx, cl_command_queue command_queue, cl_mem src_buffer, cl_mem dst_buffer, size_t src_offset, size_t dst_offset, size_t size, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event);
|
|
|
|
int hc_clEnqueueFillBuffer (void *hashcat_ctx, cl_command_queue command_queue, cl_mem buffer, const void *pattern, size_t pattern_size, size_t offset, size_t size, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event);
|
|
|
|
int hc_clEnqueueReadBuffer (void *hashcat_ctx, cl_command_queue command_queue, cl_mem buffer, cl_bool blocking_read, size_t offset, size_t size, void *ptr, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event);
|
|
|
|
int hc_clGetPlatformIDs (void *hashcat_ctx, cl_uint num_entries, cl_platform_id *platforms, cl_uint *num_platforms);
|
|
|
|
int hc_clGetPlatformInfo (void *hashcat_ctx, cl_platform_id platform, cl_platform_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clGetDeviceIDs (void *hashcat_ctx, cl_platform_id platform, cl_device_type device_type, cl_uint num_entries, cl_device_id *devices, cl_uint *num_devices);
|
|
|
|
int hc_clGetDeviceInfo (void *hashcat_ctx, cl_device_id device, cl_device_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clCreateContext (void *hashcat_ctx, const cl_context_properties *properties, cl_uint num_devices, const cl_device_id *devices, void (CL_CALLBACK *pfn_notify) (const char *errinfo, const void *private_info, size_t cb, void *user_data), void *user_data, cl_context *context);
|
|
|
|
int hc_clCreateCommandQueue (void *hashcat_ctx, cl_context context, cl_device_id device, cl_command_queue_properties properties, cl_command_queue *command_queue);
|
|
|
|
int hc_clCreateBuffer (void *hashcat_ctx, cl_context context, cl_mem_flags flags, size_t size, void *host_ptr, cl_mem *mem);
|
2021-12-28 20:55:05 +00:00
|
|
|
int hc_clCreateProgramWithSource (void *hashcat_ctx, cl_context context, cl_uint count, const char **strings, const size_t *lengths, cl_program *program);
|
|
|
|
int hc_clCreateProgramWithBinary (void *hashcat_ctx, cl_context context, cl_uint num_devices, const cl_device_id *device_list, const size_t *lengths, const unsigned char **binaries, cl_int *binary_status, cl_program *program);
|
2022-01-03 01:41:12 +00:00
|
|
|
int hc_clBuildProgram (void *hashcat_ctx, cl_program program, cl_uint num_devices, const cl_device_id *device_list, const char *options, void (CL_CALLBACK *pfn_notify) (cl_program program, void *user_data), void *user_data);
|
|
|
|
int hc_clCompileProgram (void *hashcat_ctx, cl_program program, cl_uint num_devices, const cl_device_id *device_list, const char *options, cl_uint num_input_headers, const cl_program *input_headers, const char **header_include_names, void (CL_CALLBACK *pfn_notify) (cl_program program, void *user_data), void *user_data);
|
|
|
|
int hc_clLinkProgram (void *hashcat_ctx, cl_context context, cl_uint num_devices, const cl_device_id *device_list, const char *options, cl_uint num_input_programs, const cl_program *input_programs, void (CL_CALLBACK *pfn_notify) (cl_program program, void *user_data), void *user_data, cl_program *program);
|
|
|
|
int hc_clCreateKernel (void *hashcat_ctx, cl_program program, const char *kernel_name, cl_kernel *kernel);
|
|
|
|
int hc_clReleaseMemObject (void *hashcat_ctx, cl_mem mem);
|
|
|
|
int hc_clReleaseKernel (void *hashcat_ctx, cl_kernel kernel);
|
|
|
|
int hc_clReleaseProgram (void *hashcat_ctx, cl_program program);
|
|
|
|
int hc_clReleaseCommandQueue (void *hashcat_ctx, cl_command_queue command_queue);
|
|
|
|
int hc_clReleaseContext (void *hashcat_ctx, cl_context context);
|
|
|
|
int hc_clEnqueueMapBuffer (void *hashcat_ctx, cl_command_queue command_queue, cl_mem buffer, cl_bool blocking_map, cl_map_flags map_flags, size_t offset, size_t size, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event, void **buf);
|
|
|
|
int hc_clEnqueueUnmapMemObject (void *hashcat_ctx, cl_command_queue command_queue, cl_mem memobj, void *mapped_ptr, cl_uint num_events_in_wait_list, const cl_event *event_wait_list, cl_event *event);
|
|
|
|
int hc_clGetKernelWorkGroupInfo (void *hashcat_ctx, cl_kernel kernel, cl_device_id device, cl_kernel_work_group_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clGetProgramBuildInfo (void *hashcat_ctx, cl_program program, cl_device_id device, cl_program_build_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clGetProgramInfo (void *hashcat_ctx, cl_program program, cl_program_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clWaitForEvents (void *hashcat_ctx, cl_uint num_events, const cl_event *event_list);
|
|
|
|
int hc_clGetEventProfilingInfo (void *hashcat_ctx, cl_event event, cl_profiling_info param_name, size_t param_value_size, void *param_value, size_t *param_value_size_ret);
|
|
|
|
int hc_clReleaseEvent (void *hashcat_ctx, cl_event event);
|
|
|
|
//int hc_clUnloadPlatformCompiler (void *hashcat_ctx, cl_platform_id platform);
|
2021-12-28 20:55:05 +00:00
|
|
|
|
2016-09-06 16:44:05 +00:00
|
|
|
#endif // _EXT_OPENCL_H
|