diff options
author | David Majnemer <david.majnemer@gmail.com> | 2014-10-03 07:41:09 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2014-10-03 07:41:09 +0000 |
commit | ba7f49a23d834fb42fa42ad0a2e0d8a65743d4c9 (patch) | |
tree | babede03f25cb8a8177ce086c8d287eae965d93e /clang/test/Layout/ms-x86-empty-layout.c | |
parent | 44fe05beeb23850f729b9d8d1c0a82c0ce9c2909 (diff) | |
download | bcm5719-llvm-ba7f49a23d834fb42fa42ad0a2e0d8a65743d4c9.tar.gz bcm5719-llvm-ba7f49a23d834fb42fa42ad0a2e0d8a65743d4c9.zip |
MS ABI: Add an additional test for empty structs in C
Empty structs in C differ from those in C++.
- C++ requires that empty types have size 1; alignment requirements may
increase the size of the struct.
- The C implementation doesn't let empty structs have a size under 4
bytes. Again, alignment requirements may increase the struct's size.
Add a test to stress these differences.
llvm-svn: 218963
Diffstat (limited to 'clang/test/Layout/ms-x86-empty-layout.c')
-rw-r--r-- | clang/test/Layout/ms-x86-empty-layout.c | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/clang/test/Layout/ms-x86-empty-layout.c b/clang/test/Layout/ms-x86-empty-layout.c new file mode 100644 index 00000000000..faca0be0a9c --- /dev/null +++ b/clang/test/Layout/ms-x86-empty-layout.c @@ -0,0 +1,88 @@ +// RUN: %clang_cc1 -fno-rtti -emit-llvm-only -triple i686-pc-win32 -fdump-record-layouts -fsyntax-only %s 2>/dev/null \ +// RUN: | FileCheck %s +// RUN: %clang_cc1 -fno-rtti -emit-llvm-only -triple x86_64-pc-win32 -fdump-record-layouts -fsyntax-only %s 2>/dev/null \ +// RUN: | FileCheck %s + +struct EmptyIntMemb { + int FlexArrayMemb[0]; +}; +// CHECK: *** Dumping AST Record Layout +// CHECK: Type: struct EmptyIntMemb +// CHECK: Record: +// CHECK: Layout: <ASTRecordLayout +// CHECK: Size:32 +// CHECK: Alignment:32 +// CHECK: FieldOffsets: [0]> + +struct EmptyLongLongMemb { + long long FlexArrayMemb[0]; +}; +// CHECK: *** Dumping AST Record Layout +// CHECK: Type: struct EmptyLongLongMemb +// CHECK: Record: +// CHECK: Layout: <ASTRecordLayout +// CHECK: Size:32 +// CHECK: Alignment:64 +// CHECK: FieldOffsets: [0]> + +struct EmptyAligned2LongLongMemb { + long long __declspec(align(2)) FlexArrayMemb[0]; +}; + +// CHECK: *** Dumping AST Record Layout +// CHECK: Type: struct EmptyAligned2LongLongMemb +// CHECK: Record: +// CHECK: Layout: <ASTRecordLayout +// CHECK: Size:32 +// CHECK: Alignment:64 +// CHECK: FieldOffsets: [0]> + +struct EmptyAligned8LongLongMemb { + long long __declspec(align(8)) FlexArrayMemb[0]; +}; + +// CHECK: *** Dumping AST Record Layout +// CHECK: Type: struct EmptyAligned8LongLongMemb +// CHECK: Record: +// CHECK: Layout: <ASTRecordLayout +// CHECK: Size:64 +// CHECK: Alignment:64 +// CHECK: FieldOffsets: [0]> + +#pragma pack(1) +struct __declspec(align(4)) EmptyPackedAligned4LongLongMemb { + long long FlexArrayMemb[0]; +}; +#pragma pack() + +// CHECK: *** Dumping AST Record Layout +// CHECK: Type: struct EmptyPackedAligned4LongLongMemb +// CHECK: Record: +// CHECK: Layout: <ASTRecordLayout +// CHECK: Size:32 +// CHECK: Alignment:32 +// CHECK: FieldOffsets: [0]> + +#pragma pack(1) +struct EmptyPackedAligned8LongLongMemb { + long long __declspec(align(8)) FlexArrayMemb[0]; +}; +#pragma pack() + +// CHECK: *** Dumping AST Record Layout +// CHECK: Type: struct EmptyPackedAligned8LongLongMemb +// CHECK: Record: +// CHECK: Layout: <ASTRecordLayout +// CHECK: Size:64 +// CHECK: Alignment:64 +// CHECK: FieldOffsets: [0]> + + +int a[ +sizeof(struct EmptyIntMemb)+ +sizeof(struct EmptyLongLongMemb)+ +sizeof(struct EmptyAligned2LongLongMemb)+ +sizeof(struct EmptyAligned8LongLongMemb)+ +sizeof(struct EmptyPackedAligned4LongLongMemb)+ +sizeof(struct EmptyPackedAligned8LongLongMemb)+ +0]; |