]> granicus.if.org Git - clang/commitdiff
ARM/APCS: Fix alignment of long double.
authorDaniel Dunbar <daniel@zuster.org>
Wed, 27 Jan 2010 20:23:08 +0000 (20:23 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Wed, 27 Jan 2010 20:23:08 +0000 (20:23 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@94685 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Basic/Targets.cpp
test/Sema/arm-layout.c [new file with mode: 0644]

index ac5a7d16b1565bceb2bb08b6d6b26080e62fab5b..1d898726f9cd79d3b9f970ea1bc4243e6b08a49a 100644 (file)
@@ -1240,7 +1240,7 @@ public:
     // FIXME: We need support for -meabi... we could just mangle it into the
     // name.
     if (Name == "apcs-gnu") {
-      DoubleAlign = LongLongAlign = 32;
+      DoubleAlign = LongLongAlign = LongDoubleAlign = 32;
       SizeType = UnsignedLong;
 
       if (IsThumb) {
diff --git a/test/Sema/arm-layout.c b/test/Sema/arm-layout.c
new file mode 100644 (file)
index 0000000..1e239d2
--- /dev/null
@@ -0,0 +1,20 @@
+// RUN: %clang_cc1 -triple armv7-unknown-unknown -target-abi apcs-gnu %s -verify
+// RUN: %clang_cc1 -triple armv7-unknown-unknown -target-abi aapcs %s -verify
+
+#ifdef __ARM_EABI__
+
+struct s0 { char field0; double field1; };
+int g0[sizeof(struct s0) == 16 ? 1 : -1];
+
+struct s1 { char field0; long double field1; };
+int g1[sizeof(struct s1) == 16 ? 1 : -1];
+
+#else
+
+struct s0 { char field0; double field1; };
+int g0[sizeof(struct s0) == 12 ? 1 : -1];
+
+struct s1 { char field0; long double field1; };
+int g1[sizeof(struct s1) == 12 ? 1 : -1];
+
+#endif