source: CIVL/examples/opencl/2.14/cl.cvl

main
Last change on this file was ea777aa, checked in by Alex Wilton <awilton@…>, 3 years ago

Moved examples, include, build_default.properties, common.xml, and README out from dev.civl.com into the root of the repo.

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

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