Go to file
lengyang3 351c05c8e7 fix BUILD.gn format check error
Signed-off-by: lengyang3 <lengyang3@hisilicon.com>
2023-12-19 13:29:02 +08:00
.github/workflows re-enable format string warning in CI 2020-12-09 11:53:44 -05:00
CL update opencl header version to v2022.05.18 2023-12-19 12:46:19 +08:00
include 添加开发板GLES_impl路径,封装opencl函数clEnqueueReadBufferRect接口 2023-08-23 10:29:15 +08:00
src 添加开发板GLES_impl路径,封装opencl函数clEnqueueReadBufferRect接口 2023-08-23 10:29:15 +08:00
tests update opencl header version to v2022.05.18 2023-12-19 12:46:19 +08:00
BUILD.gn fix BUILD.gn format check error 2023-12-19 13:29:02 +08:00
build.py update opencl header version to v2022.05.18 2023-12-19 12:46:19 +08:00
bundle.json 修改BUILD.gn的output_name字段 2023-06-26 10:13:19 +08:00
CMakeLists.txt update opencl header version to v2022.05.18 2023-12-19 12:46:19 +08:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2018-10-10 15:50:24 -04:00
conanfile.py update opencl header version to v2022.05.18 2023-12-19 12:46:19 +08:00
LICENSE Change license to Apache 2.0 (#76) 2020-03-25 00:52:39 -07:00
OAT.xml fix license bug 2022-09-22 15:37:15 +08:00
README_zh.md add wrapper 2022-08-31 17:51:26 +08:00
README.md update opencl header version to v2022.05.18 2023-12-19 12:46:19 +08:00
README.OpenSource add README.OpenSource 2022-03-24 06:27:07 -07:00

OpenCLTM API Headers

This repository contains C language headers for the OpenCL API.

The authoritative public repository for these headers is located at:

https://github.com/KhronosGroup/OpenCL-Headers

Issues, proposed fixes for issues, and other suggested changes should be created using Github.

Build instructions

While the OpenCL Headers can be built and installed in isolation, it is part of the OpenCL SDK. If looking for streamlined build experience and a complete development package, refer to the SDK build instructions instead of the following guide.

Dependencies

  • The OpenCL Headers CMake package support uses CMake for its build system. If CMake is not provided by your build system or OS package manager, please consult the CMake website.

Example Build

While the headers may just be copied as-is, this repository also contains a CMake script with an install rule to allow for packaging the headers.

cmake -S . -B build -DCMAKE_INSTALL_PREFIX=/chosen/install/prefix
cmake --build build --target install

Example Use

Example CMake invocation

cmake -D CMAKE_PREFIX_PATH=/chosen/install/prefix /path/to/opencl/app 

and sample CMakeLists.txt

cmake_minimum_required(VERSION 3.0)
cmake_policy(VERSION 3.0...3.18.4)
project(proj)
add_executable(app main.cpp)
find_package(OpenCLHeaders REQUIRED)
target_link_libraries(app PRIVATE OpenCL::Headers)

Branch Structure

The OpenCL API headers in this repository are Unified headers and are designed to work with all released OpenCL versions. This differs from previous OpenCL API headers, where version-specific API headers either existed in separate branches, or in separate folders in a branch.

Compiling for a Specific OpenCL Version

By default, the OpenCL API headers in this repository are for the latest OpenCL version (currently OpenCL 3.0). To use these API headers to target a different OpenCL version, an application may #define the preprocessor value CL_TARGET_OPENCL_VERSION before including the OpenCL API headers. The CL_TARGET_OPENCL_VERSION is a three digit decimal value representing the OpenCL API version.

For example, to enforce usage of no more than the OpenCL 1.2 APIs, you may include the OpenCL API headers as follows:

#define CL_TARGET_OPENCL_VERSION 120
#include <CL/opencl.h>

Directory Structure

README.md               This file
LICENSE                 Source license for the OpenCL API headers
CL/                     Unified OpenCL API headers tree

License

See LICENSE.


OpenCL and the OpenCL logo are trademarks of Apple Inc. used by permission by Khronos.