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

LLVM May Get A TGSI Gallium3D Compiler Back-End

Compiler

Published on 05 April 2013 02:05 AM EDT
Written by Michael Larabel in Compiler
4 Comments

A proposal has been made to develop a new LLVM compiler back-end that would generate TGSI instructions, the intermediate representation used by Mesa's Gallium3D drivers.

Francisco Jerez, the open-source developer that has long been involved with Nouveau and did an X.Org EVoC project to work on Gallium3D OpenCL, is the developer proposing this LLVM TGSI back-end. During his "Endless Vacation of Code" project for the X.Org Foundation, the student made the Gallium3D OpenCL state tracker nearly work. Well, it does work for OpenCL on Nouveau to some extent.

This developer with experience is proposing to do this new back-end as a Google Summer of Code project for LLVM. Jerez was quick to acknowledge that it will likely take more than a couple summer months to make a fully working TGSI back-end, but he's committed to seeing it through even after GSoC has been completed.

With a back-end to LLVM generating TGSI, it could in effect be understood by any of the Gallium3D drivers as they all accept TGSI for their IR as is done for graphics. Jerez's focus would be though on testing against the Nouveau drivers and seeing what sort of OpenCL could be handled this way.

Francisco writes in his mailing list proposal, "TGSI is the intermediate representation that all open-source GPU drivers using the Gallium3D architecture understand. Until now it's mainly beenused for graphics (vertex and fragment shaders and such), but doing general-purpose computing with it is possible in principle (actually, necessary for GL4), and it's been the object of a number of extensions and improvements during the last couple of years to make it more suitable for that purpose. The objective of the project would be to set a basis for a compiler back-end targeting the TGSI language."

Francisco adds, "The first to be benefited from such a back-end would be the Nouveau nv50 and nve4 drivers, that would get OpenCL support easily without much additional work, other Gallium drivers will also benefit from it as they implement the missing language and API bits."

This isn't the first time a TGSI back-end for LLVM has been discussed, and it wouldn't be without some limitations, but hopefully it will be able to materialize this year as part of Google Summer of Code. If all else fails, hopefully the X.Org Foundation will sponsor the development through another EVoC.

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. CompuLab Intense-PC2: An Excellent, Fanless, Mini PC Powered By Intel's i7 Haswell
  2. From The Atom 330 To Haswell ULT: Intel Linux Performance Benchmarks
  3. AMD Radeon R9 285 Tonga Performance On Linux
  4. Apotop Wi-Copy
Latest Linux Articles
  1. AMD Moves Forward With Unified Linux Driver Strategy, New Kernel Driver
  2. MSI: Update Your BIOS From The Linux Desktop
  3. NVIDIA vs. AMD 2D Linux Drivers: Catalyst Is Getting Quite Good At 2D
  4. 15-Way GPU Comparison With Mesa 10.3 + Linux 3.17
Latest Linux News
  1. Linux 3.18-rc1 Released One Week Early With Many Changes
  2. The VC4 Gallium3D Driver Is Still Moving Along For The Raspberry Pi
  3. Direct3D 9 Support Might Land Within Mainline Mesa 3D Drivers
  4. OpenGL Preview Benchmarks For NVIDIA's GeForce GTX 970
  5. HOPE: The Ease Of Python With The Speed Of C++
  6. Vitesse: Using LLVM To Speed Up Databases
  7. AMD Is Restructuring Again, Losing 7% Of Employees
  8. Linux Testing Of The NVIDIA GeForce GTX 970
  9. Qt 5.4 Now In Beta With Web, Bluetooth LE, Graphics Improvements
  10. AMD's Radeon R9 285 On Linux Offers Good OpenCL Performance
Latest Forum Discussions
  1. NVIDIA Presents Its Driver Plans To Support Mir/Wayland & KMS On Linux
  2. AMD Is Restructuring Again, Losing 7% Of Employees
  3. Bye bye BSD, Hello Linux: A Sys Admin's Story
  4. Open-Source AMD Fusion E-350 Support Takes A Dive
  5. Upgrade to Kaveri, very slow VDPAU performance
  6. ChromeOS Drops Support For EXT2/EXT3/EXT4 File-Systems
  7. Lennart Poettering On The Open-Source Community: A Sick Place To Be In
  8. The Slides Announcing The New "AMDGPU" Kernel Driver