ioctl(2)
ioctl --
control device
Synopsis
#include <unistd.h>
#include <stropts.h>
int ioctl(int fildes, int request, ... /* arg */);
Description
ioctl performs a variety of control functions
on devices and STREAMS.
For non-STREAMS files, the functions
performed by this call are device-specific control functions.
request and an optional third argument with varying type
are passed to the file designated by fildes
and are interpreted by the device driver.
This control is not frequently used on non-STREAMS devices,
where the basic input/output functions are usually performed through the
read(2)
and
write(2)
system calls.
For STREAMS files, specific functions are performed by
the ioctl call as described in
streamio(7).
fildes is an open file descriptor that refers to a device.
request selects the control function to be performed
and depends on the device being addressed.
arg represents a third argument that has additional information
that is needed by this specific device to perform the requested function.
The data type of arg depends on the particular control request,
but it is either an int or a pointer to a device-specific data structure.
In addition to device-specific and STREAMS functions,
generic functions are provided by more than one device driver,
for example, the general terminal interface [see
termio(7)].
Return values
On success, ioctl returns a non-negative integer that depends on
the device control function.
On failure, ioctl returns -1 and sets errno to identify the error.
Errors
In the following conditions, ioctl fails and sets errno to:
- EACCES
-
The type of access requested on the file designated by fildes is denied.
- EBADF
-
fildes is not a valid open file descriptor.
- ENOTTY
-
fildes is not associated with a character-special file
that accepts control functions.
- EINTR
-
A signal was caught during the ioctl system call.
ioctl also fails if the device driver detects an error.
In this case, the error is passed through ioctl
without change to the caller.
A particular driver might not have all the following error cases.
In the following conditions, requests to device drivers may fail
and set errno to:
- EFAULT
-
request requires a data transfer to or from
a buffer pointed to by arg, but some part of the buffer is outside
the process's allocated space.
- EINVAL
-
request or arg is not valid for this device.
- EIO
-
Some physical I/O error has occurred.
- ENXIO
-
The request and arg are valid for this device driver,
but the service requested cannot be performed on this particular subdevice.
- ENOLINK
-
fildes is on a remote machine and the link to that machine is no
longer active.
STREAMS errors are described in
streamio(7).
References
streamio(7),
termio(7)
Notices
Considerations for threads programming
Open file descriptors are a process resource and available to any sibling thread;
if used concurrently, actions by one thread can interfere with
those of a sibling.
While one thread is blocked, siblings might still be executing.
30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.