-
-
Save dpo/fc9c506c357613a87a9e74876712a405 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/******************************************************************************* | |
* Copyright (c) 2008 - 2012 The Khronos Group Inc. | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining a | |
* copy of this software and/or associated documentation files (the | |
* "Materials"), to deal in the Materials without restriction, including | |
* without limitation the rights to use, copy, modify, merge, publish, | |
* distribute, sublicense, and/or sell copies of the Materials, and to | |
* permit persons to whom the Materials are furnished to do so, subject to | |
* the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be included | |
* in all copies or substantial portions of the Materials. | |
* | |
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. | |
******************************************************************************/ | |
#ifndef __OPENCL_CL_H | |
#define __OPENCL_CL_H | |
#ifdef __APPLE__ | |
#include <OpenCL/cl_platform.h> | |
#else | |
#include <CL/cl_platform.h> | |
#endif | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
/******************************************************************************/ | |
typedef struct _cl_platform_id * cl_platform_id; | |
typedef struct _cl_device_id * cl_device_id; | |
typedef struct _cl_context * cl_context; | |
typedef struct _cl_command_queue * cl_command_queue; | |
typedef struct _cl_mem * cl_mem; | |
typedef struct _cl_program * cl_program; | |
typedef struct _cl_kernel * cl_kernel; | |
typedef struct _cl_event * cl_event; | |
typedef struct _cl_sampler * cl_sampler; | |
typedef cl_uint cl_bool; /* WARNING! Unlike cl_ types in cl_platform.h, cl_bool is not guaranteed to be the same size as the bool in kernels. */ | |
typedef cl_ulong cl_bitfield; | |
typedef cl_bitfield cl_device_type; | |
typedef cl_uint cl_platform_info; | |
typedef cl_uint cl_device_info; | |
typedef cl_bitfield cl_device_fp_config; | |
typedef cl_uint cl_device_mem_cache_type; | |
typedef cl_uint cl_device_local_mem_type; | |
typedef cl_bitfield cl_device_exec_capabilities; | |
typedef cl_bitfield cl_command_queue_properties; | |
typedef intptr_t cl_device_partition_property; | |
typedef cl_bitfield cl_device_affinity_domain; | |
typedef intptr_t cl_context_properties; | |
typedef cl_uint cl_context_info; | |
typedef cl_uint cl_command_queue_info; | |
typedef cl_uint cl_channel_order; | |
typedef cl_uint cl_channel_type; | |
typedef cl_bitfield cl_mem_flags; | |
typedef cl_uint cl_mem_object_type; | |
typedef cl_uint cl_mem_info; | |
typedef cl_bitfield cl_mem_migration_flags; | |
typedef cl_uint cl_image_info; | |
typedef cl_uint cl_buffer_create_type; | |
typedef cl_uint cl_addressing_mode; | |
typedef cl_uint cl_filter_mode; | |
typedef cl_uint cl_sampler_info; | |
typedef cl_bitfield cl_map_flags; | |
typedef cl_uint cl_program_info; | |
typedef cl_uint cl_program_build_info; | |
typedef cl_uint cl_program_binary_type; | |
typedef cl_int cl_build_status; | |
typedef cl_uint cl_kernel_info; | |
typedef cl_uint cl_kernel_arg_info; | |
typedef cl_uint cl_kernel_arg_address_qualifier; | |
typedef cl_uint cl_kernel_arg_access_qualifier; | |
typedef cl_bitfield cl_kernel_arg_type_qualifier; | |
typedef cl_uint cl_kernel_work_group_info; | |
typedef cl_uint cl_event_info; | |
typedef cl_uint cl_command_type; | |
typedef cl_uint cl_profiling_info; | |
typedef struct _cl_image_format { | |
cl_channel_order image_channel_order; | |
cl_channel_type image_channel_data_type; | |
} cl_image_format; | |
typedef struct _cl_image_desc { | |
cl_mem_object_type image_type; | |
size_t image_width; | |
size_t image_height; | |
size_t image_depth; | |
size_t image_array_size; | |
size_t image_row_pitch; | |
size_t image_slice_pitch; | |
cl_uint num_mip_levels; | |
cl_uint num_samples; | |
cl_mem buffer; | |
} cl_image_desc; | |
typedef struct _cl_buffer_region { | |
size_t origin; | |
size_t size; | |
} cl_buffer_region; | |
/******************************************************************************/ | |
/* Error Codes */ | |
#define CL_SUCCESS 0 | |
#define CL_DEVICE_NOT_FOUND -1 | |
#define CL_DEVICE_NOT_AVAILABLE -2 | |
#define CL_COMPILER_NOT_AVAILABLE -3 | |
#define CL_MEM_OBJECT_ALLOCATION_FAILURE -4 | |
#define CL_OUT_OF_RESOURCES -5 | |
#define CL_OUT_OF_HOST_MEMORY -6 | |
#define CL_PROFILING_INFO_NOT_AVAILABLE -7 | |
#define CL_MEM_COPY_OVERLAP -8 | |
#define CL_IMAGE_FORMAT_MISMATCH -9 | |
#define CL_IMAGE_FORMAT_NOT_SUPPORTED -10 | |
#define CL_BUILD_PROGRAM_FAILURE -11 | |
#define CL_MAP_FAILURE -12 | |
#define CL_MISALIGNED_SUB_BUFFER_OFFSET -13 | |
#define CL_EXEC_STATUS_ERROR_FOR_EVENTS_IN_WAIT_LIST -14 | |
#define CL_COMPILE_PROGRAM_FAILURE -15 | |
#define CL_LINKER_NOT_AVAILABLE -16 | |
#define CL_LINK_PROGRAM_FAILURE -17 | |
#define CL_DEVICE_PARTITION_FAILED -18 | |
#define CL_KERNEL_ARG_INFO_NOT_AVAILABLE -19 | |
#define CL_INVALID_VALUE -30 | |
#define CL_INVALID_DEVICE_TYPE -31 | |
#define CL_INVALID_PLATFORM -32 | |
#define CL_INVALID_DEVICE -33 | |
#define CL_INVALID_CONTEXT -34 | |
#define CL_INVALID_QUEUE_PROPERTIES -35 | |
#define CL_INVALID_COMMAND_QUEUE -36 | |
#define CL_INVALID_HOST_PTR -37 | |
#define CL_INVALID_MEM_OBJECT -38 | |
#define CL_INVALID_IMAGE_FORMAT_DESCRIPTOR -39 | |
#define CL_INVALID_IMAGE_SIZE -40 | |
#define CL_INVALID_SAMPLER -41 | |
#define CL_INVALID_BINARY -42 | |
#define CL_INVALID_BUILD_OPTIONS -43 | |
#define CL_INVALID_PROGRAM -44 | |
#define CL_INVALID_PROGRAM_EXECUTABLE -45 | |
#define CL_INVALID_KERNEL_NAME -46 | |
#define CL_INVALID_KERNEL_DEFINITION -47 | |
#define CL_INVALID_KERNEL -48 | |
#define CL_INVALID_ARG_INDEX -49 | |
#define CL_INVALID_ARG_VALUE -50 | |
#define CL_INVALID_ARG_SIZE -51 | |
#define CL_INVALID_KERNEL_ARGS -52 | |
#define CL_INVALID_WORK_DIMENSION -53 | |
#define CL_INVALID_WORK_GROUP_SIZE -54 | |
#define CL_INVALID_WORK_ITEM_SIZE -55 | |
#define CL_INVALID_GLOBAL_OFFSET -56 | |
#define CL_INVALID_EVENT_WAIT_LIST -57 | |
#define CL_INVALID_EVENT -58 | |
#define CL_INVALID_OPERATION -59 | |
#define CL_INVALID_GL_OBJECT -60 | |
#define CL_INVALID_BUFFER_SIZE -61 | |
#define CL_INVALID_MIP_LEVEL -62 | |
#define CL_INVALID_GLOBAL_WORK_SIZE -63 | |
#define CL_INVALID_PROPERTY -64 | |
#define CL_INVALID_IMAGE_DESCRIPTOR -65 | |
#define CL_INVALID_COMPILER_OPTIONS -66 | |
#define CL_INVALID_LINKER_OPTIONS -67 | |
#define CL_INVALID_DEVICE_PARTITION_COUNT -68 | |
/* OpenCL Version */ | |
#define CL_VERSION_1_0 1 | |
#define CL_VERSION_1_1 1 | |
#define CL_VERSION_1_2 1 | |
/* cl_bool */ | |
#define CL_FALSE 0 | |
#define CL_TRUE 1 | |
#define CL_BLOCKING CL_TRUE | |
#define CL_NON_BLOCKING CL_FALSE | |
/* cl_platform_info */ | |
#define CL_PLATFORM_PROFILE 0x0900 | |
#define CL_PLATFORM_VERSION 0x0901 | |
#define CL_PLATFORM_NAME 0x0902 | |
#define CL_PLATFORM_VENDOR 0x0903 | |
#define CL_PLATFORM_EXTENSIONS 0x0904 | |
/* cl_device_type - bitfield */ | |
#define CL_DEVICE_TYPE_DEFAULT (1 << 0) | |
#define CL_DEVICE_TYPE_CPU (1 << 1) | |
#define CL_DEVICE_TYPE_GPU (1 << 2) | |
#define CL_DEVICE_TYPE_ACCELERATOR (1 << 3) | |
#define CL_DEVICE_TYPE_CUSTOM (1 << 4) | |
#define CL_DEVICE_TYPE_ALL 0xFFFFFFFF | |
/* cl_device_info */ | |
#define CL_DEVICE_TYPE 0x1000 | |
#define CL_DEVICE_VENDOR_ID 0x1001 | |
#define CL_DEVICE_MAX_COMPUTE_UNITS 0x1002 | |
#define CL_DEVICE_MAX_WORK_ITEM_DIMENSIONS 0x1003 | |
#define CL_DEVICE_MAX_WORK_GROUP_SIZE 0x1004 | |
#define CL_DEVICE_MAX_WORK_ITEM_SIZES 0x1005 | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_CHAR 0x1006 | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_SHORT 0x1007 | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_INT 0x1008 | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_LONG 0x1009 | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_FLOAT 0x100A | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_DOUBLE 0x100B | |
#define CL_DEVICE_MAX_CLOCK_FREQUENCY 0x100C | |
#define CL_DEVICE_ADDRESS_BITS 0x100D | |
#define CL_DEVICE_MAX_READ_IMAGE_ARGS 0x100E | |
#define CL_DEVICE_MAX_WRITE_IMAGE_ARGS 0x100F | |
#define CL_DEVICE_MAX_MEM_ALLOC_SIZE 0x1010 | |
#define CL_DEVICE_IMAGE2D_MAX_WIDTH 0x1011 | |
#define CL_DEVICE_IMAGE2D_MAX_HEIGHT 0x1012 | |
#define CL_DEVICE_IMAGE3D_MAX_WIDTH 0x1013 | |
#define CL_DEVICE_IMAGE3D_MAX_HEIGHT 0x1014 | |
#define CL_DEVICE_IMAGE3D_MAX_DEPTH 0x1015 | |
#define CL_DEVICE_IMAGE_SUPPORT 0x1016 | |
#define CL_DEVICE_MAX_PARAMETER_SIZE 0x1017 | |
#define CL_DEVICE_MAX_SAMPLERS 0x1018 | |
#define CL_DEVICE_MEM_BASE_ADDR_ALIGN 0x1019 | |
#define CL_DEVICE_MIN_DATA_TYPE_ALIGN_SIZE 0x101A | |
#define CL_DEVICE_SINGLE_FP_CONFIG 0x101B | |
#define CL_DEVICE_GLOBAL_MEM_CACHE_TYPE 0x101C | |
#define CL_DEVICE_GLOBAL_MEM_CACHELINE_SIZE 0x101D | |
#define CL_DEVICE_GLOBAL_MEM_CACHE_SIZE 0x101E | |
#define CL_DEVICE_GLOBAL_MEM_SIZE 0x101F | |
#define CL_DEVICE_MAX_CONSTANT_BUFFER_SIZE 0x1020 | |
#define CL_DEVICE_MAX_CONSTANT_ARGS 0x1021 | |
#define CL_DEVICE_LOCAL_MEM_TYPE 0x1022 | |
#define CL_DEVICE_LOCAL_MEM_SIZE 0x1023 | |
#define CL_DEVICE_ERROR_CORRECTION_SUPPORT 0x1024 | |
#define CL_DEVICE_PROFILING_TIMER_RESOLUTION 0x1025 | |
#define CL_DEVICE_ENDIAN_LITTLE 0x1026 | |
#define CL_DEVICE_AVAILABLE 0x1027 | |
#define CL_DEVICE_COMPILER_AVAILABLE 0x1028 | |
#define CL_DEVICE_EXECUTION_CAPABILITIES 0x1029 | |
#define CL_DEVICE_QUEUE_PROPERTIES 0x102A | |
#define CL_DEVICE_NAME 0x102B | |
#define CL_DEVICE_VENDOR 0x102C | |
#define CL_DRIVER_VERSION 0x102D | |
#define CL_DEVICE_PROFILE 0x102E | |
#define CL_DEVICE_VERSION 0x102F | |
#define CL_DEVICE_EXTENSIONS 0x1030 | |
#define CL_DEVICE_PLATFORM 0x1031 | |
#define CL_DEVICE_DOUBLE_FP_CONFIG 0x1032 | |
/* 0x1033 reserved for CL_DEVICE_HALF_FP_CONFIG */ | |
#define CL_DEVICE_PREFERRED_VECTOR_WIDTH_HALF 0x1034 | |
#define CL_DEVICE_HOST_UNIFIED_MEMORY 0x1035 | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_CHAR 0x1036 | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_SHORT 0x1037 | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_INT 0x1038 | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_LONG 0x1039 | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_FLOAT 0x103A | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_DOUBLE 0x103B | |
#define CL_DEVICE_NATIVE_VECTOR_WIDTH_HALF 0x103C | |
#define CL_DEVICE_OPENCL_C_VERSION 0x103D | |
#define CL_DEVICE_LINKER_AVAILABLE 0x103E | |
#define CL_DEVICE_BUILT_IN_KERNELS 0x103F | |
#define CL_DEVICE_IMAGE_MAX_BUFFER_SIZE 0x1040 | |
#define CL_DEVICE_IMAGE_MAX_ARRAY_SIZE 0x1041 | |
#define CL_DEVICE_PARENT_DEVICE 0x1042 | |
#define CL_DEVICE_PARTITION_MAX_SUB_DEVICES 0x1043 | |
#define CL_DEVICE_PARTITION_PROPERTIES 0x1044 | |
#define CL_DEVICE_PARTITION_AFFINITY_DOMAIN 0x1045 | |
#define CL_DEVICE_PARTITION_TYPE 0x1046 | |
#define CL_DEVICE_REFERENCE_COUNT 0x1047 | |
#define CL_DEVICE_PREFERRED_INTEROP_USER_SYNC 0x1048 | |
#define CL_DEVICE_PRINTF_BUFFER_SIZE 0x1049 | |
#define CL_DEVICE_IMAGE_PITCH_ALIGNMENT 0x104A | |
#define CL_DEVICE_IMAGE_BASE_ADDRESS_ALIGNMENT 0x104B | |
/* cl_device_fp_config - bitfield */ | |
#define CL_FP_DENORM (1 << 0) | |
#define CL_FP_INF_NAN (1 << 1) | |
#define CL_FP_ROUND_TO_NEAREST (1 << 2) | |
#define CL_FP_ROUND_TO_ZERO (1 << 3) | |
#define CL_FP_ROUND_TO_INF (1 << 4) | |
#define CL_FP_FMA (1 << 5) | |
#define CL_FP_SOFT_FLOAT (1 << 6) | |
#define CL_FP_CORRECTLY_ROUNDED_DIVIDE_SQRT (1 << 7) | |
/* cl_device_mem_cache_type */ | |
#define CL_NONE 0x0 | |
#define CL_READ_ONLY_CACHE 0x1 | |
#define CL_READ_WRITE_CACHE 0x2 | |
/* cl_device_local_mem_type */ | |
#define CL_LOCAL 0x1 | |
#define CL_GLOBAL 0x2 | |
/* cl_device_exec_capabilities - bitfield */ | |
#define CL_EXEC_KERNEL (1 << 0) | |
#define CL_EXEC_NATIVE_KERNEL (1 << 1) | |
/* cl_command_queue_properties - bitfield */ | |
#define CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE (1 << 0) | |
#define CL_QUEUE_PROFILING_ENABLE (1 << 1) | |
/* cl_context_info */ | |
#define CL_CONTEXT_REFERENCE_COUNT 0x1080 | |
#define CL_CONTEXT_DEVICES 0x1081 | |
#define CL_CONTEXT_PROPERTIES 0x1082 | |
#define CL_CONTEXT_NUM_DEVICES 0x1083 | |
/* cl_context_properties */ | |
#define CL_CONTEXT_PLATFORM 0x1084 | |
#define CL_CONTEXT_INTEROP_USER_SYNC 0x1085 | |
/* cl_device_partition_property */ | |
#define CL_DEVICE_PARTITION_EQUALLY 0x1086 | |
#define CL_DEVICE_PARTITION_BY_COUNTS 0x1087 | |
#define CL_DEVICE_PARTITION_BY_COUNTS_LIST_END 0x0 | |
#define CL_DEVICE_PARTITION_BY_AFFINITY_DOMAIN 0x1088 | |
/* cl_device_affinity_domain */ | |
#define CL_DEVICE_AFFINITY_DOMAIN_NUMA (1 << 0) | |
#define CL_DEVICE_AFFINITY_DOMAIN_L4_CACHE (1 << 1) | |
#define CL_DEVICE_AFFINITY_DOMAIN_L3_CACHE (1 << 2) | |
#define CL_DEVICE_AFFINITY_DOMAIN_L2_CACHE (1 << 3) | |
#define CL_DEVICE_AFFINITY_DOMAIN_L1_CACHE (1 << 4) | |
#define CL_DEVICE_AFFINITY_DOMAIN_NEXT_PARTITIONABLE (1 << 5) | |
/* cl_command_queue_info */ | |
#define CL_QUEUE_CONTEXT 0x1090 | |
#define CL_QUEUE_DEVICE 0x1091 | |
#define CL_QUEUE_REFERENCE_COUNT 0x1092 | |
#define CL_QUEUE_PROPERTIES 0x1093 | |
/* cl_mem_flags - bitfield */ | |
#define CL_MEM_READ_WRITE (1 << 0) | |
#define CL_MEM_WRITE_ONLY (1 << 1) | |
#define CL_MEM_READ_ONLY (1 << 2) | |
#define CL_MEM_USE_HOST_PTR (1 << 3) | |
#define CL_MEM_ALLOC_HOST_PTR (1 << 4) | |
#define CL_MEM_COPY_HOST_PTR (1 << 5) | |
// reserved (1 << 6) | |
#define CL_MEM_HOST_WRITE_ONLY (1 << 7) | |
#define CL_MEM_HOST_READ_ONLY (1 << 8) | |
#define CL_MEM_HOST_NO_ACCESS (1 << 9) | |
/* cl_mem_migration_flags - bitfield */ | |
#define CL_MIGRATE_MEM_OBJECT_HOST (1 << 0) | |
#define CL_MIGRATE_MEM_OBJECT_CONTENT_UNDEFINED (1 << 1) | |
/* cl_channel_order */ | |
#define CL_R 0x10B0 | |
#define CL_A 0x10B1 | |
#define CL_RG 0x10B2 | |
#define CL_RA 0x10B3 | |
#define CL_RGB 0x10B4 | |
#define CL_RGBA 0x10B5 | |
#define CL_BGRA 0x10B6 | |
#define CL_ARGB 0x10B7 | |
#define CL_INTENSITY 0x10B8 | |
#define CL_LUMINANCE 0x10B9 | |
#define CL_Rx 0x10BA | |
#define CL_RGx 0x10BB | |
#define CL_RGBx 0x10BC | |
#define CL_DEPTH 0x10BD | |
#define CL_DEPTH_STENCIL 0x10BE | |
/* cl_channel_type */ | |
#define CL_SNORM_INT8 0x10D0 | |
#define CL_SNORM_INT16 0x10D1 | |
#define CL_UNORM_INT8 0x10D2 | |
#define CL_UNORM_INT16 0x10D3 | |
#define CL_UNORM_SHORT_565 0x10D4 | |
#define CL_UNORM_SHORT_555 0x10D5 | |
#define CL_UNORM_INT_101010 0x10D6 | |
#define CL_SIGNED_INT8 0x10D7 | |
#define CL_SIGNED_INT16 0x10D8 | |
#define CL_SIGNED_INT32 0x10D9 | |
#define CL_UNSIGNED_INT8 0x10DA | |
#define CL_UNSIGNED_INT16 0x10DB | |
#define CL_UNSIGNED_INT32 0x10DC | |
#define CL_HALF_FLOAT 0x10DD | |
#define CL_FLOAT 0x10DE | |
#define CL_UNORM_INT24 0x10DF | |
/* cl_mem_object_type */ | |
#define CL_MEM_OBJECT_BUFFER 0x10F0 | |
#define CL_MEM_OBJECT_IMAGE2D 0x10F1 | |
#define CL_MEM_OBJECT_IMAGE3D 0x10F2 | |
#define CL_MEM_OBJECT_IMAGE2D_ARRAY 0x10F3 | |
#define CL_MEM_OBJECT_IMAGE1D 0x10F4 | |
#define CL_MEM_OBJECT_IMAGE1D_ARRAY 0x10F5 | |
#define CL_MEM_OBJECT_IMAGE1D_BUFFER 0x10F6 | |
/* cl_mem_info */ | |
#define CL_MEM_TYPE 0x1100 | |
#define CL_MEM_FLAGS 0x1101 | |
#define CL_MEM_SIZE 0x1102 | |
#define CL_MEM_HOST_PTR 0x1103 | |
#define CL_MEM_MAP_COUNT 0x1104 | |
#define CL_MEM_REFERENCE_COUNT 0x1105 | |
#define CL_MEM_CONTEXT 0x1106 | |
#define CL_MEM_ASSOCIATED_MEMOBJECT 0x1107 | |
#define CL_MEM_OFFSET 0x1108 | |
/* cl_image_info */ | |
#define CL_IMAGE_FORMAT 0x1110 | |
#define CL_IMAGE_ELEMENT_SIZE 0x1111 | |
#define CL_IMAGE_ROW_PITCH 0x1112 | |
#define CL_IMAGE_SLICE_PITCH 0x1113 | |
#define CL_IMAGE_WIDTH 0x1114 | |
#define CL_IMAGE_HEIGHT 0x1115 | |
#define CL_IMAGE_DEPTH 0x1116 | |
#define CL_IMAGE_ARRAY_SIZE 0x1117 | |
#define CL_IMAGE_BUFFER 0x1118 | |
#define CL_IMAGE_NUM_MIP_LEVELS 0x1119 | |
#define CL_IMAGE_NUM_SAMPLES 0x111A | |
/* cl_addressing_mode */ | |
#define CL_ADDRESS_NONE 0x1130 | |
#define CL_ADDRESS_CLAMP_TO_EDGE 0x1131 | |
#define CL_ADDRESS_CLAMP 0x1132 | |
#define CL_ADDRESS_REPEAT 0x1133 | |
#define CL_ADDRESS_MIRRORED_REPEAT 0x1134 | |
/* cl_filter_mode */ | |
#define CL_FILTER_NEAREST 0x1140 | |
#define CL_FILTER_LINEAR 0x1141 | |
/* cl_sampler_info */ | |
#define CL_SAMPLER_REFERENCE_COUNT 0x1150 | |
#define CL_SAMPLER_CONTEXT 0x1151 | |
#define CL_SAMPLER_NORMALIZED_COORDS 0x1152 | |
#define CL_SAMPLER_ADDRESSING_MODE 0x1153 | |
#define CL_SAMPLER_FILTER_MODE 0x1154 | |
/* cl_map_flags - bitfield */ | |
#define CL_MAP_READ (1 << 0) | |
#define CL_MAP_WRITE (1 << 1) | |
#define CL_MAP_WRITE_INVALIDATE_REGION (1 << 2) | |
/* cl_program_info */ | |
#define CL_PROGRAM_REFERENCE_COUNT 0x1160 | |
#define CL_PROGRAM_CONTEXT 0x1161 | |
#define CL_PROGRAM_NUM_DEVICES 0x1162 | |
#define CL_PROGRAM_DEVICES 0x1163 | |
#define CL_PROGRAM_SOURCE 0x1164 | |
#define CL_PROGRAM_BINARY_SIZES 0x1165 | |
#define CL_PROGRAM_BINARIES 0x1166 | |
#define CL_PROGRAM_NUM_KERNELS 0x1167 | |
#define CL_PROGRAM_KERNEL_NAMES 0x1168 | |
/* cl_program_build_info */ | |
#define CL_PROGRAM_BUILD_STATUS 0x1181 | |
#define CL_PROGRAM_BUILD_OPTIONS 0x1182 | |
#define CL_PROGRAM_BUILD_LOG 0x1183 | |
#define CL_PROGRAM_BINARY_TYPE 0x1184 | |
/* cl_program_binary_type */ | |
#define CL_PROGRAM_BINARY_TYPE_NONE 0x0 | |
#define CL_PROGRAM_BINARY_TYPE_COMPILED_OBJECT 0x1 | |
#define CL_PROGRAM_BINARY_TYPE_LIBRARY 0x2 | |
#define CL_PROGRAM_BINARY_TYPE_EXECUTABLE 0x4 | |
/* cl_build_status */ | |
#define CL_BUILD_SUCCESS 0 | |
#define CL_BUILD_NONE -1 | |
#define CL_BUILD_ERROR -2 | |
#define CL_BUILD_IN_PROGRESS -3 | |
/* cl_kernel_info */ | |
#define CL_KERNEL_FUNCTION_NAME 0x1190 | |
#define CL_KERNEL_NUM_ARGS 0x1191 | |
#define CL_KERNEL_REFERENCE_COUNT 0x1192 | |
#define CL_KERNEL_CONTEXT 0x1193 | |
#define CL_KERNEL_PROGRAM 0x1194 | |
#define CL_KERNEL_ATTRIBUTES 0x1195 | |
/* cl_kernel_arg_info */ | |
#define CL_KERNEL_ARG_ADDRESS_QUALIFIER 0x1196 | |
#define CL_KERNEL_ARG_ACCESS_QUALIFIER 0x1197 | |
#define CL_KERNEL_ARG_TYPE_NAME 0x1198 | |
#define CL_KERNEL_ARG_TYPE_QUALIFIER 0x1199 | |
#define CL_KERNEL_ARG_NAME 0x119A | |
/* cl_kernel_arg_address_qualifier */ | |
#define CL_KERNEL_ARG_ADDRESS_GLOBAL 0x119B | |
#define CL_KERNEL_ARG_ADDRESS_LOCAL 0x119C | |
#define CL_KERNEL_ARG_ADDRESS_CONSTANT 0x119D | |
#define CL_KERNEL_ARG_ADDRESS_PRIVATE 0x119E | |
/* cl_kernel_arg_access_qualifier */ | |
#define CL_KERNEL_ARG_ACCESS_READ_ONLY 0x11A0 | |
#define CL_KERNEL_ARG_ACCESS_WRITE_ONLY 0x11A1 | |
#define CL_KERNEL_ARG_ACCESS_READ_WRITE 0x11A2 | |
#define CL_KERNEL_ARG_ACCESS_NONE 0x11A3 | |
/* cl_kernel_arg_type_qualifer */ | |
#define CL_KERNEL_ARG_TYPE_NONE 0 | |
#define CL_KERNEL_ARG_TYPE_CONST (1 << 0) | |
#define CL_KERNEL_ARG_TYPE_RESTRICT (1 << 1) | |
#define CL_KERNEL_ARG_TYPE_VOLATILE (1 << 2) | |
/* cl_kernel_work_group_info */ | |
#define CL_KERNEL_WORK_GROUP_SIZE 0x11B0 | |
#define CL_KERNEL_COMPILE_WORK_GROUP_SIZE 0x11B1 | |
#define CL_KERNEL_LOCAL_MEM_SIZE 0x11B2 | |
#define CL_KERNEL_PREFERRED_WORK_GROUP_SIZE_MULTIPLE 0x11B3 | |
#define CL_KERNEL_PRIVATE_MEM_SIZE 0x11B4 | |
#define CL_KERNEL_GLOBAL_WORK_SIZE 0x11B5 | |
/* cl_event_info */ | |
#define CL_EVENT_COMMAND_QUEUE 0x11D0 | |
#define CL_EVENT_COMMAND_TYPE 0x11D1 | |
#define CL_EVENT_REFERENCE_COUNT 0x11D2 | |
#define CL_EVENT_COMMAND_EXECUTION_STATUS 0x11D3 | |
#define CL_EVENT_CONTEXT 0x11D4 | |
/* cl_command_type */ | |
#define CL_COMMAND_NDRANGE_KERNEL 0x11F0 | |
#define CL_COMMAND_TASK 0x11F1 | |
#define CL_COMMAND_NATIVE_KERNEL 0x11F2 | |
#define CL_COMMAND_READ_BUFFER 0x11F3 | |
#define CL_COMMAND_WRITE_BUFFER 0x11F4 | |
#define CL_COMMAND_COPY_BUFFER 0x11F5 | |
#define CL_COMMAND_READ_IMAGE 0x11F6 | |
#define CL_COMMAND_WRITE_IMAGE 0x11F7 | |
#define CL_COMMAND_COPY_IMAGE 0x11F8 | |
#define CL_COMMAND_COPY_IMAGE_TO_BUFFER 0x11F9 | |
#define CL_COMMAND_COPY_BUFFER_TO_IMAGE 0x11FA | |
#define CL_COMMAND_MAP_BUFFER 0x11FB | |
#define CL_COMMAND_MAP_IMAGE 0x11FC | |
#define CL_COMMAND_UNMAP_MEM_OBJECT 0x11FD | |
#define CL_COMMAND_MARKER 0x11FE | |
#define CL_COMMAND_ACQUIRE_GL_OBJECTS 0x11FF | |
#define CL_COMMAND_RELEASE_GL_OBJECTS 0x1200 | |
#define CL_COMMAND_READ_BUFFER_RECT 0x1201 | |
#define CL_COMMAND_WRITE_BUFFER_RECT 0x1202 | |
#define CL_COMMAND_COPY_BUFFER_RECT 0x1203 | |
#define CL_COMMAND_USER 0x1204 | |
#define CL_COMMAND_BARRIER 0x1205 | |
#define CL_COMMAND_MIGRATE_MEM_OBJECTS 0x1206 | |
#define CL_COMMAND_FILL_BUFFER 0x1207 | |
#define CL_COMMAND_FILL_IMAGE 0x1208 | |
/* command execution status */ | |
#define CL_COMPLETE 0x0 | |
#define CL_RUNNING 0x1 | |
#define CL_SUBMITTED 0x2 | |
#define CL_QUEUED 0x3 | |
/* cl_buffer_create_type */ | |
#define CL_BUFFER_CREATE_TYPE_REGION 0x1220 | |
/* cl_profiling_info */ | |
#define CL_PROFILING_COMMAND_QUEUED 0x1280 | |
#define CL_PROFILING_COMMAND_SUBMIT 0x1281 | |
#define CL_PROFILING_COMMAND_START 0x1282 | |
#define CL_PROFILING_COMMAND_END 0x1283 | |
/********************************************************************************************************/ | |
/* Platform API */ | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetPlatformIDs(cl_uint /* num_entries */, | |
cl_platform_id * /* platforms */, | |
cl_uint * /* num_platforms */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetPlatformInfo(cl_platform_id /* platform */, | |
cl_platform_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
/* Device APIs */ | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetDeviceIDs(cl_platform_id /* platform */, | |
cl_device_type /* device_type */, | |
cl_uint /* num_entries */, | |
cl_device_id * /* devices */, | |
cl_uint * /* num_devices */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetDeviceInfo(cl_device_id /* device */, | |
cl_device_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clCreateSubDevices(cl_device_id /* in_device */, | |
const cl_device_partition_property * /* properties */, | |
cl_uint /* num_devices */, | |
cl_device_id * /* out_devices */, | |
cl_uint * /* num_devices_ret */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainDevice(cl_device_id /* device */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseDevice(cl_device_id /* device */) CL_API_SUFFIX__VERSION_1_2; | |
/* Context APIs */ | |
extern CL_API_ENTRY cl_context CL_API_CALL | |
clCreateContext(const cl_context_properties * /* properties */, | |
cl_uint /* num_devices */, | |
const cl_device_id * /* devices */, | |
void (CL_CALLBACK * /* pfn_notify */)(const char *, const void *, size_t, void *), | |
void * /* user_data */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_context CL_API_CALL | |
clCreateContextFromType(const cl_context_properties * /* properties */, | |
cl_device_type /* device_type */, | |
void (CL_CALLBACK * /* pfn_notify*/ )(const char *, const void *, size_t, void *), | |
void * /* user_data */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainContext(cl_context /* context */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseContext(cl_context /* context */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetContextInfo(cl_context /* context */, | |
cl_context_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
/* Command Queue APIs */ | |
extern CL_API_ENTRY cl_command_queue CL_API_CALL | |
clCreateCommandQueue(cl_context /* context */, | |
cl_device_id /* device */, | |
cl_command_queue_properties /* properties */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainCommandQueue(cl_command_queue /* command_queue */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseCommandQueue(cl_command_queue /* command_queue */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetCommandQueueInfo(cl_command_queue /* command_queue */, | |
cl_command_queue_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
/* Memory Object APIs */ | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateBuffer(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
size_t /* size */, | |
void * /* host_ptr */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateSubBuffer(cl_mem /* buffer */, | |
cl_mem_flags /* flags */, | |
cl_buffer_create_type /* buffer_create_type */, | |
const void * /* buffer_create_info */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateImage(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
const cl_image_format * /* image_format */, | |
const cl_image_desc * /* image_desc */, | |
void * /* host_ptr */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainMemObject(cl_mem /* memobj */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseMemObject(cl_mem /* memobj */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetSupportedImageFormats(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
cl_mem_object_type /* image_type */, | |
cl_uint /* num_entries */, | |
cl_image_format * /* image_formats */, | |
cl_uint * /* num_image_formats */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetMemObjectInfo(cl_mem /* memobj */, | |
cl_mem_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetImageInfo(cl_mem /* image */, | |
cl_image_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clSetMemObjectDestructorCallback( cl_mem /* memobj */, | |
void (CL_CALLBACK * /*pfn_notify*/)( cl_mem /* memobj */, void* /*user_data*/), | |
void * /*user_data */ ) CL_API_SUFFIX__VERSION_1_1; | |
/* Sampler APIs */ | |
extern CL_API_ENTRY cl_sampler CL_API_CALL | |
clCreateSampler(cl_context /* context */, | |
cl_bool /* normalized_coords */, | |
cl_addressing_mode /* addressing_mode */, | |
cl_filter_mode /* filter_mode */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainSampler(cl_sampler /* sampler */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseSampler(cl_sampler /* sampler */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetSamplerInfo(cl_sampler /* sampler */, | |
cl_sampler_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
/* Program Object APIs */ | |
extern CL_API_ENTRY cl_program CL_API_CALL | |
clCreateProgramWithSource(cl_context /* context */, | |
cl_uint /* count */, | |
const char ** /* strings */, | |
const size_t * /* lengths */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_program CL_API_CALL | |
clCreateProgramWithBinary(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_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_program CL_API_CALL | |
clCreateProgramWithBuiltInKernels(cl_context /* context */, | |
cl_uint /* num_devices */, | |
const cl_device_id * /* device_list */, | |
const char * /* kernel_names */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainProgram(cl_program /* program */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseProgram(cl_program /* program */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clBuildProgram(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 */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clCompileProgram(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 */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_program CL_API_CALL | |
clLinkProgram(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_int * /* errcode_ret */ ) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clUnloadPlatformCompiler(cl_platform_id /* platform */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetProgramInfo(cl_program /* program */, | |
cl_program_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetProgramBuildInfo(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 */) CL_API_SUFFIX__VERSION_1_0; | |
/* Kernel Object APIs */ | |
extern CL_API_ENTRY cl_kernel CL_API_CALL | |
clCreateKernel(cl_program /* program */, | |
const char * /* kernel_name */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clCreateKernelsInProgram(cl_program /* program */, | |
cl_uint /* num_kernels */, | |
cl_kernel * /* kernels */, | |
cl_uint * /* num_kernels_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainKernel(cl_kernel /* kernel */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseKernel(cl_kernel /* kernel */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clSetKernelArg(cl_kernel /* kernel */, | |
cl_uint /* arg_index */, | |
size_t /* arg_size */, | |
const void * /* arg_value */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetKernelInfo(cl_kernel /* kernel */, | |
cl_kernel_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetKernelArgInfo(cl_kernel /* kernel */, | |
cl_uint /* arg_indx */, | |
cl_kernel_arg_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetKernelWorkGroupInfo(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 */) CL_API_SUFFIX__VERSION_1_0; | |
/* Event Object APIs */ | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clWaitForEvents(cl_uint /* num_events */, | |
const cl_event * /* event_list */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetEventInfo(cl_event /* event */, | |
cl_event_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_event CL_API_CALL | |
clCreateUserEvent(cl_context /* context */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clRetainEvent(cl_event /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clReleaseEvent(cl_event /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clSetUserEventStatus(cl_event /* event */, | |
cl_int /* execution_status */) CL_API_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clSetEventCallback( cl_event /* event */, | |
cl_int /* command_exec_callback_type */, | |
void (CL_CALLBACK * /* pfn_notify */)(cl_event, cl_int, void *), | |
void * /* user_data */) CL_API_SUFFIX__VERSION_1_1; | |
/* Profiling APIs */ | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetEventProfilingInfo(cl_event /* event */, | |
cl_profiling_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
/* Flush and Finish APIs */ | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clFlush(cl_command_queue /* command_queue */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clFinish(cl_command_queue /* command_queue */) CL_API_SUFFIX__VERSION_1_0; | |
/* Enqueued Commands APIs */ | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueReadBuffer(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 */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueReadBufferRect(cl_command_queue /* command_queue */, | |
cl_mem /* buffer */, | |
cl_bool /* blocking_read */, | |
const size_t * /* buffer_offset */, | |
const size_t * /* host_offset */, | |
const size_t * /* region */, | |
size_t /* buffer_row_pitch */, | |
size_t /* buffer_slice_pitch */, | |
size_t /* host_row_pitch */, | |
size_t /* host_slice_pitch */, | |
void * /* ptr */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueWriteBuffer(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 */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueWriteBufferRect(cl_command_queue /* command_queue */, | |
cl_mem /* buffer */, | |
cl_bool /* blocking_write */, | |
const size_t * /* buffer_offset */, | |
const size_t * /* host_offset */, | |
const size_t * /* region */, | |
size_t /* buffer_row_pitch */, | |
size_t /* buffer_slice_pitch */, | |
size_t /* host_row_pitch */, | |
size_t /* host_slice_pitch */, | |
const void * /* ptr */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueFillBuffer(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 */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueCopyBuffer(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 */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueCopyBufferRect(cl_command_queue /* command_queue */, | |
cl_mem /* src_buffer */, | |
cl_mem /* dst_buffer */, | |
const size_t * /* src_origin */, | |
const size_t * /* dst_origin */, | |
const size_t * /* region */, | |
size_t /* src_row_pitch */, | |
size_t /* src_slice_pitch */, | |
size_t /* dst_row_pitch */, | |
size_t /* dst_slice_pitch */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueReadImage(cl_command_queue /* command_queue */, | |
cl_mem /* image */, | |
cl_bool /* blocking_read */, | |
const size_t * /* origin[3] */, | |
const size_t * /* region[3] */, | |
size_t /* row_pitch */, | |
size_t /* slice_pitch */, | |
void * /* ptr */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueWriteImage(cl_command_queue /* command_queue */, | |
cl_mem /* image */, | |
cl_bool /* blocking_write */, | |
const size_t * /* origin[3] */, | |
const size_t * /* region[3] */, | |
size_t /* input_row_pitch */, | |
size_t /* input_slice_pitch */, | |
const void * /* ptr */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueFillImage(cl_command_queue /* command_queue */, | |
cl_mem /* image */, | |
const void * /* fill_color */, | |
const size_t * /* origin[3] */, | |
const size_t * /* region[3] */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueCopyImage(cl_command_queue /* command_queue */, | |
cl_mem /* src_image */, | |
cl_mem /* dst_image */, | |
const size_t * /* src_origin[3] */, | |
const size_t * /* dst_origin[3] */, | |
const size_t * /* region[3] */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueCopyImageToBuffer(cl_command_queue /* command_queue */, | |
cl_mem /* src_image */, | |
cl_mem /* dst_buffer */, | |
const size_t * /* src_origin[3] */, | |
const size_t * /* region[3] */, | |
size_t /* dst_offset */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueCopyBufferToImage(cl_command_queue /* command_queue */, | |
cl_mem /* src_buffer */, | |
cl_mem /* dst_image */, | |
size_t /* src_offset */, | |
const size_t * /* dst_origin[3] */, | |
const size_t * /* region[3] */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY void * CL_API_CALL | |
clEnqueueMapBuffer(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 */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY void * CL_API_CALL | |
clEnqueueMapImage(cl_command_queue /* command_queue */, | |
cl_mem /* image */, | |
cl_bool /* blocking_map */, | |
cl_map_flags /* map_flags */, | |
const size_t * /* origin[3] */, | |
const size_t * /* region[3] */, | |
size_t * /* image_row_pitch */, | |
size_t * /* image_slice_pitch */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueUnmapMemObject(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 */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueMigrateMemObjects(cl_command_queue /* command_queue */, | |
cl_uint /* num_mem_objects */, | |
const cl_mem * /* mem_objects */, | |
cl_mem_migration_flags /* flags */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueNDRangeKernel(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 */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueTask(cl_command_queue /* command_queue */, | |
cl_kernel /* kernel */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueNativeKernel(cl_command_queue /* command_queue */, | |
void (CL_CALLBACK * /*user_func*/)(void *), | |
void * /* args */, | |
size_t /* cb_args */, | |
cl_uint /* num_mem_objects */, | |
const cl_mem * /* mem_list */, | |
const void ** /* args_mem_loc */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueMarkerWithWaitList(cl_command_queue /* command_queue */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueBarrierWithWaitList(cl_command_queue /* command_queue */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_2; | |
/* Extension function access | |
* | |
* Returns the extension function address for the given function name, | |
* or NULL if a valid function can not be found. The client must | |
* check to make sure the address is not NULL, before using or | |
* calling the returned function address. | |
*/ | |
extern CL_API_ENTRY void * CL_API_CALL | |
clGetExtensionFunctionAddressForPlatform(cl_platform_id /* platform */, | |
const char * /* func_name */) CL_API_SUFFIX__VERSION_1_2; | |
// Deprecated OpenCL 1.1 APIs | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_mem CL_API_CALL | |
clCreateImage2D(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
const cl_image_format * /* image_format */, | |
size_t /* image_width */, | |
size_t /* image_height */, | |
size_t /* image_row_pitch */, | |
void * /* host_ptr */, | |
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_mem CL_API_CALL | |
clCreateImage3D(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
const cl_image_format * /* image_format */, | |
size_t /* image_width */, | |
size_t /* image_height */, | |
size_t /* image_depth */, | |
size_t /* image_row_pitch */, | |
size_t /* image_slice_pitch */, | |
void * /* host_ptr */, | |
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_int CL_API_CALL | |
clEnqueueMarker(cl_command_queue /* command_queue */, | |
cl_event * /* event */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_int CL_API_CALL | |
clEnqueueWaitForEvents(cl_command_queue /* command_queue */, | |
cl_uint /* num_events */, | |
const cl_event * /* event_list */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_int CL_API_CALL | |
clEnqueueBarrier(cl_command_queue /* command_queue */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED cl_int CL_API_CALL | |
clUnloadCompiler(void) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY CL_EXT_PREFIX__VERSION_1_1_DEPRECATED void * CL_API_CALL | |
clGetExtensionFunctionAddress(const char * /* func_name */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __OPENCL_CL_H */ | |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/******************************************************************************* | |
* Copyright (c) 2008 - 2012 The Khronos Group Inc. | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining a | |
* copy of this software and/or associated documentation files (the | |
* "Materials"), to deal in the Materials without restriction, including | |
* without limitation the rights to use, copy, modify, merge, publish, | |
* distribute, sublicense, and/or sell copies of the Materials, and to | |
* permit persons to whom the Materials are furnished to do so, subject to | |
* the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be included | |
* in all copies or substantial portions of the Materials. | |
* | |
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. | |
******************************************************************************/ | |
#ifndef __CL_EXT_H | |
#define __CL_EXT_H | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
#include <stdarg.h> | |
#include <OpenCL/cl.h> | |
#include <AvailabilityMacros.h> | |
/* enum can be used if cl_khr_fp64 extension is supported by the OpenCL implementation. */ | |
#define CL_DEVICE_DOUBLE_FP_CONFIG 0x1032 | |
/* enum can be used if cl_khr_fp16 extension is supported by the OpenCL implementation. */ | |
#define CL_DEVICE_HALF_FP_CONFIG 0x1033 | |
/* | |
* Apple extensions: | |
* Apple has been allocated a block of identifiers starting at 0x10000000, and error codes in the range | |
* -1060 ... -1091. | |
*/ | |
/* Memory object destruction | |
* | |
* Apple extension for use to manage externally allocated buffers used with cl_mem objects with CL_MEM_USE_HOST_PTR | |
* | |
* Registers a user callback function that will be called when the memory object is deleted and its resources | |
* freed. Each call to clSetMemObjectCallbackFn registers the specified user callback function on a callback | |
* stack associated with memobj. The registered user callback functions are called in the reverse order in | |
* which they were registered. The user callback functions are called and then the memory object is deleted | |
* and its resources freed. This provides a mechanism for the application (and libraries) using memobj to be | |
* notified when the memory referenced by host_ptr, specified when the memory object is created and used as | |
* the storage bits for the memory object, can be reused or freed. | |
* | |
* The application may not call CL api's with the cl_mem object passed to the pfn_notify. | |
* | |
* Please check for the "cl_APPLE_SetMemObjectDestructor" extension using clGetDeviceInfo(CL_DEVICE_EXTENSIONS) | |
* before using. | |
* | |
* NOTE: This feature is a core feature in OpenCL 1.1. Please use clSetMemObjectDestructorCallback instead. | |
*/ | |
/* *** DEPRECATED! **** Please use the equivalent standard function clSetMemObjectDestructor instead. It was added in OpenCL 1.1. */ | |
cl_int clSetMemObjectDestructorAPPLE( cl_mem /* memobj */, | |
void (CL_CALLBACK * /*pfn_notify*/)( cl_mem /* memobj */, void* /*user_data*/), | |
void * /*user_data */ ) CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED; | |
/* Context Logging Functions | |
* | |
* The next three convenience functions are intended to be used as the pfn_notify parameter to clCreateContext(). | |
* Please check for the "cl_APPLE_ContextLoggingFunctions" extension using clGetDeviceInfo(CL_DEVICE_EXTENSIONS) | |
* before using. Note that if you pass NULL to the clCreateContext pfn_notify parameter, you can also use these | |
* by setting the CL_LOG_ERRORS environment variable to one of stdout, stderr, or console. Pass your own do-nothing | |
* context logging function to disable the CL_LOG_ERRORS override. | |
* | |
* clLogMessagesToSystemLog fowards on all log messages to the Apple System Logger | |
*/ | |
extern void clLogMessagesToSystemLogAPPLE( const char * /* errstr */, | |
const void * /* private_info */, | |
size_t /* cb */, | |
void * /* user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; | |
/* clLogMessagesToStdout sends all log messages to the file descriptor stdout */ | |
extern void clLogMessagesToStdoutAPPLE( const char * /* errstr */, | |
const void * /* private_info */, | |
size_t /* cb */, | |
void * /* user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; | |
/* clLogMessagesToStderr sends all log messages to the file descriptor stderr */ | |
extern void clLogMessagesToStderrAPPLE( const char * /* errstr */, | |
const void * /* private_info */, | |
size_t /* cb */, | |
void * /* user_data */ ) CL_EXT_SUFFIX__VERSION_1_0; | |
/* Extension: cl_APPLE_clut | |
* New APIs that allow apps to reduce the number of CL API calls they need to make | |
* to setup CL before a kernel can be enqueued for execution. | |
*/ | |
extern CL_API_ENTRY cl_int CL_API_CALL clCreateContextAndCommandQueueAPPLE( | |
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_command_queue_properties /* queue_properties */, | |
cl_context * /* context */, | |
cl_command_queue * /* queues */) CL_EXT_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL clCreateProgramAndKernelsWithSourceAPPLE( | |
cl_context /* context */, | |
cl_uint /* count */, | |
const char ** /* program_source_strings */, | |
const size_t * /* program_source_lengths */, | |
cl_uint /* num_devices */, | |
const cl_device_id * /* device_list */, | |
const char * /* options */, | |
cl_uint /* num_kernels */, | |
const char ** /* kernel_name_strings */, | |
cl_program * /* program */, | |
cl_kernel * /* kernels */) CL_EXT_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL clSetKernelArgsListAPPLE(cl_kernel /* kernel */, | |
cl_uint /* num_args */, | |
... ) CL_EXT_SUFFIX__VERSION_1_1; | |
extern CL_API_ENTRY cl_int CL_API_CALL clSetKernelArgsVaListAPPLE(cl_kernel /* kernel */, | |
cl_uint /* num_args */, | |
va_list /* argp */) CL_EXT_SUFFIX__VERSION_1_1; | |
#define CL_INVALID_ARG_NAME_APPLE -1060 | |
extern CL_API_ENTRY cl_int CL_API_CALL clSetKernelArgByNameAPPLE(cl_kernel /* kernel */, | |
const char * /* arg_name */, | |
size_t /* arg_size */, | |
const void * /* arg_value */) CL_EXT_SUFFIX__VERSION_1_1; | |
/* Extension: cl_APPLE_query_kernel_names | |
* | |
* These selectors may be passed to clGetProgramInfo to obtain information about the kernel functions in a cl_program. | |
* The cl_program must be successfully built with clBuildProgram for at least one device to succeed. Otherwise CL_INVALID_PROGRAM_EXECUTABLE is returned. | |
*/ | |
#define CL_PROGRAM_NUM_KERNELS_APPLE 0x10000004 /* Introduced in MacOS X.7. Returns a cl_uint for number of kernels in program. */ | |
#define CL_PROGRAM_KERNEL_NAMES_APPLE 0x10000005 /* Introduced in MacOS X.7. Returns a ';' delimited char[] containing the names of kernels in program */ | |
/* Extension: cl_APPLE_fixed_alpha_channel_orders | |
* | |
* These selectors may be passed to clCreateImage2D() in the cl_image_format.image_channel_order field. | |
* They are like CL_BGRA and CL_ARGB except that the alpha channel to be ignored. On calls to read_imagef, | |
* the alpha will be 0xff (1.0f) if the sample falls in the image and 0 if it does not fall in the image. | |
* On calls to write_imagef, the alpha value is ignored and 0xff (1.0f) is written. These formats are | |
* currently only available for the CL_UNORM_INT8 cl_channel_type. They are intended to support legacy | |
* image formats. | |
*/ | |
#define CL_1RGB_APPLE 0x10000006 /* Introduced in MacOS X.7. */ | |
#define CL_BGR1_APPLE 0x10000007 /* Introduced in MacOS X.7. */ | |
/* Extension: cl_APPLE_biased_fixed_point_image_formats | |
* | |
* This selector may be passed to clCreateImage2D() in the cl_image_format.image_channel_data_type field. | |
* It defines a biased signed 1.14 fixed point storage format, with range [-1, 3). The conversion from | |
* float to this fixed point format is defined as follows: | |
* | |
* ushort float_to_sfixed14( float x ){ | |
* int i = convert_int_sat_rte( x * 0x1.0p14f ); // scale [-1, 3.0) to [-16384, 3*16384), round to nearest integer | |
* i = add_sat( i, 0x4000 ); // apply bias, to convert to [0, 65535) range | |
* return convert_ushort_sat(i); // clamp to destination size | |
* } | |
* | |
* The inverse conversion is the reverse process. The formats are currently only available on the CPU with | |
* the CL_RGBA channel layout. | |
*/ | |
#define CL_SFIXED14_APPLE 0x10000008 /* Introduced in MacOS X.7. */ | |
#define CL_BIASED_HALF_APPLE 0x10000009 /* Introduced in MacOS X.7. */ | |
/* Extension: YUV image support | |
* | |
* These formats can only be used when creating images from YUV 4:2:2 IOSurface, using the | |
* clCreateImageFromIOSurface2DAPPLE() API. These formats are only available for the CL_UNORM_INT8, | |
* CL_UNSIGNED_INT8, and CL_SIGNED_INT8 cl_channel_type. | |
*/ | |
#define CL_YCbYCr_APPLE 0x10000010 /* Introduced in MacOS X.7. */ | |
#define CL_CbYCrY_APPLE 0x10000011 /* Introduced in MacOS X.7. */ | |
/* Extension: ABGR and xBGR formats for CoreImage CL-GPU support */ | |
#define CL_ABGR_APPLE 0x10000012 | |
/* Extension: cl_APPLE_fp64_ops | |
* | |
* This extension if enabled supports double-precision basic arithmetic operations (add, sub, mul, divide and sqrt) | |
* This is a subset of the cl_khr_fp64 extension defined in the OpenCL 1.1 and 1.2 specifications. | |
* The precision values for these basic operations are the same as defined by the cl_khr_fp64 extension | |
*/ | |
/* Extension: clCreateDAGAPPLE | |
* | |
* Create a DAG object which owns the individual program fragments (DAG nodes) | |
* used to create the final kernel. If the context is invalid, returns | |
* NULL for the dag. | |
*/ | |
typedef struct _cl_dag * cl_dag; | |
typedef int cl_dag_node; | |
cl_dag clCreateDAGAPPLE(cl_context c) CL_EXT_SUFFIX__VERSION_1_2; | |
/* Extension: clReleaseDAGAPPLE | |
* Release a DAG object used to create the final kernel | |
*/ | |
void clReleaseDAGAPPLE(cl_dag dag) CL_EXT_SUFFIX__VERSION_1_2; | |
/* Extension: clGetDAGNodeAPPLE | |
* For a given function 'f' created with clCreateDAGAPPLE(), set 0 or more | |
* arguments from args at their corresponding index in 'arg_indices'. For | |
* functions: | |
* | |
* void foo(float4, float4); | |
* float4 bar(float4); | |
* | |
* You can set either the 1st, 2nd, or both inputs to foo() with the output of | |
* bar() by passing the bar() cl_dag_node one or more times in args(). | |
* Argument indices which are unset by this function are required to be | |
* set by a clSetKernelArg() call on 'f' for each unset argument prior to | |
* clEnqueueNDRangeKernel() on the output of clCreateKernelFromDAGAPPLE(). | |
*/ | |
cl_dag_node clGetDAGNodeAPPLE(cl_dag d, cl_kernel f, cl_dag_node *args, | |
unsigned *arg_indices, unsigned nargs) CL_EXT_SUFFIX__VERSION_1_2; | |
/* Extension: clCreateKernelFromDAGAPPLE | |
* Given a DAG, ask CVMS to create a functional kernel from it. | |
*/ | |
cl_kernel clCreateKernelFromDAGAPPLE(cl_dag d, cl_uint n, | |
const cl_device_id *list) CL_EXT_SUFFIX__VERSION_1_2; | |
/* Extension: clCreateCommandQueueWithPropertiesAPPLE | |
* Create a command queue for the specified device. The properties array | |
* specifies a list of command queue property names and their corresponding | |
* values. Each property name is immediately followed by the corresponding | |
* value. The list is terminated with 0. | |
* | |
* List of supported properties are: | |
* | |
* CL_QUEUE_PROPERTIES cl_command_queue_properties bitfield | |
* ( CL_QUEUE_PROFILING_ENABLE, | |
* CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE) | |
* | |
* CL_COMMAND_QUEUE_PRIORITY_APPLE cl_queue_properties_APPLE | |
* ( CL_COMMAND_QUEUE_PRIORITY_DEFAULT_APPLE, | |
* CL_COMMAND_QUEUE_PRIORITY_BACKGROUND_APPLE ) | |
* | |
* These properties may only be used if the cl_APPLE_command_queue_priority is | |
* supported by the device. | |
* | |
* CL_COMMAND_QUEUE_NUM_COMPUTE_UNITS_APPLE int (value can be 1 .. CL_DEVICE_MAX_COMPUTE_UNITS). | |
* | |
* This property may only be used if the | |
* cl_APPLE_command_queue_select_compute_units extension is supported by the | |
* device. | |
*/ | |
#define cl_APPLE_command_queue_priority 1 | |
#define cl_APPLE_command_queue_select_compute_units 1 | |
typedef intptr_t cl_queue_properties_APPLE; | |
extern CL_API_ENTRY cl_command_queue CL_API_CALL | |
clCreateCommandQueueWithPropertiesAPPLE (cl_context /* context */, | |
cl_device_id /* device */, | |
const cl_queue_properties_APPLE * /* properties */, | |
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_2; | |
#define CL_QUEUE_PRIORITY_APPLE 0x10000013 | |
#define CL_QUEUE_NUM_COMPUTE_UNITS_APPLE 0x10000014 | |
#define CL_QUEUE_PRIORITY_BACKGROUND_APPLE 0x10000015 | |
#define CL_QUEUE_PRIORITY_DEFAULT_APPLE 0x10000016 | |
/* Application can pass context name in the property list when calling clCreateContext. | |
* This will let us do application specific "stuff" in framework. As an example | |
* CoreImage passes context name "CoreImage" and use it to perform flush right after | |
* clEnqueueNDRangeKernel when CoreImage enqueues a large kernel (in terms of number of global work items) | |
* on weak GPU because we know it improves performance to start large work on weak GPU right away | |
*/ | |
#define CL_OBJECT_NAME_APPLE 0x10000018 | |
/* | |
* Enums for CL_YCbCr formats | |
*/ | |
/* 64-bit (cl_ulong) IOKit registryID for this device. May be zero for pure software devices. */ | |
#define CL_DEVICE_REGISTRY_ID_APPLE 0x10000030 | |
/* cl_bool that reports whether this device is removable or not (eGPU) */ | |
#define CL_DEVICE_REMOVABLE_APPLE 0x10000031 | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __CL_EXT_H */ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/********************************************************************************** | |
* Copyright (c) 2008-2012 The Khronos Group Inc. | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining a | |
* copy of this software and/or associated documentation files (the | |
* "Materials"), to deal in the Materials without restriction, including | |
* without limitation the rights to use, copy, modify, merge, publish, | |
* distribute, sublicense, and/or sell copies of the Materials, and to | |
* permit persons to whom the Materials are furnished to do so, subject to | |
* the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be included | |
* in all copies or substantial portions of the Materials. | |
* | |
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. | |
**********************************************************************************/ | |
#ifndef __OPENCL_CL_GL_H | |
#define __OPENCL_CL_GL_H | |
#ifdef __APPLE__ | |
#include <OpenCL/cl.h> | |
#else | |
#include <CL/cl.h> | |
#endif | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
typedef cl_uint cl_gl_object_type; | |
typedef cl_uint cl_gl_texture_info; | |
typedef cl_uint cl_gl_platform_info; | |
typedef struct __GLsync *cl_GLsync; | |
/* cl_gl_object_type = 0x2000 - 0x200F enum values are currently taken */ | |
#define CL_GL_OBJECT_BUFFER 0x2000 | |
#define CL_GL_OBJECT_TEXTURE2D 0x2001 | |
#define CL_GL_OBJECT_TEXTURE3D 0x2002 | |
#define CL_GL_OBJECT_RENDERBUFFER 0x2003 | |
#define CL_GL_OBJECT_TEXTURE2D_ARRAY 0x200E | |
#define CL_GL_OBJECT_TEXTURE1D 0x200F | |
#define CL_GL_OBJECT_TEXTURE1D_ARRAY 0x2010 | |
#define CL_GL_OBJECT_TEXTURE_BUFFER 0x2011 | |
/* cl_gl_texture_info */ | |
#define CL_GL_TEXTURE_TARGET 0x2004 | |
#define CL_GL_MIPMAP_LEVEL 0x2005 | |
#define CL_GL_NUM_SAMPLES 0x2012 | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateFromGLBuffer(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
cl_GLuint /* bufobj */, | |
int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateFromGLTexture(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
cl_GLenum /* target */, | |
cl_GLint /* miplevel */, | |
cl_GLuint /* texture */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_2; | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateFromGLRenderbuffer(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
cl_GLuint /* renderbuffer */, | |
cl_int * /* errcode_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetGLObjectInfo(cl_mem /* memobj */, | |
cl_gl_object_type * /* gl_object_type */, | |
cl_GLuint * /* gl_object_name */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clGetGLTextureInfo(cl_mem /* memobj */, | |
cl_gl_texture_info /* param_name */, | |
size_t /* param_value_size */, | |
void * /* param_value */, | |
size_t * /* param_value_size_ret */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueAcquireGLObjects(cl_command_queue /* command_queue */, | |
cl_uint /* num_objects */, | |
const cl_mem * /* mem_objects */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_int CL_API_CALL | |
clEnqueueReleaseGLObjects(cl_command_queue /* command_queue */, | |
cl_uint /* num_objects */, | |
const cl_mem * /* mem_objects */, | |
cl_uint /* num_events_in_wait_list */, | |
const cl_event * /* event_wait_list */, | |
cl_event * /* event */) CL_API_SUFFIX__VERSION_1_0; | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateFromGLTexture2D(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
cl_GLenum /* target */, | |
cl_GLint /* miplevel */, | |
cl_GLuint /* texture */, | |
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
extern CL_API_ENTRY cl_mem CL_API_CALL | |
clCreateFromGLTexture3D(cl_context /* context */, | |
cl_mem_flags /* flags */, | |
cl_GLenum /* target */, | |
cl_GLint /* miplevel */, | |
cl_GLuint /* texture */, | |
cl_int * /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED; | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __OPENCL_CL_GL_H */ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/******************************************************************************* | |
* Copyright (c) 2008 - 2012 The Khronos Group Inc. | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining a | |
* copy of this software and/or associated documentation files (the | |
* "Materials"), to deal in the Materials without restriction, including | |
* without limitation the rights to use, copy, modify, merge, publish, | |
* distribute, sublicense, and/or sell copies of the Materials, and to | |
* permit persons to whom the Materials are furnished to do so, subject to | |
* the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be included | |
* in all copies or substantial portions of the Materials. | |
* | |
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. | |
******************************************************************************/ | |
#ifndef __OPENCL_CL_GL_EXT_H | |
#define __OPENCL_CL_GL_EXT_H | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
#include <OpenCL/cl_gl.h> | |
#include <OpenGL/CGLTypes.h> | |
#include <OpenGL/CGLDevice.h> | |
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#include <IOSurface/IOSurface.h> | |
#endif | |
/* Context GL sharing | |
* | |
* Please check for the "cl_APPLE_gl_sharing" extension using clGetDeviceInfo(CL_DEVICE_EXTENSIONS) | |
* before using these extensions. | |
* Apple extension for creating a CL context from a CGL share group | |
* | |
* This enumerated value can be specified as part of the <properties> argument passed to clCreateContext | |
* to allow OpenCL compliant devices in an existing CGL share group to be used as the devices in | |
* the newly created CL context. GL objects that were allocated in the given CGL share group can | |
* now be shared between CL and GL. | |
* | |
* If the <num_devices> and <devices> argument values to clCreateContext are 0 and NULL respectively, | |
* all CL compliant devices in the CGL share group will be used to create the context. | |
* Additional CL devices can also be specified using the <num_devices> and <devices> arguments. | |
* These, however, cannot be GPU devices. On Mac OS X, you can add the CPU to the list of CL devices | |
* (in addition to the CL compliant devices in the CGL share group) used to create the CL context. | |
* Note that if a CPU device is specified, the CGL share group must also include the GL float renderer; | |
* Otherwise CL_INVALID_DEVICE will be returned. | |
* | |
* NOTE: Make sure that appropriate cl_gl.h header file is included separately | |
*/ | |
#define CL_CONTEXT_PROPERTY_USE_CGL_SHAREGROUP_APPLE 0x10000000 /* Introduced in Mac OS X 10.6 */ | |
/* Apple extension for retrieving OpenGL context information for a CL context | |
* created via the above method. | |
* | |
* Provides a query mechanism to retrieve OpenGL context specific information | |
* from an OpenCL context to help identify device specific mappings and usage. | |
* | |
* For example, one possible usage would be to allow the client to map a CGL | |
* virtual screen index to an appropriate CL device id to insure that the | |
* rendering device and the compute device are the same, thus guaranteeing | |
* any shared OpenGL memory that is attached o a CL memory object remains | |
* resident on the active device. | |
*/ | |
cl_int clGetGLContextInfoAPPLE ( cl_context __nonnull /* context */, | |
void * __nonnull /* platform_gl_ctx */, | |
cl_gl_platform_info /* param_name */, | |
size_t /* param_value_size */, | |
void * __nullable /* param_value */, | |
size_t * __nullable /* param_value_size_ret */) CL_EXT_SUFFIX__VERSION_1_0; | |
/* The list of supported param_name values and the information returned in param_value by | |
* clGetContextInfo are listed below: | |
* Returns a cl_device_id for the CL device associated with the virtual screen for | |
* the given CGL context. Return type: cl_device_id | |
*/ | |
#define CL_CGL_DEVICE_FOR_CURRENT_VIRTUAL_SCREEN_APPLE 0x10000002 /* Introduced in Mac OS X 10.6 */ | |
/* Returns an array of cl_device_ids for the CL device(s) corresponding to | |
* the virtual screen(s) for the given CGL context. Return type: cl_device_id[] | |
*/ | |
#define CL_CGL_DEVICES_FOR_SUPPORTED_VIRTUAL_SCREENS_APPLE 0x10000003 /* Introduced in Mac OS X 10.6 */ | |
/* Error code returned by clGetGLContextInfoAPPLE if an invalid platform_gl_ctx is provided */ | |
#define CL_INVALID_GL_CONTEXT_APPLE -1000 /* Introduced in Mac OS X 10.6 */ | |
/* | |
* cl_khr_gl_event extension | |
* See section 9.9 in the OpenCL 1.1 spec for more information | |
*/ | |
#define CL_COMMAND_GL_FENCE_SYNC_OBJECT_KHR 0x200D | |
extern CL_API_ENTRY cl_event __nullable CL_API_CALL | |
clCreateEventFromGLsyncKHR(cl_context __nonnull /* context */, | |
cl_GLsync __nonnull /* cl_GLsync */, | |
cl_int * __nullable /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1; | |
#ifdef AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#if __has_feature(objc_class_property) | |
typedef struct __attribute__((objc_bridge(id))) __IOSurface *IOSurfaceRef __attribute__((swift_name("IOSurfaceRef"))); | |
#else | |
typedef struct __attribute__((objc_bridge(id))) __IOSurface *IOSurfaceRef; | |
#endif | |
#endif | |
cl_mem __nullable clCreateImageFromIOSurface2DAPPLE(cl_context __nonnull /* context */, | |
cl_mem_flags /* flags */, | |
const cl_image_format * __nonnull /* image_format */, | |
size_t /* image_width */, | |
size_t /* image_height */, | |
IOSurfaceRef __nonnull/* iosurface */, | |
cl_int * __nullable /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_1; | |
typedef intptr_t cl_iosurface_properties_APPLE; | |
/* Specifies the IOSurfaceRef used to create the cl_mem image object. */ | |
#define CL_IOSURFACE_REF_APPLE 0x10000019 /* Introduced in Mac OS X 10.9 */ | |
/* Specifies the plane of the IOSurface that the cl_mem should be bound. Default 0 */ | |
#define CL_IOSURFACE_PLANE_APPLE 0x1000001a /* Introduced in Mac OS X 10.9 */ | |
/* | |
* Create a 2D CL image from an IOSurface given a format, optional description, and property list. If | |
* the image_desc argument is NULL, the width and height of the IOSurfaceRef will be used. | |
*/ | |
cl_mem __nullable clCreateImageFromIOSurfaceWithPropertiesAPPLE(cl_context __nonnull /* context */, | |
cl_mem_flags /* flags */, | |
const cl_image_format * __nonnull /* image_format */, | |
const cl_image_desc * __nonnull /* image_desc */, | |
cl_iosurface_properties_APPLE * __nonnull /* properties */, | |
cl_int * __nullable /* errcode_ret */) CL_EXT_SUFFIX__VERSION_1_2; | |
/* Query parameter name for clGetImageInfo that returns the IOSurface backing the image (IOSurfaceRef) */ | |
#define CL_IMAGE_IOSURFACE_APPLE 0x1000001b /* Introduced in Mac OS X 10.9 */ | |
/* Query parameter name for clGetImageInfo that returns the plane of the IOSurface backing the image (cl_uint) */ | |
#define CL_IMAGE_IOSURFACE_PLANE_APPLE 0x1000001c /* Introduced in Mac OS X 10.9 */ | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __OPENCL_CL_GL_EXT_H */ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/********************************************************************************** | |
* Copyright (c) 2008-2012 The Khronos Group Inc. | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining a | |
* copy of this software and/or associated documentation files (the | |
* "Materials"), to deal in the Materials without restriction, including | |
* without limitation the rights to use, copy, modify, merge, publish, | |
* distribute, sublicense, and/or sell copies of the Materials, and to | |
* permit persons to whom the Materials are furnished to do so, subject to | |
* the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be included | |
* in all copies or substantial portions of the Materials. | |
* | |
* THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |
* MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. | |
**********************************************************************************/ | |
/* $Revision: 11803 $ on $Date: 2010-06-25 10:02:12 -0700 (Fri, 25 Jun 2010) $ */ | |
#ifndef __CL_PLATFORM_H | |
#define __CL_PLATFORM_H | |
#ifdef __APPLE__ | |
/* Contains #defines for AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER below */ | |
#include <AvailabilityMacros.h> | |
#endif | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
#if defined(_WIN32) | |
#define CL_API_ENTRY | |
#define CL_API_CALL __stdcall | |
#define CL_CALLBACK __stdcall | |
#else | |
#define CL_API_ENTRY | |
#define CL_API_CALL | |
#define CL_CALLBACK | |
#endif | |
#ifdef __APPLE__ | |
#define CL_EXTENSION_WEAK_LINK __attribute__((weak_import)) | |
#define CL_API_SUFFIX__VERSION_1_0 AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER | |
#define CL_EXT_SUFFIX__VERSION_1_0 CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER | |
#define CL_API_SUFFIX__VERSION_1_1 AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#define GCL_API_SUFFIX__VERSION_1_1 AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#define CL_EXT_SUFFIX__VERSION_1_1 CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED | |
#define CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_7 | |
#ifdef AVAILABLE_MAC_OS_X_VERSION_10_8_AND_LATER | |
#define CL_API_SUFFIX__VERSION_1_2 AVAILABLE_MAC_OS_X_VERSION_10_8_AND_LATER | |
#define GCL_API_SUFFIX__VERSION_1_2 AVAILABLE_MAC_OS_X_VERSION_10_8_AND_LATER | |
#define CL_EXT_SUFFIX__VERSION_1_2 CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_8_AND_LATER | |
#define CL_EXT_PREFIX__VERSION_1_1_DEPRECATED | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_8 | |
#else | |
#warning This path should never happen outside of internal operating system development. AvailabilityMacros do not function correctly here! | |
#define CL_API_SUFFIX__VERSION_1_2 AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#define GCL_API_SUFFIX__VERSION_1_2 AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#define CL_EXT_SUFFIX__VERSION_1_2 CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#define CL_EXT_PREFIX__VERSION_1_1_DEPRECATED | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED CL_EXTENSION_WEAK_LINK AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#endif | |
#else | |
#ifdef __GNUC__ | |
#ifdef CL_USE_DEPRECATED_OPENCL_1_0_APIS | |
#define CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED | |
#else | |
#define CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED __attribute__((deprecated)) | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED | |
#endif | |
#ifdef CL_USE_DEPRECATED_OPENCL_1_1_APIS | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED | |
#else | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED __attribute__((deprecated)) | |
#define CL_EXT_PREFIX__VERSION_1_1_DEPRECATED | |
#endif | |
#elif _WIN32 | |
#ifdef CL_USE_DEPRECATED_OPENCL_1_0_APIS | |
#define CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED | |
#else | |
#define CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED __declspec(deprecated) | |
#endif | |
#ifdef CL_USE_DEPRECATED_OPENCL_1_1_APIS | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_1_DEPRECATED | |
#else | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_1_DEPRECATED ___declspec(deprecated) | |
#endif | |
#else | |
#define CL_EXT_SUFFIX__VERSION_1_0_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_0_DEPRECATED | |
#define CL_EXT_SUFFIX__VERSION_1_1_DEPRECATED | |
#define CL_EXT_PREFIX__VERSION_1_1_DEPRECATED | |
#endif | |
#endif | |
#if (defined (_WIN32) && defined(_MSC_VER)) | |
/* scalar types */ | |
typedef signed __int8 cl_char; | |
typedef unsigned __int8 cl_uchar; | |
typedef signed __int16 cl_short; | |
typedef unsigned __int16 cl_ushort; | |
typedef signed __int32 cl_int; | |
typedef unsigned __int32 cl_uint; | |
typedef signed __int64 cl_long; | |
typedef unsigned __int64 cl_ulong; | |
typedef unsigned __int16 cl_half; | |
typedef float cl_float; | |
typedef double cl_double; | |
/* Macro names and corresponding values defined by OpenCL */ | |
#define CL_CHAR_BIT 8 | |
#define CL_SCHAR_MAX 127 | |
#define CL_SCHAR_MIN (-127-1) | |
#define CL_CHAR_MAX CL_SCHAR_MAX | |
#define CL_CHAR_MIN CL_SCHAR_MIN | |
#define CL_UCHAR_MAX 255 | |
#define CL_SHRT_MAX 32767 | |
#define CL_SHRT_MIN (-32767-1) | |
#define CL_USHRT_MAX 65535 | |
#define CL_INT_MAX 2147483647 | |
#define CL_INT_MIN (-2147483647-1) | |
#define CL_UINT_MAX 0xffffffffU | |
#define CL_LONG_MAX ((cl_long) 0x7FFFFFFFFFFFFFFFLL) | |
#define CL_LONG_MIN ((cl_long) -0x7FFFFFFFFFFFFFFFLL - 1LL) | |
#define CL_ULONG_MAX ((cl_ulong) 0xFFFFFFFFFFFFFFFFULL) | |
#define CL_FLT_DIG 6 | |
#define CL_FLT_MANT_DIG 24 | |
#define CL_FLT_MAX_10_EXP +38 | |
#define CL_FLT_MAX_EXP +128 | |
#define CL_FLT_MIN_10_EXP -37 | |
#define CL_FLT_MIN_EXP -125 | |
#define CL_FLT_RADIX 2 | |
#define CL_FLT_MAX 340282346638528859811704183484516925440.0f | |
#define CL_FLT_MIN 1.175494350822287507969e-38f | |
#define CL_FLT_EPSILON 0x1.0p-23f | |
#define CL_DBL_DIG 15 | |
#define CL_DBL_MANT_DIG 53 | |
#define CL_DBL_MAX_10_EXP +308 | |
#define CL_DBL_MAX_EXP +1024 | |
#define CL_DBL_MIN_10_EXP -307 | |
#define CL_DBL_MIN_EXP -1021 | |
#define CL_DBL_RADIX 2 | |
#define CL_DBL_MAX 179769313486231570814527423731704356798070567525844996598917476803157260780028538760589558632766878171540458953514382464234321326889464182768467546703537516986049910576551282076245490090389328944075868508455133942304583236903222948165808559332123348274797826204144723168738177180919299881250404026184124858368.0 | |
#define CL_DBL_MIN 2.225073858507201383090e-308 | |
#define CL_DBL_EPSILON 2.220446049250313080847e-16 | |
#define CL_M_E 2.718281828459045090796 | |
#define CL_M_LOG2E 1.442695040888963387005 | |
#define CL_M_LOG10E 0.434294481903251816668 | |
#define CL_M_LN2 0.693147180559945286227 | |
#define CL_M_LN10 2.302585092994045901094 | |
#define CL_M_PI 3.141592653589793115998 | |
#define CL_M_PI_2 1.570796326794896557999 | |
#define CL_M_PI_4 0.785398163397448278999 | |
#define CL_M_1_PI 0.318309886183790691216 | |
#define CL_M_2_PI 0.636619772367581382433 | |
#define CL_M_2_SQRTPI 1.128379167095512558561 | |
#define CL_M_SQRT2 1.414213562373095145475 | |
#define CL_M_SQRT1_2 0.707106781186547572737 | |
#define CL_M_E_F 2.71828174591064f | |
#define CL_M_LOG2E_F 1.44269502162933f | |
#define CL_M_LOG10E_F 0.43429449200630f | |
#define CL_M_LN2_F 0.69314718246460f | |
#define CL_M_LN10_F 2.30258512496948f | |
#define CL_M_PI_F 3.14159274101257f | |
#define CL_M_PI_2_F 1.57079637050629f | |
#define CL_M_PI_4_F 0.78539818525314f | |
#define CL_M_1_PI_F 0.31830987334251f | |
#define CL_M_2_PI_F 0.63661974668503f | |
#define CL_M_2_SQRTPI_F 1.12837922573090f | |
#define CL_M_SQRT2_F 1.41421353816986f | |
#define CL_M_SQRT1_2_F 0.70710676908493f | |
#define CL_NAN (CL_INFINITY - CL_INFINITY) | |
#define CL_HUGE_VALF ((cl_float) 1e50) | |
#define CL_HUGE_VAL ((cl_double) 1e500) | |
#define CL_MAXFLOAT CL_FLT_MAX | |
#define CL_INFINITY CL_HUGE_VALF | |
#else | |
#include <stdint.h> | |
/* scalar types */ | |
typedef int8_t cl_char; | |
typedef uint8_t cl_uchar; | |
typedef int16_t cl_short __attribute__((aligned(2))); | |
typedef uint16_t cl_ushort __attribute__((aligned(2))); | |
typedef int32_t cl_int __attribute__((aligned(4))); | |
typedef uint32_t cl_uint __attribute__((aligned(4))); | |
typedef int64_t cl_long __attribute__((aligned(8))); | |
typedef uint64_t cl_ulong __attribute__((aligned(8))); | |
typedef uint16_t cl_half __attribute__((aligned(2))); | |
typedef float cl_float __attribute__((aligned(4))); | |
typedef double cl_double __attribute__((aligned(8))); | |
/* Macro names and corresponding values defined by OpenCL */ | |
#define CL_CHAR_BIT 8 | |
#define CL_SCHAR_MAX 127 | |
#define CL_SCHAR_MIN (-127-1) | |
#define CL_CHAR_MAX CL_SCHAR_MAX | |
#define CL_CHAR_MIN CL_SCHAR_MIN | |
#define CL_UCHAR_MAX 255 | |
#define CL_SHRT_MAX 32767 | |
#define CL_SHRT_MIN (-32767-1) | |
#define CL_USHRT_MAX 65535 | |
#define CL_INT_MAX 2147483647 | |
#define CL_INT_MIN (-2147483647-1) | |
#define CL_UINT_MAX 0xffffffffU | |
#define CL_LONG_MAX ((cl_long) 0x7FFFFFFFFFFFFFFFLL) | |
#define CL_LONG_MIN ((cl_long) -0x7FFFFFFFFFFFFFFFLL - 1LL) | |
#define CL_ULONG_MAX ((cl_ulong) 0xFFFFFFFFFFFFFFFFULL) | |
#define CL_FLT_DIG 6 | |
#define CL_FLT_MANT_DIG 24 | |
#define CL_FLT_MAX_10_EXP +38 | |
#define CL_FLT_MAX_EXP +128 | |
#define CL_FLT_MIN_10_EXP -37 | |
#define CL_FLT_MIN_EXP -125 | |
#define CL_FLT_RADIX 2 | |
#define CL_FLT_MAX 0x1.fffffep127f | |
#define CL_FLT_MIN 0x1.0p-126f | |
#define CL_FLT_EPSILON 0x1.0p-23f | |
#define CL_DBL_DIG 15 | |
#define CL_DBL_MANT_DIG 53 | |
#define CL_DBL_MAX_10_EXP +308 | |
#define CL_DBL_MAX_EXP +1024 | |
#define CL_DBL_MIN_10_EXP -307 | |
#define CL_DBL_MIN_EXP -1021 | |
#define CL_DBL_RADIX 2 | |
#define CL_DBL_MAX 0x1.fffffffffffffp1023 | |
#define CL_DBL_MIN 0x1.0p-1022 | |
#define CL_DBL_EPSILON 0x1.0p-52 | |
#define CL_M_E 2.718281828459045090796 | |
#define CL_M_LOG2E 1.442695040888963387005 | |
#define CL_M_LOG10E 0.434294481903251816668 | |
#define CL_M_LN2 0.693147180559945286227 | |
#define CL_M_LN10 2.302585092994045901094 | |
#define CL_M_PI 3.141592653589793115998 | |
#define CL_M_PI_2 1.570796326794896557999 | |
#define CL_M_PI_4 0.785398163397448278999 | |
#define CL_M_1_PI 0.318309886183790691216 | |
#define CL_M_2_PI 0.636619772367581382433 | |
#define CL_M_2_SQRTPI 1.128379167095512558561 | |
#define CL_M_SQRT2 1.414213562373095145475 | |
#define CL_M_SQRT1_2 0.707106781186547572737 | |
#define CL_M_E_F 2.71828174591064f | |
#define CL_M_LOG2E_F 1.44269502162933f | |
#define CL_M_LOG10E_F 0.43429449200630f | |
#define CL_M_LN2_F 0.69314718246460f | |
#define CL_M_LN10_F 2.30258512496948f | |
#define CL_M_PI_F 3.14159274101257f | |
#define CL_M_PI_2_F 1.57079637050629f | |
#define CL_M_PI_4_F 0.78539818525314f | |
#define CL_M_1_PI_F 0.31830987334251f | |
#define CL_M_2_PI_F 0.63661974668503f | |
#define CL_M_2_SQRTPI_F 1.12837922573090f | |
#define CL_M_SQRT2_F 1.41421353816986f | |
#define CL_M_SQRT1_2_F 0.70710676908493f | |
#if defined( __GNUC__ ) | |
#define CL_HUGE_VALF __builtin_huge_valf() | |
#define CL_HUGE_VAL __builtin_huge_val() | |
#define CL_NAN __builtin_nanf( "" ) | |
#else | |
#define CL_HUGE_VALF ((cl_float) 1e50) | |
#define CL_HUGE_VAL ((cl_double) 1e500) | |
float nanf( const char * ); | |
#define CL_NAN nanf( "" ) | |
#endif | |
#define CL_MAXFLOAT CL_FLT_MAX | |
#define CL_INFINITY CL_HUGE_VALF | |
#endif | |
#include <stddef.h> | |
/* Mirror types to GL types. Mirror types allow us to avoid deciding which headers to load based on whether we are using GL or GLES here. */ | |
typedef unsigned int cl_GLuint; | |
typedef int cl_GLint; | |
typedef unsigned int cl_GLenum; | |
/* | |
* Vector types | |
* | |
* Note: OpenCL requires that all types be naturally aligned. | |
* This means that vector types must be naturally aligned. | |
* For example, a vector of four floats must be aligned to | |
* a 16 byte boundary (calculated as 4 * the natural 4-byte | |
* alignment of the float). The alignment qualifiers here | |
* will only function properly if your compiler supports them | |
* and if you don't actively work to defeat them. For example, | |
* in order for a cl_float4 to be 16 byte aligned in a struct, | |
* the start of the struct must itself be 16-byte aligned. | |
* | |
* Maintaining proper alignment is the user's responsibility. | |
*/ | |
/* Define basic vector types */ | |
#ifndef __has_feature // Optional of course. | |
#define __has_feature(x) 0 // Compatibility with non-clang compilers. | |
#endif | |
#ifndef __has_extension | |
#define __has_extension __has_feature // Compatibility with pre-3.0 compilers. | |
#endif | |
#if defined( __VEC__ ) | |
#include <altivec.h> /* may be omitted depending on compiler. AltiVec spec provides no way to detect whether the header is required. */ | |
typedef vector unsigned char __cl_uchar16; | |
typedef vector signed char __cl_char16; | |
typedef vector unsigned short __cl_ushort8; | |
typedef vector signed short __cl_short8; | |
typedef vector unsigned int __cl_uint4; | |
typedef vector signed int __cl_int4; | |
typedef vector float __cl_float4; | |
#define __CL_UCHAR16__ 1 | |
#define __CL_CHAR16__ 1 | |
#define __CL_USHORT8__ 1 | |
#define __CL_SHORT8__ 1 | |
#define __CL_UINT4__ 1 | |
#define __CL_INT4__ 1 | |
#define __CL_FLOAT4__ 1 | |
#endif | |
#if defined( __SSE__ ) | |
#if defined( __MINGW64__ ) | |
#include <intrin.h> | |
#else | |
#include <xmmintrin.h> | |
#endif | |
#if __has_extension(attribute_ext_vector_type) | |
typedef __attribute__((ext_vector_type(4))) float __cl_float4; | |
#elif defined( __GNUC__ ) | |
typedef __attribute__((vector_size(16))) float __cl_float4; | |
#else | |
typedef __m128 __cl_float4; | |
#endif | |
#define __CL_FLOAT4__ 1 | |
#endif | |
#if defined( __SSE2__ ) | |
#if defined( __MINGW64__ ) | |
#include <intrin.h> | |
#else | |
#include <emmintrin.h> | |
#endif | |
#if __has_extension(attribute_ext_vector_type) | |
typedef cl_uchar __attribute__((ext_vector_type(16))) __cl_uchar16; | |
typedef cl_char __attribute__((ext_vector_type(16))) __cl_char16; | |
typedef cl_ushort __attribute__((ext_vector_type(8))) __cl_ushort8; | |
typedef cl_short __attribute__((ext_vector_type(8))) __cl_short8; | |
typedef cl_uint __attribute__((ext_vector_type(4))) __cl_uint4; | |
typedef cl_int __attribute__((ext_vector_type(4))) __cl_int4; | |
typedef cl_ulong __attribute__((ext_vector_type(2))) __cl_ulong2; | |
typedef cl_long __attribute__((ext_vector_type(2))) __cl_long2; | |
typedef cl_double __attribute__((ext_vector_type(2))) __cl_double2; | |
#elif defined( __GNUC__ ) | |
typedef cl_uchar __attribute__((vector_size(16))) __cl_uchar16; | |
typedef cl_char __attribute__((vector_size(16))) __cl_char16; | |
typedef cl_ushort __attribute__((vector_size(16))) __cl_ushort8; | |
typedef cl_short __attribute__((vector_size(16))) __cl_short8; | |
typedef cl_uint __attribute__((vector_size(16))) __cl_uint4; | |
typedef cl_int __attribute__((vector_size(16))) __cl_int4; | |
typedef cl_ulong __attribute__((vector_size(16))) __cl_ulong2; | |
typedef cl_long __attribute__((vector_size(16))) __cl_long2; | |
typedef cl_double __attribute__((vector_size(16))) __cl_double2; | |
#else | |
typedef __m128i __cl_uchar16; | |
typedef __m128i __cl_char16; | |
typedef __m128i __cl_ushort8; | |
typedef __m128i __cl_short8; | |
typedef __m128i __cl_uint4; | |
typedef __m128i __cl_int4; | |
typedef __m128i __cl_ulong2; | |
typedef __m128i __cl_long2; | |
typedef __m128d __cl_double2; | |
#endif | |
#define __CL_UCHAR16__ 1 | |
#define __CL_CHAR16__ 1 | |
#define __CL_USHORT8__ 1 | |
#define __CL_SHORT8__ 1 | |
#define __CL_INT4__ 1 | |
#define __CL_UINT4__ 1 | |
#define __CL_ULONG2__ 1 | |
#define __CL_LONG2__ 1 | |
#define __CL_DOUBLE2__ 1 | |
#endif | |
#if defined( __MMX__ ) | |
#include <mmintrin.h> | |
#if __has_extension(attribute_ext_vector_type) | |
typedef cl_uchar __attribute__((ext_vector_type(8))) __cl_uchar8; | |
typedef cl_char __attribute__((ext_vector_type(8))) __cl_char8 ; | |
typedef cl_ushort __attribute__((ext_vector_type(4))) __cl_ushort4 ; | |
typedef cl_short __attribute__((ext_vector_type(4))) __cl_short4; | |
typedef cl_uint __attribute__((ext_vector_type(2))) __cl_uint2; | |
typedef cl_int __attribute__((ext_vector_type(2))) __cl_int2; | |
typedef cl_ulong __attribute__((ext_vector_type(1))) __cl_ulong1; | |
typedef cl_long __attribute__((ext_vector_type(1))) __cl_long1; | |
#elif defined( __GNUC__ ) | |
typedef cl_uchar __attribute__((vector_size(8))) __cl_uchar8; | |
typedef cl_char __attribute__((vector_size(8))) __cl_char8; | |
typedef cl_ushort __attribute__((vector_size(8))) __cl_ushort4; | |
typedef cl_short __attribute__((vector_size(8))) __cl_short4; | |
typedef cl_uint __attribute__((vector_size(8))) __cl_uint2; | |
typedef cl_int __attribute__((vector_size(8))) __cl_int2; | |
typedef cl_ulong __attribute__((vector_size(8))) __cl_ulong1; | |
typedef cl_long __attribute__((vector_size(8))) __cl_long1; | |
#else | |
typedef __m64 __cl_uchar8; | |
typedef __m64 __cl_char8; | |
typedef __m64 __cl_ushort4; | |
typedef __m64 __cl_short4; | |
typedef __m64 __cl_uint2; | |
typedef __m64 __cl_int2; | |
typedef __m64 __cl_ulong1; | |
typedef __m64 __cl_long1; | |
#endif | |
#define __CL_UCHAR8__ 1 | |
#define __CL_CHAR8__ 1 | |
#define __CL_USHORT4__ 1 | |
#define __CL_SHORT4__ 1 | |
#define __CL_INT2__ 1 | |
#define __CL_UINT2__ 1 | |
#define __CL_ULONG1__ 1 | |
#define __CL_LONG1__ 1 | |
#endif | |
#if defined( __AVX__ ) | |
#if defined( __MINGW64__ ) | |
#include <intrin.h> | |
#else | |
#include <immintrin.h> | |
#endif | |
#if __has_extension(attribute_ext_vector_type) | |
typedef cl_float __attribute__((ext_vector_type(8))) __cl_float8; | |
typedef cl_double __attribute__((ext_vector_type(4))) __cl_double4; | |
#elif defined( __GNUC__ ) | |
typedef cl_float __attribute__((vector_size(32))) __cl_float8; | |
typedef cl_double __attribute__((vector_size(32))) __cl_double4; | |
#else | |
typedef __m256 __cl_float8; | |
typedef __m256d __cl_double4; | |
#endif | |
#define __CL_FLOAT8__ 1 | |
#define __CL_DOUBLE4__ 1 | |
#endif | |
#if defined( __AVX2__ ) | |
#if defined( __MINGW64__ ) | |
#include <intrin.h> | |
#else | |
#include <immintrin.h> | |
#endif | |
#if __has_extension(attribute_ext_vector_type) | |
typedef cl_ushort __attribute__((ext_vector_type(16))) __cl_ushort16; | |
typedef cl_short __attribute__((ext_vector_type(16))) __cl_short16; | |
typedef cl_uint __attribute__((ext_vector_type(8))) __cl_uint8; | |
typedef cl_int __attribute__((ext_vector_type(8))) __cl_int8; | |
typedef cl_uint __attribute__((ext_vector_type(4))) __cl_ulong4; | |
typedef cl_int __attribute__((ext_vector_type(4))) __cl_long4; | |
#elif defined( __GNUC__ ) | |
typedef cl_ushort __attribute__((vector_size(32))) __cl_ushort16; | |
typedef cl_short __attribute__((vector_size(32))) __cl_short16; | |
typedef cl_uint __attribute__((vector_size(32))) __cl_uint8; | |
typedef cl_int __attribute__((vector_size(32))) __cl_int8; | |
typedef cl_uint __attribute__((vector_size(32))) __cl_ulong4; | |
typedef cl_int __attribute__((vector_size(32))) __cl_long4; | |
#else | |
typedef __m256i __cl_ushort16; | |
typedef __m256i __cl_short16; | |
typedef __m256i __cl_uint8; | |
typedef __m256i __cl_int8; | |
typedef __m256i __cl_ulong4; | |
typedef __m256i __cl_long4; | |
#endif | |
#define __CL_USHORT16__ 1 | |
#define __CL_SHORT16__ 1 | |
#define __CL_UINT8__ 1 | |
#define __CL_INT8__ 1 | |
#define __CL_ULONG4__ 1 | |
#define __CL_LONG4__ 1 | |
#endif | |
/* Define alignment keys */ | |
#if defined( __GNUC__ ) | |
#define CL_ALIGNED(_x) __attribute__ ((aligned(_x))) | |
#elif defined( _WIN32) && (_MSC_VER) | |
/* Alignment keys neutered on windows because MSVC can't swallow function arguments with alignment requirements */ | |
/* http://msdn.microsoft.com/en-us/library/373ak2y1%28VS.71%29.aspx */ | |
/* #include <crtdefs.h> */ | |
/* #define CL_ALIGNED(_x) _CRT_ALIGN(_x) */ | |
#define CL_ALIGNED(_x) | |
#else | |
#warning Need to implement some method to align data here | |
#define CL_ALIGNED(_x) | |
#endif | |
/* Indicate whether .xyzw, .s0123 and .hi.lo are supported */ | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
/* .xyzw and .s0123...{f|F} are supported */ | |
#define CL_HAS_NAMED_VECTOR_FIELDS 1 | |
/* .hi and .lo are supported */ | |
#define CL_HAS_HI_LO_VECTOR_FIELDS 1 | |
#endif | |
/* Define cl_vector types */ | |
/* ---- cl_charn ---- */ | |
typedef union | |
{ | |
cl_char CL_ALIGNED(2) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_char x, y; }; | |
__extension__ struct{ cl_char s0, s1; }; | |
__extension__ struct{ cl_char lo, hi; }; | |
#endif | |
#if defined( __CL_CHAR2__) | |
__cl_char2 v2; | |
#endif | |
}cl_char2; | |
typedef union | |
{ | |
cl_char CL_ALIGNED(4) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_char x, y, z, w; }; | |
__extension__ struct{ cl_char s0, s1, s2, s3; }; | |
__extension__ struct{ cl_char2 lo, hi; }; | |
#endif | |
#if defined( __CL_CHAR2__) | |
__cl_char2 v2[2]; | |
#endif | |
#if defined( __CL_CHAR4__) | |
__cl_char4 v4; | |
#endif | |
}cl_char4; | |
/* cl_char3 is identical in size, alignment and behavior to cl_char4. See section 6.1.5. */ | |
typedef cl_char4 cl_char3; | |
typedef union | |
{ | |
cl_char CL_ALIGNED(8) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_char x, y, z, w; }; | |
__extension__ struct{ cl_char s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_char4 lo, hi; }; | |
#endif | |
#if defined( __CL_CHAR2__) | |
__cl_char2 v2[4]; | |
#endif | |
#if defined( __CL_CHAR4__) | |
__cl_char4 v4[2]; | |
#endif | |
#if defined( __CL_CHAR8__ ) | |
__cl_char8 v8; | |
#endif | |
}cl_char8; | |
typedef union | |
{ | |
cl_char CL_ALIGNED(16) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_char x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_char s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_char8 lo, hi; }; | |
#endif | |
#if defined( __CL_CHAR2__) | |
__cl_char2 v2[8]; | |
#endif | |
#if defined( __CL_CHAR4__) | |
__cl_char4 v4[4]; | |
#endif | |
#if defined( __CL_CHAR8__ ) | |
__cl_char8 v8[2]; | |
#endif | |
#if defined( __CL_CHAR16__ ) | |
__cl_char16 v16; | |
#endif | |
}cl_char16; | |
/* ---- cl_ucharn ---- */ | |
typedef union | |
{ | |
cl_uchar CL_ALIGNED(2) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uchar x, y; }; | |
__extension__ struct{ cl_uchar s0, s1; }; | |
__extension__ struct{ cl_uchar lo, hi; }; | |
#endif | |
#if defined( __cl_uchar2__) | |
__cl_uchar2 v2; | |
#endif | |
}cl_uchar2; | |
typedef union | |
{ | |
cl_uchar CL_ALIGNED(4) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uchar x, y, z, w; }; | |
__extension__ struct{ cl_uchar s0, s1, s2, s3; }; | |
__extension__ struct{ cl_uchar2 lo, hi; }; | |
#endif | |
#if defined( __CL_UCHAR2__) | |
__cl_uchar2 v2[2]; | |
#endif | |
#if defined( __CL_UCHAR4__) | |
__cl_uchar4 v4; | |
#endif | |
}cl_uchar4; | |
/* cl_uchar3 is identical in size, alignment and behavior to cl_uchar4. See section 6.1.5. */ | |
typedef cl_uchar4 cl_uchar3; | |
typedef union | |
{ | |
cl_uchar CL_ALIGNED(8) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uchar x, y, z, w; }; | |
__extension__ struct{ cl_uchar s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_uchar4 lo, hi; }; | |
#endif | |
#if defined( __CL_UCHAR2__) | |
__cl_uchar2 v2[4]; | |
#endif | |
#if defined( __CL_UCHAR4__) | |
__cl_uchar4 v4[2]; | |
#endif | |
#if defined( __CL_UCHAR8__ ) | |
__cl_uchar8 v8; | |
#endif | |
}cl_uchar8; | |
typedef union | |
{ | |
cl_uchar CL_ALIGNED(16) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uchar x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_uchar s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_uchar8 lo, hi; }; | |
#endif | |
#if defined( __CL_UCHAR2__) | |
__cl_uchar2 v2[8]; | |
#endif | |
#if defined( __CL_UCHAR4__) | |
__cl_uchar4 v4[4]; | |
#endif | |
#if defined( __CL_UCHAR8__ ) | |
__cl_uchar8 v8[2]; | |
#endif | |
#if defined( __CL_UCHAR16__ ) | |
__cl_uchar16 v16; | |
#endif | |
}cl_uchar16; | |
/* ---- cl_shortn ---- */ | |
typedef union | |
{ | |
cl_short CL_ALIGNED(4) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_short x, y; }; | |
__extension__ struct{ cl_short s0, s1; }; | |
__extension__ struct{ cl_short lo, hi; }; | |
#endif | |
#if defined( __CL_SHORT2__) | |
__cl_short2 v2; | |
#endif | |
}cl_short2; | |
typedef union | |
{ | |
cl_short CL_ALIGNED(8) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_short x, y, z, w; }; | |
__extension__ struct{ cl_short s0, s1, s2, s3; }; | |
__extension__ struct{ cl_short2 lo, hi; }; | |
#endif | |
#if defined( __CL_SHORT2__) | |
__cl_short2 v2[2]; | |
#endif | |
#if defined( __CL_SHORT4__) | |
__cl_short4 v4; | |
#endif | |
}cl_short4; | |
/* cl_short3 is identical in size, alignment and behavior to cl_short4. See section 6.1.5. */ | |
typedef cl_short4 cl_short3; | |
typedef union | |
{ | |
cl_short CL_ALIGNED(16) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_short x, y, z, w; }; | |
__extension__ struct{ cl_short s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_short4 lo, hi; }; | |
#endif | |
#if defined( __CL_SHORT2__) | |
__cl_short2 v2[4]; | |
#endif | |
#if defined( __CL_SHORT4__) | |
__cl_short4 v4[2]; | |
#endif | |
#if defined( __CL_SHORT8__ ) | |
__cl_short8 v8; | |
#endif | |
}cl_short8; | |
typedef union | |
{ | |
cl_short CL_ALIGNED(32) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_short x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_short s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_short8 lo, hi; }; | |
#endif | |
#if defined( __CL_SHORT2__) | |
__cl_short2 v2[8]; | |
#endif | |
#if defined( __CL_SHORT4__) | |
__cl_short4 v4[4]; | |
#endif | |
#if defined( __CL_SHORT8__ ) | |
__cl_short8 v8[2]; | |
#endif | |
#if defined( __CL_SHORT16__ ) | |
__cl_short16 v16; | |
#endif | |
}cl_short16; | |
/* ---- cl_ushortn ---- */ | |
typedef union | |
{ | |
cl_ushort CL_ALIGNED(4) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ushort x, y; }; | |
__extension__ struct{ cl_ushort s0, s1; }; | |
__extension__ struct{ cl_ushort lo, hi; }; | |
#endif | |
#if defined( __CL_USHORT2__) | |
__cl_ushort2 v2; | |
#endif | |
}cl_ushort2; | |
typedef union | |
{ | |
cl_ushort CL_ALIGNED(8) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ushort x, y, z, w; }; | |
__extension__ struct{ cl_ushort s0, s1, s2, s3; }; | |
__extension__ struct{ cl_ushort2 lo, hi; }; | |
#endif | |
#if defined( __CL_USHORT2__) | |
__cl_ushort2 v2[2]; | |
#endif | |
#if defined( __CL_USHORT4__) | |
__cl_ushort4 v4; | |
#endif | |
}cl_ushort4; | |
/* cl_ushort3 is identical in size, alignment and behavior to cl_ushort4. See section 6.1.5. */ | |
typedef cl_ushort4 cl_ushort3; | |
typedef union | |
{ | |
cl_ushort CL_ALIGNED(16) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ushort x, y, z, w; }; | |
__extension__ struct{ cl_ushort s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_ushort4 lo, hi; }; | |
#endif | |
#if defined( __CL_USHORT2__) | |
__cl_ushort2 v2[4]; | |
#endif | |
#if defined( __CL_USHORT4__) | |
__cl_ushort4 v4[2]; | |
#endif | |
#if defined( __CL_USHORT8__ ) | |
__cl_ushort8 v8; | |
#endif | |
}cl_ushort8; | |
typedef union | |
{ | |
cl_ushort CL_ALIGNED(32) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ushort x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_ushort s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_ushort8 lo, hi; }; | |
#endif | |
#if defined( __CL_USHORT2__) | |
__cl_ushort2 v2[8]; | |
#endif | |
#if defined( __CL_USHORT4__) | |
__cl_ushort4 v4[4]; | |
#endif | |
#if defined( __CL_USHORT8__ ) | |
__cl_ushort8 v8[2]; | |
#endif | |
#if defined( __CL_USHORT16__ ) | |
__cl_ushort16 v16; | |
#endif | |
}cl_ushort16; | |
/* ---- cl_intn ---- */ | |
typedef union | |
{ | |
cl_int CL_ALIGNED(8) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_int x, y; }; | |
__extension__ struct{ cl_int s0, s1; }; | |
__extension__ struct{ cl_int lo, hi; }; | |
#endif | |
#if defined( __CL_INT2__) | |
__cl_int2 v2; | |
#endif | |
}cl_int2; | |
typedef union | |
{ | |
cl_int CL_ALIGNED(16) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_int x, y, z, w; }; | |
__extension__ struct{ cl_int s0, s1, s2, s3; }; | |
__extension__ struct{ cl_int2 lo, hi; }; | |
#endif | |
#if defined( __CL_INT2__) | |
__cl_int2 v2[2]; | |
#endif | |
#if defined( __CL_INT4__) | |
__cl_int4 v4; | |
#endif | |
}cl_int4; | |
/* cl_int3 is identical in size, alignment and behavior to cl_int4. See section 6.1.5. */ | |
typedef cl_int4 cl_int3; | |
typedef union | |
{ | |
cl_int CL_ALIGNED(32) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_int x, y, z, w; }; | |
__extension__ struct{ cl_int s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_int4 lo, hi; }; | |
#endif | |
#if defined( __CL_INT2__) | |
__cl_int2 v2[4]; | |
#endif | |
#if defined( __CL_INT4__) | |
__cl_int4 v4[2]; | |
#endif | |
#if defined( __CL_INT8__ ) | |
__cl_int8 v8; | |
#endif | |
}cl_int8; | |
typedef union | |
{ | |
cl_int CL_ALIGNED(64) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_int x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_int s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_int8 lo, hi; }; | |
#endif | |
#if defined( __CL_INT2__) | |
__cl_int2 v2[8]; | |
#endif | |
#if defined( __CL_INT4__) | |
__cl_int4 v4[4]; | |
#endif | |
#if defined( __CL_INT8__ ) | |
__cl_int8 v8[2]; | |
#endif | |
#if defined( __CL_INT16__ ) | |
__cl_int16 v16; | |
#endif | |
}cl_int16; | |
/* ---- cl_uintn ---- */ | |
typedef union | |
{ | |
cl_uint CL_ALIGNED(8) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uint x, y; }; | |
__extension__ struct{ cl_uint s0, s1; }; | |
__extension__ struct{ cl_uint lo, hi; }; | |
#endif | |
#if defined( __CL_UINT2__) | |
__cl_uint2 v2; | |
#endif | |
}cl_uint2; | |
typedef union | |
{ | |
cl_uint CL_ALIGNED(16) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uint x, y, z, w; }; | |
__extension__ struct{ cl_uint s0, s1, s2, s3; }; | |
__extension__ struct{ cl_uint2 lo, hi; }; | |
#endif | |
#if defined( __CL_UINT2__) | |
__cl_uint2 v2[2]; | |
#endif | |
#if defined( __CL_UINT4__) | |
__cl_uint4 v4; | |
#endif | |
}cl_uint4; | |
/* cl_uint3 is identical in size, alignment and behavior to cl_uint4. See section 6.1.5. */ | |
typedef cl_uint4 cl_uint3; | |
typedef union | |
{ | |
cl_uint CL_ALIGNED(32) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uint x, y, z, w; }; | |
__extension__ struct{ cl_uint s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_uint4 lo, hi; }; | |
#endif | |
#if defined( __CL_UINT2__) | |
__cl_uint2 v2[4]; | |
#endif | |
#if defined( __CL_UINT4__) | |
__cl_uint4 v4[2]; | |
#endif | |
#if defined( __CL_UINT8__ ) | |
__cl_uint8 v8; | |
#endif | |
}cl_uint8; | |
typedef union | |
{ | |
cl_uint CL_ALIGNED(64) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_uint x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_uint s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_uint8 lo, hi; }; | |
#endif | |
#if defined( __CL_UINT2__) | |
__cl_uint2 v2[8]; | |
#endif | |
#if defined( __CL_UINT4__) | |
__cl_uint4 v4[4]; | |
#endif | |
#if defined( __CL_UINT8__ ) | |
__cl_uint8 v8[2]; | |
#endif | |
#if defined( __CL_UINT16__ ) | |
__cl_uint16 v16; | |
#endif | |
}cl_uint16; | |
/* ---- cl_longn ---- */ | |
typedef union | |
{ | |
cl_long CL_ALIGNED(16) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_long x, y; }; | |
__extension__ struct{ cl_long s0, s1; }; | |
__extension__ struct{ cl_long lo, hi; }; | |
#endif | |
#if defined( __CL_LONG2__) | |
__cl_long2 v2; | |
#endif | |
}cl_long2; | |
typedef union | |
{ | |
cl_long CL_ALIGNED(32) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_long x, y, z, w; }; | |
__extension__ struct{ cl_long s0, s1, s2, s3; }; | |
__extension__ struct{ cl_long2 lo, hi; }; | |
#endif | |
#if defined( __CL_LONG2__) | |
__cl_long2 v2[2]; | |
#endif | |
#if defined( __CL_LONG4__) | |
__cl_long4 v4; | |
#endif | |
}cl_long4; | |
/* cl_long3 is identical in size, alignment and behavior to cl_long4. See section 6.1.5. */ | |
typedef cl_long4 cl_long3; | |
typedef union | |
{ | |
cl_long CL_ALIGNED(64) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_long x, y, z, w; }; | |
__extension__ struct{ cl_long s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_long4 lo, hi; }; | |
#endif | |
#if defined( __CL_LONG2__) | |
__cl_long2 v2[4]; | |
#endif | |
#if defined( __CL_LONG4__) | |
__cl_long4 v4[2]; | |
#endif | |
#if defined( __CL_LONG8__ ) | |
__cl_long8 v8; | |
#endif | |
}cl_long8; | |
typedef union | |
{ | |
cl_long CL_ALIGNED(128) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_long x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_long s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_long8 lo, hi; }; | |
#endif | |
#if defined( __CL_LONG2__) | |
__cl_long2 v2[8]; | |
#endif | |
#if defined( __CL_LONG4__) | |
__cl_long4 v4[4]; | |
#endif | |
#if defined( __CL_LONG8__ ) | |
__cl_long8 v8[2]; | |
#endif | |
#if defined( __CL_LONG16__ ) | |
__cl_long16 v16; | |
#endif | |
}cl_long16; | |
/* ---- cl_ulongn ---- */ | |
typedef union | |
{ | |
cl_ulong CL_ALIGNED(16) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ulong x, y; }; | |
__extension__ struct{ cl_ulong s0, s1; }; | |
__extension__ struct{ cl_ulong lo, hi; }; | |
#endif | |
#if defined( __CL_ULONG2__) | |
__cl_ulong2 v2; | |
#endif | |
}cl_ulong2; | |
typedef union | |
{ | |
cl_ulong CL_ALIGNED(32) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ulong x, y, z, w; }; | |
__extension__ struct{ cl_ulong s0, s1, s2, s3; }; | |
__extension__ struct{ cl_ulong2 lo, hi; }; | |
#endif | |
#if defined( __CL_ULONG2__) | |
__cl_ulong2 v2[2]; | |
#endif | |
#if defined( __CL_ULONG4__) | |
__cl_ulong4 v4; | |
#endif | |
}cl_ulong4; | |
/* cl_ulong3 is identical in size, alignment and behavior to cl_ulong4. See section 6.1.5. */ | |
typedef cl_ulong4 cl_ulong3; | |
typedef union | |
{ | |
cl_ulong CL_ALIGNED(64) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ulong x, y, z, w; }; | |
__extension__ struct{ cl_ulong s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_ulong4 lo, hi; }; | |
#endif | |
#if defined( __CL_ULONG2__) | |
__cl_ulong2 v2[4]; | |
#endif | |
#if defined( __CL_ULONG4__) | |
__cl_ulong4 v4[2]; | |
#endif | |
#if defined( __CL_ULONG8__ ) | |
__cl_ulong8 v8; | |
#endif | |
}cl_ulong8; | |
typedef union | |
{ | |
cl_ulong CL_ALIGNED(128) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_ulong x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_ulong s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_ulong8 lo, hi; }; | |
#endif | |
#if defined( __CL_ULONG2__) | |
__cl_ulong2 v2[8]; | |
#endif | |
#if defined( __CL_ULONG4__) | |
__cl_ulong4 v4[4]; | |
#endif | |
#if defined( __CL_ULONG8__ ) | |
__cl_ulong8 v8[2]; | |
#endif | |
#if defined( __CL_ULONG16__ ) | |
__cl_ulong16 v16; | |
#endif | |
}cl_ulong16; | |
/* --- cl_floatn ---- */ | |
typedef union | |
{ | |
cl_float CL_ALIGNED(8) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_float x, y; }; | |
__extension__ struct{ cl_float s0, s1; }; | |
__extension__ struct{ cl_float lo, hi; }; | |
#endif | |
#if defined( __CL_FLOAT2__) | |
__cl_float2 v2; | |
#endif | |
}cl_float2; | |
typedef union | |
{ | |
cl_float CL_ALIGNED(16) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_float x, y, z, w; }; | |
__extension__ struct{ cl_float s0, s1, s2, s3; }; | |
__extension__ struct{ cl_float2 lo, hi; }; | |
#endif | |
#if defined( __CL_FLOAT2__) | |
__cl_float2 v2[2]; | |
#endif | |
#if defined( __CL_FLOAT4__) | |
__cl_float4 v4; | |
#endif | |
}cl_float4; | |
/* cl_float3 is identical in size, alignment and behavior to cl_float4. See section 6.1.5. */ | |
typedef cl_float4 cl_float3; | |
typedef union | |
{ | |
cl_float CL_ALIGNED(32) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_float x, y, z, w; }; | |
__extension__ struct{ cl_float s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_float4 lo, hi; }; | |
#endif | |
#if defined( __CL_FLOAT2__) | |
__cl_float2 v2[4]; | |
#endif | |
#if defined( __CL_FLOAT4__) | |
__cl_float4 v4[2]; | |
#endif | |
#if defined( __CL_FLOAT8__ ) | |
__cl_float8 v8; | |
#endif | |
}cl_float8; | |
typedef union | |
{ | |
cl_float CL_ALIGNED(64) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_float x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_float s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_float8 lo, hi; }; | |
#endif | |
#if defined( __CL_FLOAT2__) | |
__cl_float2 v2[8]; | |
#endif | |
#if defined( __CL_FLOAT4__) | |
__cl_float4 v4[4]; | |
#endif | |
#if defined( __CL_FLOAT8__ ) | |
__cl_float8 v8[2]; | |
#endif | |
#if defined( __CL_FLOAT16__ ) | |
__cl_float16 v16; | |
#endif | |
}cl_float16; | |
/* --- cl_doublen ---- */ | |
typedef union | |
{ | |
cl_double CL_ALIGNED(16) s[2]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_double x, y; }; | |
__extension__ struct{ cl_double s0, s1; }; | |
__extension__ struct{ cl_double lo, hi; }; | |
#endif | |
#if defined( __CL_DOUBLE2__) | |
__cl_double2 v2; | |
#endif | |
}cl_double2; | |
typedef union | |
{ | |
cl_double CL_ALIGNED(32) s[4]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_double x, y, z, w; }; | |
__extension__ struct{ cl_double s0, s1, s2, s3; }; | |
__extension__ struct{ cl_double2 lo, hi; }; | |
#endif | |
#if defined( __CL_DOUBLE2__) | |
__cl_double2 v2[2]; | |
#endif | |
#if defined( __CL_DOUBLE4__) | |
__cl_double4 v4; | |
#endif | |
}cl_double4; | |
/* cl_double3 is identical in size, alignment and behavior to cl_double4. See section 6.1.5. */ | |
typedef cl_double4 cl_double3; | |
typedef union | |
{ | |
cl_double CL_ALIGNED(64) s[8]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_double x, y, z, w; }; | |
__extension__ struct{ cl_double s0, s1, s2, s3, s4, s5, s6, s7; }; | |
__extension__ struct{ cl_double4 lo, hi; }; | |
#endif | |
#if defined( __CL_DOUBLE2__) | |
__cl_double2 v2[4]; | |
#endif | |
#if defined( __CL_DOUBLE4__) | |
__cl_double4 v4[2]; | |
#endif | |
#if defined( __CL_DOUBLE8__ ) | |
__cl_double8 v8; | |
#endif | |
}cl_double8; | |
typedef union | |
{ | |
cl_double CL_ALIGNED(128) s[16]; | |
#if defined( __GNUC__) && ! defined( __STRICT_ANSI__ ) | |
__extension__ struct{ cl_double x, y, z, w, __spacer4, __spacer5, __spacer6, __spacer7, __spacer8, __spacer9, sa, sb, sc, sd, se, sf; }; | |
__extension__ struct{ cl_double s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, sA, sB, sC, sD, sE, sF; }; | |
__extension__ struct{ cl_double8 lo, hi; }; | |
#endif | |
#if defined( __CL_DOUBLE2__) | |
__cl_double2 v2[8]; | |
#endif | |
#if defined( __CL_DOUBLE4__) | |
__cl_double4 v4[4]; | |
#endif | |
#if defined( __CL_DOUBLE8__ ) | |
__cl_double8 v8[2]; | |
#endif | |
#if defined( __CL_DOUBLE16__ ) | |
__cl_double16 v16; | |
#endif | |
}cl_double16; | |
/* Macro to facilitate debugging | |
* Usage: | |
* Place CL_PROGRAM_STRING_DEBUG_INFO on the line before the first line of your source. | |
* The first line ends with: CL_PROGRAM_STRING_DEBUG_INFO \" | |
* Each line thereafter of OpenCL C source must end with: \n\ | |
* The last line ends in "; | |
* | |
* Example: | |
* | |
* const char *my_program = CL_PROGRAM_STRING_DEBUG_INFO "\ | |
* kernel void foo( int a, float * b ) \n\ | |
* { \n\ | |
* // my comment \n\ | |
* *b[ get_global_id(0)] = a; \n\ | |
* } \n\ | |
* "; | |
* | |
* This should correctly set up the line, (column) and file information for your source | |
* string so you can do source level debugging. | |
*/ | |
#define __CL_STRINGIFY( _x ) # _x | |
#define _CL_STRINGIFY( _x ) __CL_STRINGIFY( _x ) | |
#define CL_PROGRAM_STRING_DEBUG_INFO "#line " _CL_STRINGIFY(__LINE__) " \"" __FILE__ "\" \n\n" | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __CL_PLATFORM_H */ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/******************************************************************************* | |
* Copyright: (c) 2010-2012 by Apple, Inc., All Rights Reserved. | |
******************************************************************************/ | |
#ifndef __GCL_H | |
#define __GCL_H | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
#include <stdarg.h> | |
#include <stdint.h> | |
#include <AvailabilityMacros.h> | |
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_7_AND_LATER | |
#include <IOSurface/IOSurface.h> | |
#endif | |
#include <OpenGL/gltypes.h> | |
#include <OpenCL/opencl.h> | |
#include <dispatch/dispatch.h> | |
typedef struct _cl_ndrange { | |
size_t work_dim; | |
size_t global_work_offset[3]; | |
size_t global_work_size[3]; | |
size_t local_work_size[3]; | |
} cl_ndrange; | |
typedef cl_mem cl_image; | |
typedef uint64_t cl_timer; | |
typedef uintptr_t sampler_t; | |
typedef cl_bitfield cl_queue_flags; | |
typedef cl_bitfield cl_malloc_flags; | |
typedef cl_mem_object_type cl_image_type; | |
#define CL_IMAGE_2D CL_MEM_OBJECT_IMAGE2D | |
#define CL_IMAGE_3D CL_MEM_OBJECT_IMAGE3D | |
#define CL_DISPATCH_QUEUE_PRIORITY_DEFAULT ((cl_ulong)1 << 59) | |
#define CL_DISPATCH_QUEUE_PRIORITY_BACKGROUND ((cl_ulong)1 << 60) | |
#define CL_DISPATCH_QUEUE_PRIORITY_HIGH ((cl_ulong)1 << 62) | |
#define CL_DISPATCH_QUEUE_PRIORITY_LOW ((cl_ulong)1 << 63) | |
#define CL_DEVICE_TYPE_USE_ID ((cl_ulong)1 << 61) | |
typedef enum clk_sampler_type | |
{ | |
__CLK_ADDRESS_BASE = 0, | |
CLK_ADDRESS_NONE = 0 << __CLK_ADDRESS_BASE, | |
CLK_ADDRESS_CLAMP = 1 << __CLK_ADDRESS_BASE, | |
CLK_ADDRESS_CLAMP_TO_EDGE = 2 << __CLK_ADDRESS_BASE, | |
CLK_ADDRESS_REPEAT = 3 << __CLK_ADDRESS_BASE, | |
CLK_ADDRESS_MIRRORED_REPEAT = 4 << __CLK_ADDRESS_BASE, | |
__CLK_ADDRESS_MASK = CLK_ADDRESS_NONE | CLK_ADDRESS_CLAMP | CLK_ADDRESS_CLAMP_TO_EDGE | CLK_ADDRESS_REPEAT | CLK_ADDRESS_MIRRORED_REPEAT, | |
__CLK_ADDRESS_BITS = 3, // number of bits required to represent address info | |
__CLK_NORMALIZED_BASE = __CLK_ADDRESS_BITS, | |
CLK_NORMALIZED_COORDS_FALSE = 0, | |
CLK_NORMALIZED_COORDS_TRUE = 1 << __CLK_NORMALIZED_BASE, | |
__CLK_NORMALIZED_MASK = CLK_NORMALIZED_COORDS_FALSE | CLK_NORMALIZED_COORDS_TRUE, | |
__CLK_NORMALIZED_BITS = 1, // number of bits required to represent normalization | |
__CLK_FILTER_BASE = __CLK_NORMALIZED_BASE + __CLK_NORMALIZED_BITS, | |
CLK_FILTER_NEAREST = 0 << __CLK_FILTER_BASE, | |
CLK_FILTER_LINEAR = 1 << __CLK_FILTER_BASE, | |
__CLK_FILTER_MASK = CLK_FILTER_NEAREST | CLK_FILTER_LINEAR, | |
__CLK_FILTER_BITS = 2 // number of bits required to represent address info | |
} clk_sampler_type; | |
//************************************************************************************************************************ | |
// create a dispatch queue for an OpenCL device | |
// | |
// gcl_queue_flags can be a combination of the following | |
// CL_DEVICE_TYPE_GPU, CL_DEVICE_TYPE_CPU or CL_DEVICE_TYPE_USE_DEVICE_ID | |
// CL_CONCURRENT_QUEUE (only allowed for the CPU device) | |
// CL_QUEUE_PRIORITY_LOW (default), CL_QUEUE_PRIORITY_DEFAULT or CL_QUEUE_PRIORITY_HIGH | |
//************************************************************************************************************************ | |
#ifdef AVAILABLE_MAC_OS_X_VERSION_10_8_AND_LATER | |
DISPATCH_RETURNS_RETAINED | |
#endif | |
extern dispatch_queue_t __nullable gcl_create_dispatch_queue(cl_queue_flags flags, | |
cl_device_id __nullable device_id) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following APIs describe how to create OpenCL memory objects | |
//************************************************************************************************************************ | |
//************************************************************************************************************************ | |
// gcl_malloc() allocates a buffer object. The void * value returned is a memory object handle. The void * value returned | |
// cannot be used to directly access the memory region on the host CPU. To access this memory region for reading and | |
// writing on the host CPU, use APIs such as gcl_memcpy that can be passed in a blocks to GCD APIs that queue tasks for | |
// dispatch. | |
// | |
// flags can be 0, CL_MEM_USE_HOST_PTR, or CL_MEM_COPY_HOST_PTR. | |
//************************************************************************************************************************ | |
extern void * __nullable gcl_malloc(size_t bytes, | |
void * __nullable host_ptr, | |
cl_malloc_flags flags) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_free(void * __nonnull ptr) GCL_API_SUFFIX__VERSION_1_1; | |
//********************************************************************************************************************************** | |
// gcl_create_image() creates a 2D image (depth = 1) or a 3D image (depth > 1). | |
// This API can also be used to create an image from an IOSurfaceRef. | |
// A cl_image is equivalent to the cl_mem object returned by clCreateImage{2D|3D} and can be used by both GCL and OpenCL APIs. | |
//********************************************************************************************************************************** | |
extern cl_image __nullable gcl_create_image(const cl_image_format * __nonnull image_format, | |
size_t image_width, | |
size_t image_height, | |
size_t image_depth, | |
IOSurfaceRef __nullable io_surface) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_retain_image(cl_image __nonnull image) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_release_image(cl_image __nonnull image) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// gcl_get_supported_image_formats() queries the image formats supported by the OpenCL device specified by device_id. | |
// image_type can be CL_MEM_OBJECT_IMAGE2D, or CL_MEM_OBJECT_IMAGE3D. num_entries describes the number of image_formats | |
// available in image_formats, and num_image_formats, if not NULL, contains the number of formats returned by OpenCL. | |
// Note that a post-return num_image_formats == 0 indicates that an error occurred. | |
//************************************************************************************************************************ | |
extern void gcl_get_supported_image_formats(cl_device_id __nonnull device_id, | |
cl_image_type image_type, | |
unsigned int num_entries, | |
cl_image_format * __nonnull image_formats, | |
unsigned int * __nullable num_image_formats) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following APIs are OpenCL commands that can be passed in a block(s) to the GCD APIs that queue tasks for dispatch | |
// such as dispatch_async. These commands are equivalent to the corresponding clEnqueue* API calls except that we can now | |
// queue these commands directly to a dispatch queue instead of a CL command-queue. | |
//************************************************************************************************************************ | |
extern void gcl_memcpy(void * __nonnull dst, | |
const void * __nonnull src, | |
size_t size) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_memcpy_rect(void * __nonnull dst, | |
const void * __nonnull src, | |
const size_t dst_origin[3], | |
const size_t src_origin[3], | |
const size_t region[3], | |
size_t dst_row_pitch, | |
size_t dst_slice_pitch, | |
size_t src_row_pitch, | |
size_t src_slice_pitch) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_copy_image(cl_image __nonnull dst_image, | |
cl_image __nonnull src_image, | |
const size_t dst_origin[3], | |
const size_t src_origin[3], | |
const size_t region[3]) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_copy_ptr_to_image(cl_mem __nonnull dst_image, | |
void * __nonnull src_ptr, | |
const size_t dst_origin[3], | |
const size_t region[3]) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_copy_image_to_ptr(void * __nonnull dst_ptr, | |
cl_image __nonnull src_image, | |
const size_t src_origin[3], | |
const size_t region[3]) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following map functions allow you to map a region of the buffer or image into the host address space | |
// for reading and/or writing. | |
//************************************************************************************************************************ | |
extern void * __nullable gcl_map_ptr(void * __nonnull ptr, | |
cl_map_flags map_flags, | |
size_t cb) GCL_API_SUFFIX__VERSION_1_1; | |
extern void * __nullable gcl_map_image(cl_image __nonnull image, | |
cl_map_flags map_flags, | |
const size_t origin[3], | |
const size_t region[3]) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_unmap(void * __nonnull) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// gcl_create_kernel_from_block() is required to query the work-group size to use in cl_ndrange.local_work_size. | |
// This is needed to ensure good performance across GPUs as the work-group sizes vary across GPUs. | |
//************************************************************************************************************************ | |
extern cl_kernel __nullable gcl_create_kernel_from_block(void * __nonnull kernel_block_ptr) GCL_API_SUFFIX__VERSION_1_1; | |
extern void gcl_get_kernel_block_workgroup_info(void * __nonnull kernel_block_ptr, | |
cl_kernel_work_group_info param_name, | |
size_t param_value_size, | |
void * __nonnull param_value, | |
size_t *__nullable param_value_size_ret) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// gcl_get_device_id_with_dispatch_queue() returns the cl_device_id. This can then be used to query device information | |
// using the clGetDeviceInfo OpenCL API. | |
//************************************************************************************************************************ | |
extern cl_device_id __nullable gcl_get_device_id_with_dispatch_queue(dispatch_queue_t __nonnull queue) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// gcl_set_finalizer() sets the finalizer function for any objects created by gcl_malloc or gcl_create_*** | |
// APIs (such as gcl_create_image) | |
//************************************************************************************************************************ | |
extern void gcl_set_finalizer(void * __nonnull object, | |
void (* __nonnull cl_pfn_finalizer)(void * __nonnull object, void * __nullable user_data), | |
void * __nullable user_data) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following APIs allows you to measure the time it takes to execute a set of CL commands in a block | |
// gcl_start_timer starts the timer. gcl_stop_timer will return the time elapsed in seconds. | |
//************************************************************************************************************************ | |
extern cl_timer gcl_start_timer(void) GCL_API_SUFFIX__VERSION_1_1; | |
extern double gcl_stop_timer(cl_timer t) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// Create a buffer cl_mem object from ptr returned by gcl_malloc. This cl_mem object can be used by CL API calls and enables | |
// sharing of objects between GCL and the OpenCL API. The cl_mem object references the data store associated with | |
// ptr. The cl_mem objects created using gcl_create_buffer_from_ptr must be released before ptr is freed using gcl_free. | |
//************************************************************************************************************************ | |
extern cl_mem __nullable gcl_create_buffer_from_ptr(void * __nonnull ptr) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following APIs implement sharing of OpenGL vertex buffer, texture and renderbuffer objects with OpenCL. | |
// | |
// A cl_image is equivalent to the cl_mem object returned by clCreateFromGLTexture{2D|3D} or clCreateFromGLRenderbuffer | |
// and can be used by both GCL and OpenCL APIs. | |
//************************************************************************************************************************ | |
extern void * __nullable gcl_gl_create_ptr_from_buffer(GLuint bufobj) GCL_API_SUFFIX__VERSION_1_1; | |
extern cl_image __nullable gcl_gl_create_image_from_texture(GLenum texture_target, | |
GLint mip_level, | |
GLuint texture) GCL_API_SUFFIX__VERSION_1_1; | |
extern cl_image __nullable gcl_gl_create_image_from_renderbuffer(GLuint render_buffer) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following APIs passed in a block(s) to a dispatch queue implement synchronization of commands between OpenGL and OpenCL. | |
//************************************************************************************************************************ | |
//************************************************************************************************************************ | |
// gcl_set_gl_sharegroup() specifies the GL ShareGroup used to create the GCL context. | |
// share is a sharegroup. This API must be called first before any other GCL API calls. | |
// This associates a GL sharegroup that is used to allocate objects (in CL and/or GL) and to enable CL / GL sharing. | |
// | |
// The sharegroup can only be specified once. | |
//************************************************************************************************************************ | |
extern void gcl_gl_set_sharegroup(void* __nonnull share) GCL_API_SUFFIX__VERSION_1_1; | |
//************************************************************************************************************************ | |
// The following APIs allow the OpenCL objects underlying the GCL implementation to be obtained for interoperation | |
// with legacy applications and libraries | |
//************************************************************************************************************************ | |
//************************************************************************************************************************ | |
// gcl_get_context() returns the cl_context used by all GCL dispatch queues. The context may not be retained or released. | |
//************************************************************************************************************************ | |
extern cl_context __nullable gcl_get_context(void) GCL_API_SUFFIX__VERSION_1_1; | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __GCL_H */ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
//****************************************************************************** | |
// Copyright: (c) 2010-2012 by Apple, Inc., All Rights Reserved. | |
//*****************************************************************************/ | |
#ifndef __GRANDCL_PRIV_H | |
#define __GRANDCL_PRIV_H | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
#include <OpenCL/opencl.h> | |
// Internal type used to map blocks to kernels | |
typedef struct { | |
void *block_ptr; // block pointer | |
cl_kernel kernel; // associated kernel | |
} block_kernel_pair; | |
typedef struct block_kernel_map { | |
cl_program program; | |
const size_t num_kernels; | |
void (*initBlocks)(void); | |
block_kernel_pair *map; | |
} block_kernel_map; | |
// Table of block_kernel_map | |
typedef struct block_kernel_map_table { | |
block_kernel_map** table; | |
size_t size; | |
size_t capacity; | |
} block_kernel_map_table; | |
// Structure to hold setting arguments | |
typedef struct kargs_struct { | |
cl_bitfield *arg_flags; | |
size_t *arg_sizes; | |
void **arg_values; | |
} kargs_struct; | |
// Logging functions for situations that do and do not involve an underlying | |
// OpenCL error | |
void gcl_log_warning( const char* fmt, ... ); | |
void gcl_log_error( const char* fmt, ... ); | |
void gcl_log_fatal( const char* fmt, ... ) __attribute__((noreturn)); | |
void gcl_log_cl_error( int err, const char* fmt, ... ); | |
void gcl_log_cl_fatal( int err, const char* fmt, ... ); | |
// Helper function to create and initialize and delete setting arguments | |
// in a kernel | |
void gclCreateArgsAPPLE(cl_kernel k, kargs_struct *args); | |
void gclDeleteArgsAPPLE(cl_kernel k, kargs_struct *args); | |
// Helper function used to set a by value argument on a kernel. | |
int gclSetKernelArgAPPLE(cl_kernel k, cl_uint arg_index, | |
size_t arg_size, const void *arg_value, | |
kargs_struct* args); | |
// Helper function used to set a cl_mem kernel argument. | |
int gclSetKernelArgMemAPPLE(cl_kernel k, cl_uint arg_index, | |
const void *arg_value, | |
kargs_struct* args); | |
// Helper function used to set a sampler_t kernel argument | |
int gclSetKernelArgSamplerAPPLE(cl_kernel k, cl_uint arg_index, | |
const void *arg_value, | |
kargs_struct* args, cl_sampler* sampler); | |
int gclReleaseSampler(cl_sampler sampler); | |
// Helper function to execute the kernel | |
int gclExecKernelAPPLE(cl_kernel k, const cl_ndrange *ndrange, | |
kargs_struct* args); | |
// Helper function to build program | |
int gclBuildProgramAPPLE(char* filename, block_kernel_map *map); | |
// Helper function to build a kernel using a portable binary where filename | |
// is the relative path from the app to the file (without the suffix). | |
int gclBuildProgramBinaryAPPLE(const char* filename, const char* bundle_id, | |
block_kernel_map *map, const char* build_opts); | |
// Helper function to register a block_kernel_map to the framework | |
void gclRegisterBlockKernelMap(block_kernel_map* map); | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif // __GRANDCL_PRIV_H |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/******************************************************************************* | |
* Copyright: (c) 2007-2012 by Apple, Inc., All Rights Reserved. | |
******************************************************************************/ | |
#ifndef __OPENCL_H | |
#define __OPENCL_H | |
#ifdef __cplusplus | |
extern "C" { | |
#endif | |
#include <OpenCL/cl.h> | |
#include <OpenCL/cl_gl.h> | |
#include <OpenCL/cl_gl_ext.h> | |
#include <OpenCL/cl_ext.h> | |
#include <OpenCL/gcl.h> | |
#ifdef __cplusplus | |
} | |
#endif | |
#endif /* __OPENCL_H */ | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment