From owner-freebsd-stable@FreeBSD.ORG Sun Jul 26 14:42:34 2009 Return-Path: Delivered-To: freebsd-stable@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 196381065672; Sun, 26 Jul 2009 14:42:34 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from mail.zoral.com.ua (skuns.zoral.com.ua [91.193.166.194]) by mx1.freebsd.org (Postfix) with ESMTP id A4F848FC17; Sun, 26 Jul 2009 14:42:32 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from deviant.kiev.zoral.com.ua (root@deviant.kiev.zoral.com.ua [10.1.1.148]) by mail.zoral.com.ua (8.14.2/8.14.2) with ESMTP id n6QEgSXH051654 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Sun, 26 Jul 2009 17:42:28 +0300 (EEST) (envelope-from kostikbel@gmail.com) Received: from deviant.kiev.zoral.com.ua (kostik@localhost [127.0.0.1]) by deviant.kiev.zoral.com.ua (8.14.3/8.14.3) with ESMTP id n6QEgS8f070114; Sun, 26 Jul 2009 17:42:28 +0300 (EEST) (envelope-from kostikbel@gmail.com) Received: (from kostik@localhost) by deviant.kiev.zoral.com.ua (8.14.3/8.14.3/Submit) id n6QEgRv5070113; Sun, 26 Jul 2009 17:42:27 +0300 (EEST) (envelope-from kostikbel@gmail.com) X-Authentication-Warning: deviant.kiev.zoral.com.ua: kostik set sender to kostikbel@gmail.com using -f Date: Sun, 26 Jul 2009 17:42:27 +0300 From: Kostik Belousov To: Jamie Gritton Message-ID: <20090726144227.GK55190@deviant.kiev.zoral.com.ua> References: <4A6B0BD3.6040206@protected-networks.net> <4A6B9A60.90302@FreeBSD.org> <4A6BAC1A.5080303@protected-networks.net> <20090726120608.GE55190@deviant.kiev.zoral.com.ua> <20090726122230.E245@maildrop.int.zabbadoz.net> <4A6C67F5.8080408@FreeBSD.org> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="+l1kYfus1Zojx2Di" Content-Disposition: inline In-Reply-To: <4A6C67F5.8080408@FreeBSD.org> User-Agent: Mutt/1.4.2.3i X-Virus-Scanned: clamav-milter 0.95.2 at skuns.kiev.zoral.com.ua X-Virus-Status: Clean X-Spam-Status: No, score=-4.4 required=5.0 tests=ALL_TRUSTED,AWL,BAYES_00 autolearn=ham version=3.2.5 X-Spam-Checker-Version: SpamAssassin 3.2.5 (2008-06-10) on skuns.kiev.zoral.com.ua Cc: Kostik Belousov , "Bjoern A. Zeeb" , freebsd-stable Subject: Re: regression with jexec? X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 26 Jul 2009 14:42:34 -0000 --+l1kYfus1Zojx2Di Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Sun, Jul 26, 2009 at 08:28:05AM -0600, Jamie Gritton wrote: > Bjoern A. Zeeb wrote: > >On Sun, 26 Jul 2009, Kostik Belousov wrote: > > > >>On Sat, Jul 25, 2009 at 09:06:34PM -0400, Michael Butler wrote: > >>>-----BEGIN PGP SIGNED MESSAGE----- > >>>Hash: SHA1 > >>> > >>>Jamie Gritton wrote: > >>>>Michael Butler wrote: > >>>>>imb@aaron:/home/imb> sudo jexec 5 tcsh > >>>>>jexec: Unable to parse jail ID.: No such file or directory > >>> > >>>> > >>>>The symptom in jexec can be fixed by this little patch: > >>>> > >>>>Index: usr.sbin/jexec/jexec.c > >>>>=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D > >>>>--- usr.sbin/jexec/jexec.c (revision 195879) > >>>>+++ usr.sbin/jexec/jexec.c (working copy) > >>>>@@ -248,6 +248,7 @@ > >>>> if (argc < 2) > >>>> usage(); > >>>> if (strlen(argv[0]) > 0) { > >>>>+ errno =3D 0; > >>>> jid =3D (int)strtol(argv[0], NULL, 10); > >>>> if (errno) > >>>> err(1, "Unable to parse jail ID."); > >>> > >>>Thanks - this certainly cures the effect. > >>> > >>>>But the broader problem is malloc. It's leaving errno set to > >>>>ENOENT when /etc/malloc.conf doesn't exist. This seems like > >>>>wrong behavior to me. > >>> > >>>Seems like a POLA violation to me, > >> > >>No, this is how errno generally work, it is not changed if no error > >>happens. > > > >I haven't really understood which part, when and why would set the errno= in > >first place so that it would still be there? Is it something in jexec > >that gets the errno in first place or is it something internal to > >malloc that sets it returns successfully and doesn't clear it? >=20 > The POLA violation is in malloc - it sets errno even when there was no > error. The allocation succeeded and a pointer was returned, yet errno > was set to ENOENT (not even an error malloc should be able to return). > The fact that malloc looks for an optional config file and doesn't find > one shouldn't be relayed back to the caller in errno. If > /etc/malloc.conf doesn't exist, it should either clear errno after that, > or perhaps restore its previous value. There's also a > getenv("MALLOC_OPTIONS") that can similarly set errno. >=20 > Perhaps this has all been gone over before and I missed it (this is from > code that's been stable since 2006), so I wouldn't want to just rush in > and fix malloc. Maybe this general principle has already been discussed > and my viewpoint lost. But if not, it's my opinion that malloc is > acting badly and needs a change. >=20 > In the meantime, I have no problem with errno not being cleared in > strtol, and the patch to jexec is correct (though strictly speaking it > shouldn't be necessary since we "know" errno has not yet been set). Let me restate that errno is never cleared when no error occured. It is only set when error took place. E.g., for syscalls, you should look into errno only if syscall returned -1, in most cases. For non-syscall libc functions, you need to clear errno before the call, then check for the error return (for strtoul that would be ULONG_MAX or 0), that seems to be missed from your patch, and only then look for errno. See RETURN VALUES section of the strtoul(3). --+l1kYfus1Zojx2Di Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.9 (FreeBSD) iEYEARECAAYFAkpsa1MACgkQC3+MBN1Mb4iVPACfXZPsMNWuzYkCCopuywys3OL0 xEoAoNsjcZM7CoB9jdph6ED1F7RMKwzJ =rVve -----END PGP SIGNATURE----- --+l1kYfus1Zojx2Di--