Discussing The LLVM IR Shortcomings

Posted by Michael Larabel on October 05, 2011

While GCC developers are currently discussing merging the D programming language front-end into their compiler, LLVM developers are currently discussing their IR and its sufficiency.

Dan Gohman, an Apple engineer, volleyed a long and technical e-mail to the LLVM development list about the LLVM IR. Dan argues that the intermediate representation for this Apple-sponsored compiler infrastructure is "a poor system for building a Platform." He and many felt that LLVM IR would work well for multiple architectures, but in the end it's not been so pretty. In his email he argues his case at length.

Dan ends up proposing a new platform IR for LLVM. "In conclusion, consider the task of writing an independent implementation of an LLVM IR Platform. The set of capabilities it provides depends on who you talk to. Semantic details are left to chance. There are features which require a bunch of complicated infrastructure to implement which are rarely used. And if you want light-weight execution, you'll probably need to translate it into something else better suited for it first. This all doesn't sound very appealing."

There's many responses already from his message that was sent yesterday. Most of the developers agree with his points. Chris Lattner, the primary developer behind LLVM/Clang and who's been heading Apple's Compiler Group, also agrees with most points raised by his colleague. However, he doesn't agree with the conclusion of creating a new IR. The email from Chris can be read here.

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. Sumo Lounge Emperor
  2. Gallium3D Continues Improving OpenGL For Older Radeon GPUs
  3. 15-Way Open vs. Closed Source NVIDIA/AMD Linux GPU Comparison
  4. Nouveau vs. NVIDIA Linux Comparison Shows Shortcomings
Latest Software Articles
  1. GCC 4.8.0 vs. LLVM Clang 3.3 Compiler Performance
  2. Intel Linux OpenGL Driver Leading Over Apple OS X
  3. The Cost Of Ubuntu Disk Encryption
  4. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
Latest Linux News
  1. A New X.Org-Free Wayland LiveCD Released
  2. Unity 8, Mir Made Progress This Week On Features
  3. LLVM Clang 3.3 RC2 Is Ready For Testing
  4. AMD RadeonSI Gallium3D Begins Simple CL Demos
  5. Intel Shows Off GNOME3-Based Tizen Shell
  6. Linux Desktop Security Could Be A Whole Lot Better
  7. KDE 4.11 Will Be The Last Major KDE4 Workspaces Feature Release
  8. New NVIDIA Linux Driver Supports The GeForce GTX 780
  9. Chrome 28 To Offer More Speed Improvements
  10. Digia Announces "Boot To Qt" Project
  11. X.Org Libraries Hit By Round Of Security Issues
Latest Forum Talk
  1. A New X.Org-Free Wayland LiveCD Released
  2. GCC 4.8.0 vs. LLVM Clang 3.3 Compiler Performance
  3. Intel Shows Off GNOME3-Based Tizen Shell
  4. Is there anyway to improve the performance of the...
  5. KDE 4.11 Will Be The Last Major KDE4 Workspaces...
  6. Steam: No used games...
  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