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 Benchmarking Platform
Phoromatic Test Orchestration

In Road To OpenCL, R600g LLVM Back-End Arrives

AMD

Published on 09 December 2011 04:24 PM EST
Written by Michael Larabel in AMD
30 Comments

Before calling it a week, Tom Stellard at AMD published a Git branch that offers up an LLVM shader back-end for the AMD R600 Gallium3D driver. This is one of the steps in bringing Compute/OpenCL support to the open-source AMD Radeon Linux graphics drivers.

Tom Stellard announced on Friday afternoon this R600g LLVM shader back-end branch to the Mesa developer's mailing list. Tom's r600g-llvm-shader branch of his Mesa repository offers a TGSI (the current Gallium3D IR) to LLVM IR converter, changes to Gallivm to make it portable with the TGSI-to-LLVM converter, and the LLVM back-end for R600g itself. The TGSI-to-LLVM converter will likely be of use to more Gallium3D drivers besides the R600g driver itself, since TGSI is universal to the drivers and not Radeon-specific.

This LLVM back-end is based upon AMD's AMDIL LLVM back-end for OpenCL with various modifications. Tom says this new shader back-end currently passes 99% of the Piglit regression tests that work with the current R600g shader back-end. The failures are coming from unimplemented texture instructions and on a current lack of indirect addressing support. The LLVM back-end also isn't optimized for VLIW at this point plus other optimizations are lacking. "The optimizations in r600_asm.c are able to do some instruction packing, but the resulting code is not yet as good as the current backend."

And here's the key part of his message:
The main motivation for this LLVM backend is to help bring compute/OpenCL support to r600g by making it easier to support different compiler frontends. I don't have a concrete plan for integrating this into mainline Mesa yet, but I don't expect it to be in the next release. I would really like to make it compatible with LLVM 3.0 before it gets merged (it only works with LLVM 2.9 now), but if compute support evolves quickly, I might be tempted to push the 2.9 version into the master branch.

More information coming soon.

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 Articles & Reviews
  1. GeForce GTX 750 Series: Nouveau vs. NVIDIA Linux Driver Performance
  2. GLAMOR + RadeonSI 2D Acceleration Is Quite Good For Open-Source AMD 2D Performance
  3. AMD Radeon R9 290 OpenGL On Ubuntu 15.04: Catalyst vs. RadeonSI Gallium3D
  4. Ubuntu 15.04 Offers Faster OpenGL For AMD Radeon GPUs On Open-Source
  5. Ubuntu 15.04 Brings Some Graphics Performance Improvements For Intel Haswell
  6. Sub-$20 802.11n USB WiFi Adapter That's Linux Friendly
Latest Linux News
  1. HHVM 3.7 Brings More Performance Improvements
  2. Experimental DragonFlyBSD Code Adds Experimental Broadwell Graphics
  3. Virt-Manager 1.2.0 Brings OVMF/AAVMF Support For UEFI In VMs
  4. Interesting GSoC 2015 Projects: Wine D3DRM, GameStream, NaCL Fun
  5. An Ubuntu Phone Will Ship This Year With The Converged Unity Experience
  6. Ubuntu 15.10 Is Codenamed The Wily Werewolf
  7. Mono 4 Is Planned For Fedora 23
  8. Ubuntu 15.10's "W" Codename Being Revealed Soon
  9. The Six X.Org Summer GSoC Projects For 2015
  10. Linux 4.1-RC2 Kernel Released
Most Viewed News This Week
  1. Trying Out Microsoft Visual Studio Code On Linux
  2. Microsoft Releases New Code IDE For Linux!
  3. Improvements On The Way For GNOME's Nautilus File Manager
  4. Kodi 15.0 Beta 1 Released
  5. A Lot Of Improvements Are Coming For Mir 0.13, Including Work Towards Libinput
  6. Mono 4.0 Makes Use Of Microsoft's Open-Source Code, C# 6.0
  7. GCC 4.9.2 vs. GCC 5 Benchmarks On An Intel Xeon Haswell
  8. QEMU 2.3 Officially Released