Bug: 326052668

Clone this repo:
  1. 5ccd379 Add janitors to the OWNERS file by Sadaf Ebrahimi · 5 weeks ago main
  2. 3cc2575 Merge remote-tracking branch 'origin/upstream' am: 99cde8603b am: bbc2d0cbd6 by Frank Piva · 8 months ago android15-tests-dev aml_adb_351010000 aml_ads_351017080 aml_ads_351121120 aml_art_350913340 aml_art_351011240 aml_art_351011340 aml_art_351110180 aml_ase_351010000 aml_ase_351112060 aml_ase_351114000 aml_cbr_350910020 aml_cbr_351011020 aml_cbr_351111000 aml_con_351010000 aml_con_351110000 aml_doc_350915120 aml_doc_351012120 aml_doc_351113060 aml_ext_350912020 aml_ext_351122080 aml_ext_351312060 aml_hef_350921160 aml_hef_351016140 aml_hef_351120040 aml_ips_351010000 aml_ips_351111040 aml_med_350914000 aml_med_351010060 aml_mpr_350914160 aml_mpr_351013100 aml_mpr_351013160 aml_mpr_351113060 aml_mpr_351113100 aml_odp_351020000 aml_odp_351121040 aml_per_350910080 aml_per_351014000 aml_per_351112280 aml_per_351112300 aml_res_351011000 aml_res_351111020 aml_rkp_350910000 aml_rkp_351011000 aml_sch_351010000 aml_sdk_350910000 aml_sdk_351110000 aml_sta_350911020 aml_sta_351110040 aml_tet_350911120 aml_tet_351010220 aml_tet_351110060 aml_uwb_350911040 aml_uwb_351011040 aml_wif_350912040 aml_wif_351010040 aml_wif_351110060
  3. bbc2d0c Merge remote-tracking branch 'origin/upstream' am: 99cde8603b by Frank Piva · 8 months ago
  4. 747c5d0 Merge remote-tracking branch 'goog/mirror-aosp-main' by Jeremy Kemp · 9 months ago
  5. 99cde86 Merge remote-tracking branch 'origin/upstream' by Frank Piva · 10 months ago

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>

Controlling Function Prototypes

By default, the OpenCL API headers in this repository declare function prototypes for every known core OpenCL API and OpenCL extension API. If this is not desired, the declared function prototypes can be controlled by the following preprocessor defines:

  • CL_NO_PROTOTYPES: No function prototypes will be declared. This control applies to core OpenCL APIs and OpenCL extension APIs.
  • CL_NO_CORE_PROTOTYPES: No function prototypes will be declared for core OpenCL APIs.
  • CL_NO_EXTENSION_PROTOTYPES: No function prototypes will be declared for OpenCL extension APIs. This control applies to all OpenCL extension APIs.
  • CL_NO_ICD_DISPATCH_EXTENSION_PROTOTYPES: No function prototypes will be declared for OpenCL extension APIs that are in the ICD dispatch table for historical reasons.
  • CL_NO_NON_ICD_DISPATCH_EXTENSION_PROTOTYPES: No function prototypes will be declared for OpenCL extension APIs that are not in the ICD dispatch table.

For example, to declare function prototypes for core OpenCL 3.0 APIs only, you may include the OpenCL API headers as follows:

#define CL_TARGET_OPENCL_VERSION 300
#define CL_NO_EXTENSION_PROTOTYPES
#include <CL/opencl.h>

Compatibility Notes

OpenCL values backward compatibility and in most cases an application using an older version of the OpenCL API headers can seamlessly update to a newer version of the OpenCL API headers. In rare cases, though, the OpenCL API headers may break backward compatibility:

  • Very rarely, there may be bugs or other issues in the OpenCL API headers that cannot be fixed without breaking compatibility.
  • The OpenCL API headers for provisional features or provisional extensions may be changed in a way that breaks compatibility.

Applications or libraries that require stable OpenCL API headers are encouraged to use tagged or released OpenCL API headers. We will do our best to document any breaking changes in the description of each release. The OpenCL API headers are tagged at least as often as each OpenCL specification release.

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.