R600 LLVM Back-End Gets Indirect Addressing Support

Posted by Michael Larabel on January 22, 2013

The open-source Radeon R600 LLVM back-end has finally received support for indirect memory addressing.

AMD's Tom Stellard put out the 1200 line patch today that enables indirect addressing support within the R600 LLVM GPU target. Indirect addressing support has been one of the major limitations so far in this Radeon LLVM back-end. This back-end can be optionally used by the R600 Gallium3D driver for its shader compiler and is a key requirement for the Radeon OpenCL/GPGPU compute support. As far as end-users are concerned, the lack of indirect addressing support has made the LLVM back-end shader compiler not work for some OpenGL games like Unigine and Sauerbraten. (See Trying Out AMD's Radeon Gallium3D LLVM Compiler.)

Stellard writes in his mailing list message that for now this indirect addressing is R600-only with the Radeon HD 7000 "Southern islands" implementation still missing a few callbacks used during this process. He additionally writes, "At the moment R600 only supports array sizes of 16 dwords or less. Register packing of vector types is currently disabled, which means that a vec4 is stored in T0_X, T1_X, T2_X, T3_X, rather than T0_XYZW. In order to correctly pack registers in all cases, we will need to implement an analysis pass for R600 that determines the correct vector width for each array."

The R600 LLVM GPU back-end was removed from Mesa and merged into upstream LLVM. This R600 LLVM indirect addressing support will soon likely be merged into Tom Stellard's R600 LLVM repository followed by eventually making it into the next R600 GPU LLVM pull that should end up being released as part of LLVM 3.3 later this year.

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. Intel Haswell HD Graphics 4600 vs. AMD Radeon Graphics On Linux
  2. Intel Haswell HD Graphics 4600 Performance On Ubuntu Linux
  3. Intel Core i7 4770K "Haswell" Benchmarks On Ubuntu Linux
  4. The First Experience Of Intel Haswell On Linux
Latest Software Articles
  1. Optimized Binaries Provide Great Benefits For Intel Haswell
  2. 11-Way Linux, BSD Platform Comparison
  3. SNA Acceleration Works Great For Intel Core i7 Haswell
  4. The Linux Evolution For Intel Haswell's Performance
Latest Linux News
  1. Ubuntu Announces Carrier Advisory Group
  2. Qt 5.1 Release Candidate 1 Has Arrived
  3. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  4. Subversion 1.8 Presents New Features
  5. LLVM 3.3 Officially Released
  6. LLVM/Clang Now Uses Loop Vectorizer At New Levels
  7. Intel GPU Driver Tries To Rip Out FBDEV Support
  8. Coreboot Doing AMD USB 3.0, Q35 QEMU Emulation
  9. VP9 Codec Now Enabled By Default In Chrome
  10. openSUSE 13.1 M2 Plays On PulseAudio 4.0
  11. Debian 7.1 Rounds In Some Bug-Fixes
Latest Forum Talk
  1. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  2. Intel GPU Driver Tries To Rip Out FBDEV Support
  3. Intel Haswell-Based Apple MacBook Air, HD 5000...
  4. Vote for GOG to add Linux versions of games they...
  5. Mir Still Causing Concerns By Ubuntu Derivatives
  6. The Wayland Situation: Facts About X vs. Wayland
  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