llvm-project/clang/test/Sema/mms-bitfields.c
Oliver Hunt 8a05c20c96
Add an off-by-default warning to complain about MSVC bitfield padding (#117428)
This just adds a warning for bitfields placed next to other bitfields
where the underlying type has different storage. Under the MS struct
bitfield packing ABI such bitfields are not packed.
2025-05-13 14:00:20 -07:00

33 lines
975 B
C

// RUN: %clang_cc1 -mms-bitfields -fsyntax-only -verify -triple x86_64-apple-darwin9 %s
// RUN: %clang_cc1 -mms-bitfields -fsyntax-only -Wms-bitfield-padding -verify=checkms -triple x86_64-apple-darwin9 %s
// expected-no-diagnostics
// The -mms-bitfields commandline parameter should behave the same
// as the ms_struct attribute.
struct
{
int a : 1; // #a
short b : 1;
// checkms-warning@-1 {{bit-field 'b' of type 'short' has a different storage size than the preceding bit-field (2 vs 4 bytes) and will not be packed under the Microsoft ABI}}
// checkms-note@#a {{preceding bit-field 'a' declared here with type 'int'}}
} t;
// MS pads out bitfields between different types.
static int arr[(sizeof(t) == 8) ? 1 : -1];
#pragma pack (push,1)
typedef unsigned int UINT32;
struct Inner {
UINT32 A : 1;
UINT32 B : 1;
UINT32 C : 1;
UINT32 D : 30;
} Inner;
#pragma pack (pop)
static int arr2[(sizeof(Inner) == 8) ? 1 : -1];