svn commit: r307756 - in head: include sys/sys

John Baldwin jhb at freebsd.org
Mon Oct 24 17:07:03 UTC 2016


On Saturday, October 22, 2016 12:00:56 AM Brooks Davis wrote:
> On Fri, Oct 21, 2016 at 11:50:02PM +0000, John Baldwin wrote:
> > Author: jhb
> > Date: Fri Oct 21 23:50:02 2016
> > New Revision: 307756
> > URL: https://svnweb.freebsd.org/changeset/base/307756
> > 
> > Log:
> >   Define max_align_t for C11.
> >   
> >   libc++'s stddef.h includes an existing definition of max_align_t for
> >   C++11, but it is only defined for C++, not for C.  In addition, GCC and
> >   clang both define an alternate version of max_align_t that uses a
> >   union of multiple types rather than a plain long double as in libc++.
> >   This adds a __max_align_t to <sys/_types.h> that matches the GCC and
> >   clang definition that is mapped to max_align_t in <stddef.h>.
> >   
> >   PR:		210890
> >   Reviewed by:	dim
> >   MFC after:	1 month
> >   Differential Revision:	https://reviews.freebsd.org/D8194
> > 
> > Modified:
> >   head/include/stddef.h
> >   head/sys/sys/_types.h
> > 
> > Modified: head/include/stddef.h
> > ==============================================================================
> > --- head/include/stddef.h	Fri Oct 21 21:55:50 2016	(r307755)
> > +++ head/include/stddef.h	Fri Oct 21 23:50:02 2016	(r307756)
> > @@ -62,6 +62,14 @@ typedef	___wchar_t	wchar_t;
> >  #endif
> >  #endif
> >  
> > +#if __STDC_VERSION__ >= 201112L || __cplusplus >= 201103L
> > +#ifndef __CLANG_MAX_ALIGN_T_DEFINED
> > +typedef	__max_align_t	max_align_t;
> > +#define __CLANG_MAX_ALIGN_T_DEFINED
> > +#define __GCC_MAX_ALIGN_T
> > +#endif
> > +#endif
> > +
> >  #define	offsetof(type, member)	__offsetof(type, member)
> >  
> >  #endif /* _STDDEF_H_ */
> > 
> > Modified: head/sys/sys/_types.h
> > ==============================================================================
> > --- head/sys/sys/_types.h	Fri Oct 21 21:55:50 2016	(r307755)
> > +++ head/sys/sys/_types.h	Fri Oct 21 23:50:02 2016	(r307756)
> > @@ -100,6 +100,11 @@ typedef	__uint_least32_t __char32_t;
> >  #define	_CHAR32_T_DECLARED
> >  #endif
> >  
> > +typedef struct {
> 
> Should this be union per the commit message?

Dimitry's response is correct of course.  I think my brain had "fixed" this
when I read it to be a union instead of a struct since a struct seems so
obviously wrong.

-- 
John Baldwin


More information about the svn-src-all mailing list