Support pack pragma and ms_struct attributes. // rdar://8823265

llvm-svn: 131142
This commit is contained in:
Fariborz Jahanian 2011-05-10 19:00:50 +00:00
parent 6878c36328
commit 07ceb0a1a4
2 changed files with 41 additions and 0 deletions

View File

@ -1299,6 +1299,13 @@ void RecordLayoutBuilder::LayoutFields(const RecordDecl *D) {
uint64_t UnpaddedFieldOffset = uint64_t UnpaddedFieldOffset =
getDataSizeInBits() - UnfilledBitsInLastByte; getDataSizeInBits() - UnfilledBitsInLastByte;
FieldAlign = std::max(FieldAlign, FieldAlignLastFD); FieldAlign = std::max(FieldAlign, FieldAlignLastFD);
// The maximum field alignment overrides the aligned attribute.
if (!MaxFieldAlignment.isZero()) {
unsigned MaxFieldAlignmentInBits =
Context.toBits(MaxFieldAlignment);
FieldAlign = std::min(FieldAlign, MaxFieldAlignmentInBits);
}
uint64_t NewSizeInBits = uint64_t NewSizeInBits =
llvm::RoundUpToAlignment(UnpaddedFieldOffset, FieldAlign); llvm::RoundUpToAlignment(UnpaddedFieldOffset, FieldAlign);
setDataSize(llvm::RoundUpToAlignment(NewSizeInBits, setDataSize(llvm::RoundUpToAlignment(NewSizeInBits,

View File

@ -0,0 +1,34 @@
// RUN: %clang_cc1 -emit-llvm-only -triple i386-apple-darwin9 %s
// rdar://8823265
#pragma pack(1)
struct _two_ms {
short m:9; // size is 2
int q:27; // size is 6
short w:13; // size is 8
short e:3; // size is 8
char r:4; // size is 9
char t:7; // size is 10
short y:16; // size is 12
// clang and gcc start differing here. clang seems to follow the rules.
short u:1; // size is clang: 13 gcc:14
char i:2; // size is 14
int a; // size is 18
char o:6; // size is 19
char s:2; // size is 19
short d:10; // size is 21
short f:4; // size is 21
char b; // size is 22
char g:1; // size is 23
short h:13; // size is 25
char j:8; // size is 26
char k:5; // size is 27
char c; // size is 28
int l:28; // size is 32
char z:7; // size is 33
int x:20; // size is clang: 36 gcc:38
} __attribute__((__ms_struct__));
typedef struct _two_ms two_ms;
// gcc says size is 38, but its does not seem right!
static int a1[(sizeof(two_ms) == 36) - 1];