glibc/inet
Joseph Myers 6a1cefac19 Make endian-conversion macros always return correct types (bug 16458).
Bug 16458 reports that the endian-conversion macros in <endian.h> and
<netinet/in.h>, in the case where no endian conversion is needed, just
return their arguments without converting to the expected return type,
so failing to act as expected for a macro version of a function.  (The
<netinet/in.h> macros, in particular, are described with prototypes in
POSIX so should act like correspondingly prototyped functions.)

Where previously this was a fairly obscure issue, it now results in
glibc build with GCC mainline breaking for big-endian systems:

nss_hesiod/hesiod-service.c: In function '_nss_hesiod_getservbyport_r':
nss_hesiod/hesiod-service.c:142:39: error: '%d' directive output may be truncated writing between 1 and 11 bytes into a region of size 6 [-Werror=format-truncation=]
   snprintf (portstr, sizeof portstr, "%d", ntohs (port));
                                       ^~
nss_hesiod/hesiod-service.c:142:38: note: using the range [1, -2147483648] for directive argument
   snprintf (portstr, sizeof portstr, "%d", ntohs (port));
                                      ^~~~
nss_hesiod/hesiod-service.c:142:3: note: format output between 2 and 12 bytes into a destination of size 6
   snprintf (portstr, sizeof portstr, "%d", ntohs (port));
   ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The port argument is passed as int to this function, so when ntohs
does not convert the compiler cannot tell that the result is within
the range of uint16_t.  (I don't know if in fact it's possible for
out-of-range values to reach this function and so get truncated as
strings without this patch or as integers with it.)

This patch arranges for these macros to use identity functions to
ensure appropriate conversions while having warnings for implicit
conversions of function arguments that might not occur with a cast.

