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

Some PNaCl LLVM Patches Might Make Writing LLVM Back-Ends Easier

Compiler

Published on 05 March 2014 01:25 AM EST
Written by Michael Larabel in Compiler
Comment On This Article

Some work from Google's Portable Native Client (PNaCl) work might be pushed upstream in LLVM as it benefits the EmScripten JavaScript back-end and other interesting use-cases.

Google's Native Client is the company's sandboxing technology for running native x86/ARM code in a sandbox from their Chrome web browser and ChromeOS. Portable Natice Client applications are compiled to a subset of the LLVM IR bytecode. While the code is available and under a BSD license, Google isn't leveraging upstream LLVM in their work. Google though is a big contributor to LLVM in general and the PNaCl team is now attempting to push some PNaCl IR passes back into upstream LLVM.

What makes these IR passes interesting and worth mentioning is that they appear to be useful simplification/lowering passes that can ease development of new LLVM back-ends, especially for interesting use-cases like EmScripten with compiling out to JavaScript for the web browser. These IR simplification passes end up simplifying LLVM IR from complex features into simpler features. With a reduced set of IR to target, it's easier for developers to make new back-ends and provides a more stable subset of LLVM IR. These PNaCl passes are modular and simplify calling conventions and module-level lowering.

Mark Seaborn of the PNaCl team at Google has proposed upstreaming this work (just these passes and not mainlining all of their PNaCl LLVM code) to help other new potential back-ends or at the very least centering the work currently done by PNaCl and EmScripten.

Alon Zakai added additional commentary about these patches in EmScripten's new back-end use-case, "It made writing the backend much easier than it otherwise would have been...I think the shared thing in these examples is that LLVM IR is very nice to work with, and there are some situations where you're using it and you have a reason to convert it into something else, and you want to do that in as _simple_ a way as possible as opposed to generating the most _optimal_ results. The PNaCl IR simplification passes are in my opinion a big help there."

Developers at Apple and Google, among other contributors, seem to be interested in this work for the potential wins. However, there is some concern amongst LLVM developers (including by Chris Lattner) over maintenance -- though Google's PNaCl team has claimed they will support it -- of these passes and not having any in-tree back-ends at the moment that utilize the passes (or any test cases right now for stressing them), but if this code pans out to be interesting and helpful, hopefully it will manage to make it in for LLVM 3.5.

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. Even With Re-Clocking, Nouveau Remains Behind NVIDIA's Proprietary Linux Driver
  2. The Power Consumption & Efficiency Of Open-Source GPU Drivers
  3. AMD R600g/RadeonSI Performance On Linux 3.16 With Mesa 10.3-devel
  4. Intel Pentium G3258 On Linux
Latest Linux Articles
  1. Nouveau vs. Radeon vs. Intel Tests On Linux 3.16, Mesa 10.3-devel
  2. KVM Benchmarks On Ubuntu 14.10
  3. X.Org Server 1.16 Officially Released With Terrific Features
  4. Ubuntu With Linux 3.16 Smashes OS X 10.9.4 On The MacBook Air
Latest Linux News
  1. The FFmpeg vs. Libav War Continues In Debian Land
  2. Grand Theft Auto Running On Direct3D Natively On Linux Shows Gallium3D Potential
  3. GCC As A Just-In Time Compiler Is An Interesting Project
  4. Age Of Wonders III Is Still Being Ported To Linux
  5. Git 2.1 To Further Mainline Windows Support Patches
  6. Debian 8.0 Jessie Is Settling For Linux 3.16
  7. Meson: A Next-Gen Build System Showing Promise
  8. Linux 3.16-rc7 Calms Things Down For The Linux 3.16 Kernel
  9. Open-Source AMD Users Report Hawaii GPU Acceleration Is Working
  10. Linus Torvalds On GCC 4.9: Pure & Utter Crap
Latest Forum Discussions
  1. List of Linux friendly Kickstarter projects
  2. Updated and Optimized Ubuntu Free Graphics Drivers
  3. Linus Torvalds On GCC 4.9: Pure & Utter Crap
  4. Porting Mesa to the Playstation 2
  5. ASRock AM1H-ITX: One Of The Best AM1 Mini-ITX Motherboards
  6. Debian + radeonsi
  7. Open-source drivers on ATI R7 260X
  8. Table test