<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">Fabio, the work I was mentioning here is an extension beyond those blog posts.<br class=""><div class=""><br class=""></div><div class="">Some details:</div><div class=""><br class=""></div><div class="">* The “almost 40%” number I referred to is a multi-stage clang build. That means we build a host-capable compiler, then build the actual compiler we want to ship.</div><div class="">* I’m at Apple, so points 1 and 2 are already covered (we only use clang, and ld64 is a fast linker).</div><div class="">* Our system compiler is PGO+LTO’d, but our stage1 isn’t. Stage1 isn’t because the performance improvement of PGO+LTO is less than the time it takes to build, and stage1 is basically a throwaway.</div><div class="">* We are using Ninja and CMake, but this configuration isn’t really significantly faster than autoconf/make, and actually “ninja install” is slower in my tests than the old autoconf “make install”. The slowdown is almost entirely due to Ninja’s “all” target being a lot bigger.</div><div class="">* This performance is for clean builds, not incremental so ccache or shared libraries would not be a valid optimization</div><div class="">* We do use optimized tablegen</div><div class="">* “Build Less” is exactly what the LLVM_DISTRIBUTION_COMPONENTS enables, just in a friendly wrapper target.</div><div class=""><br class=""></div><div class="">-Chris<br class=""><div class=""><div class=""><br class=""></div><div class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Mar 1, 2016, at 1:12 PM, Fabio Pagani <<a href="mailto:pagabuc@gmail.com" class="">pagabuc@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">For faster builds and rebuilds you should definitely read:<br class=""><a href="https://blogs.s-osg.org/an-introduction-to-accelerating-your-build-with-clang/" class="">https://blogs.s-osg.org/an-introduction-to-accelerating-your-build-with-clang/</a><br class=""><a href="https://blogs.s-osg.org/a-conclusion-to-accelerating-your-build-with-clang/" class="">https://blogs.s-osg.org/a-conclusion-to-accelerating-your-build-with-clang/</a><br class=""><br class="">Hope this helps! </div><div class="gmail_extra"><br class=""><div class="gmail_quote">On Tue, Mar 1, 2016 at 9:17 PM, ChrisBieneman via llvm-dev <span dir="ltr" class=""><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank" class="">llvm-dev@lists.llvm.org</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class=""><br class="">
<br class="">
> On Mar 1, 2016, at 10:01 AM, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" class="">mehdi.amini@apple.com</a>> wrote:<br class="">
><br class="">
><br class="">
>> On Mar 1, 2016, at 9:57 AM, Chris Bieneman <<a href="mailto:cbieneman@apple.com" class="">cbieneman@apple.com</a>> wrote:<br class="">
>><br class="">
>> There are a few notes I'd like to add to this thread.<br class="">
>><br class="">
>> (1) we have a number of places throughout out CMake build where we use features from newer CMakes gated by version checks. Most of these features are performance or usability related. None of them are correctness. Using the latest CMake release will often result in faster builds, so I encourage it.<br class="">
>><br class="">
>> (2) CMake's "install" target will pretty much always be slower from clean than the old autoconf/make "install" target. This is because in CMake "install" depends on "all", and our CMake builds more stuff in "all" than autoconf did. To help with this or CMake system has lots of convenient "install-${name}" targets that support component-based installation. Not every component has one of these rules, but if one you need is missing let me know. I also recently (r261681) added a new option (LLVM_DISTRIBUTION_COMPONENTS) that allows you to specify a list of components that have custom install targets. It then creates a new "install-distribution" target that wraps just the components you want. For Apple this is almost a 40% speed up over "ninja install".<br class="">
><br class="">
> That sounds great, I want to use it!<br class="">
> It would even be more awesome with an description/example in docs/CMake.rst :)<br class="">
<br class="">
</span>Once I get the last of the kinks worked out for our internal adoption I'm going to open source our config files that use it.<br class="">
<br class="">
I've also made a note to remind myself to document it in docs/CMake.rst. I need to do a pass updating that with a bunch of the cool new things we're doing with CMake. Thanks for the reminder.<br class="">
<span class="HOEnZb"><font color="#888888" class=""><br class="">
-Chris<br class="">
</font></span><div class="HOEnZb"><div class="h5"><br class="">
><br class="">
> --<br class="">
> Mehdi<br class="">
>><br class="">
>> On Feb 25, 2016, at 11:08 AM, Sedat Dilek via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class="">
>><br class="">
>>>> Which combination of cmake/ninja versions are you using (latest are<br class="">
>>>> v3.4.3 and v1.6.0)?<br class="">
>>><br class="">
>>> With this combination I could reduce build-time down from approx. 3h<br class="">
>>> down to 01h20m.<br class="">
>>><br class="">
>>> $ egrep -i 'jobs|ninja' llvm-build/CMakeCache.txt<br class="">
>>> //Program used to build from build.ninja files.<br class="">
>>> CMAKE_MAKE_PROGRAM:FILEPATH=/opt/cmake/bin/ninja<br class="">
>>> //Define the maximum number of concurrent compilation jobs.<br class="">
>>> LLVM_PARALLEL_COMPILE_JOBS:STRING=3<br class="">
>>> //Define the maximum number of concurrent link jobs.<br class="">
>>> LLVM_PARALLEL_LINK_JOBS:STRING=1<br class="">
>>> CMAKE_GENERATOR:INTERNAL=Ninja<br class="">
>>><br class="">
>>> $ LC_ALL=C ls -alt logs/3.8.0rc3_clang-3-8-0-rc3_cmake-3-4-3_ninja-1-6-0/<br class="">
>>> total 360<br class="">
>>> drwxr-xr-x 2 wearefam wearefam   4096 Feb 25 19:58 .<br class="">
>>> drwxr-xr-x 6 wearefam wearefam   4096 Feb 25 19:58 ..<br class="">
>>> -rw-r--r-- 1 wearefam wearefam 130196 Feb 25 19:54<br class="">
>>> install-log_llvm-toolchain-3.8.0rc3.txt<br class="">
>>> -rw-r--r-- 1 wearefam wearefam 205762 Feb 25 19:51<br class="">
>>> build-log_llvm-toolchain-3.8.0rc3.txt<br class="">
>>> -rw-r--r-- 1 wearefam wearefam  14331 Feb 25 18:30<br class="">
>>> configure-log_llvm-toolchain-3.8.0rc3.txt<br class="">
>>><br class="">
>>> $ LC_ALL=C du -s -m llvm* /opt/llvm-toolchain-3.8.0rc3<br class="">
>>> 315     llvm<br class="">
>>> 941     llvm-build<br class="">
>>> 609     /opt/llvm-toolchain-3.8.0rc3<br class="">
>>><br class="">
>>> - Sedat -<br class="">
>>><br class="">
>>> [1] <a href="https://cmake.org/files/v3.5/cmake-3.5.0-rc3-Linux-x86_64.tar.gz" rel="noreferrer" target="_blank" class="">https://cmake.org/files/v3.5/cmake-3.5.0-rc3-Linux-x86_64.tar.gz</a><br class="">
>>> _______________________________________________<br class="">
>>> LLVM Developers mailing list<br class="">
>>> <a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">
>>> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank" class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br class="">
><br class="">
_______________________________________________<br class="">
LLVM Developers mailing list<br class="">
<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank" class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br class="">
</div></div></blockquote></div><br class=""></div>
</div></blockquote></div><br class=""></div></div></div></body></html>