Tested for x86_64 and x86; with build-many-glibcs.py with GCC 6; and
with build-many-glibcs.py with GCC mainline for powerpc to test the
build fix.

	[BZ #16458]
	* bits/uintn-identity.h: New file.
	* inet/netinet/in.h: Include <bits/uintn-identity.h>.
	[__BYTE_ORDER == __BIG_ENDIAN] (ntohl): Use __uint32_identity.
	[__BYTE_ORDER == __BIG_ENDIAN] (ntohs): Use __uint16_identity.
	[__BYTE_ORDER == __BIG_ENDIAN] (htonl): Use __uint32_identity.
	[__BYTE_ORDER == __BIG_ENDIAN] (htohs): Use __uint16_identity.
	* string/endian.h: Include <bits/uintn-identity.h>.
	[__BYTE_ORDER == __LITTLE_ENDIAN] (htole16): Use
	__uint16_identity.
	[__BYTE_ORDER == __LITTLE_ENDIAN] (le16toh): Likewise.
	[__BYTE_ORDER == __LITTLE_ENDIAN] (htole32): Use
	__uint32_identity.
	[__BYTE_ORDER == __LITTLE_ENDIAN] (le32toh): Likewise.
	[__BYTE_ORDER == __LITTLE_ENDIAN] (htole64): Use
	__uint64_identity.
	[__BYTE_ORDER == __LITTLE_ENDIAN] (le64toh): Likewise.
	[__BYTE_ORDER != __LITTLE_ENDIAN] (htobe16): Use
	__uint16_identity.
	[__BYTE_ORDER != __LITTLE_ENDIAN] (be16toh): Likewise.
	[__BYTE_ORDER != __LITTLE_ENDIAN] (htobe32): Use
	__uint32_identity.
	[__BYTE_ORDER != __LITTLE_ENDIAN] (be32toh): Likewise.
	[__BYTE_ORDER != __LITTLE_ENDIAN] (htobe64): Use
	__uint64_identity.
	[__BYTE_ORDER != __LITTLE_ENDIAN] (be64toh): Likewise.
	* string/Makefile (headers): Add bits/uintn-identity.h.
	(tests): Add test-endian-types.
	* string/test-endian-types.c: New file.
	* inet/Makefile (tests): Add test-hnto-types.
	* inet/test-hnto-types.c: New file.
2017-01-11 15:28:08 +00:00
..
arpa Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
netinet Make endian-conversion macros always return correct types (bug 16458). 2017-01-11 15:28:08 +00:00
protocols Installed-header hygiene (BZ#20366): conditionally defined structures. 2016-09-23 08:43:56 -04:00
Makefile Make endian-conversion macros always return correct types (bug 16458). 2017-01-11 15:28:08 +00:00
Versions inet: Add __inet6_scopeid_pton function [BZ #20611] 2016-09-15 15:46:30 +02:00
aliases.h Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
bug-if1.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
check_native.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
check_pf.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_aton.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_aton_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_hton.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_line.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_ntoa.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_ntoa_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ether_ntoh.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getaliasent.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getaliasent_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getaliasname.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getaliasname_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstbyad.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstbyad_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstbynm.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstbynm2.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstbynm2_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstbynm_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstent.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
gethstent_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getipv4sourcefilter.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnameinfo.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetbyad.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetbyad_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetbynm.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetbynm_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetent.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetent_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetgrent.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getnetgrent_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getproto.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getproto_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getprtent.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getprtent_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getprtname.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getprtname_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getservent.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getservent_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getsourcefilter.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getsrvbynm.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getsrvbynm_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getsrvbypt.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
getsrvbypt_r.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
herrno-loc.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
herrno.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
htonl.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
htons.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
htontest.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
if_index.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ifaddrs.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ifaddrs.h Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
ifreq.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
in6_addr.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
inet6_opt.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
inet6_option.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
inet6_rth.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
inet6_scopeid_pton.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
inet_lnaof.c inet: Remove SCCS keywords 2016-04-28 12:53:50 +02:00
inet_mkadr.c inet: Remove SCCS keywords 2016-04-28 12:53:50 +02:00
inet_net.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
inet_netof.c inet: Remove SCCS keywords 2016-04-28 12:53:50 +02:00
inet_ntoa.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
net-internal.h Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
netgroup.h Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
rcmd.c inet: Remove SCCS keywords 2016-04-28 12:53:50 +02:00
rexec.c inet: Remove SCCS keywords 2016-04-28 12:53:50 +02:00
ruserpass.c 2016-05-30 Paul Pluzhnikov <ppluzhnikov@google.com> 2016-05-30 15:32:09 -07:00
setipv4sourcefilter.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
setsourcefilter.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
test-hnto-types.c Make endian-conversion macros always return correct types (bug 16458). 2017-01-11 15:28:08 +00:00
test-ifaddrs.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
test-inet6_opt.c Modify several tests to use test-skeleton.c 2014-11-05 15:24:08 +05:30
test_ifindex.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
tst-checks-posix.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
tst-checks.c inet: Make IN6_IS_ADDR_UNSPECIFIED etc. usable with POSIX [BZ #16421] 2016-12-09 11:27:44 +01:00
tst-ether_aton.c Modify several tests to use test-skeleton.c 2015-08-06 02:59:04 -04:00
tst-ether_line.c [BZ #5441, BZ #5452, BZ #5454] 2007-12-07 16:50:11 +00:00
tst-gethnm.c Modify several tests to use test-skeleton.c 2014-11-05 15:24:08 +05:30
tst-getni1.c Remove trailing whitespace. 2013-06-05 20:44:03 +00:00
tst-getni2.c Remove trailing whitespace. 2013-06-05 20:44:03 +00:00
tst-inet6_rth.c Fix a strict-alias warning in tst-inet6_rth. 2012-11-29 13:35:14 -08:00
tst-inet6_scopeid_pton.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
tst-network.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00
tst-ntoa.c Modify several tests to use test-skeleton.c 2014-11-05 15:24:08 +05:30
tst-sockaddr.c Update copyright dates with scripts/update-copyrights. 2017-01-01 00:14:16 +00:00