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

Mesa Compiler Stacks, A Hard Dependency On LLVM

AMD

Published on 14 September 2011 12:38 PM EDT
Written by Michael Larabel in AMD
2 Comments

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.

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. 13-Way Low-End GPU Comparison With AMD's AM1 Athlon
  2. ASUS AM1I-A: A Mini-ITX Board For Socketed Kabini APUs
  3. Mini-Box M350: A Simple, Affordable Mini-ITX Case
  4. Overclocking The AMD AM1 Athlon & Sempron APUs
Latest Linux Articles
  1. Ubuntu 12.04 LTS vs. 14.04 LTS Cloud Benchmarks
  2. Ubuntu 12.04.4 vs. 13.10 vs. 14.04 LTS Desktop Benchmarks
  3. AMD OpenCL Performance With AM1 Kabini APUs
  4. A Quick Look At GCC 4.9 vs. LLVM Clang 3.5
Latest Linux News
  1. Borderlands Is Being Considered For Linux
  2. Mesa 10.0 & 10.1 Stable Get Updated
  3. Getting Hit By The Variable Performance Of The Public Cloud
  4. Git 2.0 Test Releases Begin With Many Changes
  5. Wine 1.7.17 Works On Its Task Scheduler, C Run-Time
  6. The Improv ARM Board Still Isn't Shipping; Riding A Dead Horse?
  7. Debian To Maintain 6.0 Squeeze As An LTS Release
  8. Wasteland 2 Is Finally Released For Linux Gamers
  9. FreeBSD Advances For ARM, Bhyve, Clang
  10. Ubuntu 14.04 LTS "Trusty Tahr" Officially Released
  11. Ubuntu 12.04 LTS vs. 14.04 LTS Server Benchmarks
  12. QEMU 2.0 Released With ARM, x86 Enhancements
Latest Forum Discussions
  1. Suggestions about how to make a Radeon HD 7790 work decently?
  2. The GNOME Foundation Is Running Short On Money
  3. Updated and Optimized Ubuntu Free Graphics Drivers
  4. Radeon 8000M problematic on Linux?
  5. Linux Kernel Developers Fed Up With Ridiculous Bugs In Systemd
  6. After Jack Keane, RuseSoft will briing Ankh 3 to Linux through Desura
  7. Suspected PHP Proxy Issue
  8. Change installation destination from home directory