diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-05-13 21:34:08 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-05-13 21:34:08 +0000 |
commit | 1faf5baa2f5e1adecb289679fe41c8a5080e4611 (patch) | |
tree | 2d8b3dc7fb08b3ddf340eca835c2289e1c11ecd9 | |
parent | 6a502a3bc72700d5db65f07ffcf1f11b67ca86db (diff) |
Add a test case to showcase a difference in #pragma pack handling
compared to gcc. This is worrisome, but I believe we are doing the
"correct" thing, and if I recall correctly I previously verified this
versus MSVC.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71723 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/Sema/pragma-pack-3.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/test/Sema/pragma-pack-3.c b/test/Sema/pragma-pack-3.c new file mode 100644 index 0000000000..a2d665ea74 --- /dev/null +++ b/test/Sema/pragma-pack-3.c @@ -0,0 +1,34 @@ +// RUN: clang-cc -triple i686-apple-darwin9 %s -fsyntax-only -verify + +// Stack: [], Alignment: 8 + +#pragma pack(push, 1) +// Stack: [8], Alignment: 1 + +#pragma pack(push, 4) +// Stack: [8, 1], Alignment: 4 + +// Note that this differs from gcc; pack() in gcc appears to pop the +// top stack entry and resets the current alignment. This is both +// inconsistent with MSVC, and the gcc documentation. In other cases, +// for example changing this to pack(8), I don't even understand what gcc +// is doing. + +#pragma pack() +// Stack: [8, 1], Alignment: 8 + +#pragma pack(pop) +// Stack: [8], Alignment: 1 +struct s0 { + char f0; + short f1; +}; +int a[sizeof(struct s0) == 3 ? 1 : -1]; + +#pragma pack(pop) +// Stack: [], Alignment: 8 +struct s1 { + char f0; + short f1; +}; +int b[sizeof(struct s1) == 4 ? 1 : -1]; |