Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 1 | :mod:`fcntl` --- The ``fcntl`` and ``ioctl`` system calls |
| 2 | ========================================================= |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 3 | |
| 4 | .. module:: fcntl |
| 5 | :platform: Unix |
| 6 | :synopsis: The fcntl() and ioctl() system calls. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 7 | |
Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame] | 8 | .. sectionauthor:: Jaap Vermeulen |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 9 | |
| 10 | .. index:: |
Georg Brandl | 8569e58 | 2010-05-19 20:57:08 +0000 | [diff] [blame] | 11 | pair: UNIX; file control |
| 12 | pair: UNIX; I/O control |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 13 | |
Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame] | 14 | ---------------- |
| 15 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 16 | This module performs file control and I/O control on file descriptors. It is an |
Senthil Kumaran | 0779129 | 2016-06-02 23:49:05 -0700 | [diff] [blame] | 17 | interface to the :c:func:`fcntl` and :c:func:`ioctl` Unix routines. For a |
| 18 | complete description of these calls, see :manpage:`fcntl(2)` and |
| 19 | :manpage:`ioctl(2)` Unix manual pages. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 20 | |
| 21 | All functions in this module take a file descriptor *fd* as their first |
| 22 | argument. This can be an integer file descriptor, such as returned by |
Martin Panter | 7462b649 | 2015-11-02 03:37:02 +0000 | [diff] [blame] | 23 | ``sys.stdin.fileno()``, or an :class:`io.IOBase` object, such as ``sys.stdin`` |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 24 | itself, which provides a :meth:`~io.IOBase.fileno` that returns a genuine file |
| 25 | descriptor. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 26 | |
Antoine Pitrou | 62ab10a0 | 2011-10-12 20:10:51 +0200 | [diff] [blame] | 27 | .. versionchanged:: 3.3 |
Martin Panter | 7462b649 | 2015-11-02 03:37:02 +0000 | [diff] [blame] | 28 | Operations in this module used to raise an :exc:`IOError` where they now |
| 29 | raise an :exc:`OSError`. |
Antoine Pitrou | 62ab10a0 | 2011-10-12 20:10:51 +0200 | [diff] [blame] | 30 | |
Christian Heimes | 8cbb5b6 | 2019-05-31 18:32:33 +0200 | [diff] [blame] | 31 | .. versionchanged:: 3.8 |
| 32 | The fcntl module now contains ``F_ADD_SEALS``, ``F_GET_SEALS``, and |
| 33 | ``F_SEAL_*`` constants for sealing of :func:`os.memfd_create` file |
| 34 | descriptors. |
Antoine Pitrou | 62ab10a0 | 2011-10-12 20:10:51 +0200 | [diff] [blame] | 35 | |
Vinay Sharma | 13f37f2 | 2019-08-29 07:26:17 +0530 | [diff] [blame] | 36 | .. versionchanged:: 3.9 |
| 37 | On macOS, the fcntl module exposes the ``F_GETPATH`` constant, which obtains |
| 38 | the path of a file from a file descriptor. |
| 39 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 40 | The module defines the following functions: |
| 41 | |
| 42 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 43 | .. function:: fcntl(fd, cmd, arg=0) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 44 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 45 | Perform the operation *cmd* on file descriptor *fd* (file objects providing |
R David Murray | d5a2f0b | 2013-11-07 10:51:07 -0500 | [diff] [blame] | 46 | a :meth:`~io.IOBase.fileno` method are accepted as well). The values used |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 47 | for *cmd* are operating system dependent, and are available as constants |
R David Murray | d5a2f0b | 2013-11-07 10:51:07 -0500 | [diff] [blame] | 48 | in the :mod:`fcntl` module, using the same names as used in the relevant C |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 49 | header files. The argument *arg* can either be an integer value, or a |
| 50 | :class:`bytes` object. With an integer value, the return value of this |
| 51 | function is the integer return value of the C :c:func:`fcntl` call. When |
| 52 | the argument is bytes it represents a binary structure, e.g. created by |
| 53 | :func:`struct.pack`. The binary data is copied to a buffer whose address is |
| 54 | passed to the C :c:func:`fcntl` call. The return value after a successful |
| 55 | call is the contents of the buffer, converted to a :class:`bytes` object. |
| 56 | The length of the returned object will be the same as the length of the |
| 57 | *arg* argument. This is limited to 1024 bytes. If the information returned |
| 58 | in the buffer by the operating system is larger than 1024 bytes, this is |
| 59 | most likely to result in a segmentation violation or a more subtle data |
| 60 | corruption. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 61 | |
Antoine Pitrou | 62ab10a0 | 2011-10-12 20:10:51 +0200 | [diff] [blame] | 62 | If the :c:func:`fcntl` fails, an :exc:`OSError` is raised. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 63 | |
| 64 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 65 | .. function:: ioctl(fd, request, arg=0, mutate_flag=True) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 66 | |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 67 | This function is identical to the :func:`~fcntl.fcntl` function, except |
| 68 | that the argument handling is even more complicated. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 69 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 70 | The *request* parameter is limited to values that can fit in 32-bits. |
| 71 | Additional constants of interest for use as the *request* argument can be |
R David Murray | d5a2f0b | 2013-11-07 10:51:07 -0500 | [diff] [blame] | 72 | found in the :mod:`termios` module, under the same names as used in |
| 73 | the relevant C header files. |
Christian Heimes | e25f35e | 2008-03-20 10:49:03 +0000 | [diff] [blame] | 74 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 75 | The parameter *arg* can be one of an integer, an object supporting the |
| 76 | read-only buffer interface (like :class:`bytes`) or an object supporting |
| 77 | the read-write buffer interface (like :class:`bytearray`). |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 78 | |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 79 | In all but the last case, behaviour is as for the :func:`~fcntl.fcntl` |
| 80 | function. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 81 | |
| 82 | If a mutable buffer is passed, then the behaviour is determined by the value of |
| 83 | the *mutate_flag* parameter. |
| 84 | |
| 85 | If it is false, the buffer's mutability is ignored and behaviour is as for a |
| 86 | read-only buffer, except that the 1024 byte limit mentioned above is avoided -- |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 87 | so long as the buffer you pass is at least as long as what the operating system |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 88 | wants to put there, things should work. |
| 89 | |
Georg Brandl | 71515ca | 2009-05-17 12:29:12 +0000 | [diff] [blame] | 90 | If *mutate_flag* is true (the default), then the buffer is (in effect) passed |
| 91 | to the underlying :func:`ioctl` system call, the latter's return code is |
| 92 | passed back to the calling Python, and the buffer's new contents reflect the |
| 93 | action of the :func:`ioctl`. This is a slight simplification, because if the |
| 94 | supplied buffer is less than 1024 bytes long it is first copied into a static |
| 95 | buffer 1024 bytes long which is then passed to :func:`ioctl` and copied back |
| 96 | into the supplied buffer. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 97 | |
Victor Stinner | d0d5154 | 2016-04-09 11:32:58 +0200 | [diff] [blame] | 98 | If the :c:func:`ioctl` fails, an :exc:`OSError` exception is raised. |
Victor Stinner | 9cccfce | 2015-11-13 09:13:48 +0100 | [diff] [blame] | 99 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 100 | An example:: |
| 101 | |
| 102 | >>> import array, fcntl, struct, termios, os |
| 103 | >>> os.getpgrp() |
| 104 | 13341 |
| 105 | >>> struct.unpack('h', fcntl.ioctl(0, termios.TIOCGPGRP, " "))[0] |
| 106 | 13341 |
| 107 | >>> buf = array.array('h', [0]) |
| 108 | >>> fcntl.ioctl(0, termios.TIOCGPGRP, buf, 1) |
| 109 | 0 |
| 110 | >>> buf |
| 111 | array('h', [13341]) |
| 112 | |
| 113 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 114 | .. function:: flock(fd, operation) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 115 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 116 | Perform the lock operation *operation* on file descriptor *fd* (file objects providing |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 117 | a :meth:`~io.IOBase.fileno` method are accepted as well). See the Unix manual |
Georg Brandl | ec80688 | 2009-06-04 10:23:20 +0000 | [diff] [blame] | 118 | :manpage:`flock(2)` for details. (On some systems, this function is emulated |
Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame] | 119 | using :c:func:`fcntl`.) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 120 | |
Victor Stinner | d0d5154 | 2016-04-09 11:32:58 +0200 | [diff] [blame] | 121 | If the :c:func:`flock` fails, an :exc:`OSError` exception is raised. |
Victor Stinner | 9cccfce | 2015-11-13 09:13:48 +0100 | [diff] [blame] | 122 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 123 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 124 | .. function:: lockf(fd, cmd, len=0, start=0, whence=0) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 125 | |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 126 | This is essentially a wrapper around the :func:`~fcntl.fcntl` locking calls. |
Eric O. LEBIGOT (EOL) | 77cd0ce | 2019-09-13 19:32:28 +0200 | [diff] [blame^] | 127 | *fd* is the file descriptor (file objects providing a :meth:`~io.IOBase.fileno` |
| 128 | method are accepted as well) of the file to lock or unlock, and *cmd* |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 129 | is one of the following values: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 130 | |
| 131 | * :const:`LOCK_UN` -- unlock |
| 132 | * :const:`LOCK_SH` -- acquire a shared lock |
| 133 | * :const:`LOCK_EX` -- acquire an exclusive lock |
| 134 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 135 | When *cmd* is :const:`LOCK_SH` or :const:`LOCK_EX`, it can also be |
Christian Heimes | faf2f63 | 2008-01-06 16:59:19 +0000 | [diff] [blame] | 136 | bitwise ORed with :const:`LOCK_NB` to avoid blocking on lock acquisition. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 137 | If :const:`LOCK_NB` is used and the lock cannot be acquired, an |
Antoine Pitrou | 62ab10a0 | 2011-10-12 20:10:51 +0200 | [diff] [blame] | 138 | :exc:`OSError` will be raised and the exception will have an *errno* |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 139 | attribute set to :const:`EACCES` or :const:`EAGAIN` (depending on the |
| 140 | operating system; for portability, check for both values). On at least some |
| 141 | systems, :const:`LOCK_EX` can only be used if the file descriptor refers to a |
| 142 | file opened for writing. |
| 143 | |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 144 | *len* is the number of bytes to lock, *start* is the byte offset at |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 145 | which the lock starts, relative to *whence*, and *whence* is as with |
| 146 | :func:`io.IOBase.seek`, specifically: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 147 | |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 148 | * :const:`0` -- relative to the start of the file (:data:`os.SEEK_SET`) |
| 149 | * :const:`1` -- relative to the current buffer position (:data:`os.SEEK_CUR`) |
| 150 | * :const:`2` -- relative to the end of the file (:data:`os.SEEK_END`) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 151 | |
| 152 | The default for *start* is 0, which means to start at the beginning of the file. |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 153 | The default for *len* is 0 which means to lock to the end of the file. The |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 154 | default for *whence* is also 0. |
| 155 | |
| 156 | Examples (all on a SVR4 compliant system):: |
| 157 | |
| 158 | import struct, fcntl, os |
| 159 | |
| 160 | f = open(...) |
| 161 | rv = fcntl.fcntl(f, fcntl.F_SETFL, os.O_NDELAY) |
| 162 | |
| 163 | lockdata = struct.pack('hhllhh', fcntl.F_WRLCK, 0, 0, 0, 0, 0) |
| 164 | rv = fcntl.fcntl(f, fcntl.F_SETLKW, lockdata) |
| 165 | |
| 166 | Note that in the first example the return value variable *rv* will hold an |
Serhiy Storchaka | 17d3a58 | 2015-03-20 20:04:21 +0200 | [diff] [blame] | 167 | integer value; in the second example it will hold a :class:`bytes` object. The |
| 168 | structure lay-out for the *lockdata* variable is system dependent --- therefore |
| 169 | using the :func:`flock` call may be better. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 170 | |
| 171 | |
| 172 | .. seealso:: |
| 173 | |
| 174 | Module :mod:`os` |
Serhiy Storchaka | 926099d | 2013-10-09 14:20:22 +0300 | [diff] [blame] | 175 | If the locking flags :data:`~os.O_SHLOCK` and :data:`~os.O_EXLOCK` are |
| 176 | present in the :mod:`os` module (on BSD only), the :func:`os.open` |
| 177 | function provides an alternative to the :func:`lockf` and :func:`flock` |
| 178 | functions. |