1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

Nouveau Can Do OpenCL Compute For Open-Source NVIDIA

Nouveau

Published on 06 February 2012 08:50 PM EST
Written by Michael Larabel in Nouveau
10 Comments

There's another big accomplishment within the open-source graphics camp: Nouveau developers now having an initial working OpenCL implementation for NVIDIA GeForce graphics hardware on the driver that the Linux community developed themselves via reverse-engineering without NVIDIA's support.

This past weekend at FOSDEM 2012 in Brussels was a presentation by Francisco Jerez concerning OpenCL support for the reverse-engineered open-source NVIDIA graphics driver. Francisco is the developer that the X.Org Foundation has been paying to do some OpenCL work since none of the open-source Linux graphics drivers have supported this GPGPU technology yet.

At the end of last month Francisco reported on his OpenCL code nearing a working state while at FOSDEM he shared that the initial NV50 code for OpenCL is in fact working -- he then showed off the OpenCL-Nouveau support working with clinfo and then a few OpenCL demos on Linux with this unofficial graphics card driver.

The Nouveau NV50 driver is what handles the GeForce 8/9/100/200/300 series, but not the newer GeForce 400/500 "Fermi" graphics cards. OpenCL support there is still much more early on with the developers still working out other Fermi features and bugs.

Nouveau Can Do OpenCL Compute For Open-Source NVIDIA


The community-spawned OpenCL support within Nouveau takes advantage of the earlier work done by Zack Rusin on the Clover state tracker for Gallium3D in recent years and then this past year during the work done as part of Google's Summer of Code. With the Clover/OpenCL state tracker for Gallium3D, LLVM/Clang is used as the OpenCL compiler.

While AMD has been paying for open-source OpenCL love and the open-source Radeon OpenCL support is still behind and not ready for showing off OpenCL demos, Nouveau NV50 doing OpenCL is quite an achievement. Intel's Open-Source Technology Center team working on graphics also hasn't been up to anything with OpenCL since they don't use the Gallium3D driver architecture and another Intel group offers a CPU-based closed-source OpenCL SDK.

PathScale is also another company that's been playing around with open-source OpenCL GPU-based acceleration using their fork of the Nouveau driver.

Among the work that's still left for Francisco or others to do with the Nouveau OpenCL support beyond supporting the latest-generation Fermi or upcoming Kepler graphics processors is still the need for an LLVM back-end for TGSI (the LLVM back-end in Nouveau is still a ways off so TGSI is being relied upon as the IR), DRM authentication support without an X.Org Server, and inter-GPU synchronization and resource sharing support. This will take a considerable amount of kernel work to do, as talked about during the hour-long presentation.

Unfortunately this current Nouveau OpenCL work done by Francisco Jerez isn't in the upstream Nouveau code-base but rather a separate branched Git repository. This is still out-of-tree work and it's not clear when it will be merged, but is already out of the question for the soon-to-be-out Mesa 8.0. The next hope would be seeing Mesa 8.1 be more OpenCL compute friend when that arrives in the middle of 2012.

The Nouveau camp also still has other significant problems to worry about besides just implementing OpenCL support across the spectrum of NVIDIA hardware, but regardless seeing the OpenCL demos first-hand this weekend was quite impressive.

For those wanting to learn more about the ongoing OpenCL Nouveau work, embedded below is a video I recorded from the Brussels presentation.


About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Linux Hardware Reviews
  1. AMD Launches New FX CPUs, Cuts Prices On Existing Processors
  2. Preview: AMD's FX-9590 Eight-Core At Up To 5.0GHz On Linux
  3. Intel Launches The Core i7 5960X, Mighty Powerful Haswell-E CPUs
  4. AMD Radeon R9 290: Gallium3D vs. Catalyst Drivers
Latest Linux Articles
  1. LLVM Clang 3.5 Brings Some Compiler Performance Improvements
  2. Ondemand vs. Performance CPU Governing For AMD FX CPUs On Linux 3.17
  3. How Intel Graphics On Linux Compare To Open-Source AMD/NVIDIA Drivers
  4. The Fastest NVIDIA GPUs For Open-Source Nouveau With Steam Linux Gaming
Latest Linux News
  1. New Group Calls For Boycotting Systemd
  2. The Features To Find With The Imminent Release Of LLVM/Clang 3.5
  3. Borderlands 2 Is Coming To Linux
  4. The Witcher 2 Ups The Performance More & Works Around Catalyst Bug
  5. Running Gallium3D's LLVMpipe On The Eight-Core 5GHz CPU
  6. Trying Intel OpenCL On Linux For Video Encoding
  7. GSoC 2014 Yielded Some Improvements For Mesa/X.Org This Year
  8. webOS Lives On As LuneOS With New Release
  9. Marek Lands Radeon Gallium3D HyperZ Improvements
  10. Mozilla Firefox 32 Surfaces With HTML5, Developer Changes
Latest Forum Discussions
  1. Lennart Poettering Talks Up His New Linux Vision That Involves Btrfs
  2. nv and xorg.conf under Debian PPC
  3. AMD graphics doesn't work with AMD Catalyst drivers
  4. Best Radeon for a Power Mac G5?
  5. The dangers of Linux kernel development
  6. Updated and Optimized Ubuntu Free Graphics Drivers
  7. AMD Releases UVD Video Decode Support For R600 GPUs
  8. SSD seems slow