Clang // is a compiler front end for the C, C++, Objective-C and Objective-C++ programming languages, as well as the OpenMP, OpenCL, RenderScript and CUDA frameworks. It uses the LLVM compiler infrastructure as its back end and has been part of the LLVM release cycle since LLVM 2.6.
Clang being used to compile Chicken
|Original author(s)||Chris Lattner|
|Developer(s)||LLVM Developer Group|
|Initial release||September 26, 2007|
|Platform||LLVM (ARMv7, AArch64, IA-32, x64, ppc64le)|
Apache License 2.0 with LLVM Exceptions (v9.0.0 or later)
It is designed to act as a drop-in replacement for the GNU Compiler Collection (GCC), supporting most of its compilation flags and unofficial language extensions. Its contributors include Apple, Microsoft, Google, ARM, Sony, Intel and Advanced Micro Devices (AMD). It is open-source software, with source code released under the University of Illinois/NCSA License, a permissive free software licence. Since v9.0.0, it was relicensed to the Apache License 2.0 with LLVM Exceptions.
One of the first uses of LLVM was an OpenGL code compiler for OS X that converts OpenGL calls into more fundamental calls for graphics processing units (GPU) that do not support certain features. This allowed Apple to support OpenGL on computers using Intel Graphics Media Accelerator (GMA) chipsets, increasing performance on those machines. For GPUs that support it, the code is compiled to fully exploit the underlying hardware, but on non-GMA machines, LLVM compiles the same OpenGL code into subroutines to ensure continued proper function.
LLVM was intended originally to use GCC's front end, but GCC turned out to cause some problems for developers of LLVM and at Apple. The GCC source code is a large and somewhat cumbersome system for developers to work with; as one long-time GCC developer put it referring to LLVM, "Trying to make the hippo dance is not really a lot of fun".
Apple software makes heavy use of Objective-C, but the Objective-C front-end in GCC is a low priority for GCC developers. Also, GCC does not integrate smoothly into Apple's integrated development environment (IDE). Finally, GCC is licensed under the terms of GNU General Public License (GPL) version 3, which requires developers who distribute extensions for, or modified versions of, GCC to make their source code available, whereas LLVM has a BSD-like license which does not have such a requirement.
Clang is intended to work atop LLVM. The combination of Clang and LLVM provides most of the toolchain, to allow replacing the full GCC stack. Because it is built with a library-based design, like the rest of LLVM, Clang is easy to embed into other applications. This is one reason why most OpenCL implementations are built with Clang and LLVM.
One of Clang's main goals is to provide a library-based architecture, to allow the compiler to be more tightly tied to tools that interact with source code, such as an integrated development environment (IDE) graphical user interface (GUI). In contrast, GCC is designed to work in a compile-link-debug workflow, and integrating it with other tools is not always easy. For instance, GCC uses a step called fold that is key to the overall compile process, which has the side effect of translating the code tree into a form that looks unlike the original source code. If an error is found during or after the fold step, it can be difficult to translate that back into one location in the original source. Also, vendors using the GCC stack within IDEs use separate tools to index the code, to provide features like syntax highlighting and autocomplete.
Clang is designed to retain more information during the compiling process than GCC, and to preserve the overall form of the original code. The goal of this is to make it easier to map errors back into the original source. The error reports offered by Clang are also aimed to be more detailed and specific, as well as machine-readable, so IDEs can index the output of the compiler during compiling. Modular design of the compiler can offer source code indexing, syntax checking, and other features normally associated with rapid application development systems. The parse tree is also more suitable for supporting automated code refactoring, as it directly represents the original source code.
Clang compiles only C-like languages, such as C, C++, Objective-C, Objective-C++, OpenCL, and CUDA. For other languages, like Ada, LLVM remains dependent on GCC or another compiler frontend. In many cases, Clang can be used or swapped out for GCC as needed, with no other effects on the toolchain as a whole. It supports most of the commonly used GCC options. A sub-project Flang by Nvidia and The Portland Group added Fortran support.
Performance and GCC compatibility
Clang is designed to be highly compatible with GCC. Clang's command-line interface is similar to and shares many flags and options with GCC. Clang implements many GNU language extensions and enables them by default. Clang implements many GCC compiler intrinsics purely for compatibility. For example, even though Clang implements atomic intrinsics which correspond exactly with C11 atomics, it also implements GCC's
__sync_* intrinsics for compatibility with GCC and libstdc++. Clang also maintains ABI compatibility with GCC-generated object code. In practice Clang can often be used as a drop-in replacement for GCC.
Clang's developers aim to reduce memory footprint and increase compilation speed compared to competing compilers, such as GCC. In October 2007, they report that Clang compiled the Carbon libraries more than twice as fast as GCC, while using about one-sixth GCC's memory and disk space. However, as of 2011 this was not a typical result. As of mid-2014, Clang won more than a third of the benchmarks, with GCC winning most. As of 2014, performance of Clang-compiled programs lagged behind performance of the GCC-compiled program, sometimes by large factors (up to 5.5x), replicating earlier reports of slower performance.
More recent comparisons in November 2016 indicate that both compilers have evolved to increase their performance. As of GCC 4.8.2 versus clang 3.4, on a large harness of test files, GCC outperforms clang by approximately 17% on well-optimized source code. Test results are code-specific, and unoptimized C source code can reverse such differences. The two compilers now seem broadly comparable.
This table presents only significant steps and releases in Clang history.
|11 July 2007||Clang frontend released under open-source licence|
|25 February 2009||Clang/LLVM can compile a working FreeBSD kernel.|
|16 March 2009||Clang/LLVM can compile a working DragonFly BSD kernel.|
|23 October 2009||Clang 1.0 released, with LLVM 2.6 for the first time.|
|December 2009||Code generation for C and Objective-C reach production quality. Support for C++ and Objective-C++ still incomplete. Clang C++ can parse GCC 4.2 libstdc++ and generate working code for non-trivial programs, and can compile itself.|
|2 February 2010||Clang self-hosting.|
|20 May 2010||Clang latest version built the Boost C++ libraries successfully, and passed nearly all tests.|
|10 June 2010||Clang/LLVM becomes integral part of FreeBSD, but default compiler is still GCC.|
|25 October 2010||Clang/LLVM can compile a working modified Linux kernel.|
|January 2011||Preliminary work completed to support the draft C++0x standard, with a few of the draft's new features supported in Clang development version.|
|10 February 2011||Clang can compile a working HotSpot Java virtual machine.|
|19 January 2012||Clang becomes an optional component in NetBSD cross-platform build system, but GCC is still default.|
|29 February 2012||Clang 3.0 can rebuild 91.2% of the Debian archive.|
|29 February 2012||Clang becomes default compiler in MINIX 3|
|12 May 2012||Clang/LLVM announced to replace GCC in FreeBSD.|
|5 November 2012||Clang becomes default compiler in FreeBSD 10.x.|
|18 February 2013||Clang/LLVM can compile a working modified Android Linux Kernel for Nexus 7.|
|19 April 2013||Clang is C++11 feature complete.|
|6 November 2013||Clang is C++14 feature complete.|
|11 September 2014||Clang 3.5 can rebuild 94.3% of the Debian archive. The percentage of failures has dropped by 1.2% per release since January 2013, mainly due to increased compatibility with GCC flags.|
|October 2016||Clang becomes default compiler for Android (and later only compiler supported by Android NDK).|
|13 March 2017||Clang 4.0.0 released|
|26 July 2017||Clang becomes default compiler in OpenBSD 6.2.|
|7 September 2017||Clang 5.0.0 released|
|5 March 2018||Clang is now used to build Google Chrome for Windows. Mozilla does the same change for Firefox in September same year.|
|8 March 2018||Clang 6.0.0 released|
|19 September 2018||Clang 7.0.0 released|
|20 March 2019||Clang 8.0.0 released|
|19 September 2019||Clang 9.0.0 released|
- LICENSE.TXT, llvm.org, retrieved 24 September 2019
- Christopher, Eric (3 July 2008). "simply wonder pronunciation of Clang". LLVMdev (Mailing list). Retrieved 22 September 2015.
- "OpenMP Support". LLVM Project Blog. Retrieved 28 March 2016.
- "Clang Language Extensions". Retrieved 8 November 2017.
In addition to the language extensions listed here, Clang aims to support a broad range of GCC extensions.
- Clang - Features and Goals: GCC Compatibility, 15 April 2013
- Clang "Getting started" instructions, Clang.llvm.org, retrieved 18 September 2012
- "Clang Static Analyzer". LLVM. Retrieved 3 September 2009.
- Treat, Adam (19 February 2005). "mkspecs and patches for LLVM compile of Qt4". Qt4-preview-feedback (Mailing list). Archived from the original on 4 October 2011.
- Lattner, Chris (25 May 2007). LLVM for OpenGL and other stuff (Slides). LLVM Developers' Meeting.
- Zadeck, Kenneth (19 November 2005). "Re: LLVM/GCC Integration Proposal". GCC development (Mailing list).
- Naroff, Steve (25 May 2007). New LLVM C Front-end (Slides). LLVM Developers' Meeting.
- Clang team, clang: a C language family frontend for LLVM
- Lattner, Chris (11 July 2007). "New LLVM C front-end: "clang"". cfe-dev (Mailing list). Archived from the original on 25 March 2015.
- Clang: Utility and Applications: Library Based Architecture
- FLANG: NVIDIA Brings Fortran To LLVM
- Clang can often be used as a drop-in replacement for GCC, October 2019
- Clang - Features and Goals: Fast compiles and Low Memory Use, October 2007
- Simonis, Volker (10 February 2011). "Compiling the HotSpot VM with Clang". Archived from the original on 18 February 2011. Retrieved 13 February 2011.
While the overall GCC compatibility is excellent and the compile times are impressive, the performance of the generated code is still lacking behind a recent GCC version.
- "Benchmarking LLVM & Clang Against GCC 4.5". Phoronix. 21 April 2010. Retrieved 13 February 2011.
Binaries from LLVM-GCC and Clang both struggled to compete with GCC 4.5.0 in the timed HMMer benchmark of a Pfam database search. LLVM-GCC and Clang were about 23% slower(...)Though LLVM / Clang isn't the performance champion at this point, both components continue to be under very active development and there will hopefully be more news to report in the coming months
- "GCC 4.9 VS. LLVM Clang 3.5 Linux Compiler Benchmarks". OpenBenchmarking.org. 14 April 2014. Retrieved 25 June 2014.
- "Clang vs GCC - which produces better binaries?". stackoverflow.com. Retrieved 1 October 2018.
- Divacky, Roman. "[Announce] clang/llvm can compile booting FreeBSD kernel on i386/amd64".
- Building FreeBSD with Clang, Wiki.freebsd.org, 24 August 2012, retrieved 18 September 2012
- Hornung, Alex. "llvm/clang once more".
- Clang, DragonFly BSD, retrieved 18 September 2012
- "Clang can compile LLVM and Clang". LLVM Project Blog.
- "Clang Successfully Self-Hosts". LLVM Project Blog.
- Gregor, Doug. "Clang++ Builds Boost!". LLVM Project Blog.
- Davis, Brad. "FreeBSD Status Reports April - June, 2010".
- Clang builds a working Linux Kernel (Boots to RL5 with SMP, networking and X, self hosts), Lists.cs.uiuc.edu, archived from the original on 7 September 2015, retrieved 18 September 2012
- Gregor, Douglas (26 January 2011). "New C++0x feature support in Clang" (Mailing list). Archived from the original on 30 January 2011. Retrieved 29 January 2011.
- "C++ and C++'0x Support in Clang". LLVM.
- Sonnenberger, Jörg (19 January 2012). "Status of NetBSD and LLVM". Retrieved 26 February 2014.
- Ledru, Sylvestre. "Rebuild of the Debian archive with clang".
- "Official Minix 3 website: News".
- Gerzo, Daniel (12 May 2012). "FreeBSD Quarterly Status Report January-March, 2012" (Mailing list). Retrieved 14 May 2012.
- Davis, Brooks (5 November 2012). "Heads Up: Clang now the default on x86" (Mailing list). Retrieved 7 November 2012.
- Webster, Behan (18 February 2013). "LLVMLinux: Compiling Android with LLVM" (PDF). Retrieved 11 May 2013.
- Tinti, Vinicius (17 March 2013). "LLVMLinux: Nexus 7". Retrieved 11 May 2013.
- Du Toit, Stefanus. "Clang is C++11 feature complete as of *just now*!".
- "[llvm-project] Revision 194194".
- Ledru, Sylvestre. "Rebuild of Debian using Clang 3.5.0".
- "NDK Revision History | Android Developers". developer.android.com. Retrieved 6 March 2018.
- "NDK Revision History | Android NDK | Android Developers". Android Developers. Retrieved 30 April 2018.
- Nagy, Robert (26 July 2017). "switch the default compiler on amd64 and i386 to clang" (Mailing list). Retrieved 30 September 2017.
- "Clang is now used to build Chrome for Windows". blog.llvm.org. Retrieved 7 April 2018.
- "1443590 - Use clang-cl for Windows builds we ship to users". bugzilla.mozilla.org. Retrieved 7 April 2018.