Khronos SPIR For OpenCL Brings Binary Compatibility

Posted by Michael Larabel on September 12, 2012

One of the latest initiatives out of the Khronos Group -- the industry consortium that leads various open industry standards like OpenGL, OpenCL, and WebGL -- is SPIR. The goal of Khronos SPIR is to provide a Standard Portable IR for the OpenCL kernel language.

The provisional Khronos SPIR 1.0 specification was released in late August and in the past few days the SPIR discussion has ignited on the LLVM development list, since Khronos is actually basic this OpenCL kernel IR upon the LLVM IR.

SPIR specifies a standard intermediate representation (IR) to be used for the OpenCL kernel language, or simply said it's a standard IR for OpenCL programs so that there's binary compatibility between OpenCL drivers.

The Standard Portable IR is derived from LLVM and its IR, which already is leveraged quite extensively throughout the OpenCL/GPGPU and computing worlds. LLVM was chosen by the Khronos Group since it was deemed to be "highly portable" with its many back-ends and the open-source compiler infrastructure suits the needs of the Khronos stakeholders.

In theory, a SPIR front-end can generate OpenCL binaries in this IR format that can then be directly sent to any OpenCL drivers supporting SPIR. SPIR though doesn't govern the design and implementation of such front-ends. "Today, many of the OpenCL vendors base their technology on LLVM. This makes LLVM IR the de facto OpenCL IR and the immediate candidate to be considered by the Khronos members. An analysis showed that LLVM IR has its limitations but in general provides a very good solution for SPIR."

From Intel's Boaz Ouriel, here's his description from the LLVMdev mailing list thread why the SPIR work is important:
SPIR offers binary portability between OpenCL implementations, and a stable target for 3rd party compilers without having to go through OpenCL "C".

Binary compatibility simplifies the support burden for developers delivering applications that use OpenCL. The same application can be delivered in fully binary form and work across existing and future OpenCL implementations supporting SPIR. This helps the entire OpenCL ecosystem.

Generally speaking OpenCL is a JIT environment and as such deserves and requires an intermediate representation like other major JIT environments already have.

Also, some developers using OpenCL have requested portability at binary level. Today OpenCL offers portability only at the source level with OpenCL “C”. They are concerned with protecting their IP by meeting “Digital Millennium Copyright Act” requirements. Today, those companies are forced to distribute their OpenCL code using device specific binaries. This leads to many difficulties for SW developers and end users. In addition, the binaries are not guaranteed to be functionally working as new devices and vendors appear in the market. This constraint places OpenCL standard in a disadvantage compared to other standards which already have a portable binary distribution form.
Aside from that original mailing list thread, there's also now a forked thread.

The provisional SPIR 1.0 specification is available for viewing from Khronos.org (PDF).

Discuss this article in our forums, IRC channel, or email the author. You can also follow our content via RSS and on social networks like Facebook, Identi.ca, and Twitter (@Phoronix and @MichaelLarabel). Subscribe to Phoronix Premium to view our content without advertisements, view entire articles on a single page, and experience other benefits.
Latest Hardware Reviews
  1. Sumo Lounge Emperor
  2. Gallium3D Continues Improving OpenGL For Older Radeon GPUs
  3. 15-Way Open vs. Closed Source NVIDIA/AMD Linux GPU Comparison
  4. Nouveau vs. NVIDIA Linux Comparison Shows Shortcomings
Latest Software Articles
  1. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
  2. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
  3. F2FS File-System Shows Regressions On Linux 3.10
  4. Previewing The Radeon Gallium3D Shader Optimizations
Latest Linux News
  1. Mageia 3 Released, Still Using Legacy GRUB
  2. NetBSD 6.1 Brings In More Features
  3. Using Six Monitors With AMD's Open-Source Linux Driver
  4. Benchmarking The Intel P-State, CPUfreq Changes
  5. FreeBSD Still Working On Next-Gen Package Manager
  6. DNF Still Advancing As Experimental Yum For Fedora
  7. Logitech Begins Supporting Linux Users
  8. Modern Intel Gallium3D Driver Still Being Toyed With
  9. Linux 3.10 Kernel Benchmarks On A Core i7 Laptop
  10. GCC 4.8.1 Compiler Due To Be Out Next Week
  11. Linux 3.10 Kernel Benchmarks For Intel Ivy Bridge
Latest Forum Talk
  1. Using Six Monitors With AMD's Open-Source Linux...
  2. Mageia 3 Released, Still Using Legacy GRUB
  3. Sumo Lounge Emperor
  4. BHyVe: A New Hypervisor Coming To FreeBSD 10.0
  5. Benchmarking The Intel P-State, CPUfreq Changes
  6. DRM Moves Ahead With HTML5 Specification
  1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Motherboards
  5. Peripherals
  6. Processors
  7. Software
  8. Operating Systems
  9. All Articles
  1. Linux Benchmarking
  2. OpenBenchmarking.org
  3. Phoronix Test Suite