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
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to