]> granicus.if.org Git - clang/commit
Implement #pragma pack use in structure packing. The general approach
authorDaniel Dunbar <daniel@zuster.org>
Thu, 16 Oct 2008 02:34:03 +0000 (02:34 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Thu, 16 Oct 2008 02:34:03 +0000 (02:34 +0000)
commit3b0db908ebd07eaa26bc90deba5e826de00fe515
tree2316573acc7083d4f2a9a4aecdf8beb50bab7713
parentdc914c876cd2a4308c81a9bb0ac07033f2117c23
Implement #pragma pack use in structure packing. The general approach
is to encode the state of the #pragma pack stack as an attribute when
the structure is declared.

 - Extend PackedAttr to take an alignment (in bits), and reuse for
   both __attribute__((packed)) (which takes no argument, instead
   packing tightly (to "minimize the memory required") and for #pragma
   pack (which allows specification of the maximum alignment in
   bytes). __attribute__((packed)) is just encoded as Alignment=1.

   This conflates two related but different mechanisms, but it didn't
   seem worth another attribute.

 - I have attempted to follow the MSVC semantics as opposed to the gcc
   ones, since if I understand correctly #pragma pack originated with
   MSVC. The semantics are generally equivalent except when the stack
   is altered during the definition of a structure; its not clear if
   anyone does this in practice. See testcase if curious.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57623 91177308-0d34-0410-b5e6-96231b3b80d8
include/clang/AST/Attr.h
include/clang/AST/RecordLayout.h
lib/AST/ASTContext.cpp
lib/Sema/SemaDecl.cpp
lib/Sema/SemaDeclAttr.cpp
test/Sema/pragma-pack-2.c [new file with mode: 0644]