[PATCH] Ensure i686-nacl long long is aligned 8 bytes (like malign-double)
Jan Voung
jvoung at chromium.org
Mon Jan 13 16:45:43 PST 2014
Hi dschuff,
Set NaCl OSTargetInfo to have LongLongAlign = 64. Otherwise, it will pick up the setting of 32 from X86_32TargetInfo.
http://llvm-reviews.chandlerc.com/D2544
Files:
lib/Basic/Targets.cpp
test/CodeGen/malign-double-x86-nacl.c
Index: lib/Basic/Targets.cpp
===================================================================
--- lib/Basic/Targets.cpp
+++ lib/Basic/Targets.cpp
@@ -619,6 +619,8 @@
this->DoubleAlign = 64;
this->LongDoubleWidth = 64;
this->LongDoubleAlign = 64;
+ this->LongLongWidth = 64;
+ this->LongLongAlign = 64;
this->SizeType = TargetInfo::UnsignedInt;
this->PtrDiffType = TargetInfo::SignedInt;
this->IntPtrType = TargetInfo::SignedInt;
Index: test/CodeGen/malign-double-x86-nacl.c
===================================================================
--- test/CodeGen/malign-double-x86-nacl.c
+++ test/CodeGen/malign-double-x86-nacl.c
@@ -1,7 +1,43 @@
// RUN: %clang_cc1 %s -emit-llvm -o - -triple=i686-unknown-nacl | FileCheck %s
+// Check that i686-nacl essentially has -malign-double, which aligns
+// double, long double, and long long to 64-bits.
-long double x = 0;
-int checksize[sizeof(x) == 8 ? 1 : -1];
+int checksize[sizeof(long double) == 8 ? 1 : -1];
+int checkalign[__alignof(long double) == 8 ? 1 : -1];
// CHECK-LABEL: define void @s1(double %a)
void s1(long double a) {}
+
+struct st_ld {
+ char c;
+ long double ld;
+};
+int checksize2[sizeof(struct st_ld) == 16 ? 1 : -1];
+int checkalign2[__alignof(struct st_ld) == 8 ? 1 : -1];
+
+int checksize3[sizeof(double) == 8 ? 1 : -1];
+int checkalign3[__alignof(double) == 8 ? 1 : -1];
+
+// CHECK-LABEL: define void @s2(double %a)
+void s2(double a) {}
+
+struct st_d {
+ char c;
+ double d;
+};
+int checksize4[sizeof(struct st_d) == 16 ? 1 : -1];
+int checkalign4[__alignof(struct st_d) == 8 ? 1 : -1];
+
+
+int checksize5[sizeof(long long) == 8 ? 1 : -1];
+int checkalign5[__alignof(long long) == 8 ? 1 : -1];
+
+// CHECK-LABEL: define void @s3(i64 %a)
+void s3(long long a) {}
+
+struct st_ll {
+ char c;
+ long long ll;
+};
+int checksize6[sizeof(struct st_ll) == 16 ? 1 : -1];
+int checkalign6[__alignof(struct st_ll) == 8 ? 1 : -1];
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D2544.1.patch
Type: text/x-patch
Size: 1947 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20140113/fa0fdf8b/attachment.bin>
More information about the cfe-commits
mailing list