Mesa Compiler Stacks, A Hard Dependency On LLVM

Posted by Michael Larabel on September 14, 2011

Tom Stellard, the former Google Summer of Code student who worked on R300 GLSL improvements and a new register allocator, is now working for AMD and his work is focused on bringing up open-source OpenCL / GPGPU support in the Radeon Linux driver.

The OpenCL implementation for the open-source Radeon Linux driver will be relying upon the Mesa Gallium3D "Clover" OpenCL state tracker. This will rely heavily on the LLVM compiler with the Clang front-end. LLVM is used for its optimization library, back-end generators for x86/ARM/PPC, etc. The plan of attack is to go from OpenCL C to compile with Clang to LLVM ASM and then pass it to the LLVM back-end and to then generate the targeted machine code. The hope is also to do some code sharing between OpenCL and GLSL.

What's still to be determined is whether to integrate the LLVM back-end into each Gallium3D hardware driver or to write an LLVM back-end that simply generates TGSI. If going with the approach of having an LLVM back-end for each Gallium3D driver, it's easier to write GPU-specific optimizations and makes a better trivial shader compiler, but might need to use LLVM for shaders and each driver would need to write its own LLVM back-end to generate code for the respective target/architecture. With the later approach of just having one LLVM back-end that can generate TGSI instructions, which any Gallium3D driver can understand, they can re-use the current code emitters and only one back-end would be needed, but TGSI would need to be extended to support OpenCL functionality.

If going with a TGSI to LLVM converter, this already exists for the most part thanks to the LLVMpipe Gallium3D driver that is already doing these translations. Tom Stellard has been working on the TGSI to LLVM converter support and an LLVM back-end for R600g. John Bridgman also shared during the XDC2011 talk that Tom is playing internally with using AMD IL and some other things as part of this open-source Radeon compute upbringing.

In a separate talk, Ian Romanick talked about the Low-Level Virtual Machine in Mesa. It was pretty much agreed upon that LLVM will be made a hard dependency when building Mesa. LLVM is already required when building the older Radeon drivers, but it's been optional for other uses up to this point. Going forward, LLVM is a hard requirement for this open-source graphics library.

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. Intel Linux OpenGL Driver Leading Over Apple OS X
  2. The Cost Of Ubuntu Disk Encryption
  3. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
  4. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
Latest Linux News
  1. SQLite Now Faster With Memory Mapped I/O
  2. Microsoft Releases Skype For Linux 4.2, Has Bug-Fixes
  3. Qt For Tizen Launches, Based On Qt 5.1
  4. KTAP Released For Linux Kernel Dynamic Tracing
  5. Linux 3.10-rc2 Kernel Takes In A Few Extra Pulls
  6. QEMU 1.5 Supports VGA Passthrough, Better USB 3.0
  7. Handbrake 0.9.9 Supports OpenCL Offloading
  8. Freedreno Gallium3D Now Banging The Adreno A3XX
  9. Jolla Announces Their First Phone
  10. Mageia 3 Released, Still Using Legacy GRUB
  11. NetBSD 6.1 Brings In More Features
Latest Forum Talk
  1. Modern Intel Gallium3D Driver Still Being Toyed...
  2. Linux's "Ondemand" Governor Is No...
  3. Microsoft Releases Skype For Linux 4.2, Has...
  4. Qt For Tizen Launches, Based On Qt 5.1
  5. Intel Linux OpenGL Driver Leading Over Apple OS X
  6. QEMU 1.5 Supports VGA Passthrough, Better USB 3.0
  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