[cfe-dev] Slowness of clang build
David Chisnall
David.Chisnall at cl.cam.ac.uk
Sat Dec 29 09:08:58 PST 2012
On 29 Dec 2012, at 16:47, Edward Diener wrote:
> I am periodically retrieving the latest sources from the llvm/clang repository, as specified in the Getting Started page.
>
> When I do a build of clang, through the 'make' command from the build directory, the build runs very slow.
Are you doing a parallel build? On an i7 laptop, I can do a clean build in 5-10 minutes, with -j4, on a faster desktop it's about 3 minutes. I usually use ninja (just add -G Ninja to your cmake command), rather than make, although there isn't much difference in performance between the two when doing a clean build. For incremental builds, ninja is so much faster that make isn't even in the same league.
> Evidently the default is a Debug+Assert build. Compiling a single source file averages 5-10 seconds and overall the build takes hours considering how many modules must be built. It is all successful in the end and when I am finished I have the latest clang, which is great.
The Debug+Asserts build is usually faster to compile, because it turns off optimisations, but slower to link, because the debug info is very large. While it can take 5-10 seconds to compile each file, that only matters if you're doing one file at a time.
> I have plenty of memory, plenty of disk space, a fairly fast CPU, and am doing the build on Fedora 17 with hardly any other applications running.
ninja -j8, if you've got enough RAM. If you're not on an SSD, then more processes than you have cores is generally a good idea, because it lets some run while the other are waiting for the disk, but be careful not to have to many more than you have GBs of RAM. A few of the files take about 1GB to compile, and for a debug build with ld-bdf you'll go over 2GB for the final linking step (enabling shared libraries speeds this up, but results in about a 5% slower executable at the end on x86-64).
> Why is compiling clang so slow ? Is there any way to speed up the build ? If I do a release build ( how ? )is it significantly quicker ?
I've not found the compilation time to be much different for release and debug builds (I've not measured it, but I do both fairly regularly and neither feels much slower than the other). The big difference is the time spent linking. If the linker runs out of physical memory and starts to swap then linking time can easily hit 5+ minutes. I've seen it go over 2GB with a statically-linked debug+asserts build of clang.
If you're doing a bootstrap build, make sure that you do a release build first, because the builds with asserts run a lot slower (factor of 10 or so), and trying to build LLVM/Clang with a build with asserts enabled is quite painful.
David
More information about the cfe-dev
mailing list