# HG changeset patch # User Paul Eggert # Date 1327688238 28800 # Node ID 39ff0ed6c426de6d308794ae8279b3410ff1501e # Parent c38ba07a30d174af16d5b71eb1cd585422b12967 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 -r c38ba07a30d1 -r 39ff0ed6c426 ChangeLog --- a/ChangeLog Fri Jan 27 10:19:26 2012 +0100 +++ b/ChangeLog Fri Jan 27 10:17:18 2012 -0800 @@ -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 -r c38ba07a30d1 -r 39ff0ed6c426 m4/stdalign.m4 --- a/m4/stdalign.m4 Fri Jan 27 10:19:26 2012 +0100 +++ b/m4/stdalign.m4 Fri Jan 27 10:17:18 2012 -0800 @@ -14,13 +14,26 @@ [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],