svn commit: r211023 - head/usr.sbin/syslogd
M. Warner Losh
imp at bsdimp.com
Tue Aug 10 18:43:19 UTC 2010
In message: <11606.1281464144 at critter.freebsd.dk>
"Poul-Henning Kamp" <phk at phk.freebsd.dk> writes:
: In message <20100810.115457.1126759349893144516.imp at bsdimp.com>, "M. Warner Los
: h" writes:
: >In message: <20100811.023235.13138059.hrs at allbsd.org>
: > Hiroki Sato <hrs at FreeBSD.org> writes:
: >: Oliver Fromme <olli at fromme.com> wrote
: >: in <201008101623.o7AGNs7I042679 at haluter.fromme.com>:
: >:
: >: ol> -static int validate(struct sockaddr *, const char *);
: >: ol> -static void unmapped(struct sockaddr *);
: >: ol> +static int validate(struct sockaddr_storage *, const char *);
: >: ol> +static void unmapped(struct sockaddr_storage *);
: >:
: >: Why is s/struct sockaddr */struct sockaddr_storage */ needed here?
: >: Using (struct sockaddr *) as an argument looks reasonable to me since
: >: the struct sockaddr_storage is mostly for memory allocation, not for
: >: access via pointer.
: >
: >Because struct sockaddr * has a too loose alignment requirement for
: >later casting, while sockaddr_storage has the proper alignment.
:
: This is the kind of detail Bruce, Warner and I know, but I bet it
: was news to most of you.
:
: Somebody should add it to the relevant manualpages...
It was news to me when I saw it :) But given other posix requirements
for this interface, maybe there's a better fix...
Warner
More information about the svn-src-head
mailing list