Skip to content

Commit

Permalink
Modules: Do not serialize #pragma pack state
Browse files Browse the repository at this point in the history
The modules side of r299226, which serializes #pragma pack state,
doesn't work well.

The main purpose was to make -include and -include-pch match semantics
(the PCH side).  We also started serializing #pragma pack in PCMs, in
the hopes of making modules and non-modules builds more consistent.  But
consider:

    $ cat a.h
    $ cat b.h
    #pragma pack(push, 2)
    $ cat module.modulemap
    module M {
        module a { header "a.h" }
        module b { header "b.h" }
    }
    $ cat t.cpp
    #include "a.h"
    #pragma pack(show)

As of r299226, the #pragma pack(show) gives "2", even though we've only
included "a.h".

- With -fmodules-local-submodule-visibility, this is clearly wrong.  We
  should get the default state (8 on x86_64).

- Without -fmodules-local-submodule-visibility, this kind of matches how
  other things work (as if include-the-whole-module), but it's still
  really terrible, and it doesn't actually make modules and non-modules
  builds more consistent.

This commit disables the serialization for modules, essentially a
partial revert of r299226.

Going forward:

 1. Having this #pragma pack stuff escape is terrible design (or, more
    often, a horrible bug).  We should prioritize adding warnings (maybe
    -Werror by default?).

 2. If we eventually reintroduce this for modules, it should only apply
    to -fmodules-local-submodule-visibility, and it should be tracked on
    a per-submodule basis.

llvm-svn: 300380
  • Loading branch information
dexonsmith committed Apr 15, 2017
1 parent 044f956 commit 03df14c
Show file tree
Hide file tree
Showing 6 changed files with 33 additions and 59 deletions.
5 changes: 5 additions & 0 deletions clang/lib/Serialization/ASTWriter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4186,6 +4186,11 @@ void ASTWriter::WriteMSPointersToMembersPragmaOptions(Sema &SemaRef) {

/// \brief Write the state of 'pragma pack' at the end of the module.
void ASTWriter::WritePackPragmaOptions(Sema &SemaRef) {
// Don't serialize pragma pack state for modules, since it should only take
// effect on a per-submodule basis.
if (WritingModule)
return;

RecordData Record;
Record.push_back(SemaRef.PackStack.CurrentValue);
AddSourceLocation(SemaRef.PackStack.CurrentPragmaLocation, Record);
Expand Down
17 changes: 3 additions & 14 deletions clang/test/Modules/Inputs/module.map
Original file line number Diff line number Diff line change
Expand Up @@ -265,20 +265,9 @@ module diag_pragma {
header "diag_pragma.h"
}

module pragma_pack_set {
header "pragma_pack_set.h"
}

module pragma_pack_push {
header "pragma_pack_push.h"
}

module pragma_pack_empty {
header "empty.h"
}

module pragma_pack_reset_push {
header "pragma_pack_reset_push.h"
module pragma_pack {
module set { header "pragma_pack_set.h" }
module empty { header "empty.h" }
}

module dummy {
Expand Down
6 changes: 0 additions & 6 deletions clang/test/Modules/Inputs/pragma_pack_push.h

This file was deleted.

4 changes: 0 additions & 4 deletions clang/test/Modules/Inputs/pragma_pack_reset_push.h

This file was deleted.

35 changes: 0 additions & 35 deletions clang/test/Modules/pragma-pack.c

This file was deleted.

25 changes: 25 additions & 0 deletions clang/test/Modules/pragma-pack.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
// RUN: rm -rf %t.cache %tlocal.cache
// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fmodules \
// RUN: -fimplicit-module-maps -x c++ -emit-module \
// RUN: -fmodules-cache-path=%t.cache \
// RUN: -fmodule-name=pragma_pack %S/Inputs/module.map
// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fmodules \
// RUN: -fimplicit-module-maps -x c++ -verify \
// RUN: -fmodules-cache-path=%t.cache \
// RUN: -I%S/Inputs %s
// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fmodules \
// RUN: -fmodules-local-submodule-visibility \
// RUN: -fimplicit-module-maps -x c++ -emit-module \
// RUN: -fmodules-cache-path=%tlocal.cache \
// RUN: -fmodule-name=pragma_pack %S/Inputs/module.map
// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fmodules \
// RUN: -fmodules-local-submodule-visibility \
// RUN: -fimplicit-module-maps -x c++ -verify \
// RUN: -fmodules-cache-path=%tlocal.cache \
// RUN: -I%S/Inputs %s

// Check that we don't serialize pragma pack state until/unless including an
// empty file from the same module (but different submodule) has no effect.
#pragma pack (show) // expected-warning {{value of #pragma pack(show) == 8}}
#include "empty.h"
#pragma pack (show) // expected-warning {{value of #pragma pack(show) == 8}}

0 comments on commit 03df14c

Please sign in to comment.