From: Paul Eggert Date: Fri, 27 Jan 2012 18:17:18 +0000 (-0800) Subject: stdalign: check that alignof and offsetof are consistent X-Git-Tag: v0.1~1208 X-Git-Url: http://erislabs.org.uk/gitweb/?a=commitdiff_plain;h=cdd776a1aa13e95d69d57083a921f1e6899ed075;p=gnulib.git stdalign: check that alignof and offsetof are consistent * m4/stdalign.m4 (gl_STDALIGN_H): Check for GCC bug 52023. Problem reported for gnulib by Richard W.M. Jones in . --- diff --git a/ChangeLog b/ChangeLog index 329cc3af0..36861724d 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2012-01-27 Paul Eggert + + stdalign: check that alignof and offsetof are consistent + * m4/stdalign.m4 (gl_STDALIGN_H): Check for GCC bug 52023. + Problem reported for gnulib by Richard W.M. Jones in + . + 2012-01-27 Jim Meyering update-copyright: accept new option: UPDATE_COPYRIGHT_USE_INTERVALS=2 diff --git a/m4/stdalign.m4 b/m4/stdalign.m4 index 9752ba568..fa6d5d55b 100644 --- a/m4/stdalign.m4 +++ b/m4/stdalign.m4 @@ -14,13 +14,26 @@ AC_DEFUN([gl_STDALIGN_H], [AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[#include - int align_int = alignof (int) + _Alignof (double); + #include + + /* Test that alignof yields a result consistent with offsetof. + This catches GCC bug 51316 + . */ + #ifdef __cplusplus + template struct alignof_helper { char a; t b; }; + # define ao(type) offsetof (alignof_helper, b) + #else + # define ao(type) offsetof (struct { char a; type b; }, b) + #endif + char test1[_Alignof (double) == ao (double) ? 1 : -1]; + char test2[alignof (long int) == ao (long int) ? 1 : -1]; /* Test _Alignas only on platforms where gnulib can help. */ #if \ (__GNUC__ || __IBMC__ || __IBMCPP__ \ || 0x5110 <= __SUNPRO_C || 1300 <= _MSC_VER) int alignas (8) alignas_int = 1; + char test3[8 <= _Alignof (alignas_int) ? 1 : -1]; #endif ]])], [gl_cv_header_working_stdalign_h=yes],