From owner-freebsd-python@FreeBSD.ORG Sat Jun 26 09:13:02 2010 Return-Path: Delivered-To: python@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 98BE4106564A for ; Sat, 26 Jun 2010 09:13:02 +0000 (UTC) (envelope-from lioux@FreeBSD.org) Received: from goat.gigo.com (ipv6.gigo.com [IPv6:2001:470:1:18::2]) by mx1.freebsd.org (Postfix) with ESMTP id 7843B8FC14 for ; Sat, 26 Jun 2010 09:13:02 +0000 (UTC) Received: from localhost (localhost [127.0.0.1]) by goat.gigo.com (Postfix) with ESMTP id 7421A5C6D for ; Sat, 26 Jun 2010 02:13:02 -0700 (PDT) Received: from goat.gigo.com ([127.0.0.1]) by localhost (vette.gigo.com [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id Yfo6J-0BF4nG for ; Sat, 26 Jun 2010 02:13:02 -0700 (PDT) Received: from 189.72.155.250 (189-72-155-250.bsace702.dsl.brasiltelecom.net.br [189.72.155.250]) by goat.gigo.com (Postfix) with ESMTPSA id 6CF085C7A for ; Sat, 26 Jun 2010 02:13:01 -0700 (PDT) Received: (qmail 82644 invoked from network); 26 Jun 2010 06:09:39 -0300 Received: from unknown (HELO exxodus.fedaykin.here) (127.0.0.1) by exxodus.fedaykin.here with SMTP; 26 Jun 2010 06:09:39 -0300 Message-ID: <4C25C3D3.3030109@FreeBSD.org> Date: Sat, 26 Jun 2010 06:09:39 -0300 From: Mario Sergio Fujikawa Ferreira User-Agent: Mozilla/5.0 (X11; U; FreeBSD amd64; pt-BR; rv:1.9.1.10) Gecko/20100622 Thunderbird/3.0.5 MIME-Version: 1.0 To: Jung-uk Kim References: <20100623025855.82916.qmail@exxodus.fedaykin.here> <201006231708.40032.jkim@FreeBSD.org> <20100625085404.94155.qmail@exxodus.fedaykin.here> <201006251758.56393.jkim@FreeBSD.org> (sfid-20100625_19270_E0B8159B) In-Reply-To: <201006251758.56393.jkim@FreeBSD.org> (sfid-20100625_19270_E0B8159B) Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: d@delphij.net, freebsd-stable@FreeBSD.org, python@FreeBSD.org Subject: Re: FreeBSD 8.1-PRERELEASE: WARNING ioctl sign-extension ioctl ffffffff8004667e X-BeenThere: freebsd-python@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: FreeBSD-specific Python issues List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 26 Jun 2010 09:13:02 -0000 On 25/06/2010 18:58, Jung-uk Kim wrote: > On Friday 25 June 2010 04:54 am, Mario Sergio Fujikawa Ferreira wrote: >> On Wed, Jun 23, 2010 at 05:08:38PM -0400, Jung-uk Kim wrote: >>> Date: Wed, 23 Jun 2010 17:08:38 -0400 >>> From: Jung-uk Kim >>> To: freebsd-stable@FreeBSD.org >>> Cc: d@delphij.net, Mario Sergio Fujikawa Ferreira >>> Subject: Re: FreeBSD 8.1-PRERELEASE: WARNING >>> ioctl sign-extension ioctl ffffffff8004667e >>> User-Agent: KMail/1.6.2 >>> >>> On Wednesday 23 June 2010 03:38 pm, Jung-uk Kim wrote: >>>> On Wednesday 23 June 2010 03:10 pm, Jung-uk Kim wrote: >>>>> On Wednesday 23 June 2010 03:01 pm, Jung-uk Kim wrote: >>>>>> On Wednesday 23 June 2010 02:41 pm, Xin LI wrote: >>>>>>> On 2010/06/23 11:37, Jung-uk Kim wrote: >>>>>>>> On Wednesday 23 June 2010 02:12 pm, Xin LI wrote: >>>>>>>>> Hi, >>>>>>>>> >>>>>>>>> On 2010/06/22 19:58, Mario Sergio Fujikawa Ferreira > wrote: >>>>>>>>>> Hi, >>>>>>>>>> >>>>>>>>>> I am getting more than 4 thousand of the following >>>>>>>>>> messages a day: >>>>>>>>>> >>>>>>>>>> WARNING pid 24509 (python2.6): ioctl sign-extension >>>>>>>>>> ioctl ffffffff8004667e >>>>>>>>> >>>>>>>>> [...] >>>>>>>>> >>>>>>>>> I think we may need to check the code and patch it. >>>>>>>>> Basically this means that python (or some .so modules) >>>>>>>>> passed an int or unsigned int as parameter 'cmd', we >>>>>>>>> need to change it to unsigned long. >>>>>>>>> >>>>>>>>> The warning itself should be harmless to my best of >>>>>>>>> knowledge, one can probably remove the printf in >>>>>>>>> kernel source code as a workaround. >>>>>>>>> >>>>>>>>> By the way it seems to be a POSIX violation and we >>>>>>>>> didn't seem to really use so wide cmd, but I have not >>>>>>>>> yet verified everything myself. >>>>>>>> >>>>>>>> Long time ago, I had a similar problem with termios >>>>>>>> TIOCGWINSZ and we patched the port like this: >>>>>>>> >>>>>>>> http://www.freebsd.org/cgi/cvsweb.cgi/ports/lang/python >>>>>>>> /fil es /A tt >>>>>>>> ic/patch-Modules%3A%3Afcntlmodule.c?rev=1.1;content-typ >>>>>>>> e=te xt %2 Fpl ain >>>>>>>> >>>>>>>> I believe it was upstream patched at the time but I >>>>>>>> won't be surprised if something similar was >>>>>>>> reintroduced. It happens when a Python internal >>>>>>>> integer type is converted to a native unsigned long. >>>>>>> >>>>>>> Well, only *BSD have cmd a long value so it's likely that >>>>>>> it would be reintroduced. >>>>>> >>>>>> Yes, that's what I mean. >>>>>> >>>>>>> I have checked the 4.4BSD archive and understood that our >>>>>>> ioctl's cmd parameter was made long around 1991 or 1992s >>>>>>> but didn't see what it actually buy us... >>>>>> >>>>>> Like it or not, it is too late to revert. :-( >>>>> >>>>> From Python 2.6.5: >>>>> >>>>> static PyObject * >>>>> fcntl_ioctl(PyObject *self, PyObject *args) >>>>> { >>>>> #define IOCTL_BUFSZ 1024 >>>>> int fd; >>>>> /* In PyArg_ParseTuple below, we use the unsigned >>>>> non-checked 'I' format for the 'code' parameter because >>>>> Python turns 0x8000000 into either a large positive number >>>>> (PyLong or PyInt on 64-bit platforms) or a negative number on >>>>> others (32-bit PyInt) whereas the system expects it to be a >>>>> 32bit bit field value regardless of it being passed as an int >>>>> or unsigned long on various platforms. See the >>>>> termios.TIOCSWINSZ constant across platforms for an example >>>>> of thise. >>>>> >>>>> If any of the 64bit platforms ever decide to use more >>>>> than 32bits in their unsigned long ioctl codes this will >>>>> break and need special casing based on the platform being >>>>> built on. */ >>>>> unsigned int code; >>>>> ... >>>>> >>>>> It is still a kludge and it won't be fixed. :-( >>>> >>>> Please drop the attached patch in ports/lang/python26/files and >>>> test. Note I am not a Python guy, so please don't shoot me. ;-) >>> >>> I found that Python guys added 'k' format since 2.3, which >>> converts a Python integer to unsigned long. Please ignore the >>> previous patch and try the attached patch instead. >> >> Unfortunately it didn't work. >> >> 1) Added patch to lang/python26 >> 2) Recompiled lang/python26 >> 3) cd /var/db/ports&& portupgrade -f python* py26* deluge* >> >> Restarted deluge afterwards. The message is still there: >> >> Jun 25 05:49:38 exxodus kernel: WARNING pid 38635 (python2.6): >> ioctl sign-extension ioctl ffffffff8004667e > > It may be a deeper problen, then. :-( > > First of all, I cannot reproduce the problem because deluged dumps > core on my box and I gave it up. Just staring at the code, it seems > they rely on a bundled libtorrent for Python binding and the > libtorrent relies on Boost, in turn. Then, the actual non-blocking > socket implementation is done with Boost ASIO[1]. It is possible > that there are more complicated problems between these and the Python > binding. In fact, I can see a lot of these: > > int name() const > { > return FIONBIO; > } > ... > if (!ec&& command.name() == static_cast(FIONBIO)) > ... > socket_ops::ioctl(impl.socket_, command.name(), ...) > ... > > They are just assuming it is an int type, I guess. > > Sigh, what a mess... Given that your python patch is a step on the right direction, I would propose that it be further tested and then committed if possible. > [1] Boost and its Python binding from ports seems to be a newer ASIO > version than the bundled ASIO headers. Probably it is a reason for > the crash but I didn't bother too much. If you have the time, everything you need to run the latest deluge 1.3.0 RC1 can be found at http://www.freebsd.org/cgi/query-pr.cgi?pr=144337 Check the PR, all the necessary ports can be found there. Let me know what you think. Regards, -- Mario S F Ferreira - DF - Brazil - "I guess this is a signature." feature, n: a documented bug | bug, n: an undocumented feature