From 5cff68fca0bc21ccad20cc7c8fb9845e32b4c925 Mon Sep 17 00:00:00 2001 From: Steven Wu Date: Wed, 1 Feb 2023 10:34:05 -0800 Subject: [PATCH] [Module] Respect `-fno-pch-timestamps` when building modules Always respect the FrontendOption to not include timestamps in PCH or Modules when `-fno-pch-timestamps` is specified. Reviewed By: benlangmuir Differential Revision: https://reviews.llvm.org/D141632 --- clang/lib/Frontend/FrontendActions.cpp | 3 ++- clang/test/Modules/timestamps.c | 30 ++++++++++++++++++++++++++ 2 files changed, 32 insertions(+), 1 deletion(-) create mode 100644 clang/test/Modules/timestamps.c diff --git a/clang/lib/Frontend/FrontendActions.cpp b/clang/lib/Frontend/FrontendActions.cpp index 2d81178fa60e..b5e868fd6768 100644 --- a/clang/lib/Frontend/FrontendActions.cpp +++ b/clang/lib/Frontend/FrontendActions.cpp @@ -202,7 +202,8 @@ GenerateModuleAction::CreateASTConsumer(CompilerInstance &CI, /*AllowASTWithErrors=*/ +CI.getFrontendOpts().AllowPCMWithCompilerErrors, /*IncludeTimestamps=*/ - +CI.getFrontendOpts().BuildingImplicitModule, + +CI.getFrontendOpts().BuildingImplicitModule && + +CI.getFrontendOpts().IncludeTimestamps, /*ShouldCacheASTInMemory=*/ +CI.getFrontendOpts().BuildingImplicitModule)); Consumers.push_back(CI.getPCHContainerWriter().CreatePCHContainerGenerator( diff --git a/clang/test/Modules/timestamps.c b/clang/test/Modules/timestamps.c new file mode 100644 index 000000000000..5315750b8159 --- /dev/null +++ b/clang/test/Modules/timestamps.c @@ -0,0 +1,30 @@ +/// Verify timestamps that gets embedded in the module +#include + +// RUN: rm -rf %t +// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fdisable-module-hash \ +// RUN: -fmodules-cache-path=%t -I %S/Inputs %s +// RUN: cp %t/c_library.pcm %t1.pcm +// RUN: llvm-bcanalyzer --dump --disable-histogram %t1.pcm > %t1.dump +// RUN: FileCheck %s --check-prefix=CHECK --check-prefix=TIMESTAMP --input-file %t1.dump +// RUN: rm -rf %t +// RUN: %clang_cc1 -fmodules -fimplicit-module-maps -fdisable-module-hash \ +// RUN: -fmodules-cache-path=%t -I %S/Inputs -fno-pch-timestamp %s +// RUN: cp %t/c_library.pcm %t2.pcm +// RUN: llvm-bcanalyzer --dump --disable-histogram %t2.pcm > %t2.dump +// RUN: FileCheck %s --check-prefix=CHECK --check-prefix=NOTIMESTAMP --input-file %t2.dump +// RUN: not diff %t1.dump %t2.dump + + +// CHECK: +// CHECK-NEXT: +// CHECK-NEXT: +// CHECK-NEXT: