FreeBSD 8.1-PRERELEASE: WARNING ioctl sign-extension ioctl
ffffffff8004667e
Mario Sergio Fujikawa Ferreira
lioux at FreeBSD.org
Sat Jun 26 09:13:02 UTC 2010
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<jkim at FreeBSD.org>
>>> To: freebsd-stable at FreeBSD.org
>>> Cc: d at delphij.net, Mario Sergio Fujikawa Ferreira
>>> <lioux at freebsd.org> 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<int>(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
More information about the freebsd-python
mailing list