source: CIVL/examples/translation/opencl/setup/cl.cvl@ 50f834b

1.23 2.0 acw/focus-triggers main test-branch
Last change on this file since 50f834b was 0744ab0, checked in by Jacob Trieu <fuufusuu@…>, 12 years ago

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@1085 fb995dde-84ed-4084-dfe6-e5aef3e2452c

  • Property mode set to 100644
File size: 26.7 KB
Line 
1#include "openCL_platform.cvl"
2
3typedef struct _cl_platform_id * cl_platform_id;
4typedef struct _cl_device_id * cl_device_id;
5//typedef struct _cl_context * cl_context;
6typedef struct _cl_command_queue * cl_command_queue;
7typedef struct _cl_mem * cl_mem;
8typedef struct _cl_program * cl_program;
9typedef struct _cl_kernel * cl_kernel;
10typedef struct _cl_event * cl_event;
11typedef struct _cl_sampler * cl_sampler;
12
13
14typedef unsigned int cl_uint;
15typedef signed int cl_int;
16typedef signed int cl_long;
17//placeholders for actual types, preserves code in case we actually get those types
18//Just keep in mind that they're actually all ints, no unsigned
19
20
21typedef cl_int cl_bool;
22typedef cl_long cl_bitfield;
23typedef cl_bitfield cl_device_type;
24typedef cl_int cl_platform_info;
25typedef cl_int cl_device_info;
26typedef cl_bitfield cl_device_fp_config;
27typedef cl_int cl_device_mem_cache_type;
28typedef cl_int cl_device_local_mem_type;
29typedef cl_bitfield cl_device_exec_capabilities;
30typedef cl_bitfield cl_command_queue_properties;
31typedef int cl_device_partition_property;
32typedef cl_bitfield cl_device_affinity_domain;
33
34
35/*
36typedef cl_uint cl_bool;
37typedef cl_ulong cl_bitfield;
38typedef cl_bitfield cl_device_type;
39typedef cl_uint cl_platform_info;
40typedef cl_uint cl_device_info;
41typedef cl_bitfield cl_device_fp_config;
42typedef cl_uint cl_device_mem_cache_type;
43typedef cl_uint cl_device_local_mem_type;
44typedef cl_bitfield cl_device_exec_capabilities;
45typedef cl_bitfield cl_command_queue_properties;
46typedef intptr_t cl_device_partition_property;
47typedef cl_bitfield cl_device_affinity_domain;
48
49*/
50
51
52typedef int cl_context_properties;
53typedef cl_uint cl_context_info;
54typedef cl_uint cl_command_queue_info;
55typedef cl_uint cl_channel_order;
56typedef cl_uint cl_channel_type;
57typedef cl_bitfield cl_mem_flags;
58typedef cl_uint cl_mem_object_type;
59typedef cl_uint cl_mem_info;
60typedef cl_bitfield cl_mem_migration_flags;
61typedef cl_uint cl_image_info;
62typedef cl_uint cl_buffer_create_type;
63typedef cl_uint cl_addressing_mode;
64typedef cl_uint cl_filter_mode;
65typedef cl_uint cl_sampler_info;
66typedef cl_bitfield cl_map_flags;
67typedef cl_uint cl_program_info;
68typedef cl_uint cl_program_build_info;
69typedef cl_uint cl_program_binary_type;
70typedef cl_int cl_build_status;
71typedef cl_uint cl_kernel_info;
72typedef cl_uint cl_kernel_arg_info;
73typedef cl_uint cl_kernel_arg_address_qualifier;
74typedef cl_uint cl_kernel_arg_access_qualifier;
75typedef cl_bitfield cl_kernel_arg_type_qualifier;
76typedef cl_uint cl_kernel_work_group_info;
77typedef cl_uint cl_event_info;
78typedef cl_uint cl_command_type;
79typedef cl_uint cl_profiling_info;
80
81/*
82struct _cl_context
83{
84 cl_context_properties *properties,
85 cl_uint num_devices,
86 cl_device_id *devices,
87 void (CL_CALLBACK *pn_notify)(const char *, const void *, size_t, void *),
88 void *user_data,
89 cl_int *errcode_ret);
90}
91typedef struct _cl_context * cl_context;
92*/
93
94 typedef struct
95 {
96 cl_context_properties *properties;
97 cl_uint num_devices;
98 cl_device_id *devices;
99 void (CL_CALLBACK *pfn_notify)(const char *, const void *, size_t, void *);
100 void *user_data;
101 cl_int *errcode_ret;
102 }
103_cl_context;
104//no _cl_context;
105typedef _cl_context* cl_context;
106
107
108
109/*
110typedef struct _cl_image_format {
111 cl_channel_order image_channel_order;
112 cl_channel_type image_channel_data_type;
113} cl_image_format;
114
115typedef struct _cl_image_desc {
116 cl_mem_object_type image_type;
117 size_t image_width;
118 size_t image_height;
119 size_t image_depth;
120 size_t image_array_size;
121 size_t image_row_pitch;
122 size_t image_slice_pitch;
123 cl_uint num_mip_levels;
124 cl_uint num_samples;
125 cl_mem buffer;
126} cl_image_desc;
127
128typedef struct _cl_buffer_region {
129 size_t origin;
130 size_t size;
131} cl_buffer_region;
132*/
133/******************************************************************************/
134
135/* Error Codes */
136#define CL_SUCCESS 0
137#define CL_DEVICE_NOT_FOUND -1
138#define CL_DEVICE_NOT_AVAILABLE -2
139#define CL_COMPILER_NOT_AVAILABLE -3
140#define CL_MEM_OBJECT_ALLOCATION_FAILURE -4
141#define CL_OUT_OF_RESOURCES -5
142#define CL_OUT_OF_HOST_MEMORY -6
143#define CL_PROFILING_INFO_NOT_AVAILABLE -7
144#define CL_MEM_COPY_OVERLAP -8
145#define CL_IMAGE_FORMAT_MISMATCH -9
146#define CL_IMAGE_FORMAT_NOT_SUPPORTED -10
147#define CL_BUILD_PROGRAM_FAILURE -11
148#define CL_MAP_FAILURE -12
149#define CL_MISALIGNED_SUB_BUFFER_OFFSET -13
150#define CL_EXEC_STATUS_ERROR_FOR_EVENTS_IN_WAIT_LIST -14
151#define CL_COMPILE_PROGRAM_FAILURE -15
152#define CL_LINKER_NOT_AVAILABLE -16
153#define CL_LINK_PROGRAM_FAILURE -17
154#define CL_DEVICE_PARTITION_FAILED -18
155#define CL_KERNEL_ARG_INFO_NOT_AVAILABLE -19
156
157#define CL_INVALID_VALUE -30
158#define CL_INVALID_DEVICE_TYPE -31
159#define CL_INVALID_PLATFORM -32
160#define CL_INVALID_DEVICE -33
161#define CL_INVALID_CONTEXT -34
162#define CL_INVALID_QUEUE_PROPERTIES -35
163#define CL_INVALID_COMMAND_QUEUE -36
164#define CL_INVALID_HOST_PTR -37
165#define CL_INVALID_MEM_OBJECT -38
166#define CL_INVALID_IMAGE_FORMAT_DESCRIPTOR -39
167#define CL_INVALID_IMAGE_SIZE -40
168#define CL_INVALID_SAMPLER -41
169#define CL_INVALID_BINARY -42
170#define CL_INVALID_BUILD_OPTIONS -43
171#define CL_INVALID_PROGRAM -44
172#define CL_INVALID_PROGRAM_EXECUTABLE -45
173#define CL_INVALID_KERNEL_NAME -46
174#define CL_INVALID_KERNEL_DEFINITION -47
175#define CL_INVALID_KERNEL -48
176#define CL_INVALID_ARG_INDEX -49
177#define CL_INVALID_ARG_VALUE -50
178#define CL_INVALID_ARG_SIZE -51
179#define CL_INVALID_KERNEL_ARGS -52
180#define CL_INVALID_WORK_DIMENSION -53
181#define CL_INVALID_WORK_GROUP_SIZE -54
182#define CL_INVALID_WORK_ITEM_SIZE -55
183#define CL_INVALID_GLOBAL_OFFSET -56
184#define CL_INVALID_EVENT_WAIT_LIST -57
185#define CL_INVALID_EVENT -58
186#define CL_INVALID_OPERATION -59
187#define CL_INVALID_GL_OBJECT -60
188#define CL_INVALID_BUFFER_SIZE -61
189#define CL_INVALID_MIP_LEVEL -62
190#define CL_INVALID_GLOBAL_WORK_SIZE -63
191#define CL_INVALID_PROPERTY -64
192#define CL_INVALID_IMAGE_DESCRIPTOR -65
193#define CL_INVALID_COMPILER_OPTIONS -66
194#define CL_INVALID_LINKER_OPTIONS -67
195#define CL_INVALID_DEVICE_PARTITION_COUNT -68
196
197/* OpenCL Version */
198#define CL_VERSION_1_0 1
199#define CL_VERSION_1_1 1
200#define CL_VERSION_1_2 1
201
202/* cl_bool */
203#define CL_FALSE 0
204#define CL_TRUE 1
205#define CL_BLOCKING CL_TRUE
206#define CL_NON_BLOCKING CL_FALSE
207
208/* cl_platform_info */
209#define CL_PLATFORM_PROFILE 0x0900
210#define CL_PLATFORM_VERSION 0x0901
211#define CL_PLATFORM_NAME 0x0902
212#define CL_PLATFORM_VENDOR 0x0903
213#define CL_PLATFORM_EXTENSIONS 0x0904
214
215/* cl_device_type - bitfield */
216#define CL_DEVICE_TYPE_DEFAULT (1 << 0)
217#define CL_DEVICE_TYPE_CPU (1 << 1)
218#define CL_DEVICE_TYPE_GPU (1 << 2)
219#define CL_DEVICE_TYPE_ACCELERATOR (1 << 3)
220#define CL_DEVICE_TYPE_CUSTOM (1 << 4)
221#define CL_DEVICE_TYPE_ALL 0xFFFFFFFF
222
223/* cl_device_info */
224#define CL_DEVICE_TYPE 0x1000
225#define CL_DEVICE_VENDOR_ID 0x1001
226#define CL_DEVICE_MAX_COMPUTE_UNITS 0x1002
227#define CL_DEVICE_MAX_WORK_ITEM_DIMENSIONS 0x1003
228#define CL_DEVICE_MAX_WORK_GROUP_SIZE 0x1004
229#define CL_DEVICE_MAX_WORK_ITEM_SIZES 0x1005
230#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_CHAR 0x1006
231#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_SHORT 0x1007
232#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_INT 0x1008
233#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_LONG 0x1009
234#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_FLOAT 0x100A
235#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_DOUBLE 0x100B
236#define CL_DEVICE_MAX_CLOCK_FREQUENCY 0x100C
237#define CL_DEVICE_ADDRESS_BITS 0x100D
238#define CL_DEVICE_MAX_READ_IMAGE_ARGS 0x100E
239#define CL_DEVICE_MAX_WRITE_IMAGE_ARGS 0x100F
240#define CL_DEVICE_MAX_MEM_ALLOC_SIZE 0x1010
241#define CL_DEVICE_IMAGE2D_MAX_WIDTH 0x1011
242#define CL_DEVICE_IMAGE2D_MAX_HEIGHT 0x1012
243#define CL_DEVICE_IMAGE3D_MAX_WIDTH 0x1013
244#define CL_DEVICE_IMAGE3D_MAX_HEIGHT 0x1014
245#define CL_DEVICE_IMAGE3D_MAX_DEPTH 0x1015
246#define CL_DEVICE_IMAGE_SUPPORT 0x1016
247#define CL_DEVICE_MAX_PARAMETER_SIZE 0x1017
248#define CL_DEVICE_MAX_SAMPLERS 0x1018
249#define CL_DEVICE_MEM_BASE_ADDR_ALIGN 0x1019
250#define CL_DEVICE_MIN_DATA_TYPE_ALIGN_SIZE 0x101A
251#define CL_DEVICE_SINGLE_FP_CONFIG 0x101B
252#define CL_DEVICE_GLOBAL_MEM_CACHE_TYPE 0x101C
253#define CL_DEVICE_GLOBAL_MEM_CACHELINE_SIZE 0x101D
254#define CL_DEVICE_GLOBAL_MEM_CACHE_SIZE 0x101E
255#define CL_DEVICE_GLOBAL_MEM_SIZE 0x101F
256#define CL_DEVICE_MAX_CONSTANT_BUFFER_SIZE 0x1020
257#define CL_DEVICE_MAX_CONSTANT_ARGS 0x1021
258#define CL_DEVICE_LOCAL_MEM_TYPE 0x1022
259#define CL_DEVICE_LOCAL_MEM_SIZE 0x1023
260#define CL_DEVICE_ERROR_CORRECTION_SUPPORT 0x1024
261#define CL_DEVICE_PROFILING_TIMER_RESOLUTION 0x1025
262#define CL_DEVICE_ENDIAN_LITTLE 0x1026
263#define CL_DEVICE_AVAILABLE 0x1027
264#define CL_DEVICE_COMPILER_AVAILABLE 0x1028
265#define CL_DEVICE_EXECUTION_CAPABILITIES 0x1029
266#define CL_DEVICE_QUEUE_PROPERTIES 0x102A
267#define CL_DEVICE_NAME 0x102B
268#define CL_DEVICE_VENDOR 0x102C
269#define CL_DRIVER_VERSION 0x102D
270#define CL_DEVICE_PROFILE 0x102E
271#define CL_DEVICE_VERSION 0x102F
272#define CL_DEVICE_EXTENSIONS 0x1030
273#define CL_DEVICE_PLATFORM 0x1031
274#define CL_DEVICE_DOUBLE_FP_CONFIG 0x1032
275/* 0x1033 reserved for CL_DEVICE_HALF_FP_CONFIG */
276#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_HALF 0x1034
277#define CL_DEVICE_HOST_UNIFIED_MEMORY 0x1035
278#define CL_DEVICE_NATIVE_VECTOR_WIDTH_CHAR 0x1036
279#define CL_DEVICE_NATIVE_VECTOR_WIDTH_SHORT 0x1037
280#define CL_DEVICE_NATIVE_VECTOR_WIDTH_INT 0x1038
281#define CL_DEVICE_NATIVE_VECTOR_WIDTH_LONG 0x1039
282#define CL_DEVICE_NATIVE_VECTOR_WIDTH_FLOAT 0x103A
283#define CL_DEVICE_NATIVE_VECTOR_WIDTH_DOUBLE 0x103B
284#define CL_DEVICE_NATIVE_VECTOR_WIDTH_HALF 0x103C
285#define CL_DEVICE_OPENCL_C_VERSION 0x103D
286#define CL_DEVICE_LINKER_AVAILABLE 0x103E
287#define CL_DEVICE_BUILT_IN_KERNELS 0x103F
288#define CL_DEVICE_IMAGE_MAX_BUFFER_SIZE 0x1040
289#define CL_DEVICE_IMAGE_MAX_ARRAY_SIZE 0x1041
290#define CL_DEVICE_PARENT_DEVICE 0x1042
291#define CL_DEVICE_PARTITION_MAX_SUB_DEVICES 0x1043
292#define CL_DEVICE_PARTITION_PROPERTIES 0x1044
293#define CL_DEVICE_PARTITION_AFFINITY_DOMAIN 0x1045
294#define CL_DEVICE_PARTITION_TYPE 0x1046
295#define CL_DEVICE_REFERENCE_COUNT 0x1047
296#define CL_DEVICE_PREFERRED_INTEROP_USER_SYNC 0x1048
297#define CL_DEVICE_PRINTF_BUFFER_SIZE 0x1049
298#define CL_DEVICE_IMAGE_PITCH_ALIGNMENT 0x104A
299#define CL_DEVICE_IMAGE_BASE_ADDRESS_ALIGNMENT 0x104B
300
301/* cl_device_fp_config - bitfield */
302#define CL_FP_DENORM (1 << 0)
303#define CL_FP_INF_NAN (1 << 1)
304#define CL_FP_ROUND_TO_NEAREST (1 << 2)
305#define CL_FP_ROUND_TO_ZERO (1 << 3)
306#define CL_FP_ROUND_TO_INF (1 << 4)
307#define CL_FP_FMA (1 << 5)
308#define CL_FP_SOFT_FLOAT (1 << 6)
309#define CL_FP_CORRECTLY_ROUNDED_DIVIDE_SQRT (1 << 7)
310
311/* cl_device_mem_cache_type */
312#define CL_NONE 0x0
313#define CL_READ_ONLY_CACHE 0x1
314#define CL_READ_WRITE_CACHE 0x2
315
316/* cl_device_local_mem_type */
317#define CL_LOCAL 0x1
318#define CL_GLOBAL 0x2
319
320/* cl_device_exec_capabilities - bitfield */
321#define CL_EXEC_KERNEL (1 << 0)
322#define CL_EXEC_NATIVE_KERNEL (1 << 1)
323
324/* cl_command_queue_properties - bitfield */
325#define CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE (1 << 0)
326#define CL_QUEUE_PROFILING_ENABLE (1 << 1)
327
328/* cl_context_info */
329#define CL_CONTEXT_REFERENCE_COUNT 0x1080
330#define CL_CONTEXT_DEVICES 0x1081
331#define CL_CONTEXT_PROPERTIES 0x1082
332#define CL_CONTEXT_NUM_DEVICES 0x1083
333
334/* cl_context_properties */
335#define CL_CONTEXT_PLATFORM 0x1084
336#define CL_CONTEXT_INTEROP_USER_SYNC 0x1085
337
338/* cl_device_partition_property */
339#define CL_DEVICE_PARTITION_EQUALLY 0x1086
340#define CL_DEVICE_PARTITION_BY_COUNTS 0x1087
341#define CL_DEVICE_PARTITION_BY_COUNTS_LIST_END 0x0
342#define CL_DEVICE_PARTITION_BY_AFFINITY_DOMAIN 0x1088
343
344/* cl_device_affinity_domain */
345#define CL_DEVICE_AFFINITY_DOMAIN_NUMA (1 << 0)
346#define CL_DEVICE_AFFINITY_DOMAIN_L4_CACHE (1 << 1)
347#define CL_DEVICE_AFFINITY_DOMAIN_L3_CACHE (1 << 2)
348#define CL_DEVICE_AFFINITY_DOMAIN_L2_CACHE (1 << 3)
349#define CL_DEVICE_AFFINITY_DOMAIN_L1_CACHE (1 << 4)
350#define CL_DEVICE_AFFINITY_DOMAIN_NEXT_PARTITIONABLE (1 << 5)
351
352/* cl_command_queue_info */
353#define CL_QUEUE_CONTEXT 0x1090
354#define CL_QUEUE_DEVICE 0x1091
355#define CL_QUEUE_REFERENCE_COUNT 0x1092
356#define CL_QUEUE_PROPERTIES 0x1093
357
358/* cl_mem_flags - bitfield */
359#define CL_MEM_READ_WRITE (1 << 0)
360#define CL_MEM_WRITE_ONLY (1 << 1)
361#define CL_MEM_READ_ONLY (1 << 2)
362#define CL_MEM_USE_HOST_PTR (1 << 3)
363#define CL_MEM_ALLOC_HOST_PTR (1 << 4)
364#define CL_MEM_COPY_HOST_PTR (1 << 5)
365// reserved (1 << 6)
366#define CL_MEM_HOST_WRITE_ONLY (1 << 7)
367#define CL_MEM_HOST_READ_ONLY (1 << 8)
368#define CL_MEM_HOST_NO_ACCESS (1 << 9)
369
370/* cl_mem_migration_flags - bitfield */
371#define CL_MIGRATE_MEM_OBJECT_HOST (1 << 0)
372#define CL_MIGRATE_MEM_OBJECT_CONTENT_UNDEFINED (1 << 1)
373
374/* cl_channel_order */
375#define CL_R 0x10B0
376#define CL_A 0x10B1
377#define CL_RG 0x10B2
378#define CL_RA 0x10B3
379#define CL_RGB 0x10B4
380#define CL_RGBA 0x10B5
381#define CL_BGRA 0x10B6
382#define CL_ARGB 0x10B7
383#define CL_INTENSITY 0x10B8
384#define CL_LUMINANCE 0x10B9
385#define CL_Rx 0x10BA
386#define CL_RGx 0x10BB
387#define CL_RGBx 0x10BC
388#define CL_DEPTH 0x10BD
389#define CL_DEPTH_STENCIL 0x10BE
390
391/* cl_channel_type */
392#define CL_SNORM_INT8 0x10D0
393#define CL_SNORM_INT16 0x10D1
394#define CL_UNORM_INT8 0x10D2
395#define CL_UNORM_INT16 0x10D3
396#define CL_UNORM_SHORT_565 0x10D4
397#define CL_UNORM_SHORT_555 0x10D5
398#define CL_UNORM_INT_101010 0x10D6
399#define CL_SIGNED_INT8 0x10D7
400#define CL_SIGNED_INT16 0x10D8
401#define CL_SIGNED_INT32 0x10D9
402#define CL_UNSIGNED_INT8 0x10DA
403#define CL_UNSIGNED_INT16 0x10DB
404#define CL_UNSIGNED_INT32 0x10DC
405#define CL_HALF_FLOAT 0x10DD
406#define CL_FLOAT 0x10DE
407#define CL_UNORM_INT24 0x10DF
408
409/* cl_mem_object_type */
410#define CL_MEM_OBJECT_BUFFER 0x10F0
411#define CL_MEM_OBJECT_IMAGE2D 0x10F1
412#define CL_MEM_OBJECT_IMAGE3D 0x10F2
413#define CL_MEM_OBJECT_IMAGE2D_ARRAY 0x10F3
414#define CL_MEM_OBJECT_IMAGE1D 0x10F4
415#define CL_MEM_OBJECT_IMAGE1D_ARRAY 0x10F5
416#define CL_MEM_OBJECT_IMAGE1D_BUFFER 0x10F6
417
418/* cl_mem_info */
419#define CL_MEM_TYPE 0x1100
420#define CL_MEM_FLAGS 0x1101
421#define CL_MEM_SIZE 0x1102
422#define CL_MEM_HOST_PTR 0x1103
423#define CL_MEM_MAP_COUNT 0x1104
424#define CL_MEM_REFERENCE_COUNT 0x1105
425#define CL_MEM_CONTEXT 0x1106
426#define CL_MEM_ASSOCIATED_MEMOBJECT 0x1107
427#define CL_MEM_OFFSET 0x1108
428
429/* cl_image_info */
430#define CL_IMAGE_FORMAT 0x1110
431#define CL_IMAGE_ELEMENT_SIZE 0x1111
432#define CL_IMAGE_ROW_PITCH 0x1112
433#define CL_IMAGE_SLICE_PITCH 0x1113
434#define CL_IMAGE_WIDTH 0x1114
435#define CL_IMAGE_HEIGHT 0x1115
436#define CL_IMAGE_DEPTH 0x1116
437#define CL_IMAGE_ARRAY_SIZE 0x1117
438#define CL_IMAGE_BUFFER 0x1118
439#define CL_IMAGE_NUM_MIP_LEVELS 0x1119
440#define CL_IMAGE_NUM_SAMPLES 0x111A
441
442/* cl_addressing_mode */
443#define CL_ADDRESS_NONE 0x1130
444#define CL_ADDRESS_CLAMP_TO_EDGE 0x1131
445#define CL_ADDRESS_CLAMP 0x1132
446#define CL_ADDRESS_REPEAT 0x1133
447#define CL_ADDRESS_MIRRORED_REPEAT 0x1134
448
449/* cl_filter_mode */
450#define CL_FILTER_NEAREST 0x1140
451#define CL_FILTER_LINEAR 0x1141
452
453/* cl_sampler_info */
454#define CL_SAMPLER_REFERENCE_COUNT 0x1150
455#define CL_SAMPLER_CONTEXT 0x1151
456#define CL_SAMPLER_NORMALIZED_COORDS 0x1152
457#define CL_SAMPLER_ADDRESSING_MODE 0x1153
458#define CL_SAMPLER_FILTER_MODE 0x1154
459
460/* cl_map_flags - bitfield */
461#define CL_MAP_READ (1 << 0)
462#define CL_MAP_WRITE (1 << 1)
463#define CL_MAP_WRITE_INVALIDATE_REGION (1 << 2)
464
465/* cl_program_info */
466#define CL_PROGRAM_REFERENCE_COUNT 0x1160
467#define CL_PROGRAM_CONTEXT 0x1161
468#define CL_PROGRAM_NUM_DEVICES 0x1162
469#define CL_PROGRAM_DEVICES 0x1163
470#define CL_PROGRAM_SOURCE 0x1164
471#define CL_PROGRAM_BINARY_SIZES 0x1165
472#define CL_PROGRAM_BINARIES 0x1166
473#define CL_PROGRAM_NUM_KERNELS 0x1167
474#define CL_PROGRAM_KERNEL_NAMES 0x1168
475
476/* cl_program_build_info */
477#define CL_PROGRAM_BUILD_STATUS 0x1181
478#define CL_PROGRAM_BUILD_OPTIONS 0x1182
479#define CL_PROGRAM_BUILD_LOG 0x1183
480#define CL_PROGRAM_BINARY_TYPE 0x1184
481
482/* cl_program_binary_type */
483#define CL_PROGRAM_BINARY_TYPE_NONE 0x0
484#define CL_PROGRAM_BINARY_TYPE_COMPILED_OBJECT 0x1
485#define CL_PROGRAM_BINARY_TYPE_LIBRARY 0x2
486#define CL_PROGRAM_BINARY_TYPE_EXECUTABLE 0x4
487
488/* cl_build_status */
489#define CL_BUILD_SUCCESS 0
490#define CL_BUILD_NONE -1
491#define CL_BUILD_ERROR -2
492#define CL_BUILD_IN_PROGRESS -3
493
494/* cl_kernel_info */
495#define CL_KERNEL_FUNCTION_NAME 0x1190
496#define CL_KERNEL_NUM_ARGS 0x1191
497#define CL_KERNEL_REFERENCE_COUNT 0x1192
498#define CL_KERNEL_CONTEXT 0x1193
499#define CL_KERNEL_PROGRAM 0x1194
500#define CL_KERNEL_ATTRIBUTES 0x1195
501
502/* cl_kernel_arg_info */
503#define CL_KERNEL_ARG_ADDRESS_QUALIFIER 0x1196
504#define CL_KERNEL_ARG_ACCESS_QUALIFIER 0x1197
505#define CL_KERNEL_ARG_TYPE_NAME 0x1198
506#define CL_KERNEL_ARG_TYPE_QUALIFIER 0x1199
507#define CL_KERNEL_ARG_NAME 0x119A
508
509/* cl_kernel_arg_address_qualifier */
510#define CL_KERNEL_ARG_ADDRESS_GLOBAL 0x119B
511#define CL_KERNEL_ARG_ADDRESS_LOCAL 0x119C
512#define CL_KERNEL_ARG_ADDRESS_CONSTANT 0x119D
513#define CL_KERNEL_ARG_ADDRESS_PRIVATE 0x119E
514
515/* cl_kernel_arg_access_qualifier */
516#define CL_KERNEL_ARG_ACCESS_READ_ONLY 0x11A0
517#define CL_KERNEL_ARG_ACCESS_WRITE_ONLY 0x11A1
518#define CL_KERNEL_ARG_ACCESS_READ_WRITE 0x11A2
519#define CL_KERNEL_ARG_ACCESS_NONE 0x11A3
520
521/* cl_kernel_arg_type_qualifer */
522#define CL_KERNEL_ARG_TYPE_NONE 0
523#define CL_KERNEL_ARG_TYPE_CONST (1 << 0)
524#define CL_KERNEL_ARG_TYPE_RESTRICT (1 << 1)
525#define CL_KERNEL_ARG_TYPE_VOLATILE (1 << 2)
526
527/* cl_kernel_work_group_info */
528#define CL_KERNEL_WORK_GROUP_SIZE 0x11B0
529#define CL_KERNEL_COMPILE_WORK_GROUP_SIZE 0x11B1
530#define CL_KERNEL_LOCAL_MEM_SIZE 0x11B2
531#define CL_KERNEL_PREFERRED_WORK_GROUP_SIZE_MULTIPLE 0x11B3
532#define CL_KERNEL_PRIVATE_MEM_SIZE 0x11B4
533#define CL_KERNEL_GLOBAL_WORK_SIZE 0x11B5
534
535/* cl_event_info */
536#define CL_EVENT_COMMAND_QUEUE 0x11D0
537#define CL_EVENT_COMMAND_TYPE 0x11D1
538#define CL_EVENT_REFERENCE_COUNT 0x11D2
539#define CL_EVENT_COMMAND_EXECUTION_STATUS 0x11D3
540#define CL_EVENT_CONTEXT 0x11D4
541
542/* cl_command_type */
543#define CL_COMMAND_NDRANGE_KERNEL 0x11F0
544#define CL_COMMAND_TASK 0x11F1
545#define CL_COMMAND_NATIVE_KERNEL 0x11F2
546#define CL_COMMAND_READ_BUFFER 0x11F3
547#define CL_COMMAND_WRITE_BUFFER 0x11F4
548#define CL_COMMAND_COPY_BUFFER 0x11F5
549#define CL_COMMAND_READ_IMAGE 0x11F6
550#define CL_COMMAND_WRITE_IMAGE 0x11F7
551#define CL_COMMAND_COPY_IMAGE 0x11F8
552#define CL_COMMAND_COPY_IMAGE_TO_BUFFER 0x11F9
553#define CL_COMMAND_COPY_BUFFER_TO_IMAGE 0x11FA
554#define CL_COMMAND_MAP_BUFFER 0x11FB
555#define CL_COMMAND_MAP_IMAGE 0x11FC
556#define CL_COMMAND_UNMAP_MEM_OBJECT 0x11FD
557#define CL_COMMAND_MARKER 0x11FE
558#define CL_COMMAND_ACQUIRE_GL_OBJECTS 0x11FF
559#define CL_COMMAND_RELEASE_GL_OBJECTS 0x1200
560#define CL_COMMAND_READ_BUFFER_RECT 0x1201
561#define CL_COMMAND_WRITE_BUFFER_RECT 0x1202
562#define CL_COMMAND_COPY_BUFFER_RECT 0x1203
563#define CL_COMMAND_USER 0x1204
564#define CL_COMMAND_BARRIER 0x1205
565#define CL_COMMAND_MIGRATE_MEM_OBJECTS 0x1206
566#define CL_COMMAND_FILL_BUFFER 0x1207
567#define CL_COMMAND_FILL_IMAGE 0x1208
568
569/* command execution status */
570#define CL_COMPLETE 0x0
571#define CL_RUNNING 0x1
572#define CL_SUBMITTED 0x2
573#define CL_QUEUED 0x3
574
575/* cl_buffer_create_type */
576#define CL_BUFFER_CREATE_TYPE_REGION 0x1220
577
578/* cl_profiling_info */
579#define CL_PROFILING_COMMAND_QUEUED 0x1280
580#define CL_PROFILING_COMMAND_SUBMIT 0x1281
581#define CL_PROFILING_COMMAND_START 0x1282
582#define CL_PROFILING_COMMAND_END 0x1283
583
584/********************************************************************************************************/
585
586
587
588/* Device APIs */
Note: See TracBrowser for help on using the repository browser.