From owner-cvs-all@FreeBSD.ORG Sun Sep 23 13:35:57 2007 Return-Path: Delivered-To: cvs-all@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 8B6CE16A418; Sun, 23 Sep 2007 13:35:57 +0000 (UTC) (envelope-from des@des.no) Received: from tim.des.no (tim.des.no [194.63.250.121]) by mx1.freebsd.org (Postfix) with ESMTP id 3846813C465; Sun, 23 Sep 2007 13:35:57 +0000 (UTC) (envelope-from des@des.no) Received: from tim.des.no (localhost [127.0.0.1]) by spam.des.no (Postfix) with ESMTP id 8CB4B20A4; Sun, 23 Sep 2007 15:35:53 +0200 (CEST) X-Spam-Tests: AWL X-Spam-Learn: disabled X-Spam-Score: 0.0/3.0 X-Spam-Checker-Version: SpamAssassin 3.2.1 (2007-05-02) on tim.des.no Received: from ds4.des.no (des.no [80.203.243.180]) by smtp.des.no (Postfix) with ESMTP id 099B320A2; Sun, 23 Sep 2007 15:35:53 +0200 (CEST) Received: by ds4.des.no (Postfix, from userid 1001) id E99048448A; Sun, 23 Sep 2007 15:35:52 +0200 (CEST) From: =?utf-8?Q?Dag-Erling_Sm=C3=B8rgrav?= To: Bruce Evans References: <200709220230.l8M2UiRK020609@repoman.freebsd.org> <86r6krqbrd.fsf@ds4.des.no> <20070922202914.B90809@besplex.bde.org> Date: Sun, 23 Sep 2007 15:35:52 +0200 In-Reply-To: <20070922202914.B90809@besplex.bde.org> (Bruce Evans's message of "Sat\, 22 Sep 2007 21\:20\:48 +1000 \(EST\)") Message-ID: <86wsuhv70n.fsf@ds4.des.no> User-Agent: Gnus/5.110006 (No Gnus v0.6) Emacs/22.1 (berkeley-unix) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Cc: cvs-src@FreeBSD.org, src-committers@FreeBSD.org, cvs-all@FreeBSD.org, Sean Farley Subject: Re: cvs commit: src/lib/libc/stdlib getenv.c X-BeenThere: cvs-all@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: CVS commit messages for the entire tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 23 Sep 2007 13:35:57 -0000 Bruce Evans writes: > On Sat, 22 Sep 2007, [utf-8] Dag-Erling Sm=C3=B8rgrav wrote: > > s/to remove the warning/to actually work/ > Please be precise :-). > s/to remove the warning ... on 64-bit platforms/to avoid undefined behavi= our > on platforms where size_t is not u_int, and to avoid having to make a > delicate analysis to show that the behaviour is defined and correct on > all other platforms/. > > Delicate analysis: > - size_t is always an unsigned type, but the required type is int, so > size_t is never compatible with the required type. > - on platforms where size_t is smaller than int, the arg type is > nevertheless compatible with int, since warnx() is variadic and the > arg is one of the variadic args; the default promotions thus apply > and the arg is passed as an int whether or not you cast it explicitly > to int (but casting it to a type larger than int would break it). > FreeBSD doesn't support any platforms in this class. > - on platforms where size_t is u_int, the arg is passed as a u_int. > The analysis for this case is too delicate to give in full here. you left out the case where size_t is larger than unsigned int, i.e. all 64-bit platforms. Even if the stack is aligned to the size of size_t, you will get interesting results on a big-endian system. DES --=20 Dag-Erling Sm=C3=B8rgrav - des@des.no