-
Notifications
You must be signed in to change notification settings - Fork 62
Home
Oclgrind is an open source SPIR interpreter and OpenCL device simulator. The core of this project is an interpreter for SPIR, which can simulate the execution of an OpenCL kernel running on a virtual OpenCL device. This project aims to provide a platform with which a variety of useful tools can be created to aid OpenCL application development.
The execution of kernels is simulated on an abstract OpenCL device. This device exhibits the properties of the OpenCL execution model; it has four distinct memory address spaces and is aware of work-items, work-groups and the various execution and synchronisation constructs available within OpenCL. The simulation does not model any architecture specific properties such as SIMD execution or cache hierarchies. This means that the execution of kernels within Oclgrind is semantically correct with respect to the OpenCL standard, but completely architecture agnostic. An implementation of the OpenCL 1.2 runtime API is provided as a frontend, allowing existing OpenCL applications to target the simulator without requiring any modifications.
At present, Oclgrind includes support for the following features:
- Detecting memory access errors (such as reading/writing outside the bounds of an array)
- Interactive kernel debugging
- Detecting work-group divergence (barriers and async copies)
- Data-race detection
- Collecting histograms of instructions executed
- Logging OpenCL runtime API errors
Oclgrind is being developed by James Price and Simon McIntosh-Smith of the University of Bristol, and is provided under a 3-clause BSD license. Contributions in the form of bug reports, feature suggestions and pull-requests are always welcome. Please get in touch by raising bugs on the GitHub issues page or by emailing the developer.