]> code.delx.au - gnu-emacs/commitdiff
Merge from gnulib
authorPaul Eggert <eggert@cs.ucla.edu>
Tue, 7 Apr 2015 04:47:08 +0000 (21:47 -0700)
committerPaul Eggert <eggert@cs.ucla.edu>
Tue, 7 Apr 2015 04:47:33 +0000 (21:47 -0700)
* lib/stddef.in.h: Update from gnulib, incorporating:
2015-04-02 stddef: port to pre-C11 GCC on x86

ChangeLog
lib/stddef.in.h

index 70ab50cd443e18b280752fc6d6ec0f2fbdcf6411..6e2b4fc19d8a135ef38a347f0b8236c205baff2f 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2015-04-07  Paul Eggert  <eggert@cs.ucla.edu>
+
+       Merge from gnulib
+       * lib/stddef.in.h: Update from gnulib, incorporating:
+       2015-04-02 stddef: port to pre-C11 GCC on x86
+
 2015-04-03  Paul Eggert  <eggert@cs.ucla.edu>
 
        Port 'configure' to clang 3.5
index 44db24173c4c7438ce0b1ac710cba78d9b4b1684..698307bc9559d35e497a2bdd5c42726aeb00df94 100644 (file)
 
 /* Some platforms lack max_align_t.  */
 #if !@HAVE_MAX_ALIGN_T@
+/* On the x86, the maximum storage alignment of double, long, etc. is 4,
+   but GCC's C11 ABI for x86 says that max_align_t has an alignment of 8,
+   and the C11 standard allows this.  Work around this problem by
+   using __alignof__ (which returns 8 for double) rather than _Alignof
+   (which returns 4), and align each union member accordingly.  */
+# ifdef __GNUC__
+#  define _GL_STDDEF_ALIGNAS(type) \
+     __attribute__ ((__aligned__ (__alignof__ (type))))
+# else
+#  define _GL_STDDEF_ALIGNAS(type) /* */
+# endif
 typedef union
 {
-  char *__p;
-  double __d;
-  long double __ld;
-  long int __i;
+  char *__p _GL_STDDEF_ALIGNAS (char *);
+  double __d _GL_STDDEF_ALIGNAS (double);
+  long double __ld _GL_STDDEF_ALIGNAS (long double);
+  long int __i _GL_STDDEF_ALIGNAS (long int);
 } max_align_t;
 #endif