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

Formalizing The LLVMLinux Project: Clang'ing Kernels

Linux Kernel

Published on 11 September 2012 12:18 PM EDT
Written by Michael Larabel in Linux Kernel
13 Comments

Interest in building the Linux kernel through the LLVM/Clang compiler rather than GCC continues to grow. The consolidated LLVMLinux project was announced last week.

Interest -- and some out-of-tree-success -- in building the Linux kernel with Clang is not new; it's been covered many times on Phoronix already. Since late 2010 (when it was first covered on Phoronix), it became possible to build the Linux kernel with LLVM/Clang, albeit at the time it relied upon non-mainline patches to LLVM/Clang and the Linux kernel. Upstream LLVM/Clang now works, but there's still non-mainline changes needed for supporting a Clang'ed Linux kernel on x86 and ARM.

Earlier this year within the ARM world, building the Linux kernel with Clang was extensively talked about at the Linux Foundation Collaboration Summit by Qualcomm's Mark Charlebois and David Kipping. Just a few weeks back, Clang'ing the Linux kernel was talked about at LinuxCon San Diego by Bryce Adelstein-Lelbach, one of the original developers interested in using this alternative compiler for producing Linux x86 kernel binaries.

So last week now what was announced on the llvmdev list to LLVM developers is the LLVMLinux project. "I'd like to announce the LLVMLinux project. This project aims to fully build the Linux kernel using Clang/LLVM on the various architectures supported by the Linux kernel. The project consolidates the work of the lll-project, the PAX team, and Mark Charlebois' work on the ARM kernel."

It's nothing really new to announce and the consolidated work continues to be available from llvm.linuxfoundation.org as it has been in recent months. "The goal is for this project to be a testing/proving ground for these updates and to get patches that make this possible upstream to their respective projects (Clang/LLVM and the Linux Kernel)."

Among the troubling spots still for the mainline Linux kernel in being built by non-GCC compilers namely down to the use of variable length arrays in structs, Kbuild support for Clang, use of explicit register variables, segment reference errors with __refdata annotations, and EXPORT_SYMBOL of inline functions. As it applies to LLVM developers, there's a few compiler flags that the Linux kernel prefers but are not handled by Clang: -fdelete-null-pointer-checks, --fno-inline-functions-called-once, --Wno-unused-but-set-variable, --mabi=aapcs-linux.

In the x86 world their work is currently based upon the Linux 3.3 kernel but is able to boot a console and desktop. With ARM, however, they're more closely following the latest upstream tip of Linus Torvalds' branch. Module unloading is also completely broken for Clang-built kernels. While an x86 Clang Linux kernel desktop may boot, there's also other open bugs preventing network / firewall / drivers from working properly.

While not the Linux kernel, FreeBSD 10 can be built using Clang and over there in the BSD world it's becoming their default compiler to deprecate GCC. There's also been experiments within the Debian camp.

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. GParted 0.20 Improves Btrfs Support
  2. EXT4 In Linux 3.18 Has Clean-ups, Bug Fixes
  3. Emacs 24.4 Has Built-In Web Browser, Improved Multi-Monitor Support
  4. NVIDIA's NVPTX Support For GCC Is Close To Being Merged
  5. KDE's KWin On Wayland Begins Using Libinput
  6. Khronos Releases OpenVX 1.0 Specification
  7. Linux Kernel Working Towards GNU11/C11 Compatibility
  8. Ubuntu 15.04 Is Codenamed After A Monkey: Vivid Vervet
  9. Following GCC, Clang Looks To Default To C11
  10. Users/Developers Threatening Fork Of Debian GNU/Linux
Latest Forum Discussions
  1. Users/Developers Threatening Fork Of Debian GNU/Linux
  2. HOPE: The Ease Of Python With The Speed Of C++
  3. Bye bye BSD, Hello Linux: A Sys Admin's Story
  4. NVIDIA Presents Its Driver Plans To Support Mir/Wayland & KMS On Linux
  5. AMD Is Restructuring Again, Losing 7% Of Employees
  6. Open-Source AMD Fusion E-350 Support Takes A Dive
  7. Upgrade to Kaveri, very slow VDPAU performance
  8. ChromeOS Drops Support For EXT2/EXT3/EXT4 File-Systems