NEO should work on any modern Linux distribution (i.e. Ubuntu, Fedora, etc.) with default / stock configuration (no kernel patches), assuming the underlying kernel's drm subsystem is 4.7 or higher. Newer platforms will require a kernel version that provides support for that platform (e.g. Coffee Lake requires kernel 4.14 or higher).
Our default (most frequent) validation config is currently (as of Q4'18) Ubuntu 18.04 LTS.
Note: Neo will not work correctly on legacy kernels with Intel patches (e.g. 4.7.0.intel.r4.0).
Our closed-source driver for Windows is using the same codebase. At this time, we do not support compilation of the OpenCL stack for Windows. It is our long-term intention to offer that option.
Our Windows release process takes up to several weeks before drivers are available through intel.com and/or Windows update. Features available in github will be available on Windows later.
Note: Older platforms (e.g. Broadwell) are considered to be in maintenance mode for Windows.
The code can be ported and cross-compiled for Android systems. It is our long-term intention to offer that option.
See README.md.
To check support for any device, you can follow these steps:
- Go to Ark and find your Device ID
- Find the corresponding device ID label in GMM
- Check if this device ID label is enumerated in the supported device list
We will start adding platform support after platform is disclosed by Intel. It is our intention to offer full support ahead of platform's market availability.
See README.md.
Any platforms supporting OpenCL 2.1 are eligible for move to OpenCL 2.2.
You can enable a higher version of OpenCL using the ForceOCLVersion debug flag.
This is a mechanism to cache binary representations of OpenCL kernels provided in text form by the application. By storing the binary representations, compiling is required only the first time, which improves performance.
In the working directory, manually create cl_cache directory. The driver will use this directory to store the binary representations of the compiled kernels. Note: This will work on all supported OSes.
Cached kernels can be stored in a different directory than the default one. This is useful when the application is installed into a directory for which the user doesn't have permissions.
Set the environment variable named cl_cache_dir to new location of cl_cache directory.
If the application's directory is /home/user/Document, by default cl_cache will be stored in /home/user/Document/cl_cache.
If the new path should be /home/user/Desktop/cl_cache_place, set environment variable cl_cache_dir to /home/user/Desktop/cl_cache_place.
export cl_cache_dir=/home/user/Desktop/cl_cache_placeSubsequent application runs with passed source code and cl_cache_dir environment variable set will reuse previously cached kernel binaries instead of compiling kernels from source.
To set the new location of cl_cache directory - in the registry HKEY_LOCAL_MACHINE\SOFTWARE\Intel\IGFX\OCL:
- add key
cl_cache_dir - add string value named <path_to_app> to
cl_cache_dirkey - set data of added value to desired location of cl_cache
If application is located in C:\Program Files\application\app.exe, by default cl_cache will be stored in C:\Program Files\application\cl_cache.
If the new path should be C:\Users\USER\Documents\application\cl_cache, to subkey HKEY_LOCAL_MACHINE\SOFTWARE\Intel\IGFX\OCL\cl_cache_dir add string value named C:\Program Files\application\app.exe with data C:\Users\USER\Documents\application\cl_cache.
e.g.
string value : HKEY_LOCAL_MACHINE\SOFTWARE\Intel\IGFX\OCL\cl_cache_dir\C:\Program Files\application\app.exe
data : C:\Users\USER\Documents\application\cl_cache
Neo will look for string value (REG_SZ) C:\Program Files\application\app.exe in key HKEY_LOCAL_MACHINE\SOFTWARE\Intel\IGFX\OCL\cl_cache_dir. Data of this string value will be used as new cl_cache dump directory for this specific application.
- Not thread safe. (Workaround: Make sure your clBuildProgram calls are executed in thread safe fashion.)
- Binary representation may not be compatible between various versions of NEO and IGC drivers. (Workaround: Manually empty cl_cache directory prior to update)
- Cache is not automatically cleaned. (Workaround: Manually empty cl_cache directory)
- Cache may exhaust disk space and cause further failures. (Workaround: Monitor and manually empty cl_cache directory)
- Cache is not process safe.
Current implementation of out of order queues allows multiple kernels to be run concurently. This allows for better device utilization in scenarios where single kernel doesn't fill whole device.
More details can be found here:
- Turning on profiling on out of order command queue serializes kernel execution.
- Blocking command queue with user events blocks all further submissions until event is unblocked.
- Commands blocked by user events, when unblocked are serialized as well.
NEO OpenCL team is part of VTT (Visual Technologies Team). Historically, our team was responsible for delivery of the closed source OpenCL driver for Windows, Linux, and Android.
Most of the developers are located in Poland (UTC+1 timezone).
- Go to: https://jobs.intel.com/ListJobs/All/Search/city/Gdansk/
- Filter for OpenCL in the job title
- Browse the descriptions looking for positions mentioning this GitHub repository