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

R600 LLVM Back-End Gets Indirect Addressing Support

Mesa

Published on 22 January 2013 05:33 PM EST
Written by Michael Larabel in Mesa
4 Comments

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.

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 News
  1. Linux 4.1-rc5 Kernel Released
  2. Mesa 10.5.6 Brings Fixes All Over The Place
  3. NVIDIA's Proprietary Driver Is Moving Closer With Kernel Mode-Setting
  4. The Latest Linux Kernel Git Code Fixes The EXT4 RAID0 Corruption Problem
  5. Features Added To Mesa 10.6 For Open-Source GPU Drivers
  6. Ubuntu's LXD vs. KVM For The Linux Cloud
  7. Fedora Server 22 Benchmarks With XFS & The Linux 4.0 Kernel
  8. GCC 6 Gets Support For The IBM z13 Mainframe Server
  9. Fedora 22 Is Being Released Next Tuesday
  10. OpenWRT 15.05 Preparing Improved Security & Better Networking
Latest Articles & Reviews
  1. The Latest Features For Linux Performance Management + Benchmark Monitoring
  2. Noctua NH-U12DX i4 + NF-F12
  3. Btrfs RAID 0/1 Benchmarks On The Linux 4.1 Kernel
  4. The State Of Various Firefox Features
Most Viewed News This Week
  1. The Linux 4.0 Kernel Currently Has An EXT4 Corruption Issue
  2. The Linux 4.0 EXT4 RAID Corruption Bug Has Been Uncovered
  3. Microsoft Open-Sources The Windows Communication Foundation
  4. Systemd 220 Has Finally Been Released
  5. Another HTTPS Vulnerability Rattles The Internet
  6. LibreOffice 5.0 Open-Source Office Suite Has Been Branched
  7. LibreOffice 5.0 Beta 1 Released
  8. Will Ubuntu Linux Hit 200 Million Users This Year?