An Initial Version Of LunarGLASS-LLVM For Mesa

Posted by Michael Larabel on February 03, 2011

In October of last year there was a proposal by LunarG, a small consulting company focusing upon Gallium3D and Mesa that was formed by some of the original Tungsten Graphics crew, to create a common kernel and shader compiler stack. This stack would utilize LLVM (the Low-Level Virtual Machine) for optimizations This work was published as LunarGLASS and there is now a specification and initial implementation of it for Mesa.

The focus is upon removing the number of IRs (intermediate representations) and to turn to using LLVM IR as the common representation. The original LunarGLASS proposal also praised Low-Level Virtual Machine as being a better candidate for being able to handle OpenCL and more complex GLSL (GL Shading Language) going forward.

While the LunarGLASS proposal is very interesting, some parties (such as the Intel developers who last year invested significantly in rewriting Mesa's GLSL compiler) objected to using LLVM IR as it not being the right solution for high and low level optimizations. Some questioned whether this was even possible of using LLVM IR and then translating it to TGSI (the Gallium3D instruction language) or Mesa IR. The end result of LunarGLASS is to reduce the development burden in creating advanced graphics compiler stacks and to increase the level of optimizations for real-world graphics workloads.

LunarG in the months since has been working out to figure if this will indeed work. Today they are indeed announcing progress and that it is in fact working.

LunarG's John Kessenich announced last night on the Mesa mailing list the availability of the LunarGLASS exploration. To prove that LunarGLASS is possible, LunarG had to define the LLVM IR and then to produce a working experiment to see if translating these IRs was possible and efficient.

LunarG has published their initial IR specification at LunarGLASS.org. They have also setup a Google Code page for their current source-code hosting and to have a mailing list discussion group.

John says in his email message, "Results so far are quite encouraging for the few simple shaders we targeted (still absent flow control). In short, we were able to generate identical results to glsl2 when targeting Mesa IR, using LLVM optimizations instead of glsl2 optimizations. That is, going through the path GLSL -> glsl2-front-end -> Top-IR -> LLVM optimizations -> Mesa-IR."

While this is certainly progress in the right direction, it's not yet production-ready and the LunarGLASS design is still subject to change.

LunarG has put LunarGLASS code under the GPLv2 and the specification under the Creative Commons Attribution No Derivatives license. Though when digging around the LunarGLASS web-site, contributions to LunarGLASS must require accepting LunarG's contributors agreement

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. D Language Still Showing Promise, Advancements
  2. Planetary Annihilation Released For Linux Gamers
  3. Gentoo Starts Work On KDE-Wayland Support
  4. NVIDIA To License Its Kepler GPU Technology
  5. KDE's KWin Made Lots Of Progress In 4.11
  6. Ubuntu Announces Carrier Advisory Group
  7. Qt 5.1 Release Candidate 1 Has Arrived
  8. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  9. Subversion 1.8 Presents New Features
  10. LLVM 3.3 Officially Released
  11. LLVM/Clang Now Uses Loop Vectorizer At New Levels
Latest Forum Talk
  1. D Language Still Showing Promise, Advancements
  2. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  3. The Wayland Situation: Facts About X vs. Wayland
  4. Planetary Annihilation Plans To Come To Linux
  5. Intel GPU Driver Tries To Rip Out FBDEV Support
  6. Mir Still Causing Concerns By Ubuntu Derivatives
  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