[issue30665] pass big values for arg to fcntl.ioctl

Uwe Kleine-König report at bugs.python.org
Wed Jun 14 10:27:52 EDT 2017


New submission from Uwe Kleine-König:

When passing a big integer value to fcntl.ioctl this might result in

     OverflowError: signed integer is greater than maximum

. Traditionally ioctl(3) takes a pointer as third argument. The fcntl module however uses an int (format specifier 'i') which is too small to hold a pointer on 64 bit architectures.

The fix is to use 'k' (and an unsigned long) instead of 'i' (and an int). An unsigned long is suitable to hold a pointer value on AFAIK all platforms that matter today. (And it works on all platforms where int is already good enough, so the suggested change doesn't do any harm.)

A patch is attached.

----------
files: unsigned-long-arg-for-ioctl.patch
keywords: patch
messages: 296008
nosy: ukl
priority: normal
severity: normal
status: open
title: pass big values for arg to fcntl.ioctl
type: behavior
versions: Python 3.5
Added file: http://bugs.python.org/file46951/unsigned-long-arg-for-ioctl.patch

_______________________________________
Python tracker <report at bugs.python.org>
<http://bugs.python.org/issue30665>
_______________________________________


More information about the Python-bugs-list mailing list