From: Bruno Haible Date: Fri, 8 May 2009 11:21:34 +0000 (+0200) Subject: Use module 'alignof'. X-Git-Tag: v0.1~5933 X-Git-Url: http://erislabs.org.uk/gitweb/?a=commitdiff_plain;h=37654ecf58fe14c16eb3fbea289151c2e493e8cf;p=gnulib.git Use module 'alignof'. --- diff --git a/ChangeLog b/ChangeLog index 68b3f8ed2..92c696a2b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,11 @@ 2009-05-08 Bruno Haible + Use module 'alignof'. + * lib/malloca.h: Include alignof.h. + (sa_alignof): Remove macro. + (sa_alignment_*): Use the alignof macro. + * modules/malloca (Depends-on): Add alignof. + New module 'alignof'. * lib/alignof.h: New file. * modules/alignof: New file. diff --git a/lib/malloca.h b/lib/malloca.h index 5bb2d4734..2bf850152 100644 --- a/lib/malloca.h +++ b/lib/malloca.h @@ -1,5 +1,5 @@ /* Safe automatic memory allocation. - Copyright (C) 2003-2007 Free Software Foundation, Inc. + Copyright (C) 2003-2007, 2009 Free Software Foundation, Inc. Written by Bruno Haible , 2003. This program is free software; you can redistribute it and/or modify @@ -23,6 +23,8 @@ #include #include +#include "alignof.h" + #ifdef __cplusplus extern "C" { @@ -92,34 +94,16 @@ extern void * nmalloca (size_t n, size_t s); /* ------------------- Auxiliary, non-public definitions ------------------- */ -/* Determine the alignment of a type at compile time. */ -#if defined __GNUC__ -# define sa_alignof __alignof__ -#elif defined __cplusplus - template struct sa_alignof_helper { char __slot1; type __slot2; }; -# define sa_alignof(type) offsetof (sa_alignof_helper, __slot2) -#elif defined __hpux - /* Work around a HP-UX 10.20 cc bug with enums constants defined as offsetof - values. */ -# define sa_alignof(type) (sizeof (type) <= 4 ? 4 : 8) -#elif defined _AIX - /* Work around an AIX 3.2.5 xlc bug with enums constants defined as offsetof - values. */ -# define sa_alignof(type) (sizeof (type) <= 4 ? 4 : 8) -#else -# define sa_alignof(type) offsetof (struct { char __slot1; type __slot2; }, __slot2) -#endif - enum { /* The desired alignment of memory allocations is the maximum alignment among all elementary types. */ - sa_alignment_long = sa_alignof (long), - sa_alignment_double = sa_alignof (double), + sa_alignment_long = alignof (long), + sa_alignment_double = alignof (double), #if HAVE_LONG_LONG_INT - sa_alignment_longlong = sa_alignof (long long), + sa_alignment_longlong = alignof (long long), #endif - sa_alignment_longdouble = sa_alignof (long double), + sa_alignment_longdouble = alignof (long double), sa_alignment_max = ((sa_alignment_long - 1) | (sa_alignment_double - 1) #if HAVE_LONG_LONG_INT | (sa_alignment_longlong - 1) diff --git a/modules/malloca b/modules/malloca index d54bf3061..a132c3941 100644 --- a/modules/malloca +++ b/modules/malloca @@ -10,6 +10,7 @@ m4/eealloc.m4 m4/longlong.m4 Depends-on: +alignof alloca-opt configure.ac: