2424 lines
111 KiB
C++
2424 lines
111 KiB
C++
// GENERATED FILE - DO NOT EDIT.
|
|
// Generated by generate_entry_points.py using data from cl.xml.
|
|
//
|
|
// Copyright 2020 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.
|
|
//
|
|
// entry_points_cl_autogen.cpp:
|
|
// Defines the CL entry points.
|
|
|
|
#include "libGLESv2/entry_points_cl_autogen.h"
|
|
|
|
#include "libANGLE/validationCL_autogen.h"
|
|
#include "libGLESv2/cl_stubs_autogen.h"
|
|
#include "libGLESv2/entry_points_cl_utils.h"
|
|
|
|
namespace cl
|
|
{
|
|
|
|
// CL 1.0
|
|
cl_int CL_API_CALL clGetPlatformIDs(cl_uint num_entries,
|
|
cl_platform_id *platforms,
|
|
cl_uint *num_platforms)
|
|
{
|
|
InitBackEnds(false);
|
|
|
|
CL_EVENT(GetPlatformIDs,
|
|
"num_entries = %u, platforms = 0x%016" PRIxPTR ", num_platforms = 0x%016" PRIxPTR "",
|
|
num_entries, (uintptr_t)platforms, (uintptr_t)num_platforms);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetPlatformIDs, num_entries, platforms, num_platforms);
|
|
|
|
return GetPlatformIDs(num_entries, platforms, num_platforms);
|
|
}
|
|
|
|
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)
|
|
{
|
|
InitBackEnds(false);
|
|
|
|
CL_EVENT(GetPlatformInfo,
|
|
"platform = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)platform, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
PlatformInfo param_namePacked = PackParam<PlatformInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetPlatformInfo, platform, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetPlatformInfo(platform, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
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)
|
|
{
|
|
InitBackEnds(false);
|
|
|
|
CL_EVENT(GetDeviceIDs,
|
|
"platform = 0x%016" PRIxPTR
|
|
", device_type = %llu, num_entries = %u, devices = 0x%016" PRIxPTR
|
|
", num_devices = 0x%016" PRIxPTR "",
|
|
(uintptr_t)platform, static_cast<unsigned long long>(device_type), num_entries,
|
|
(uintptr_t)devices, (uintptr_t)num_devices);
|
|
|
|
DeviceType device_typePacked = PackParam<DeviceType>(device_type);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetDeviceIDs, platform, device_typePacked, num_entries, devices,
|
|
num_devices);
|
|
|
|
return GetDeviceIDs(platform, device_typePacked, num_entries, devices, num_devices);
|
|
}
|
|
|
|
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_EVENT(GetDeviceInfo,
|
|
"device = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)device, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
DeviceInfo param_namePacked = PackParam<DeviceInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetDeviceInfo, device, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
|
|
return GetDeviceInfo(device, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
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 *errinfo,
|
|
const void *private_info,
|
|
size_t cb,
|
|
void *user_data),
|
|
void *user_data,
|
|
cl_int *errcode_ret)
|
|
{
|
|
InitBackEnds(false);
|
|
|
|
CL_EVENT(CreateContext,
|
|
"properties = 0x%016" PRIxPTR ", num_devices = %u, devices = 0x%016" PRIxPTR
|
|
", pfn_notify = 0x%016" PRIxPTR ", user_data = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)properties, num_devices, (uintptr_t)devices, (uintptr_t)pfn_notify,
|
|
(uintptr_t)user_data, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateContext, properties, num_devices, devices, pfn_notify,
|
|
user_data);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_context object =
|
|
CreateContext(properties, num_devices, devices, pfn_notify, user_data, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_context CL_API_CALL
|
|
clCreateContextFromType(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)
|
|
{
|
|
InitBackEnds(false);
|
|
|
|
CL_EVENT(CreateContextFromType,
|
|
"properties = 0x%016" PRIxPTR ", device_type = %llu, pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)properties, static_cast<unsigned long long>(device_type),
|
|
(uintptr_t)pfn_notify, (uintptr_t)user_data, (uintptr_t)errcode_ret);
|
|
|
|
DeviceType device_typePacked = PackParam<DeviceType>(device_type);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateContextFromType, properties, device_typePacked, pfn_notify,
|
|
user_data);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_context object =
|
|
CreateContextFromType(properties, device_typePacked, pfn_notify, user_data, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainContext(cl_context context)
|
|
{
|
|
CL_EVENT(RetainContext, "context = 0x%016" PRIxPTR "", (uintptr_t)context);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainContext, context);
|
|
|
|
return RetainContext(context);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseContext(cl_context context)
|
|
{
|
|
CL_EVENT(ReleaseContext, "context = 0x%016" PRIxPTR "", (uintptr_t)context);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseContext, context);
|
|
|
|
return ReleaseContext(context);
|
|
}
|
|
|
|
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_EVENT(GetContextInfo,
|
|
"context = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
ContextInfo param_namePacked = PackParam<ContextInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetContextInfo, context, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetContextInfo(context, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainCommandQueue(cl_command_queue command_queue)
|
|
{
|
|
CL_EVENT(RetainCommandQueue, "command_queue = 0x%016" PRIxPTR "", (uintptr_t)command_queue);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainCommandQueue, command_queue);
|
|
|
|
return RetainCommandQueue(command_queue);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseCommandQueue(cl_command_queue command_queue)
|
|
{
|
|
CL_EVENT(ReleaseCommandQueue, "command_queue = 0x%016" PRIxPTR "", (uintptr_t)command_queue);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseCommandQueue, command_queue);
|
|
|
|
return ReleaseCommandQueue(command_queue);
|
|
}
|
|
|
|
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_EVENT(GetCommandQueueInfo,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
CommandQueueInfo param_namePacked = PackParam<CommandQueueInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetCommandQueueInfo, command_queue, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetCommandQueueInfo(command_queue, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_mem CL_API_CALL clCreateBuffer(cl_context context,
|
|
cl_mem_flags flags,
|
|
size_t size,
|
|
void *host_ptr,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateBuffer,
|
|
"context = 0x%016" PRIxPTR ", flags = %llu, size = %zu, host_ptr = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), size, (uintptr_t)host_ptr,
|
|
(uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateBuffer, context, flagsPacked, size, host_ptr);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object = CreateBuffer(context, flagsPacked, size, host_ptr, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainMemObject(cl_mem memobj)
|
|
{
|
|
CL_EVENT(RetainMemObject, "memobj = 0x%016" PRIxPTR "", (uintptr_t)memobj);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainMemObject, memobj);
|
|
|
|
return RetainMemObject(memobj);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseMemObject(cl_mem memobj)
|
|
{
|
|
CL_EVENT(ReleaseMemObject, "memobj = 0x%016" PRIxPTR "", (uintptr_t)memobj);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseMemObject, memobj);
|
|
|
|
return ReleaseMemObject(memobj);
|
|
}
|
|
|
|
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_EVENT(GetSupportedImageFormats,
|
|
"context = 0x%016" PRIxPTR
|
|
", flags = %llu, image_type = %u, num_entries = %u, image_formats = 0x%016" PRIxPTR
|
|
", num_image_formats = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), image_type, num_entries,
|
|
(uintptr_t)image_formats, (uintptr_t)num_image_formats);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
MemObjectType image_typePacked = PackParam<MemObjectType>(image_type);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetSupportedImageFormats, context, flagsPacked, image_typePacked,
|
|
num_entries, image_formats, num_image_formats);
|
|
|
|
return GetSupportedImageFormats(context, flagsPacked, image_typePacked, num_entries,
|
|
image_formats, num_image_formats);
|
|
}
|
|
|
|
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_EVENT(GetMemObjectInfo,
|
|
"memobj = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)memobj, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
MemInfo param_namePacked = PackParam<MemInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetMemObjectInfo, memobj, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetMemObjectInfo(memobj, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
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_EVENT(GetImageInfo,
|
|
"image = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)image, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
ImageInfo param_namePacked = PackParam<ImageInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetImageInfo, image, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
|
|
return GetImageInfo(image, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainSampler(cl_sampler sampler)
|
|
{
|
|
CL_EVENT(RetainSampler, "sampler = 0x%016" PRIxPTR "", (uintptr_t)sampler);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainSampler, sampler);
|
|
|
|
return RetainSampler(sampler);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseSampler(cl_sampler sampler)
|
|
{
|
|
CL_EVENT(ReleaseSampler, "sampler = 0x%016" PRIxPTR "", (uintptr_t)sampler);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseSampler, sampler);
|
|
|
|
return ReleaseSampler(sampler);
|
|
}
|
|
|
|
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_EVENT(GetSamplerInfo,
|
|
"sampler = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)sampler, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
SamplerInfo param_namePacked = PackParam<SamplerInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetSamplerInfo, sampler, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetSamplerInfo(sampler, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_program CL_API_CALL clCreateProgramWithSource(cl_context context,
|
|
cl_uint count,
|
|
const char **strings,
|
|
const size_t *lengths,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateProgramWithSource,
|
|
"context = 0x%016" PRIxPTR ", count = %u, strings = 0x%016" PRIxPTR
|
|
", lengths = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, count, (uintptr_t)strings, (uintptr_t)lengths,
|
|
(uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateProgramWithSource, context, count, strings, lengths);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_program object = CreateProgramWithSource(context, count, strings, lengths, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(CreateProgramWithBinary,
|
|
"context = 0x%016" PRIxPTR ", num_devices = %u, device_list = 0x%016" PRIxPTR
|
|
", lengths = 0x%016" PRIxPTR ", binaries = 0x%016" PRIxPTR
|
|
", binary_status = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, num_devices, (uintptr_t)device_list, (uintptr_t)lengths,
|
|
(uintptr_t)binaries, (uintptr_t)binary_status, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateProgramWithBinary, context, num_devices, device_list,
|
|
lengths, binaries, binary_status);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_program object = CreateProgramWithBinary(context, num_devices, device_list, lengths,
|
|
binaries, binary_status, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainProgram(cl_program program)
|
|
{
|
|
CL_EVENT(RetainProgram, "program = 0x%016" PRIxPTR "", (uintptr_t)program);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainProgram, program);
|
|
|
|
return RetainProgram(program);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseProgram(cl_program program)
|
|
{
|
|
CL_EVENT(ReleaseProgram, "program = 0x%016" PRIxPTR "", (uintptr_t)program);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseProgram, program);
|
|
|
|
return ReleaseProgram(program);
|
|
}
|
|
|
|
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_EVENT(BuildProgram,
|
|
"program = 0x%016" PRIxPTR ", num_devices = %u, device_list = 0x%016" PRIxPTR
|
|
", options = 0x%016" PRIxPTR ", pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, num_devices, (uintptr_t)device_list, (uintptr_t)options,
|
|
(uintptr_t)pfn_notify, (uintptr_t)user_data);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(BuildProgram, program, num_devices, device_list, options, pfn_notify,
|
|
user_data);
|
|
|
|
return BuildProgram(program, num_devices, device_list, options, pfn_notify, user_data);
|
|
}
|
|
|
|
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_EVENT(GetProgramInfo,
|
|
"program = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
ProgramInfo param_namePacked = PackParam<ProgramInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetProgramInfo, program, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetProgramInfo(program, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
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_EVENT(GetProgramBuildInfo,
|
|
"program = 0x%016" PRIxPTR ", device = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, (uintptr_t)device, param_name, param_value_size,
|
|
(uintptr_t)param_value, (uintptr_t)param_value_size_ret);
|
|
|
|
ProgramBuildInfo param_namePacked = PackParam<ProgramBuildInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetProgramBuildInfo, program, device, param_namePacked,
|
|
param_value_size, param_value, param_value_size_ret);
|
|
|
|
return GetProgramBuildInfo(program, device, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_kernel CL_API_CALL clCreateKernel(cl_program program,
|
|
const char *kernel_name,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateKernel,
|
|
"program = 0x%016" PRIxPTR ", kernel_name = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, (uintptr_t)kernel_name, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateKernel, program, kernel_name);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_kernel object = CreateKernel(program, kernel_name, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clCreateKernelsInProgram(cl_program program,
|
|
cl_uint num_kernels,
|
|
cl_kernel *kernels,
|
|
cl_uint *num_kernels_ret)
|
|
{
|
|
CL_EVENT(CreateKernelsInProgram,
|
|
"program = 0x%016" PRIxPTR ", num_kernels = %u, kernels = 0x%016" PRIxPTR
|
|
", num_kernels_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, num_kernels, (uintptr_t)kernels, (uintptr_t)num_kernels_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(CreateKernelsInProgram, program, num_kernels, kernels, num_kernels_ret);
|
|
|
|
return CreateKernelsInProgram(program, num_kernels, kernels, num_kernels_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainKernel(cl_kernel kernel)
|
|
{
|
|
CL_EVENT(RetainKernel, "kernel = 0x%016" PRIxPTR "", (uintptr_t)kernel);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainKernel, kernel);
|
|
|
|
return RetainKernel(kernel);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseKernel(cl_kernel kernel)
|
|
{
|
|
CL_EVENT(ReleaseKernel, "kernel = 0x%016" PRIxPTR "", (uintptr_t)kernel);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseKernel, kernel);
|
|
|
|
return ReleaseKernel(kernel);
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetKernelArg(cl_kernel kernel,
|
|
cl_uint arg_index,
|
|
size_t arg_size,
|
|
const void *arg_value)
|
|
{
|
|
CL_EVENT(SetKernelArg,
|
|
"kernel = 0x%016" PRIxPTR
|
|
", arg_index = %u, arg_size = %zu, arg_value = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, arg_index, arg_size, (uintptr_t)arg_value);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetKernelArg, kernel, arg_index, arg_size, arg_value);
|
|
|
|
return SetKernelArg(kernel, arg_index, arg_size, arg_value);
|
|
}
|
|
|
|
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_EVENT(GetKernelInfo,
|
|
"kernel = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
KernelInfo param_namePacked = PackParam<KernelInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetKernelInfo, kernel, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
|
|
return GetKernelInfo(kernel, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
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_EVENT(GetKernelWorkGroupInfo,
|
|
"kernel = 0x%016" PRIxPTR ", device = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, (uintptr_t)device, param_name, param_value_size,
|
|
(uintptr_t)param_value, (uintptr_t)param_value_size_ret);
|
|
|
|
KernelWorkGroupInfo param_namePacked = PackParam<KernelWorkGroupInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetKernelWorkGroupInfo, kernel, device, param_namePacked,
|
|
param_value_size, param_value, param_value_size_ret);
|
|
|
|
return GetKernelWorkGroupInfo(kernel, device, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clWaitForEvents(cl_uint num_events, const cl_event *event_list)
|
|
{
|
|
CL_EVENT(WaitForEvents, "num_events = %u, event_list = 0x%016" PRIxPTR "", num_events,
|
|
(uintptr_t)event_list);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(WaitForEvents, num_events, event_list);
|
|
|
|
return WaitForEvents(num_events, event_list);
|
|
}
|
|
|
|
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_EVENT(GetEventInfo,
|
|
"event = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)event, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
EventInfo param_namePacked = PackParam<EventInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetEventInfo, event, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
|
|
return GetEventInfo(event, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainEvent(cl_event event)
|
|
{
|
|
CL_EVENT(RetainEvent, "event = 0x%016" PRIxPTR "", (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainEvent, event);
|
|
|
|
return RetainEvent(event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseEvent(cl_event event)
|
|
{
|
|
CL_EVENT(ReleaseEvent, "event = 0x%016" PRIxPTR "", (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseEvent, event);
|
|
|
|
return ReleaseEvent(event);
|
|
}
|
|
|
|
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_EVENT(GetEventProfilingInfo,
|
|
"event = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)event, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
ProfilingInfo param_namePacked = PackParam<ProfilingInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetEventProfilingInfo, event, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetEventProfilingInfo(event, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clFlush(cl_command_queue command_queue)
|
|
{
|
|
CL_EVENT(Flush, "command_queue = 0x%016" PRIxPTR "", (uintptr_t)command_queue);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(Flush, command_queue);
|
|
|
|
return Flush(command_queue);
|
|
}
|
|
|
|
cl_int CL_API_CALL clFinish(cl_command_queue command_queue)
|
|
{
|
|
CL_EVENT(Finish, "command_queue = 0x%016" PRIxPTR "", (uintptr_t)command_queue);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(Finish, command_queue);
|
|
|
|
return Finish(command_queue);
|
|
}
|
|
|
|
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_EVENT(EnqueueReadBuffer,
|
|
"command_queue = 0x%016" PRIxPTR ", buffer = 0x%016" PRIxPTR
|
|
", blocking_read = %u, offset = %zu, size = %zu, ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)buffer, blocking_read, offset, size,
|
|
(uintptr_t)ptr, num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueReadBuffer, command_queue, buffer, blocking_read, offset, size,
|
|
ptr, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueReadBuffer(command_queue, buffer, blocking_read, offset, size, ptr,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueWriteBuffer,
|
|
"command_queue = 0x%016" PRIxPTR ", buffer = 0x%016" PRIxPTR
|
|
", blocking_write = %u, offset = %zu, size = %zu, ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)buffer, blocking_write, offset, size,
|
|
(uintptr_t)ptr, num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueWriteBuffer, command_queue, buffer, blocking_write, offset, size,
|
|
ptr, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueWriteBuffer(command_queue, buffer, blocking_write, offset, size, ptr,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueCopyBuffer,
|
|
"command_queue = 0x%016" PRIxPTR ", src_buffer = 0x%016" PRIxPTR
|
|
", dst_buffer = 0x%016" PRIxPTR
|
|
", src_offset = %zu, dst_offset = %zu, size = %zu, num_events_in_wait_list = %u, "
|
|
"event_wait_list = 0x%016" PRIxPTR ", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)src_buffer, (uintptr_t)dst_buffer, src_offset,
|
|
dst_offset, size, num_events_in_wait_list, (uintptr_t)event_wait_list,
|
|
(uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueCopyBuffer, command_queue, src_buffer, dst_buffer, src_offset,
|
|
dst_offset, size, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueCopyBuffer(command_queue, src_buffer, dst_buffer, src_offset, dst_offset, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueReadImage(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)
|
|
{
|
|
CL_EVENT(EnqueueReadImage,
|
|
"command_queue = 0x%016" PRIxPTR ", image = 0x%016" PRIxPTR
|
|
", blocking_read = %u, origin = 0x%016" PRIxPTR ", region = 0x%016" PRIxPTR
|
|
", row_pitch = %zu, slice_pitch = %zu, ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)image, blocking_read, (uintptr_t)origin,
|
|
(uintptr_t)region, row_pitch, slice_pitch, (uintptr_t)ptr, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueReadImage, command_queue, image, blocking_read, origin, region,
|
|
row_pitch, slice_pitch, ptr, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
|
|
return EnqueueReadImage(command_queue, image, blocking_read, origin, region, row_pitch,
|
|
slice_pitch, ptr, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueWriteImage(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)
|
|
{
|
|
CL_EVENT(EnqueueWriteImage,
|
|
"command_queue = 0x%016" PRIxPTR ", image = 0x%016" PRIxPTR
|
|
", blocking_write = %u, origin = 0x%016" PRIxPTR ", region = 0x%016" PRIxPTR
|
|
", input_row_pitch = %zu, input_slice_pitch = %zu, ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)image, blocking_write, (uintptr_t)origin,
|
|
(uintptr_t)region, input_row_pitch, input_slice_pitch, (uintptr_t)ptr,
|
|
num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueWriteImage, command_queue, image, blocking_write, origin, region,
|
|
input_row_pitch, input_slice_pitch, ptr, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueWriteImage(command_queue, image, blocking_write, origin, region, input_row_pitch,
|
|
input_slice_pitch, ptr, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueCopyImage(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)
|
|
{
|
|
CL_EVENT(EnqueueCopyImage,
|
|
"command_queue = 0x%016" PRIxPTR ", src_image = 0x%016" PRIxPTR
|
|
", dst_image = 0x%016" PRIxPTR ", src_origin = 0x%016" PRIxPTR
|
|
", dst_origin = 0x%016" PRIxPTR ", region = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)src_image, (uintptr_t)dst_image,
|
|
(uintptr_t)src_origin, (uintptr_t)dst_origin, (uintptr_t)region,
|
|
num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueCopyImage, command_queue, src_image, dst_image, src_origin,
|
|
dst_origin, region, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueCopyImage(command_queue, src_image, dst_image, src_origin, dst_origin, region,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueCopyImageToBuffer(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)
|
|
{
|
|
CL_EVENT(EnqueueCopyImageToBuffer,
|
|
"command_queue = 0x%016" PRIxPTR ", src_image = 0x%016" PRIxPTR
|
|
", dst_buffer = 0x%016" PRIxPTR ", src_origin = 0x%016" PRIxPTR
|
|
", region = 0x%016" PRIxPTR
|
|
", dst_offset = %zu, num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)src_image, (uintptr_t)dst_buffer,
|
|
(uintptr_t)src_origin, (uintptr_t)region, dst_offset, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueCopyImageToBuffer, command_queue, src_image, dst_buffer,
|
|
src_origin, region, dst_offset, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueCopyImageToBuffer(command_queue, src_image, dst_buffer, src_origin, region,
|
|
dst_offset, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
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,
|
|
const size_t *region,
|
|
cl_uint num_events_in_wait_list,
|
|
const cl_event *event_wait_list,
|
|
cl_event *event)
|
|
{
|
|
CL_EVENT(EnqueueCopyBufferToImage,
|
|
"command_queue = 0x%016" PRIxPTR ", src_buffer = 0x%016" PRIxPTR
|
|
", dst_image = 0x%016" PRIxPTR ", src_offset = %zu, dst_origin = 0x%016" PRIxPTR
|
|
", region = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)src_buffer, (uintptr_t)dst_image, src_offset,
|
|
(uintptr_t)dst_origin, (uintptr_t)region, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueCopyBufferToImage, command_queue, src_buffer, dst_image,
|
|
src_offset, dst_origin, region, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueCopyBufferToImage(command_queue, src_buffer, dst_image, src_offset, dst_origin,
|
|
region, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueMapBuffer,
|
|
"command_queue = 0x%016" PRIxPTR ", buffer = 0x%016" PRIxPTR
|
|
", blocking_map = %u, map_flags = %llu, offset = %zu, size = %zu, "
|
|
"num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)buffer, blocking_map,
|
|
static_cast<unsigned long long>(map_flags), offset, size, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event, (uintptr_t)errcode_ret);
|
|
|
|
MapFlags map_flagsPacked = PackParam<MapFlags>(map_flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(EnqueueMapBuffer, command_queue, buffer, blocking_map,
|
|
map_flagsPacked, offset, size, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
void *object =
|
|
EnqueueMapBuffer(command_queue, buffer, blocking_map, map_flagsPacked, offset, size,
|
|
num_events_in_wait_list, event_wait_list, event, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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,
|
|
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)
|
|
{
|
|
CL_EVENT(EnqueueMapImage,
|
|
"command_queue = 0x%016" PRIxPTR ", image = 0x%016" PRIxPTR
|
|
", blocking_map = %u, map_flags = %llu, origin = 0x%016" PRIxPTR
|
|
", region = 0x%016" PRIxPTR ", image_row_pitch = 0x%016" PRIxPTR
|
|
", image_slice_pitch = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)image, blocking_map,
|
|
static_cast<unsigned long long>(map_flags), (uintptr_t)origin, (uintptr_t)region,
|
|
(uintptr_t)image_row_pitch, (uintptr_t)image_slice_pitch, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event, (uintptr_t)errcode_ret);
|
|
|
|
MapFlags map_flagsPacked = PackParam<MapFlags>(map_flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(
|
|
EnqueueMapImage, command_queue, image, blocking_map, map_flagsPacked, origin, region,
|
|
image_row_pitch, image_slice_pitch, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
void *object = EnqueueMapImage(command_queue, image, blocking_map, map_flagsPacked, origin,
|
|
region, image_row_pitch, image_slice_pitch,
|
|
num_events_in_wait_list, event_wait_list, event, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(EnqueueUnmapMemObject,
|
|
"command_queue = 0x%016" PRIxPTR ", memobj = 0x%016" PRIxPTR
|
|
", mapped_ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)memobj, (uintptr_t)mapped_ptr,
|
|
num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueUnmapMemObject, command_queue, memobj, mapped_ptr,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueUnmapMemObject(command_queue, memobj, mapped_ptr, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueNDRangeKernel,
|
|
"command_queue = 0x%016" PRIxPTR ", kernel = 0x%016" PRIxPTR
|
|
", work_dim = %u, global_work_offset = 0x%016" PRIxPTR
|
|
", global_work_size = 0x%016" PRIxPTR ", local_work_size = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)kernel, work_dim, (uintptr_t)global_work_offset,
|
|
(uintptr_t)global_work_size, (uintptr_t)local_work_size, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueNDRangeKernel, command_queue, kernel, work_dim,
|
|
global_work_offset, global_work_size, local_work_size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueNDRangeKernel(command_queue, kernel, work_dim, global_work_offset,
|
|
global_work_size, local_work_size, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueNativeKernel,
|
|
"command_queue = 0x%016" PRIxPTR ", user_func = 0x%016" PRIxPTR
|
|
", args = 0x%016" PRIxPTR
|
|
", cb_args = %zu, num_mem_objects = %u, mem_list = 0x%016" PRIxPTR
|
|
", args_mem_loc = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)user_func, (uintptr_t)args, cb_args,
|
|
num_mem_objects, (uintptr_t)mem_list, (uintptr_t)args_mem_loc, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueNativeKernel, command_queue, user_func, args, cb_args,
|
|
num_mem_objects, mem_list, args_mem_loc, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueNativeKernel(command_queue, user_func, args, cb_args, num_mem_objects, mem_list,
|
|
args_mem_loc, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetCommandQueueProperty(cl_command_queue command_queue,
|
|
cl_command_queue_properties properties,
|
|
cl_bool enable,
|
|
cl_command_queue_properties *old_properties)
|
|
{
|
|
CL_EVENT(SetCommandQueueProperty,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", properties = %llu, enable = %u, old_properties = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, static_cast<unsigned long long>(properties), enable,
|
|
(uintptr_t)old_properties);
|
|
|
|
CommandQueueProperties propertiesPacked = PackParam<CommandQueueProperties>(properties);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetCommandQueueProperty, command_queue, propertiesPacked, enable,
|
|
old_properties);
|
|
|
|
return SetCommandQueueProperty(command_queue, propertiesPacked, enable, old_properties);
|
|
}
|
|
|
|
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_EVENT(
|
|
CreateImage2D,
|
|
"context = 0x%016" PRIxPTR ", flags = %llu, image_format = 0x%016" PRIxPTR
|
|
", image_width = %zu, image_height = %zu, image_row_pitch = %zu, host_ptr = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), (uintptr_t)image_format,
|
|
image_width, image_height, image_row_pitch, (uintptr_t)host_ptr, (uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateImage2D, context, flagsPacked, image_format, image_width,
|
|
image_height, image_row_pitch, host_ptr);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object = CreateImage2D(context, flagsPacked, image_format, image_width, image_height,
|
|
image_row_pitch, host_ptr, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(CreateImage3D,
|
|
"context = 0x%016" PRIxPTR ", flags = %llu, image_format = 0x%016" PRIxPTR
|
|
", image_width = %zu, image_height = %zu, image_depth = %zu, image_row_pitch = %zu, "
|
|
"image_slice_pitch = %zu, host_ptr = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR
|
|
"",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), (uintptr_t)image_format,
|
|
image_width, image_height, image_depth, image_row_pitch, image_slice_pitch,
|
|
(uintptr_t)host_ptr, (uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateImage3D, context, flagsPacked, image_format, image_width,
|
|
image_height, image_depth, image_row_pitch, image_slice_pitch,
|
|
host_ptr);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object =
|
|
CreateImage3D(context, flagsPacked, image_format, image_width, image_height, image_depth,
|
|
image_row_pitch, image_slice_pitch, host_ptr, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueMarker(cl_command_queue command_queue, cl_event *event)
|
|
{
|
|
CL_EVENT(EnqueueMarker, "command_queue = 0x%016" PRIxPTR ", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueMarker, command_queue, event);
|
|
|
|
return EnqueueMarker(command_queue, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueWaitForEvents(cl_command_queue command_queue,
|
|
cl_uint num_events,
|
|
const cl_event *event_list)
|
|
{
|
|
CL_EVENT(EnqueueWaitForEvents,
|
|
"command_queue = 0x%016" PRIxPTR ", num_events = %u, event_list = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, num_events, (uintptr_t)event_list);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueWaitForEvents, command_queue, num_events, event_list);
|
|
|
|
return EnqueueWaitForEvents(command_queue, num_events, event_list);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueBarrier(cl_command_queue command_queue)
|
|
{
|
|
CL_EVENT(EnqueueBarrier, "command_queue = 0x%016" PRIxPTR "", (uintptr_t)command_queue);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueBarrier, command_queue);
|
|
|
|
return EnqueueBarrier(command_queue);
|
|
}
|
|
|
|
cl_int CL_API_CALL clUnloadCompiler()
|
|
{
|
|
CL_EVENT(UnloadCompiler, "");
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(UnloadCompiler);
|
|
|
|
return UnloadCompiler();
|
|
}
|
|
|
|
void *CL_API_CALL clGetExtensionFunctionAddress(const char *func_name)
|
|
{
|
|
CL_EVENT(GetExtensionFunctionAddress, "func_name = 0x%016" PRIxPTR "", (uintptr_t)func_name);
|
|
|
|
ANGLE_CL_VALIDATE_POINTER(GetExtensionFunctionAddress, func_name);
|
|
|
|
return GetExtensionFunctionAddress(func_name);
|
|
}
|
|
|
|
cl_command_queue CL_API_CALL clCreateCommandQueue(cl_context context,
|
|
cl_device_id device,
|
|
cl_command_queue_properties properties,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateCommandQueue,
|
|
"context = 0x%016" PRIxPTR ", device = 0x%016" PRIxPTR
|
|
", properties = %llu, errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)device, static_cast<unsigned long long>(properties),
|
|
(uintptr_t)errcode_ret);
|
|
|
|
CommandQueueProperties propertiesPacked = PackParam<CommandQueueProperties>(properties);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateCommandQueue, context, device, propertiesPacked);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_command_queue object = CreateCommandQueue(context, device, propertiesPacked, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(CreateSampler,
|
|
"context = 0x%016" PRIxPTR
|
|
", normalized_coords = %u, addressing_mode = %u, filter_mode = %u, errcode_ret = "
|
|
"0x%016" PRIxPTR "",
|
|
(uintptr_t)context, normalized_coords, addressing_mode, filter_mode,
|
|
(uintptr_t)errcode_ret);
|
|
|
|
AddressingMode addressing_modePacked = PackParam<AddressingMode>(addressing_mode);
|
|
FilterMode filter_modePacked = PackParam<FilterMode>(filter_mode);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateSampler, context, normalized_coords, addressing_modePacked,
|
|
filter_modePacked);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_sampler object = CreateSampler(context, normalized_coords, addressing_modePacked,
|
|
filter_modePacked, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(EnqueueTask,
|
|
"command_queue = 0x%016" PRIxPTR ", kernel = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)kernel, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueTask, command_queue, kernel, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueTask(command_queue, kernel, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
// CL 1.1
|
|
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_EVENT(CreateSubBuffer,
|
|
"buffer = 0x%016" PRIxPTR
|
|
", flags = %llu, buffer_create_type = %u, buffer_create_info = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)buffer, static_cast<unsigned long long>(flags), buffer_create_type,
|
|
(uintptr_t)buffer_create_info, (uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateSubBuffer, buffer, flagsPacked, buffer_create_type,
|
|
buffer_create_info);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object =
|
|
CreateSubBuffer(buffer, flagsPacked, buffer_create_type, buffer_create_info, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetMemObjectDestructorCallback(cl_mem memobj,
|
|
void(CL_CALLBACK *pfn_notify)(cl_mem memobj,
|
|
void *user_data),
|
|
void *user_data)
|
|
{
|
|
CL_EVENT(SetMemObjectDestructorCallback,
|
|
"memobj = 0x%016" PRIxPTR ", pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR "",
|
|
(uintptr_t)memobj, (uintptr_t)pfn_notify, (uintptr_t)user_data);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetMemObjectDestructorCallback, memobj, pfn_notify, user_data);
|
|
|
|
return SetMemObjectDestructorCallback(memobj, pfn_notify, user_data);
|
|
}
|
|
|
|
cl_event CL_API_CALL clCreateUserEvent(cl_context context, cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateUserEvent, "context = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateUserEvent, context);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_event object = CreateUserEvent(context, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetUserEventStatus(cl_event event, cl_int execution_status)
|
|
{
|
|
CL_EVENT(SetUserEventStatus, "event = 0x%016" PRIxPTR ", execution_status = %d",
|
|
(uintptr_t)event, execution_status);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetUserEventStatus, event, execution_status);
|
|
|
|
return SetUserEventStatus(event, execution_status);
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetEventCallback(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)
|
|
{
|
|
CL_EVENT(
|
|
SetEventCallback,
|
|
"event = 0x%016" PRIxPTR ", command_exec_callback_type = %d, pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR "",
|
|
(uintptr_t)event, command_exec_callback_type, (uintptr_t)pfn_notify, (uintptr_t)user_data);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetEventCallback, event, command_exec_callback_type, pfn_notify,
|
|
user_data);
|
|
|
|
return SetEventCallback(event, command_exec_callback_type, pfn_notify, user_data);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueReadBufferRect(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)
|
|
{
|
|
CL_EVENT(EnqueueReadBufferRect,
|
|
"command_queue = 0x%016" PRIxPTR ", buffer = 0x%016" PRIxPTR
|
|
", blocking_read = %u, buffer_origin = 0x%016" PRIxPTR ", host_origin = 0x%016" PRIxPTR
|
|
", region = 0x%016" PRIxPTR
|
|
", buffer_row_pitch = %zu, buffer_slice_pitch = %zu, host_row_pitch = %zu, "
|
|
"host_slice_pitch = %zu, ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)buffer, blocking_read, (uintptr_t)buffer_origin,
|
|
(uintptr_t)host_origin, (uintptr_t)region, buffer_row_pitch, buffer_slice_pitch,
|
|
host_row_pitch, host_slice_pitch, (uintptr_t)ptr, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueReadBufferRect, command_queue, buffer, blocking_read,
|
|
buffer_origin, host_origin, region, buffer_row_pitch,
|
|
buffer_slice_pitch, host_row_pitch, host_slice_pitch, ptr,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueReadBufferRect(command_queue, buffer, blocking_read, buffer_origin, host_origin,
|
|
region, buffer_row_pitch, buffer_slice_pitch, host_row_pitch,
|
|
host_slice_pitch, ptr, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueWriteBufferRect(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)
|
|
{
|
|
CL_EVENT(EnqueueWriteBufferRect,
|
|
"command_queue = 0x%016" PRIxPTR ", buffer = 0x%016" PRIxPTR
|
|
", blocking_write = %u, buffer_origin = 0x%016" PRIxPTR
|
|
", host_origin = 0x%016" PRIxPTR ", region = 0x%016" PRIxPTR
|
|
", buffer_row_pitch = %zu, buffer_slice_pitch = %zu, host_row_pitch = %zu, "
|
|
"host_slice_pitch = %zu, ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)buffer, blocking_write, (uintptr_t)buffer_origin,
|
|
(uintptr_t)host_origin, (uintptr_t)region, buffer_row_pitch, buffer_slice_pitch,
|
|
host_row_pitch, host_slice_pitch, (uintptr_t)ptr, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueWriteBufferRect, command_queue, buffer, blocking_write,
|
|
buffer_origin, host_origin, region, buffer_row_pitch,
|
|
buffer_slice_pitch, host_row_pitch, host_slice_pitch, ptr,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueWriteBufferRect(command_queue, buffer, blocking_write, buffer_origin, host_origin,
|
|
region, buffer_row_pitch, buffer_slice_pitch, host_row_pitch,
|
|
host_slice_pitch, ptr, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
}
|
|
|
|
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_EVENT(EnqueueCopyBufferRect,
|
|
"command_queue = 0x%016" PRIxPTR ", src_buffer = 0x%016" PRIxPTR
|
|
", dst_buffer = 0x%016" PRIxPTR ", src_origin = 0x%016" PRIxPTR
|
|
", dst_origin = 0x%016" PRIxPTR ", region = 0x%016" PRIxPTR
|
|
", src_row_pitch = %zu, src_slice_pitch = %zu, dst_row_pitch = %zu, dst_slice_pitch = "
|
|
"%zu, num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)src_buffer, (uintptr_t)dst_buffer,
|
|
(uintptr_t)src_origin, (uintptr_t)dst_origin, (uintptr_t)region, src_row_pitch,
|
|
src_slice_pitch, dst_row_pitch, dst_slice_pitch, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueCopyBufferRect, command_queue, src_buffer, dst_buffer,
|
|
src_origin, dst_origin, region, src_row_pitch, src_slice_pitch,
|
|
dst_row_pitch, dst_slice_pitch, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueCopyBufferRect(command_queue, src_buffer, dst_buffer, src_origin, dst_origin,
|
|
region, src_row_pitch, src_slice_pitch, dst_row_pitch,
|
|
dst_slice_pitch, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
// CL 1.2
|
|
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_EVENT(CreateSubDevices,
|
|
"in_device = 0x%016" PRIxPTR ", properties = 0x%016" PRIxPTR
|
|
", num_devices = %u, out_devices = 0x%016" PRIxPTR ", num_devices_ret = 0x%016" PRIxPTR
|
|
"",
|
|
(uintptr_t)in_device, (uintptr_t)properties, num_devices, (uintptr_t)out_devices,
|
|
(uintptr_t)num_devices_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(CreateSubDevices, in_device, properties, num_devices, out_devices,
|
|
num_devices_ret);
|
|
|
|
return CreateSubDevices(in_device, properties, num_devices, out_devices, num_devices_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clRetainDevice(cl_device_id device)
|
|
{
|
|
CL_EVENT(RetainDevice, "device = 0x%016" PRIxPTR "", (uintptr_t)device);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(RetainDevice, device);
|
|
|
|
return RetainDevice(device);
|
|
}
|
|
|
|
cl_int CL_API_CALL clReleaseDevice(cl_device_id device)
|
|
{
|
|
CL_EVENT(ReleaseDevice, "device = 0x%016" PRIxPTR "", (uintptr_t)device);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(ReleaseDevice, device);
|
|
|
|
return ReleaseDevice(device);
|
|
}
|
|
|
|
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_EVENT(CreateImage,
|
|
"context = 0x%016" PRIxPTR ", flags = %llu, image_format = 0x%016" PRIxPTR
|
|
", image_desc = 0x%016" PRIxPTR ", host_ptr = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), (uintptr_t)image_format,
|
|
(uintptr_t)image_desc, (uintptr_t)host_ptr, (uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateImage, context, flagsPacked, image_format, image_desc,
|
|
host_ptr);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object =
|
|
CreateImage(context, flagsPacked, image_format, image_desc, host_ptr, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(CreateProgramWithBuiltInKernels,
|
|
"context = 0x%016" PRIxPTR ", num_devices = %u, device_list = 0x%016" PRIxPTR
|
|
", kernel_names = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, num_devices, (uintptr_t)device_list, (uintptr_t)kernel_names,
|
|
(uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateProgramWithBuiltInKernels, context, num_devices,
|
|
device_list, kernel_names);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_program object =
|
|
CreateProgramWithBuiltInKernels(context, num_devices, device_list, kernel_names, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
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_EVENT(CompileProgram,
|
|
"program = 0x%016" PRIxPTR ", num_devices = %u, device_list = 0x%016" PRIxPTR
|
|
", options = 0x%016" PRIxPTR ", num_input_headers = %u, input_headers = 0x%016" PRIxPTR
|
|
", header_include_names = 0x%016" PRIxPTR ", pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, num_devices, (uintptr_t)device_list, (uintptr_t)options,
|
|
num_input_headers, (uintptr_t)input_headers, (uintptr_t)header_include_names,
|
|
(uintptr_t)pfn_notify, (uintptr_t)user_data);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(CompileProgram, program, num_devices, device_list, options,
|
|
num_input_headers, input_headers, header_include_names, pfn_notify,
|
|
user_data);
|
|
|
|
return CompileProgram(program, num_devices, device_list, options, num_input_headers,
|
|
input_headers, header_include_names, pfn_notify, user_data);
|
|
}
|
|
|
|
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_EVENT(LinkProgram,
|
|
"context = 0x%016" PRIxPTR ", num_devices = %u, device_list = 0x%016" PRIxPTR
|
|
", options = 0x%016" PRIxPTR
|
|
", num_input_programs = %u, input_programs = 0x%016" PRIxPTR
|
|
", pfn_notify = 0x%016" PRIxPTR ", user_data = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, num_devices, (uintptr_t)device_list, (uintptr_t)options,
|
|
num_input_programs, (uintptr_t)input_programs, (uintptr_t)pfn_notify,
|
|
(uintptr_t)user_data, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(LinkProgram, context, num_devices, device_list, options,
|
|
num_input_programs, input_programs, pfn_notify, user_data);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_program object = LinkProgram(context, num_devices, device_list, options, num_input_programs,
|
|
input_programs, pfn_notify, user_data, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clUnloadPlatformCompiler(cl_platform_id platform)
|
|
{
|
|
CL_EVENT(UnloadPlatformCompiler, "platform = 0x%016" PRIxPTR "", (uintptr_t)platform);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(UnloadPlatformCompiler, platform);
|
|
|
|
return UnloadPlatformCompiler(platform);
|
|
}
|
|
|
|
cl_int CL_API_CALL clGetKernelArgInfo(cl_kernel kernel,
|
|
cl_uint arg_index,
|
|
cl_kernel_arg_info param_name,
|
|
size_t param_value_size,
|
|
void *param_value,
|
|
size_t *param_value_size_ret)
|
|
{
|
|
CL_EVENT(
|
|
GetKernelArgInfo,
|
|
"kernel = 0x%016" PRIxPTR
|
|
", arg_index = %u, param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, arg_index, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
KernelArgInfo param_namePacked = PackParam<KernelArgInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetKernelArgInfo, kernel, arg_index, param_namePacked, param_value_size,
|
|
param_value, param_value_size_ret);
|
|
|
|
return GetKernelArgInfo(kernel, arg_index, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
}
|
|
|
|
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_EVENT(EnqueueFillBuffer,
|
|
"command_queue = 0x%016" PRIxPTR ", buffer = 0x%016" PRIxPTR
|
|
", pattern = 0x%016" PRIxPTR
|
|
", pattern_size = %zu, offset = %zu, size = %zu, num_events_in_wait_list = %u, "
|
|
"event_wait_list = 0x%016" PRIxPTR ", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)buffer, (uintptr_t)pattern, pattern_size, offset,
|
|
size, num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueFillBuffer, command_queue, buffer, pattern, pattern_size, offset,
|
|
size, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueFillBuffer(command_queue, buffer, pattern, pattern_size, offset, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueFillImage(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)
|
|
{
|
|
CL_EVENT(EnqueueFillImage,
|
|
"command_queue = 0x%016" PRIxPTR ", image = 0x%016" PRIxPTR
|
|
", fill_color = 0x%016" PRIxPTR ", origin = 0x%016" PRIxPTR ", region = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)image, (uintptr_t)fill_color, (uintptr_t)origin,
|
|
(uintptr_t)region, num_events_in_wait_list, (uintptr_t)event_wait_list,
|
|
(uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueFillImage, command_queue, image, fill_color, origin, region,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueFillImage(command_queue, image, fill_color, origin, region,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueMigrateMemObjects,
|
|
"command_queue = 0x%016" PRIxPTR ", num_mem_objects = %u, mem_objects = 0x%016" PRIxPTR
|
|
", flags = %llu, num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, num_mem_objects, (uintptr_t)mem_objects,
|
|
static_cast<unsigned long long>(flags), num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
MemMigrationFlags flagsPacked = PackParam<MemMigrationFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueMigrateMemObjects, command_queue, num_mem_objects, mem_objects,
|
|
flagsPacked, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueMigrateMemObjects(command_queue, num_mem_objects, mem_objects, flagsPacked,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
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_EVENT(EnqueueMarkerWithWaitList,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, num_events_in_wait_list, (uintptr_t)event_wait_list,
|
|
(uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueMarkerWithWaitList, command_queue, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueMarkerWithWaitList(command_queue, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
}
|
|
|
|
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_EVENT(EnqueueBarrierWithWaitList,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, num_events_in_wait_list, (uintptr_t)event_wait_list,
|
|
(uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueBarrierWithWaitList, command_queue, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueBarrierWithWaitList(command_queue, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
}
|
|
|
|
void *CL_API_CALL clGetExtensionFunctionAddressForPlatform(cl_platform_id platform,
|
|
const char *func_name)
|
|
{
|
|
CL_EVENT(GetExtensionFunctionAddressForPlatform,
|
|
"platform = 0x%016" PRIxPTR ", func_name = 0x%016" PRIxPTR "", (uintptr_t)platform,
|
|
(uintptr_t)func_name);
|
|
|
|
ANGLE_CL_VALIDATE_POINTER(GetExtensionFunctionAddressForPlatform, platform, func_name);
|
|
|
|
return GetExtensionFunctionAddressForPlatform(platform, func_name);
|
|
}
|
|
|
|
// CL 2.0
|
|
cl_command_queue CL_API_CALL
|
|
clCreateCommandQueueWithProperties(cl_context context,
|
|
cl_device_id device,
|
|
const cl_queue_properties *properties,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateCommandQueueWithProperties,
|
|
"context = 0x%016" PRIxPTR ", device = 0x%016" PRIxPTR ", properties = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)device, (uintptr_t)properties, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateCommandQueueWithProperties, context, device, properties);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_command_queue object =
|
|
CreateCommandQueueWithProperties(context, device, properties, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_mem CL_API_CALL clCreatePipe(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)
|
|
{
|
|
CL_EVENT(
|
|
CreatePipe,
|
|
"context = 0x%016" PRIxPTR
|
|
", flags = %llu, pipe_packet_size = %u, pipe_max_packets = %u, properties = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), pipe_packet_size,
|
|
pipe_max_packets, (uintptr_t)properties, (uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreatePipe, context, flagsPacked, pipe_packet_size,
|
|
pipe_max_packets, properties);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object =
|
|
CreatePipe(context, flagsPacked, pipe_packet_size, pipe_max_packets, properties, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clGetPipeInfo(cl_mem pipe,
|
|
cl_pipe_info param_name,
|
|
size_t param_value_size,
|
|
void *param_value,
|
|
size_t *param_value_size_ret)
|
|
{
|
|
CL_EVENT(GetPipeInfo,
|
|
"pipe = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)pipe, param_name, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
PipeInfo param_namePacked = PackParam<PipeInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetPipeInfo, pipe, param_namePacked, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
|
|
return GetPipeInfo(pipe, param_namePacked, param_value_size, param_value, param_value_size_ret);
|
|
}
|
|
|
|
void *CL_API_CALL clSVMAlloc(cl_context context,
|
|
cl_svm_mem_flags flags,
|
|
size_t size,
|
|
cl_uint alignment)
|
|
{
|
|
CL_EVENT(SVMAlloc, "context = 0x%016" PRIxPTR ", flags = %llu, size = %zu, alignment = %u",
|
|
(uintptr_t)context, static_cast<unsigned long long>(flags), size, alignment);
|
|
|
|
SVM_MemFlags flagsPacked = PackParam<SVM_MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_POINTER(SVMAlloc, context, flagsPacked, size, alignment);
|
|
|
|
return SVMAlloc(context, flagsPacked, size, alignment);
|
|
}
|
|
|
|
void CL_API_CALL clSVMFree(cl_context context, void *svm_pointer)
|
|
{
|
|
CL_EVENT(SVMFree, "context = 0x%016" PRIxPTR ", svm_pointer = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)svm_pointer);
|
|
|
|
ANGLE_CL_VALIDATE_VOID(SVMFree, context, svm_pointer);
|
|
|
|
SVMFree(context, svm_pointer);
|
|
}
|
|
|
|
cl_sampler CL_API_CALL
|
|
clCreateSamplerWithProperties(cl_context context,
|
|
const cl_sampler_properties *sampler_properties,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateSamplerWithProperties,
|
|
"context = 0x%016" PRIxPTR ", sampler_properties = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)sampler_properties, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateSamplerWithProperties, context, sampler_properties);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_sampler object = CreateSamplerWithProperties(context, sampler_properties, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetKernelArgSVMPointer(cl_kernel kernel,
|
|
cl_uint arg_index,
|
|
const void *arg_value)
|
|
{
|
|
CL_EVENT(SetKernelArgSVMPointer,
|
|
"kernel = 0x%016" PRIxPTR ", arg_index = %u, arg_value = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, arg_index, (uintptr_t)arg_value);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetKernelArgSVMPointer, kernel, arg_index, arg_value);
|
|
|
|
return SetKernelArgSVMPointer(kernel, arg_index, arg_value);
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetKernelExecInfo(cl_kernel kernel,
|
|
cl_kernel_exec_info param_name,
|
|
size_t param_value_size,
|
|
const void *param_value)
|
|
{
|
|
CL_EVENT(SetKernelExecInfo,
|
|
"kernel = 0x%016" PRIxPTR
|
|
", param_name = %u, param_value_size = %zu, param_value = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, param_name, param_value_size, (uintptr_t)param_value);
|
|
|
|
KernelExecInfo param_namePacked = PackParam<KernelExecInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetKernelExecInfo, kernel, param_namePacked, param_value_size,
|
|
param_value);
|
|
|
|
return SetKernelExecInfo(kernel, param_namePacked, param_value_size, param_value);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueSVMFree(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)
|
|
{
|
|
CL_EVENT(EnqueueSVMFree,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", num_svm_pointers = %u, svm_pointers = 0x%016" PRIxPTR
|
|
", pfn_free_func = 0x%016" PRIxPTR ", user_data = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, num_svm_pointers, (uintptr_t)svm_pointers,
|
|
(uintptr_t)pfn_free_func, (uintptr_t)user_data, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueSVMFree, command_queue, num_svm_pointers, svm_pointers,
|
|
pfn_free_func, user_data, num_events_in_wait_list, event_wait_list,
|
|
event);
|
|
|
|
return EnqueueSVMFree(command_queue, num_svm_pointers, svm_pointers, pfn_free_func, user_data,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueSVMMemcpy(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)
|
|
{
|
|
CL_EVENT(EnqueueSVMMemcpy,
|
|
"command_queue = 0x%016" PRIxPTR ", blocking_copy = %u, dst_ptr = 0x%016" PRIxPTR
|
|
", src_ptr = 0x%016" PRIxPTR
|
|
", size = %zu, num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, blocking_copy, (uintptr_t)dst_ptr, (uintptr_t)src_ptr, size,
|
|
num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueSVMMemcpy, command_queue, blocking_copy, dst_ptr, src_ptr, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueSVMMemcpy(command_queue, blocking_copy, dst_ptr, src_ptr, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueSVMMemFill(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)
|
|
{
|
|
CL_EVENT(EnqueueSVMMemFill,
|
|
"command_queue = 0x%016" PRIxPTR ", svm_ptr = 0x%016" PRIxPTR
|
|
", pattern = 0x%016" PRIxPTR
|
|
", pattern_size = %zu, size = %zu, num_events_in_wait_list = %u, event_wait_list = "
|
|
"0x%016" PRIxPTR ", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)svm_ptr, (uintptr_t)pattern, pattern_size, size,
|
|
num_events_in_wait_list, (uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueSVMMemFill, command_queue, svm_ptr, pattern, pattern_size, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueSVMMemFill(command_queue, svm_ptr, pattern, pattern_size, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueSVMMap(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)
|
|
{
|
|
CL_EVENT(EnqueueSVMMap,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", blocking_map = %u, flags = %llu, svm_ptr = 0x%016" PRIxPTR
|
|
", size = %zu, num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, blocking_map, static_cast<unsigned long long>(flags),
|
|
(uintptr_t)svm_ptr, size, num_events_in_wait_list, (uintptr_t)event_wait_list,
|
|
(uintptr_t)event);
|
|
|
|
MapFlags flagsPacked = PackParam<MapFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueSVMMap, command_queue, blocking_map, flagsPacked, svm_ptr, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueSVMMap(command_queue, blocking_map, flagsPacked, svm_ptr, size,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueSVMUnmap(cl_command_queue command_queue,
|
|
void *svm_ptr,
|
|
cl_uint num_events_in_wait_list,
|
|
const cl_event *event_wait_list,
|
|
cl_event *event)
|
|
{
|
|
CL_EVENT(EnqueueSVMUnmap,
|
|
"command_queue = 0x%016" PRIxPTR ", svm_ptr = 0x%016" PRIxPTR
|
|
", num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, (uintptr_t)svm_ptr, num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueSVMUnmap, command_queue, svm_ptr, num_events_in_wait_list,
|
|
event_wait_list, event);
|
|
|
|
return EnqueueSVMUnmap(command_queue, svm_ptr, num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
// CL 2.1
|
|
cl_int CL_API_CALL clSetDefaultDeviceCommandQueue(cl_context context,
|
|
cl_device_id device,
|
|
cl_command_queue command_queue)
|
|
{
|
|
CL_EVENT(SetDefaultDeviceCommandQueue,
|
|
"context = 0x%016" PRIxPTR ", device = 0x%016" PRIxPTR
|
|
", command_queue = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)device, (uintptr_t)command_queue);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetDefaultDeviceCommandQueue, context, device, command_queue);
|
|
|
|
return SetDefaultDeviceCommandQueue(context, device, command_queue);
|
|
}
|
|
|
|
cl_int CL_API_CALL clGetDeviceAndHostTimer(cl_device_id device,
|
|
cl_ulong *device_timestamp,
|
|
cl_ulong *host_timestamp)
|
|
{
|
|
CL_EVENT(GetDeviceAndHostTimer,
|
|
"device = 0x%016" PRIxPTR ", device_timestamp = 0x%016" PRIxPTR
|
|
", host_timestamp = 0x%016" PRIxPTR "",
|
|
(uintptr_t)device, (uintptr_t)device_timestamp, (uintptr_t)host_timestamp);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetDeviceAndHostTimer, device, device_timestamp, host_timestamp);
|
|
|
|
return GetDeviceAndHostTimer(device, device_timestamp, host_timestamp);
|
|
}
|
|
|
|
cl_int CL_API_CALL clGetHostTimer(cl_device_id device, cl_ulong *host_timestamp)
|
|
{
|
|
CL_EVENT(GetHostTimer, "device = 0x%016" PRIxPTR ", host_timestamp = 0x%016" PRIxPTR "",
|
|
(uintptr_t)device, (uintptr_t)host_timestamp);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetHostTimer, device, host_timestamp);
|
|
|
|
return GetHostTimer(device, host_timestamp);
|
|
}
|
|
|
|
cl_program CL_API_CALL clCreateProgramWithIL(cl_context context,
|
|
const void *il,
|
|
size_t length,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateProgramWithIL,
|
|
"context = 0x%016" PRIxPTR ", il = 0x%016" PRIxPTR
|
|
", length = %zu, errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)il, length, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateProgramWithIL, context, il, length);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_program object = CreateProgramWithIL(context, il, length, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_kernel CL_API_CALL clCloneKernel(cl_kernel source_kernel, cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CloneKernel, "source_kernel = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)source_kernel, (uintptr_t)errcode_ret);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CloneKernel, source_kernel);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_kernel object = CloneKernel(source_kernel, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_int CL_API_CALL clGetKernelSubGroupInfo(cl_kernel kernel,
|
|
cl_device_id device,
|
|
cl_kernel_sub_group_info 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)
|
|
{
|
|
CL_EVENT(GetKernelSubGroupInfo,
|
|
"kernel = 0x%016" PRIxPTR ", device = 0x%016" PRIxPTR
|
|
", param_name = %u, input_value_size = %zu, input_value = 0x%016" PRIxPTR
|
|
", param_value_size = %zu, param_value = 0x%016" PRIxPTR
|
|
", param_value_size_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)kernel, (uintptr_t)device, param_name, input_value_size,
|
|
(uintptr_t)input_value, param_value_size, (uintptr_t)param_value,
|
|
(uintptr_t)param_value_size_ret);
|
|
|
|
KernelSubGroupInfo param_namePacked = PackParam<KernelSubGroupInfo>(param_name);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(GetKernelSubGroupInfo, kernel, device, param_namePacked,
|
|
input_value_size, input_value, param_value_size, param_value,
|
|
param_value_size_ret);
|
|
|
|
return GetKernelSubGroupInfo(kernel, device, param_namePacked, input_value_size, input_value,
|
|
param_value_size, param_value, param_value_size_ret);
|
|
}
|
|
|
|
cl_int CL_API_CALL clEnqueueSVMMigrateMem(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)
|
|
{
|
|
CL_EVENT(EnqueueSVMMigrateMem,
|
|
"command_queue = 0x%016" PRIxPTR
|
|
", num_svm_pointers = %u, svm_pointers = 0x%016" PRIxPTR ", sizes = 0x%016" PRIxPTR
|
|
", flags = %llu, num_events_in_wait_list = %u, event_wait_list = 0x%016" PRIxPTR
|
|
", event = 0x%016" PRIxPTR "",
|
|
(uintptr_t)command_queue, num_svm_pointers, (uintptr_t)svm_pointers, (uintptr_t)sizes,
|
|
static_cast<unsigned long long>(flags), num_events_in_wait_list,
|
|
(uintptr_t)event_wait_list, (uintptr_t)event);
|
|
|
|
MemMigrationFlags flagsPacked = PackParam<MemMigrationFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(EnqueueSVMMigrateMem, command_queue, num_svm_pointers, svm_pointers,
|
|
sizes, flagsPacked, num_events_in_wait_list, event_wait_list, event);
|
|
|
|
return EnqueueSVMMigrateMem(command_queue, num_svm_pointers, svm_pointers, sizes, flagsPacked,
|
|
num_events_in_wait_list, event_wait_list, event);
|
|
}
|
|
|
|
// CL 2.2
|
|
cl_int CL_API_CALL clSetProgramReleaseCallback(cl_program program,
|
|
void(CL_CALLBACK *pfn_notify)(cl_program program,
|
|
void *user_data),
|
|
void *user_data)
|
|
{
|
|
CL_EVENT(SetProgramReleaseCallback,
|
|
"program = 0x%016" PRIxPTR ", pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, (uintptr_t)pfn_notify, (uintptr_t)user_data);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetProgramReleaseCallback, program, pfn_notify, user_data);
|
|
|
|
return SetProgramReleaseCallback(program, pfn_notify, user_data);
|
|
}
|
|
|
|
cl_int CL_API_CALL clSetProgramSpecializationConstant(cl_program program,
|
|
cl_uint spec_id,
|
|
size_t spec_size,
|
|
const void *spec_value)
|
|
{
|
|
CL_EVENT(SetProgramSpecializationConstant,
|
|
"program = 0x%016" PRIxPTR
|
|
", spec_id = %u, spec_size = %zu, spec_value = 0x%016" PRIxPTR "",
|
|
(uintptr_t)program, spec_id, spec_size, (uintptr_t)spec_value);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetProgramSpecializationConstant, program, spec_id, spec_size,
|
|
spec_value);
|
|
|
|
return SetProgramSpecializationConstant(program, spec_id, spec_size, spec_value);
|
|
}
|
|
|
|
// CL 3.0
|
|
cl_int CL_API_CALL clSetContextDestructorCallback(cl_context context,
|
|
void(CL_CALLBACK *pfn_notify)(cl_context context,
|
|
void *user_data),
|
|
void *user_data)
|
|
{
|
|
CL_EVENT(SetContextDestructorCallback,
|
|
"context = 0x%016" PRIxPTR ", pfn_notify = 0x%016" PRIxPTR
|
|
", user_data = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)pfn_notify, (uintptr_t)user_data);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(SetContextDestructorCallback, context, pfn_notify, user_data);
|
|
|
|
return SetContextDestructorCallback(context, pfn_notify, user_data);
|
|
}
|
|
|
|
cl_mem CL_API_CALL clCreateBufferWithProperties(cl_context context,
|
|
const cl_mem_properties *properties,
|
|
cl_mem_flags flags,
|
|
size_t size,
|
|
void *host_ptr,
|
|
cl_int *errcode_ret)
|
|
{
|
|
CL_EVENT(CreateBufferWithProperties,
|
|
"context = 0x%016" PRIxPTR ", properties = 0x%016" PRIxPTR
|
|
", flags = %llu, size = %zu, host_ptr = 0x%016" PRIxPTR
|
|
", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)properties, static_cast<unsigned long long>(flags),
|
|
size, (uintptr_t)host_ptr, (uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateBufferWithProperties, context, properties, flagsPacked,
|
|
size, host_ptr);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object =
|
|
CreateBufferWithProperties(context, properties, flagsPacked, size, host_ptr, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
cl_mem CL_API_CALL clCreateImageWithProperties(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)
|
|
{
|
|
CL_EVENT(CreateImageWithProperties,
|
|
"context = 0x%016" PRIxPTR ", properties = 0x%016" PRIxPTR
|
|
", flags = %llu, image_format = 0x%016" PRIxPTR ", image_desc = 0x%016" PRIxPTR
|
|
", host_ptr = 0x%016" PRIxPTR ", errcode_ret = 0x%016" PRIxPTR "",
|
|
(uintptr_t)context, (uintptr_t)properties, static_cast<unsigned long long>(flags),
|
|
(uintptr_t)image_format, (uintptr_t)image_desc, (uintptr_t)host_ptr,
|
|
(uintptr_t)errcode_ret);
|
|
|
|
MemFlags flagsPacked = PackParam<MemFlags>(flags);
|
|
|
|
ANGLE_CL_VALIDATE_ERRCODE_RET(CreateImageWithProperties, context, properties, flagsPacked,
|
|
image_format, image_desc, host_ptr);
|
|
|
|
cl_int errorCode = CL_SUCCESS;
|
|
cl_mem object = CreateImageWithProperties(context, properties, flagsPacked, image_format,
|
|
image_desc, host_ptr, errorCode);
|
|
|
|
ASSERT((errorCode == CL_SUCCESS) == (object != nullptr));
|
|
if (errcode_ret != nullptr)
|
|
{
|
|
*errcode_ret = errorCode;
|
|
}
|
|
return object;
|
|
}
|
|
|
|
// cl_khr_icd
|
|
cl_int CL_API_CALL clIcdGetPlatformIDsKHR(cl_uint num_entries,
|
|
cl_platform_id *platforms,
|
|
cl_uint *num_platforms)
|
|
{
|
|
InitBackEnds(true);
|
|
|
|
CL_EVENT(IcdGetPlatformIDsKHR,
|
|
"num_entries = %u, platforms = 0x%016" PRIxPTR ", num_platforms = 0x%016" PRIxPTR "",
|
|
num_entries, (uintptr_t)platforms, (uintptr_t)num_platforms);
|
|
|
|
ANGLE_CL_VALIDATE_ERROR(IcdGetPlatformIDsKHR, num_entries, platforms, num_platforms);
|
|
|
|
return IcdGetPlatformIDsKHR(num_entries, platforms, num_platforms);
|
|
}
|
|
|
|
} // namespace cl
|