-
Notifications
You must be signed in to change notification settings - Fork 12.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Modules] Fix rebuilding an updated module for each of its consumers.
Marking a module for a rebuild when its signature differs from the expected one causes redundant module rebuilds for incremental builds. When a module is updated, its signature changes. But its consumers still have the old signature and loading them will result in signature mismatches. It will correctly cause the rebuilds for the consumers but we don't need to rebuild the common module for each of them as it is already up to date. In practice this bug causes longer build times. We are doing more work than required and only a single process can build a module, so parallel builds degrade to a single-process mode where extra processes are just waiting on a file lock. Fix by not marking a module dependency for a rebuild on signature mismatch. We'll check if it is up to date when we load it. rdar://problem/50212358 Reviewers: dexonsmith, bruno, rsmith Reviewed By: dexonsmith, bruno Subscribers: jkorous, ributzka, cfe-commits, aprantl Differential Revision: https://reviews.llvm.org/D66907 llvm-svn: 370274
- Loading branch information
Showing
6 changed files
with
45 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,2 @@ | ||
| // A | ||
| #include "Common.h" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,2 @@ | ||
| // B | ||
| #include "Common.h" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1 @@ | ||
| // Common |
3 changes: 3 additions & 0 deletions
3
clang/test/Modules/Inputs/implicit-invalidate-common/module.modulemap
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,3 @@ | ||
| module A { header "A.h" } | ||
| module B { header "B.h" } | ||
| module Common { header "Common.h" } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,36 @@ | ||
| // REQUIRES: shell | ||
| // RUN: rm -rf %t | ||
| // RUN: mkdir -p %t/implicit-invalidate-common | ||
| // RUN: cp -r %S/Inputs/implicit-invalidate-common %t/ | ||
| // RUN: echo '#include "A.h"' > %t/A.c | ||
| // RUN: echo '#include "B.h"' > %t/B.c | ||
|
|
||
| // Build with an empty module cache. Module 'Common' should be built only once. | ||
| // | ||
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/Cache \ | ||
| // RUN: -fsyntax-only -I %t/implicit-invalidate-common -Rmodule-build \ | ||
| // RUN: %t/A.c 2> %t/initial_build.txt | ||
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/Cache \ | ||
| // RUN: -fsyntax-only -I %t/implicit-invalidate-common -Rmodule-build \ | ||
| // RUN: %t/B.c 2>> %t/initial_build.txt | ||
| // RUN: FileCheck %s --implicit-check-not "remark:" --input-file %t/initial_build.txt | ||
|
|
||
| // Update module 'Common' and build with the populated module cache. Module | ||
| // 'Common' still should be built only once. Note that we are using the same | ||
| // flags for A.c and B.c to avoid building Common.pcm at different paths. | ||
| // | ||
| // RUN: echo ' // ' >> %t/implicit-invalidate-common/Common.h | ||
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/Cache \ | ||
| // RUN: -fsyntax-only -I %t/implicit-invalidate-common -Rmodule-build \ | ||
| // RUN: %t/A.c 2> %t/incremental_build.txt | ||
| // RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fmodules-cache-path=%t/Cache \ | ||
| // RUN: -fsyntax-only -I %t/implicit-invalidate-common -Rmodule-build \ | ||
| // RUN: %t/B.c 2>> %t/incremental_build.txt | ||
| // RUN: FileCheck %s --implicit-check-not "remark:" --input-file %t/incremental_build.txt | ||
|
|
||
| // CHECK: remark: building module 'A' | ||
| // CHECK: remark: building module 'Common' | ||
| // CHECK: remark: finished building module 'Common' | ||
| // CHECK: remark: finished building module 'A' | ||
| // CHECK: remark: building module 'B' | ||
| // CHECK: remark: finished building module 'B' |