summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2010-01-27 20:23:08 +0000
committerDaniel Dunbar <daniel@zuster.org>2010-01-27 20:23:08 +0000
commit377dc2f91f1eac3649ceb7c2729a36f7c88ad15c (patch)
treee317ee82e7c0ce186a732bb7cb1bb40089aa0dc5
parent1266d46d3223948d48b1c61eece2e87a4b98221b (diff)
downloadbcm5719-llvm-377dc2f91f1eac3649ceb7c2729a36f7c88ad15c.tar.gz
bcm5719-llvm-377dc2f91f1eac3649ceb7c2729a36f7c88ad15c.zip
ARM/APCS: Fix alignment of long double.
llvm-svn: 94685
-rw-r--r--clang/lib/Basic/Targets.cpp2
-rw-r--r--clang/test/Sema/arm-layout.c20
2 files changed, 21 insertions, 1 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp
index ac5a7d16b15..1d898726f9c 100644
--- a/clang/lib/Basic/Targets.cpp
+++ b/clang/lib/Basic/Targets.cpp
@@ -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/clang/test/Sema/arm-layout.c b/clang/test/Sema/arm-layout.c
new file mode 100644
index 00000000000..1e239d275a8
--- /dev/null
+++ b/clang/test/Sema/arm-layout.c
@@ -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
OpenPOWER on IntegriCloud