forked from OSchip/llvm-project
Check module signature when the module has already been loaded
We may need to verify the signature on subsequent imports as well, just like we verify the size/modtime: @import A; @import B; // imports A @import C; // imports A llvm-svn: 221569
This commit is contained in:
parent
e531d27cd1
commit
ed98258482
|
@ -132,21 +132,27 @@ ModuleManager::addModule(StringRef FileName, ModuleKind Type,
|
|||
// Initialize the stream
|
||||
New->StreamFile.init((const unsigned char *)New->Buffer->getBufferStart(),
|
||||
(const unsigned char *)New->Buffer->getBufferEnd());
|
||||
}
|
||||
|
||||
if (ExpectedSignature) {
|
||||
New->Signature = ReadSignature(New->StreamFile);
|
||||
if (New->Signature != ExpectedSignature) {
|
||||
ErrorStr = New->Signature ? "signature mismatch"
|
||||
: "could not read module signature";
|
||||
if (ExpectedSignature) {
|
||||
if (NewModule)
|
||||
ModuleEntry->Signature = ReadSignature(ModuleEntry->StreamFile);
|
||||
else
|
||||
assert(ModuleEntry->Signature == ReadSignature(ModuleEntry->StreamFile));
|
||||
|
||||
if (ModuleEntry->Signature != ExpectedSignature) {
|
||||
ErrorStr = ModuleEntry->Signature ? "signature mismatch"
|
||||
: "could not read module signature";
|
||||
|
||||
if (NewModule) {
|
||||
// Remove the module file immediately, since removeModules might try to
|
||||
// invalidate the file cache for Entry, and that is not safe if this
|
||||
// module is *itself* up to date, but has an out-of-date importer.
|
||||
Modules.erase(Entry);
|
||||
Chain.pop_back();
|
||||
delete New;
|
||||
return OutOfDate;
|
||||
delete ModuleEntry;
|
||||
}
|
||||
return OutOfDate;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -25,4 +25,21 @@
|
|||
// RUN: diff %t/Module.pcm %t/Module.pcm.saved.2
|
||||
// RUN: not diff %t/DependsOnModule.pcm %t/DependsOnModule.pcm.saved
|
||||
|
||||
// Rebuild Module, reset its timestamp, and verify its size hasn't changed
|
||||
// RUN: rm %t/Module.pcm
|
||||
// RUN: echo '@import Module;' | %clang_cc1 -fmodules -fmodules-cache-path=%t -fdisable-module-hash -fsyntax-only -F %S/Inputs -x objective-c -
|
||||
// RUN: touch -m -a -t 201101010000 %t/Module.pcm
|
||||
// RUN: wc -c %t/Module.pcm > %t/Module.size
|
||||
// RUN: diff %t/Module.size %t/Module.size.saved
|
||||
// RUN: cp %t/Module.pcm %t/Module.pcm.saved.2
|
||||
|
||||
// Verify again with Module pre-imported.
|
||||
// NOTE: if we change how the signature is created, this test may need updating.
|
||||
// RUN: %clang_cc1 -fmodules -fmodules-cache-path=%t -fdisable-module-hash -fsyntax-only -F %S/Inputs %s
|
||||
// RUN: diff %t/Module.pcm %t/Module.pcm.saved.2
|
||||
// RUN: not diff %t/DependsOnModule.pcm %t/DependsOnModule.pcm.saved
|
||||
|
||||
#ifdef PREIMPORT
|
||||
@import Module;
|
||||
#endif
|
||||
@import DependsOnModule;
|
||||
|
|
Loading…
Reference in New Issue