Do not ignore packed member size while selecting union type.
authorDevang Patel <dpatel@apple.com>
Fri, 28 Sep 2007 23:54:26 +0000 (23:54 +0000)
committerDevang Patel <dpatel@apple.com>
Fri, 28 Sep 2007 23:54:26 +0000 (23:54 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42458 91177308-0d34-0410-b5e6-96231b3b80d8

test/CFrontend/2007-09-28-PackedUnionMember.c [new file with mode: 0644]

diff --git a/test/CFrontend/2007-09-28-PackedUnionMember.c b/test/CFrontend/2007-09-28-PackedUnionMember.c
new file mode 100644 (file)
index 0000000..1e64657
--- /dev/null
@@ -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);
+}
+