diff options
author | Duncan P. N. Exon Smith <dexonsmith@apple.com> | 2017-04-15 00:07:57 +0000 |
---|---|---|
committer | Duncan P. N. Exon Smith <dexonsmith@apple.com> | 2017-04-15 00:07:57 +0000 |
commit | 03df14c6dd2ae36b04d0a085ae9fa69aad8193ab (patch) | |
tree | d940bdde9086e4bb1732b2f3774825d870b2697a /clang/test/Modules/Inputs | |
parent | 044f956f9af8b8f4c8a2ccf5dde5cd48d34a5721 (diff) | |
download | bcm5719-llvm-03df14c6dd2ae36b04d0a085ae9fa69aad8193ab.tar.gz bcm5719-llvm-03df14c6dd2ae36b04d0a085ae9fa69aad8193ab.zip |
Modules: Do not serialize #pragma pack state
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
Diffstat (limited to 'clang/test/Modules/Inputs')
-rw-r--r-- | clang/test/Modules/Inputs/module.map | 17 | ||||
-rw-r--r-- | clang/test/Modules/Inputs/pragma_pack_push.h | 6 | ||||
-rw-r--r-- | clang/test/Modules/Inputs/pragma_pack_reset_push.h | 4 |
3 files changed, 3 insertions, 24 deletions
diff --git a/clang/test/Modules/Inputs/module.map b/clang/test/Modules/Inputs/module.map index dcb60bea851..b95eec351e8 100644 --- a/clang/test/Modules/Inputs/module.map +++ b/clang/test/Modules/Inputs/module.map @@ -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 { diff --git a/clang/test/Modules/Inputs/pragma_pack_push.h b/clang/test/Modules/Inputs/pragma_pack_push.h deleted file mode 100644 index 4fc66e51cf8..00000000000 --- a/clang/test/Modules/Inputs/pragma_pack_push.h +++ /dev/null @@ -1,6 +0,0 @@ - -#pragma pack (push, 4) -#pragma pack (push, 2) -#pragma pack (push, 1) -#pragma pack (pop) - diff --git a/clang/test/Modules/Inputs/pragma_pack_reset_push.h b/clang/test/Modules/Inputs/pragma_pack_reset_push.h deleted file mode 100644 index 18f50a00952..00000000000 --- a/clang/test/Modules/Inputs/pragma_pack_reset_push.h +++ /dev/null @@ -1,4 +0,0 @@ - -#pragma pack () -#pragma pack (push, 4) - |