================
@@ -0,0 +1,39 @@
+// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fclangir -emit-cir %s -o 
%t.cir
+// RUN: FileCheck --check-prefix=CIR --input-file=%t.cir %s
+// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fclangir -emit-llvm %s -o 
%t-cir.ll
+// RUN: FileCheck --check-prefix=LLVM --input-file=%t-cir.ll %s
+// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -emit-llvm %s -o %t.ll
+// RUN: FileCheck --check-prefix=OGCG --input-file=%t.ll %s
+
+struct SSO {
+  char *p;
+  unsigned long len;
+  union {
+    char local[16];
+    unsigned long capacity;
+  };
+};
+
+// Inner union's tail padding must not bleed into the outer record.
+// CIR: !rec_anon{{.*}} = !cir.record<union "anon{{.*}}" padded 
{!cir.array<!s8i x 16>, !u64i, !cir.array<!u8i x 8>}>
----------------
andykaylor wrote:

We've got a real problem with our representation here. We've got two members 
that are co-located members of the union and then a padding member that is 
appended to whichever element is the largest/highest aligned? The padding 
really needs to be represented separately. Something like:

`!rec_anon{{.*}} = !cir.record<union "anon{{.*}}" padded {!cir.array<!s8i x 
16>, !u64i}, padding = { !cir.array<!u8i x 8>}>`

Or maybe even

`!rec_anon{{.*}} = !cir.record<union "anon{{.*}}" padded {!cir.array<!s8i x 
16>, !u64i}, paddingSize = 8>`


https://github.com/llvm/llvm-project/pull/198361
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to