Edit

kc3-lang/angle/src/libGLESv2/cl_stubs.cpp

Branch :

  • Show log

    Commit

  • Author : John Plate
    Date : 2021-05-14 21:55:52
    Hash : a7ae63e4
    Message : CL: Move object cast from entry points to stubs and front end Move the OpenCl object cast from the generated entry points to the stubs and front end, to make it possible to properly use static_cast. This removes the limitation that the front end objects have to be standard layout (and makes it possible to use virtual functions), which is consistent with other front end objects. Move the back end initialization from the stubs to the entry point functions, which fixes a bug where the back ends were not initialized during validation. Move more code from the stubs to the front end, to keep the stubs light. Remove unused function `default_return_value` from `generate_entry_points.py`. Bug: angleproject:5904 Change-Id: Id999ad6c537888017bf3252c6f6e088b7d4c7984 Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/2897245 Commit-Queue: John Plate <jplate@google.com> Reviewed-by: Jamie Madill <jmadill@chromium.org> Reviewed-by: Cody Northrop <cnorthrop@google.com>

  • src/libGLESv2/cl_stubs.cpp
  • //
    // Copyright 2021 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    // cl_stubs.cpp: Stubs for CL entry points.
    
    #include "libGLESv2/cl_stubs_autogen.h"
    
    #include "libGLESv2/proc_table_cl.h"
    
    #include "libANGLE/CLDevice.h"
    #include "libANGLE/CLPlatform.h"
    
    #define WARN_NOT_SUPPORTED(command)                                         \
        do                                                                      \
        {                                                                       \
            static bool sWarned = false;                                        \
            if (!sWarned)                                                       \
            {                                                                   \
                sWarned = true;                                                 \
                WARN() << "OpenCL command " #command " is not (yet) supported"; \
            }                                                                   \
        } while (0)
    
    namespace cl
    {
    
    cl_int IcdGetPlatformIDsKHR(cl_uint num_entries, cl_platform_id *platforms, cl_uint *num_platforms)
    {
        return Platform::GetPlatformIDs(num_entries, platforms, num_platforms);
    }
    
    cl_int GetPlatformIDs(cl_uint num_entries, cl_platform_id *platforms, cl_uint *num_platforms)
    {
        return Platform::GetPlatformIDs(num_entries, platforms, num_platforms);
    }
    
    cl_int GetPlatformInfo(cl_platform_id platform,
                           PlatformInfo param_name,
                           size_t param_value_size,
                           void *param_value,
                           size_t *param_value_size_ret)
    {
        return Platform::CastOrDefault(platform)->getInfo(param_name, param_value_size, param_value,
                                                          param_value_size_ret);
    }
    
    cl_int GetDeviceIDs(cl_platform_id platform,
                        cl_device_type device_type,
                        cl_uint num_entries,
                        cl_device_id *devices,
                        cl_uint *num_devices)
    {
        return Platform::CastOrDefault(platform)->getDeviceIDs(device_type, num_entries, devices,
                                                               num_devices);
    }
    
    cl_int GetDeviceInfo(cl_device_id device,
                         DeviceInfo param_name,
                         size_t param_value_size,
                         void *param_value,
                         size_t *param_value_size_ret)
    {
        return static_cast<Device *>(device)->getInfo(param_name, param_value_size, param_value,
                                                      param_value_size_ret);
    }
    
    cl_int CreateSubDevices(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)
    {
        return static_cast<Device *>(in_device)->createSubDevices(properties, num_devices, out_devices,
                                                                  num_devices_ret);
    }
    
    cl_int RetainDevice(cl_device_id device)
    {
        static_cast<Device *>(device)->retain();
        return CL_SUCCESS;
    }
    
    cl_int ReleaseDevice(cl_device_id device)
    {
        static_cast<Device *>(device)->release();
        return CL_SUCCESS;
    }
    
    cl_int SetDefaultDeviceCommandQueue(cl_context context,
                                        cl_device_id device,
                                        cl_command_queue command_queue)
    {
        WARN_NOT_SUPPORTED(SetDefaultDeviceCommandQueue);
        return 0;
    }
    
    cl_int GetDeviceAndHostTimer(cl_device_id device,
                                 cl_ulong *device_timestamp,
                                 cl_ulong *host_timestamp)
    {
        WARN_NOT_SUPPORTED(GetDeviceAndHostTimer);
        return 0;
    }
    
    cl_int GetHostTimer(cl_device_id device, cl_ulong *host_timestamp)
    {
        WARN_NOT_SUPPORTED(GetHostTimer);
        return 0;
    }
    
    cl_context CreateContext(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_int *errcode_ret)
    {
        return Platform::CreateContext(properties, num_devices, devices, pfn_notify, user_data,
                                       errcode_ret);
    }
    
    cl_context CreateContextFromType(const cl_context_properties *properties,
                                     cl_device_type device_type,
                                     void(CL_CALLBACK *pfn_notify)(const char *errinfo,
                                                                   const void *private_info,
                                                                   size_t cb,
                                                                   void *user_data),
                                     void *user_data,
                                     cl_int *errcode_ret)
    {
        return Platform::CreateContextFromType(properties, device_type, pfn_notify, user_data,
                                               errcode_ret);
    }
    
    cl_int RetainContext(cl_context context)
    {
        static_cast<Context *>(context)->retain();
        return CL_SUCCESS;
    }
    
    cl_int ReleaseContext(cl_context context)
    {
        static_cast<Context *>(context)->release();
        return CL_SUCCESS;
    }
    
    cl_int GetContextInfo(cl_context context,
                          ContextInfo param_name,
                          size_t param_value_size,
                          void *param_value,
                          size_t *param_value_size_ret)
    {
        return static_cast<Context *>(context)->getInfo(param_name, param_value_size, param_value,
                                                        param_value_size_ret);
    }
    
    cl_int SetContextDestructorCallback(cl_context context,
                                        void(CL_CALLBACK *pfn_notify)(cl_context context,
                                                                      void *user_data),
                                        void *user_data)
    {
        WARN_NOT_SUPPORTED(SetContextDestructorCallback);
        return 0;
    }
    
    cl_command_queue CreateCommandQueueWithProperties(cl_context context,
                                                      cl_device_id device,
                                                      const cl_queue_properties *properties,
                                                      cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateCommandQueueWithProperties);
        return 0;
    }
    
    cl_int RetainCommandQueue(cl_command_queue command_queue)
    {
        WARN_NOT_SUPPORTED(RetainCommandQueue);
        return 0;
    }
    
    cl_int ReleaseCommandQueue(cl_command_queue command_queue)
    {
        WARN_NOT_SUPPORTED(ReleaseCommandQueue);
        return 0;
    }
    
    cl_int GetCommandQueueInfo(cl_command_queue command_queue,
                               CommandQueueInfo param_name,
                               size_t param_value_size,
                               void *param_value,
                               size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetCommandQueueInfo);
        return 0;
    }
    
    cl_mem CreateBuffer(cl_context context,
                        cl_mem_flags flags,
                        size_t size,
                        void *host_ptr,
                        cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateBuffer);
        return 0;
    }
    
    cl_mem CreateBufferWithProperties(cl_context context,
                                      const cl_mem_properties *properties,
                                      cl_mem_flags flags,
                                      size_t size,
                                      void *host_ptr,
                                      cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateBufferWithProperties);
        return 0;
    }
    
    cl_mem CreateSubBuffer(cl_mem buffer,
                           cl_mem_flags flags,
                           cl_buffer_create_type buffer_create_type,
                           const void *buffer_create_info,
                           cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateSubBuffer);
        return 0;
    }
    
    cl_mem CreateImage(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)
    {
        WARN_NOT_SUPPORTED(CreateImage);
        return 0;
    }
    
    cl_mem CreateImageWithProperties(cl_context context,
                                     const cl_mem_properties *properties,
                                     cl_mem_flags flags,
                                     const cl_image_format *image_format,
                                     const cl_image_desc *image_desc,
                                     void *host_ptr,
                                     cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateImageWithProperties);
        return 0;
    }
    
    cl_mem CreatePipe(cl_context context,
                      cl_mem_flags flags,
                      cl_uint pipe_packet_size,
                      cl_uint pipe_max_packets,
                      const cl_pipe_properties *properties,
                      cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreatePipe);
        return 0;
    }
    
    cl_int RetainMemObject(cl_mem memobj)
    {
        WARN_NOT_SUPPORTED(RetainMemObject);
        return 0;
    }
    
    cl_int ReleaseMemObject(cl_mem memobj)
    {
        WARN_NOT_SUPPORTED(ReleaseMemObject);
        return 0;
    }
    
    cl_int GetSupportedImageFormats(cl_context context,
                                    cl_mem_flags flags,
                                    MemObjectType image_type,
                                    cl_uint num_entries,
                                    cl_image_format *image_formats,
                                    cl_uint *num_image_formats)
    {
        WARN_NOT_SUPPORTED(GetSupportedImageFormats);
        return 0;
    }
    
    cl_int GetMemObjectInfo(cl_mem memobj,
                            MemInfo param_name,
                            size_t param_value_size,
                            void *param_value,
                            size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetMemObjectInfo);
        return 0;
    }
    
    cl_int GetImageInfo(cl_mem image,
                        ImageInfo param_name,
                        size_t param_value_size,
                        void *param_value,
                        size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetImageInfo);
        return 0;
    }
    
    cl_int GetPipeInfo(cl_mem pipe,
                       PipeInfo param_name,
                       size_t param_value_size,
                       void *param_value,
                       size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetPipeInfo);
        return 0;
    }
    
    cl_int SetMemObjectDestructorCallback(cl_mem memobj,
                                          void(CL_CALLBACK *pfn_notify)(cl_mem memobj, void *user_data),
                                          void *user_data)
    {
        WARN_NOT_SUPPORTED(SetMemObjectDestructorCallback);
        return 0;
    }
    
    void *SVMAlloc(cl_context context, cl_svm_mem_flags flags, size_t size, cl_uint alignment)
    {
        WARN_NOT_SUPPORTED(SVMAlloc);
        return 0;
    }
    
    void SVMFree(cl_context context, void *svm_pointer)
    {
        WARN_NOT_SUPPORTED(SVMFree);
    }
    
    cl_sampler CreateSamplerWithProperties(cl_context context,
                                           const cl_sampler_properties *sampler_properties,
                                           cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateSamplerWithProperties);
        return 0;
    }
    
    cl_int RetainSampler(cl_sampler sampler)
    {
        WARN_NOT_SUPPORTED(RetainSampler);
        return 0;
    }
    
    cl_int ReleaseSampler(cl_sampler sampler)
    {
        WARN_NOT_SUPPORTED(ReleaseSampler);
        return 0;
    }
    
    cl_int GetSamplerInfo(cl_sampler sampler,
                          SamplerInfo param_name,
                          size_t param_value_size,
                          void *param_value,
                          size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetSamplerInfo);
        return 0;
    }
    
    cl_program CreateProgramWithSource(cl_context context,
                                       cl_uint count,
                                       const char **strings,
                                       const size_t *lengths,
                                       cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateProgramWithSource);
        return 0;
    }
    
    cl_program CreateProgramWithBinary(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)
    {
        WARN_NOT_SUPPORTED(CreateProgramWithBinary);
        return 0;
    }
    
    cl_program CreateProgramWithBuiltInKernels(cl_context context,
                                               cl_uint num_devices,
                                               const cl_device_id *device_list,
                                               const char *kernel_names,
                                               cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateProgramWithBuiltInKernels);
        return 0;
    }
    
    cl_program CreateProgramWithIL(cl_context context,
                                   const void *il,
                                   size_t length,
                                   cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateProgramWithIL);
        return 0;
    }
    
    cl_int RetainProgram(cl_program program)
    {
        WARN_NOT_SUPPORTED(RetainProgram);
        return 0;
    }
    
    cl_int ReleaseProgram(cl_program program)
    {
        WARN_NOT_SUPPORTED(ReleaseProgram);
        return 0;
    }
    
    cl_int BuildProgram(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)
    {
        WARN_NOT_SUPPORTED(BuildProgram);
        return 0;
    }
    
    cl_int CompileProgram(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)
    {
        WARN_NOT_SUPPORTED(CompileProgram);
        return 0;
    }
    
    cl_program LinkProgram(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)
    {
        WARN_NOT_SUPPORTED(LinkProgram);
        return 0;
    }
    
    cl_int SetProgramReleaseCallback(cl_program program,
                                     void(CL_CALLBACK *pfn_notify)(cl_program program, void *user_data),
                                     void *user_data)
    {
        WARN_NOT_SUPPORTED(SetProgramReleaseCallback);
        return 0;
    }
    
    cl_int SetProgramSpecializationConstant(cl_program program,
                                            cl_uint spec_id,
                                            size_t spec_size,
                                            const void *spec_value)
    {
        WARN_NOT_SUPPORTED(SetProgramSpecializationConstant);
        return 0;
    }
    
    cl_int UnloadPlatformCompiler(cl_platform_id platform)
    {
        WARN_NOT_SUPPORTED(UnloadPlatformCompiler);
        return 0;
    }
    
    cl_int GetProgramInfo(cl_program program,
                          ProgramInfo param_name,
                          size_t param_value_size,
                          void *param_value,
                          size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetProgramInfo);
        return 0;
    }
    
    cl_int GetProgramBuildInfo(cl_program program,
                               cl_device_id device,
                               ProgramBuildInfo param_name,
                               size_t param_value_size,
                               void *param_value,
                               size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetProgramBuildInfo);
        return 0;
    }
    
    cl_kernel CreateKernel(cl_program program, const char *kernel_name, cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateKernel);
        return 0;
    }
    
    cl_int CreateKernelsInProgram(cl_program program,
                                  cl_uint num_kernels,
                                  cl_kernel *kernels,
                                  cl_uint *num_kernels_ret)
    {
        WARN_NOT_SUPPORTED(CreateKernelsInProgram);
        return 0;
    }
    
    cl_kernel CloneKernel(cl_kernel source_kernel, cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CloneKernel);
        return 0;
    }
    
    cl_int RetainKernel(cl_kernel kernel)
    {
        WARN_NOT_SUPPORTED(RetainKernel);
        return 0;
    }
    
    cl_int ReleaseKernel(cl_kernel kernel)
    {
        WARN_NOT_SUPPORTED(ReleaseKernel);
        return 0;
    }
    
    cl_int SetKernelArg(cl_kernel kernel, cl_uint arg_index, size_t arg_size, const void *arg_value)
    {
        WARN_NOT_SUPPORTED(SetKernelArg);
        return 0;
    }
    
    cl_int SetKernelArgSVMPointer(cl_kernel kernel, cl_uint arg_index, const void *arg_value)
    {
        WARN_NOT_SUPPORTED(SetKernelArgSVMPointer);
        return 0;
    }
    
    cl_int SetKernelExecInfo(cl_kernel kernel,
                             KernelExecInfo param_name,
                             size_t param_value_size,
                             const void *param_value)
    {
        WARN_NOT_SUPPORTED(SetKernelExecInfo);
        return 0;
    }
    
    cl_int GetKernelInfo(cl_kernel kernel,
                         KernelInfo param_name,
                         size_t param_value_size,
                         void *param_value,
                         size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetKernelInfo);
        return 0;
    }
    
    cl_int GetKernelArgInfo(cl_kernel kernel,
                            cl_uint arg_index,
                            KernelArgInfo param_name,
                            size_t param_value_size,
                            void *param_value,
                            size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetKernelArgInfo);
        return 0;
    }
    
    cl_int GetKernelWorkGroupInfo(cl_kernel kernel,
                                  cl_device_id device,
                                  KernelWorkGroupInfo param_name,
                                  size_t param_value_size,
                                  void *param_value,
                                  size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetKernelWorkGroupInfo);
        return 0;
    }
    
    cl_int GetKernelSubGroupInfo(cl_kernel kernel,
                                 cl_device_id device,
                                 KernelSubGroupInfo param_name,
                                 size_t input_value_size,
                                 const void *input_value,
                                 size_t param_value_size,
                                 void *param_value,
                                 size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetKernelSubGroupInfo);
        return 0;
    }
    
    cl_int WaitForEvents(cl_uint num_events, const cl_event *event_list)
    {
        WARN_NOT_SUPPORTED(WaitForEvents);
        return 0;
    }
    
    cl_int GetEventInfo(cl_event event,
                        EventInfo param_name,
                        size_t param_value_size,
                        void *param_value,
                        size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetEventInfo);
        return 0;
    }
    
    cl_event CreateUserEvent(cl_context context, cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateUserEvent);
        return 0;
    }
    
    cl_int RetainEvent(cl_event event)
    {
        WARN_NOT_SUPPORTED(RetainEvent);
        return 0;
    }
    
    cl_int ReleaseEvent(cl_event event)
    {
        WARN_NOT_SUPPORTED(ReleaseEvent);
        return 0;
    }
    
    cl_int SetUserEventStatus(cl_event event, cl_int execution_status)
    {
        WARN_NOT_SUPPORTED(SetUserEventStatus);
        return 0;
    }
    
    cl_int SetEventCallback(cl_event event,
                            cl_int command_exec_callback_type,
                            void(CL_CALLBACK *pfn_notify)(cl_event event,
                                                          cl_int event_command_status,
                                                          void *user_data),
                            void *user_data)
    {
        WARN_NOT_SUPPORTED(SetEventCallback);
        return 0;
    }
    
    cl_int GetEventProfilingInfo(cl_event event,
                                 ProfilingInfo param_name,
                                 size_t param_value_size,
                                 void *param_value,
                                 size_t *param_value_size_ret)
    {
        WARN_NOT_SUPPORTED(GetEventProfilingInfo);
        return 0;
    }
    
    cl_int Flush(cl_command_queue command_queue)
    {
        WARN_NOT_SUPPORTED(Flush);
        return 0;
    }
    
    cl_int Finish(cl_command_queue command_queue)
    {
        WARN_NOT_SUPPORTED(Finish);
        return 0;
    }
    
    cl_int EnqueueReadBuffer(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)
    {
        WARN_NOT_SUPPORTED(EnqueueReadBuffer);
        return 0;
    }
    
    cl_int EnqueueReadBufferRect(cl_command_queue command_queue,
                                 cl_mem buffer,
                                 cl_bool blocking_read,
                                 const size_t *buffer_origin,
                                 const size_t *host_origin,
                                 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)
    {
        WARN_NOT_SUPPORTED(EnqueueReadBufferRect);
        return 0;
    }
    
    cl_int EnqueueWriteBuffer(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)
    {
        WARN_NOT_SUPPORTED(EnqueueWriteBuffer);
        return 0;
    }
    
    cl_int EnqueueWriteBufferRect(cl_command_queue command_queue,
                                  cl_mem buffer,
                                  cl_bool blocking_write,
                                  const size_t *buffer_origin,
                                  const size_t *host_origin,
                                  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)
    {
        WARN_NOT_SUPPORTED(EnqueueWriteBufferRect);
        return 0;
    }
    
    cl_int EnqueueFillBuffer(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)
    {
        WARN_NOT_SUPPORTED(EnqueueFillBuffer);
        return 0;
    }
    
    cl_int EnqueueCopyBuffer(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)
    {
        WARN_NOT_SUPPORTED(EnqueueCopyBuffer);
        return 0;
    }
    
    cl_int EnqueueCopyBufferRect(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)
    {
        WARN_NOT_SUPPORTED(EnqueueCopyBufferRect);
        return 0;
    }
    
    cl_int EnqueueReadImage(cl_command_queue command_queue,
                            cl_mem image,
                            cl_bool blocking_read,
                            const size_t *origin,
                            const size_t *region,
                            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)
    {
        WARN_NOT_SUPPORTED(EnqueueReadImage);
        return 0;
    }
    
    cl_int EnqueueWriteImage(cl_command_queue command_queue,
                             cl_mem image,
                             cl_bool blocking_write,
                             const size_t *origin,
                             const size_t *region,
                             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)
    {
        WARN_NOT_SUPPORTED(EnqueueWriteImage);
        return 0;
    }
    
    cl_int EnqueueFillImage(cl_command_queue command_queue,
                            cl_mem image,
                            const void *fill_color,
                            const size_t *origin,
                            const size_t *region,
                            cl_uint num_events_in_wait_list,
                            const cl_event *event_wait_list,
                            cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueFillImage);
        return 0;
    }
    
    cl_int EnqueueCopyImage(cl_command_queue command_queue,
                            cl_mem src_image,
                            cl_mem dst_image,
                            const size_t *src_origin,
                            const size_t *dst_origin,
                            const size_t *region,
                            cl_uint num_events_in_wait_list,
                            const cl_event *event_wait_list,
                            cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueCopyImage);
        return 0;
    }
    
    cl_int EnqueueCopyImageToBuffer(cl_command_queue command_queue,
                                    cl_mem src_image,
                                    cl_mem dst_buffer,
                                    const size_t *src_origin,
                                    const size_t *region,
                                    size_t dst_offset,
                                    cl_uint num_events_in_wait_list,
                                    const cl_event *event_wait_list,
                                    cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueCopyImageToBuffer);
        return 0;
    }
    
    cl_int EnqueueCopyBufferToImage(cl_command_queue command_queue,
                                    cl_mem src_buffer,
                                    cl_mem dst_image,
                                    size_t src_offset,
                                    const size_t *dst_origin,
                                    const size_t *region,
                                    cl_uint num_events_in_wait_list,
                                    const cl_event *event_wait_list,
                                    cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueCopyBufferToImage);
        return 0;
    }
    
    void *EnqueueMapBuffer(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)
    {
        WARN_NOT_SUPPORTED(EnqueueMapBuffer);
        return 0;
    }
    
    void *EnqueueMapImage(cl_command_queue command_queue,
                          cl_mem image,
                          cl_bool blocking_map,
                          cl_map_flags map_flags,
                          const size_t *origin,
                          const size_t *region,
                          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)
    {
        WARN_NOT_SUPPORTED(EnqueueMapImage);
        return 0;
    }
    
    cl_int EnqueueUnmapMemObject(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)
    {
        WARN_NOT_SUPPORTED(EnqueueUnmapMemObject);
        return 0;
    }
    
    cl_int EnqueueMigrateMemObjects(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)
    {
        WARN_NOT_SUPPORTED(EnqueueMigrateMemObjects);
        return 0;
    }
    
    cl_int EnqueueNDRangeKernel(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)
    {
        WARN_NOT_SUPPORTED(EnqueueNDRangeKernel);
        return 0;
    }
    
    cl_int EnqueueNativeKernel(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)
    {
        WARN_NOT_SUPPORTED(EnqueueNativeKernel);
        return 0;
    }
    
    cl_int EnqueueMarkerWithWaitList(cl_command_queue command_queue,
                                     cl_uint num_events_in_wait_list,
                                     const cl_event *event_wait_list,
                                     cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueMarkerWithWaitList);
        return 0;
    }
    
    cl_int EnqueueBarrierWithWaitList(cl_command_queue command_queue,
                                      cl_uint num_events_in_wait_list,
                                      const cl_event *event_wait_list,
                                      cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueBarrierWithWaitList);
        return 0;
    }
    
    cl_int EnqueueSVMFree(cl_command_queue command_queue,
                          cl_uint num_svm_pointers,
                          void *svm_pointers[],
                          void(CL_CALLBACK *pfn_free_func)(cl_command_queue queue,
                                                           cl_uint num_svm_pointers,
                                                           void *svm_pointers[],
                                                           void *user_data),
                          void *user_data,
                          cl_uint num_events_in_wait_list,
                          const cl_event *event_wait_list,
                          cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueSVMFree);
        return 0;
    }
    
    cl_int EnqueueSVMMemcpy(cl_command_queue command_queue,
                            cl_bool blocking_copy,
                            void *dst_ptr,
                            const void *src_ptr,
                            size_t size,
                            cl_uint num_events_in_wait_list,
                            const cl_event *event_wait_list,
                            cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueSVMMemcpy);
        return 0;
    }
    
    cl_int EnqueueSVMMemFill(cl_command_queue command_queue,
                             void *svm_ptr,
                             const void *pattern,
                             size_t pattern_size,
                             size_t size,
                             cl_uint num_events_in_wait_list,
                             const cl_event *event_wait_list,
                             cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueSVMMemFill);
        return 0;
    }
    
    cl_int EnqueueSVMMap(cl_command_queue command_queue,
                         cl_bool blocking_map,
                         cl_map_flags flags,
                         void *svm_ptr,
                         size_t size,
                         cl_uint num_events_in_wait_list,
                         const cl_event *event_wait_list,
                         cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueSVMMap);
        return 0;
    }
    
    cl_int EnqueueSVMUnmap(cl_command_queue command_queue,
                           void *svm_ptr,
                           cl_uint num_events_in_wait_list,
                           const cl_event *event_wait_list,
                           cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueSVMUnmap);
        return 0;
    }
    
    cl_int EnqueueSVMMigrateMem(cl_command_queue command_queue,
                                cl_uint num_svm_pointers,
                                const void **svm_pointers,
                                const size_t *sizes,
                                cl_mem_migration_flags flags,
                                cl_uint num_events_in_wait_list,
                                const cl_event *event_wait_list,
                                cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueSVMMigrateMem);
        return 0;
    }
    
    void *GetExtensionFunctionAddressForPlatform(cl_platform_id platform, const char *func_name)
    {
        return GetExtensionFunctionAddress(func_name);
    }
    
    cl_int SetCommandQueueProperty(cl_command_queue command_queue,
                                   cl_command_queue_properties properties,
                                   cl_bool enable,
                                   cl_command_queue_properties *old_properties)
    {
        WARN_NOT_SUPPORTED(SetCommandQueueProperty);
        return 0;
    }
    
    cl_mem CreateImage2D(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)
    {
        WARN_NOT_SUPPORTED(CreateImage2D);
        return 0;
    }
    
    cl_mem CreateImage3D(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)
    {
        WARN_NOT_SUPPORTED(CreateImage3D);
        return 0;
    }
    
    cl_int EnqueueMarker(cl_command_queue command_queue, cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueMarker);
        return 0;
    }
    
    cl_int EnqueueWaitForEvents(cl_command_queue command_queue,
                                cl_uint num_events,
                                const cl_event *event_list)
    {
        WARN_NOT_SUPPORTED(EnqueueWaitForEvents);
        return 0;
    }
    
    cl_int EnqueueBarrier(cl_command_queue command_queue)
    {
        WARN_NOT_SUPPORTED(EnqueueBarrier);
        return 0;
    }
    
    cl_int UnloadCompiler()
    {
        WARN_NOT_SUPPORTED(UnloadCompiler);
        return 0;
    }
    
    void *GetExtensionFunctionAddress(const char *func_name)
    {
        if (func_name == nullptr)
        {
            return nullptr;
        }
        const ProcTable &procTable = GetProcTable();
        const auto it              = procTable.find(func_name);
        return it != procTable.cend() ? it->second : nullptr;
    }
    
    cl_command_queue CreateCommandQueue(cl_context context,
                                        cl_device_id device,
                                        cl_command_queue_properties properties,
                                        cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateCommandQueue);
        return 0;
    }
    
    cl_sampler CreateSampler(cl_context context,
                             cl_bool normalized_coords,
                             AddressingMode addressing_mode,
                             FilterMode filter_mode,
                             cl_int *errcode_ret)
    {
        WARN_NOT_SUPPORTED(CreateSampler);
        return 0;
    }
    
    cl_int EnqueueTask(cl_command_queue command_queue,
                       cl_kernel kernel,
                       cl_uint num_events_in_wait_list,
                       const cl_event *event_wait_list,
                       cl_event *event)
    {
        WARN_NOT_SUPPORTED(EnqueueTask);
        return 0;
    }
    
    }  // namespace cl