Skip to content
Snippets Groups Projects

CMake: Add option to build with PCH

Merged Clemens Wasser requested to merge clemenswasser/cmake:build-opt into master

This MR introduces PCH for the most expensive includes to improve build times. Additionally, I did some other smaller improvements without using PCH. PCH is only activated when using the Clang or MSVC compiler on any Platform, and for all compilers on Windows. These restrictions exist since Gcc is much slower with these changes.

Here are some Benchmarks that measure the build time of the complete CMake codebase:

All were run on this machine:

CPU: i7-12700k @ 5.0 GHz p-core, 4.0 GHz e-core
RAM: 32 GB, DDR4 @ 3200 MHz
DISK: 1TB NVME 970 EVO Plus
OS: Windows 11 22H2 22621.1848
Windows, Ninja 1.11.0, CMake 3.26.4, BUILD_TYPE=Debug
Before:
  Time (mean ± σ):     44.377 s ±  0.113 s    [User: 577.322 s, System: 95.428 s]
  Range (min … max):   44.260 s … 44.611 s    10 runs
After:
  Time (mean ± σ):     21.530 s ±  0.238 s    [User: 189.654 s, System: 66.940 s]
  Range (min … max):   21.238 s … 21.986 s    10 runs

:arrow_right: ~2.06x faster

Windows, Clang 16.0.6, Ninja 1.11.0, CMake 3.26.4, BUILD_TYPE=Debug
Before:
  Time (mean ± σ):     49.358 s ±  0.088 s    [User: 710.828 s, System: 70.272 s]
  Range (min … max):   49.237 s … 49.484 s    10 runs
After:
  Time (mean ± σ):     29.211 s ±  0.753 s    [User: 409.431 s, System: 56.650 s]
  Range (min … max):   28.037 s … 29.979 s    10 runs

:arrow_right: ~1.7x faster

Debian unstable/experimental (WSL2 6.1.21.1-microsoft-standard-WSL2+), Clang 16.0.5, Ninja 1.11.1, CMake 3.25.1, BUILD_TYPE=Debug
Before:
  Time (mean ± σ):     34.459 s ±  0.291 s    [User: 603.326 s, System: 38.245 s]
  Range (min … max):   34.169 s … 35.216 s    10 runs
After:
  Time (mean ± σ):     19.959 s ±  0.163 s    [User: 319.371 s, System: 29.997 s]
  Range (min … max):   19.650 s … 20.167 s    10 runs

:arrow_right: ~1.73x faster

Topic-rename: build-pch

Edited by Brad King

Merge request reports

Merge request pipeline #354566 canceled

Merge request pipeline canceled for aba5bab6

Merged by Kitware RobotKitware Robot 1 year ago (Jun 23, 2023 3:20pm UTC)

Loading

Pipeline #354692 waiting for manual action

Pipeline waiting for manual action for 994e88ec on master

Activity

Filter activity
  • Approvals
  • Assignees & reviewers
  • Comments (from bots)
  • Comments (from users)
  • Commits & branches
  • Edits
  • Labels
  • Lock status
  • Mentions
  • Merge request status
  • Tracking
  • Brad King
  • Brad King changed title from Build CMake itself with PCH for some toolchains to CMake: Build with PCH for some toolchains

    changed title from Build CMake itself with PCH for some toolchains to CMake: Build with PCH for some toolchains

  • Brad King added workflow:wip label and removed workflow:in-review label

    added workflow:wip label and removed workflow:in-review label

  • Clemens Wasser added 9 commits

    added 9 commits

    • b0773956 - CMake: Add CMake_BUILD_PCH dependent option
    • 7fe9efdc - C{Make,Test}Lib: Precompile common expensive headers
    • 33631a64 - CMakeLibTests: Precompile common expensive headers
    • 2f2082db - bzip: Precompile common expensive headers
    • 6b47b4b6 - curl: Precompile common expensive headers
    • ae642cfa - libarchive: Precompile common expensive headers
    • 73f10dcf - liblzma: Precompile common expensive headers
    • 17107093 - cmcppdap: Precompile common expensive headers
    • c2319366 - libuv: Precompile common expensive headers

    Compare with previous version

  • Clemens Wasser resolved all threads

    resolved all threads

  • Brad King added workflow:in-review label and removed workflow:wip label

    added workflow:in-review label and removed workflow:wip label

  • assigned to @brad.king

  • Do: stage

  • Do: unstage

  • added workflow:wip label and removed workflow:nightly-testing label

  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Please register or sign in to reply
    Loading