aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2007-09-28 23:54:26 +0000
committerDevang Patel <dpatel@apple.com>2007-09-28 23:54:26 +0000
commitfb71392848cf31bcfade094ad779176066144a9b (patch)
tree98a7269bded1e666287002caf85a3b866c846910 /test
parent9fe4662d9a9e5b346dc053b6a53bc3d096adb77b (diff)
downloadexternal_llvm-fb71392848cf31bcfade094ad779176066144a9b.zip
external_llvm-fb71392848cf31bcfade094ad779176066144a9b.tar.gz
external_llvm-fb71392848cf31bcfade094ad779176066144a9b.tar.bz2
Do not ignore packed member size while selecting union type.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42458 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test')
-rw-r--r--test/CFrontend/2007-09-28-PackedUnionMember.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/test/CFrontend/2007-09-28-PackedUnionMember.c b/test/CFrontend/2007-09-28-PackedUnionMember.c
new file mode 100644
index 0000000..1e64657
--- /dev/null
+++ b/test/CFrontend/2007-09-28-PackedUnionMember.c
@@ -0,0 +1,37 @@
+// RUN: %llvmgcc %s -S -o -
+#pragma pack(push, 2)
+struct H {
+ unsigned long f1;
+ unsigned long f2;
+ union {
+ struct opaque1 *f3;
+ struct opaque2 *f4;
+ struct {
+ struct opaque3 *f5;
+ unsigned short f6;
+ } f7;
+ } f8;
+};
+#pragma pack(pop)
+
+struct E {
+ unsigned long f1;
+ unsigned long f2;
+};
+
+typedef long (*FuncPtr) ();
+
+extern long bork(FuncPtr handler, const struct E *list);
+
+static long hndlr()
+{
+ struct H cmd = { 4, 'fart' };
+ return 0;
+}
+void foo(void *inWindow) {
+ static const struct E events[] = {
+ { 'cmds', 1 }
+ };
+ bork(hndlr, events);
+}
+