The ioctl() function shall perform a variety of control
functions on STREAMS devices. For non-STREAMS devices, the functions
performed by this call are unspecified. The request argument and an
optional third argument (with varying type) shall be passed to and
interpreted by the appropriate part of the STREAM associated with
fildes.
The fildes argument is an open file descriptor that refers
to a device.
The request argument selects the control function to be
performed and shall depend on the STREAMS device being addressed.
The arg argument represents additional information that is
needed by this specific STREAMS device to perform the requested function.
The type of arg depends upon the particular control request, but it
shall be either an integer or a pointer to a device-specific data
structure.
The ioctl() commands applicable to STREAMS, their
arguments, and error conditions that apply to each individual command are
described below.
The following ioctl() commands, with error values
indicated, are applicable to all STREAMS files:
- I_PUSH
- Pushes the module whose name is pointed to by arg onto the top of
the current STREAM, just below the STREAM head. It then calls the
open() function of the newly-pushed module.
The ioctl() function with the I_PUSH command shall fail
if:
- EINVAL
- Invalid module name.
- ENXIO
- Open function of new module failed.
- ENXIO
- Hangup received on fildes.
- I_POP
- Removes the module just below the STREAM head of the STREAM pointed to by
fildes. The arg argument should be 0 in an I_POP
request.
The ioctl() function with the I_POP command shall fail
if:
- EINVAL
- No module present in the STREAM.
- ENXIO
- Hangup received on fildes.
- I_LOOK
- Retrieves the name of the module just below the STREAM head of the STREAM
pointed to by fildes, and places it in a character string pointed
to by arg. The buffer pointed to by arg should be at least
FMNAMESZ+1 bytes long, where FMNAMESZ is defined in
<stropts.h>.
The ioctl() function with the I_LOOK command shall fail
if:
- EINVAL
- No module present in the STREAM.
- I_FLUSH
- Flushes read and/or write queues, depending on the value of arg.
Valid arg values are:
- FLUSHR
- Flush all read queues.
- FLUSHW
- Flush all write queues.
- FLUSHRW
- Flush all read and all write queues.
The ioctl() function with the I_FLUSH command shall fail
if:
- EINVAL
- Invalid arg value.
- EAGAIN or
ENOSR
-
Unable to allocate buffers for flush message.
- ENXIO
- Hangup received on fildes.
- I_FLUSHBAND
- Flushes a particular band of messages. The arg argument points to a
bandinfo structure. The bi_flag member may be one of FLUSHR,
FLUSHW, or FLUSHRW as described above. The bi_pri member determines
the priority band to be flushed.
- I_SETSIG
- Requests that the STREAMS implementation send the SIGPOLL signal to the
calling process when a particular event has occurred on the STREAM
associated with fildes. I_SETSIG supports an asynchronous
processing capability in STREAMS. The value of arg is a bitmask
that specifies the events for which the process should be signaled. It is
the bitwise-inclusive OR of any combination of the following
constants:
- S_RDNORM
- A normal (priority band set to 0) message has arrived at the head of a
STREAM head read queue. A signal shall be generated even if the message is
of zero length.
- S_RDBAND
- A message with a non-zero priority band has arrived at the head of a
STREAM head read queue. A signal shall be generated even if the message is
of zero length.
- S_INPUT
- A message, other than a high-priority message, has arrived at the head of
a STREAM head read queue. A signal shall be generated even if the message
is of zero length.
- S_HIPRI
- A high-priority message is present on a STREAM head read queue. A signal
shall be generated even if the message is of zero length.
- S_OUTPUT
- The write queue for normal data (priority band 0) just below the STREAM
head is no longer full. This notifies the process that there is room on
the queue for sending (or writing) normal data downstream.
- S_WRNORM
- Equivalent to S_OUTPUT.
- S_WRBAND
- The write queue for a non-zero priority band just below the STREAM head is
no longer full. This notifies the process that there is room on the queue
for sending (or writing) priority data downstream.
- S_MSG
- A STREAMS signal message that contains the SIGPOLL signal has reached the
front of the STREAM head read queue.
- S_ERROR
- Notification of an error condition has reached the STREAM head.
- S_HANGUP
- Notification of a hangup has reached the STREAM head.
- S_BANDURG
- When used in conjunction with S_RDBAND, SIGURG is generated instead of
SIGPOLL when a priority message reaches the front of the STREAM head read
queue.
If arg is 0, the calling process shall be unregistered and
shall not receive further SIGPOLL signals for the stream associated with
fildes.
Processes that wish to receive SIGPOLL signals shall ensure that
they explicitly register to receive them using I_SETSIG. If several
processes register to receive this signal for the same event on the same
STREAM, each process shall be signaled when the event occurs.
The ioctl() function with the I_SETSIG command shall fail
if:
- EINVAL
- The value of arg is invalid.
- EINVAL
- The value of arg is 0 and the calling process is not registered to
receive the SIGPOLL signal.
- EAGAIN
- There were insufficient resources to store the signal request.
- I_GETSIG
- Returns the events for which the calling process is currently registered
to be sent a SIGPOLL signal. The events are returned as a bitmask in an
int pointed to by arg, where the events are those specified
in the description of I_SETSIG above.
The ioctl() function with the I_GETSIG command shall fail
if:
- EINVAL
- Process is not registered to receive the SIGPOLL signal.
- I_FIND
- Compares the names of all modules currently present in the STREAM to the
name pointed to by arg, and returns 1 if the named module is
present in the STREAM, or returns 0 if the named module is not
present.
The ioctl() function with the I_FIND command shall fail
if:
- EINVAL
- arg does not contain a valid module name.
- I_PEEK
- Retrieves the information in the first message on the STREAM head read
queue without taking the message off the queue. It is analogous to
getmsg() except that this command does not remove the message from
the queue. The arg argument points to a strpeek
structure.
The application shall ensure that the maxlen member in the
ctlbuf and databuf strbuf structures is set to the number of
bytes of control information and/or data information, respectively, to
retrieve. The flags member may be marked RS_HIPRI or 0, as described
by getmsg(). If the process sets flags to RS_HIPRI, for
example, I_PEEK shall only look for a high-priority message on the STREAM
head read queue.
I_PEEK returns 1 if a message was retrieved, and returns 0 if no
message was found on the STREAM head read queue, or if the RS_HIPRI flag was
set in flags and a high-priority message was not present on the
STREAM head read queue. It does not wait for a message to arrive. On return,
ctlbuf specifies information in the control buffer, databuf
specifies information in the data buffer, and flags contains the
value RS_HIPRI or 0.
- I_SRDOPT
- Sets the read mode using the value of the argument arg. Read modes
are described in read(). Valid arg flags are:
- RNORM
- Byte-stream mode, the default.
- RMSGD
- Message-discard mode.
- RMSGN
- Message-nondiscard mode.
The bitwise-inclusive OR of RMSGD and RMSGN shall return
[EINVAL]. The bitwise-inclusive OR of RNORM and either RMSGD or RMSGN
shall result in the other flag overriding RNORM which is the default.
In addition, treatment of control messages by the STREAM head may
be changed by setting any of the following flags in arg:
- RPROTNORM
- Fail read() with [EBADMSG] if a message containing a control
part is at the front of the STREAM head read queue.
- RPROTDAT
- Deliver the control part of a message as data when a process issues a
read().
- RPROTDIS
- Discard the control part of a message, delivering any data portion, when a
process issues a read().
The ioctl() function with the I_SRDOPT command shall fail
if:
- EINVAL
- The arg argument is not valid.
- I_GRDOPT
- Returns the current read mode setting, as described above, in an
int pointed to by the argument arg. Read modes are described
in read().
- I_NREAD
- Counts the number of data bytes in the data part of the first message on
the STREAM head read queue and places this value in the int pointed
to by arg. The return value for the command shall be the number of
messages on the STREAM head read queue. For example, if 0 is returned in
arg, but the ioctl() return value is greater than 0, this
indicates that a zero-length message is next on the queue.
- I_FDINSERT
- Creates a message from specified buffer(s), adds information about another
STREAM, and sends the message downstream. The message contains a control
part and an optional data part. The data and control parts to be sent are
distinguished by placement in separate buffers, as described below. The
arg argument points to a strfdinsert structure.
The application shall ensure that the len member in the
ctlbuf strbuf structure is set to the size of a t_uscalar_t
plus the number of bytes of control information to be sent with the message.
The fildes member specifies the file descriptor of the other STREAM,
and the offset member, which must be suitably aligned for use as a
t_uscalar_t, specifies the offset from the start of the control
buffer where I_FDINSERT shall store a t_uscalar_t whose
interpretation is specific to the STREAM end. The application shall ensure
that the len member in the databuf strbuf structure is set to
the number of bytes of data information to be sent with the message, or to 0
if no data part is to be sent.
The flags member specifies the type of message to be
created. A normal message is created if flags is set to 0, and a
high-priority message is created if flags is set to RS_HIPRI. For
non-priority messages, I_FDINSERT shall block if the STREAM write queue is
full due to internal flow control conditions. For priority messages,
I_FDINSERT does not block on this condition. For non-priority messages,
I_FDINSERT does not block when the write queue is full and O_NONBLOCK is
set. Instead, it fails and sets errno to [EAGAIN].
I_FDINSERT also blocks, unless prevented by lack of internal
resources, waiting for the availability of message blocks in the STREAM,
regardless of priority or whether O_NONBLOCK has been specified. No partial
message is sent.
The ioctl() function with the I_FDINSERT command shall fail
if:
- EAGAIN
- A non-priority message is specified, the O_NONBLOCK flag is set, and the
STREAM write queue is full due to internal flow control conditions.
- EAGAIN or
ENOSR
-
Buffers cannot be allocated for the message that is to be created.
- EINVAL
- One of the following:
- --
- The fildes member of the strfdinsert structure is not a
valid, open STREAM file descriptor.
- --
- The size of a t_uscalar_t plus offset is greater than the
len member for the buffer specified through ctlbuf.
- --
- The offset member does not specify a properly-aligned location in
the data buffer.
- --
- An undefined value is stored in flags.
- ENXIO
- Hangup received on the STREAM identified by either the fildes
argument or the fildes member of the strfdinsert
structure.
- ERANGE
- The len member for the buffer specified through databuf does
not fall within the range specified by the maximum and minimum packet
sizes of the topmost STREAM module; or the len member for the
buffer specified through databuf is larger than the maximum
configured size of the data part of a message; or the len member
for the buffer specified through ctlbuf is larger than the maximum
configured size of the control part of a message.
- I_STR
- Constructs an internal STREAMS ioctl() message from the data
pointed to by arg, and sends that message downstream.
This mechanism is provided to send ioctl() requests to
downstream modules and drivers. It allows information to be sent with
ioctl(), and returns to the process any information sent upstream by
the downstream recipient. I_STR shall block until the system responds with
either a positive or negative acknowledgement message, or until the request
times out after some period of time. If the request times out, it shall fail
with errno set to [ETIME].
At most, one I_STR can be active on a STREAM. Further I_STR calls
shall block until the active I_STR completes at the STREAM head. The default
timeout interval for these requests is 15 seconds. The O_NONBLOCK flag has
no effect on this call.
To send requests downstream, the application shall ensure that
arg points to a strioctl structure.
The ic_cmd member is the internal ioctl() command
intended for a downstream module or driver and ic_timout is the
number of seconds (-1=infinite, 0=use implementation-defined timeout
interval, >0=as specified) an I_STR request shall wait for
acknowledgement before timing out. ic_len is the number of bytes in
the data argument, and ic_dp is a pointer to the data argument. The
ic_len member has two uses: on input, it contains the length of the
data argument passed in, and on return from the command, it contains the
number of bytes being returned to the process (the buffer pointed to by
ic_dp should be large enough to contain the maximum amount of data
that any module or the driver in the STREAM can return).
The STREAM head shall convert the information pointed to by the
strioctl structure to an internal ioctl() command message and
send it downstream.
The ioctl() function with the I_STR command shall fail
if:
- EAGAIN or
ENOSR
-
Unable to allocate buffers for the ioctl() message.
- EINVAL
- The ic_len member is less than 0 or larger than the maximum
configured size of the data part of a message, or ic_timout is less
than -1.
- ENXIO
- Hangup received on fildes.
- ETIME
- A downstream ioctl() timed out before acknowledgement was
received.
An I_STR can also fail while waiting for an acknowledgement if a
message indicating an error or a hangup is received at the STREAM head. In
addition, an error code can be returned in the positive or negative
acknowledgement message, in the event the ioctl() command sent
downstream fails. For these cases, I_STR shall fail with errno set to
the value in the message.
- I_SWROPT
- Sets the write mode using the value of the argument arg. Valid bit
settings for arg are:
- SNDZERO
- Send a zero-length message downstream when a write() of 0 bytes
occurs. To not send a zero-length message when a write() of 0 bytes
occurs, the application shall ensure that this bit is not set in
arg (for example, arg would be set to 0).
The ioctl() function with the I_SWROPT command shall fail
if:
- EINVAL
- arg is not the above value.
- I_GWROPT
- Returns the current write mode setting, as described above, in the
int that is pointed to by the argument arg.
- I_SENDFD
- Creates a new reference to the open file description associated with the
file descriptor arg, and writes a message on the STREAMS-based pipe
fildes containing this reference, together with the user ID and
group ID of the calling process.
The ioctl() function with the I_SENDFD command shall fail
if:
- EAGAIN
- The sending STREAM is unable to allocate a message block to contain the
file pointer; or the read queue of the receiving STREAM head is full and
cannot accept the message sent by I_SENDFD.
- EBADF
- The arg argument is not a valid, open file descriptor.
- EINVAL
- The fildes argument is not connected to a STREAM pipe.
- ENXIO
- Hangup received on fildes.
The ioctl() function with the I_SENDFD command may fail
if:
- EINVAL
- The arg argument is equal to the fildes argument.
- I_RECVFD
- Retrieves the reference to an open file description from a message written
to a STREAMS-based pipe using the I_SENDFD command, and allocates a new
file descriptor in the calling process that refers to this open file
description. The arg argument is a pointer to a strrecvfd
data structure as defined in <stropts.h>.
The fd member is a file descriptor. The uid and
gid members are the effective user ID and effective group ID,
respectively, of the sending process.
If O_NONBLOCK is not set, I_RECVFD shall block until a message is
present at the STREAM head. If O_NONBLOCK is set, I_RECVFD shall fail with
errno set to [EAGAIN] if no message is present at the STREAM
head.
If the message at the STREAM head is a message sent by an
I_SENDFD, a new file descriptor shall be allocated for the open file
descriptor referenced in the message. The new file descriptor is placed in
the fd member of the strrecvfd structure pointed to by
arg.
The ioctl() function with the I_RECVFD command shall fail
if:
- EAGAIN
- A message is not present at the STREAM head read queue and the O_NONBLOCK
flag is set.
- EBADMSG
- The message at the STREAM head read queue is not a message containing a
passed file descriptor.
- EMFILE
- All file descriptors available to the process are currently open.
- ENXIO
- Hangup received on fildes.
- I_LIST
- Allows the process to list all the module names on the STREAM, up to and
including the topmost driver name. If arg is a null pointer, the
return value shall be the number of modules, including the driver, that
are on the STREAM pointed to by fildes. This lets the process
allocate enough space for the module names. Otherwise, it should point to
a str_list structure.
The sl_nmods member indicates the number of entries the
process has allocated in the array. Upon return, the sl_modlist
member of the str_list structure shall contain the list of module
names, and the number of entries that have been filled into the
sl_modlist array is found in the sl_nmods member (the number
includes the number of modules including the driver). The return value from
ioctl() shall be 0. The entries are filled in starting at the top of
the STREAM and continuing downstream until either the end of the STREAM is
reached, or the number of requested modules (sl_nmods) is
satisfied.
The ioctl() function with the I_LIST command shall fail
if:
- EINVAL
- The sl_nmods member is less than 1.
- EAGAIN or
ENOSR
-
Unable to allocate buffers.
- I_ATMARK
- Allows the process to see if the message at the head of the STREAM head
read queue is marked by some module downstream. The arg argument
determines how the checking is done when there may be multiple marked
messages on the STREAM head read queue. It may take on the following
values:
- ANYMARK
- Check if the message is marked.
- LASTMARK
- Check if the message is the last one marked on the queue.
The bitwise-inclusive OR of the flags ANYMARK and LASTMARK is
permitted.
The return value shall be 1 if the mark condition is satisfied;
otherwise, the value shall be 0.
The ioctl() function with the I_ATMARK command shall fail
if:
- EINVAL
- Invalid arg value.
- I_CKBAND
- Checks if the message of a given priority band exists on the STREAM head
read queue. This shall return 1 if a message of the given priority exists,
0 if no such message exists, or -1 on error. arg should be of type
int.
The ioctl() function with the I_CKBAND command shall fail
if:
- EINVAL
- Invalid arg value.
- I_GETBAND
- Returns the priority band of the first message on the STREAM head read
queue in the integer referenced by arg.
The ioctl() function with the I_GETBAND command shall fail
if:
- ENODATA
- No message on the STREAM head read queue.
- I_CANPUT
- Checks if a certain band is writable. arg is set to the priority
band in question. The return value shall be 0 if the band is
flow-controlled, 1 if the band is writable, or -1 on error.
The ioctl() function with the I_CANPUT command shall fail
if:
- EINVAL
- Invalid arg value.
- I_SETCLTIME
- This request allows the process to set the time the STREAM head shall
delay when a STREAM is closing and there is data on the write queues.
Before closing each module or driver, if there is data on its write queue,
the STREAM head shall delay for the specified amount of time to allow the
data to drain. If, after the delay, data is still present, it shall be
flushed. The arg argument is a pointer to an integer specifying the
number of milliseconds to delay, rounded up to the nearest valid value. If
I_SETCLTIME is not performed on a STREAM, an implementation-defined
default timeout interval is used.
The ioctl() function with the I_SETCLTIME command shall
fail if:
- EINVAL
- Invalid arg value.
- I_GETCLTIME
- Returns the close time delay in the integer pointed to by arg.
The following commands are used for connecting and disconnecting
multiplexed STREAMS configurations. These commands use an
implementation-defined default timeout interval.
- I_LINK
- Connects two STREAMs, where fildes is the file descriptor of the
STREAM connected to the multiplexing driver, and arg is the file
descriptor of the STREAM connected to another driver. The STREAM
designated by arg is connected below the multiplexing driver.
I_LINK requires the multiplexing driver to send an acknowledgement message
to the STREAM head regarding the connection. This call shall return a
multiplexer ID number (an identifier used to disconnect the multiplexer;
see I_UNLINK) on success, and -1 on failure.
The ioctl() function with the I_LINK command shall fail
if:
- ENXIO
- Hangup received on fildes.
- ETIME
- Timeout before acknowledgement message was received at STREAM head.
- EAGAIN or
ENOSR
-
Unable to allocate STREAMS storage to perform the I_LINK.
- EBADF
- The arg argument is not a valid, open file descriptor.
- EINVAL
- The fildes argument does not support multiplexing; or arg is
not a STREAM or is already connected downstream from a multiplexer; or the
specified I_LINK operation would connect the STREAM head in more than one
place in the multiplexed STREAM.
An I_LINK can also fail while waiting for the multiplexing driver
to acknowledge the request, if a message indicating an error or a hangup is
received at the STREAM head of fildes. In addition, an error code can
be returned in the positive or negative acknowledgement message. For these
cases, I_LINK fails with errno set to the value in the message.
- I_UNLINK
- Disconnects the two STREAMs specified by fildes and arg.
fildes is the file descriptor of the STREAM connected to the
multiplexing driver. The arg argument is the multiplexer ID number
that was returned by the I_LINK ioctl() command when a STREAM was
connected downstream from the multiplexing driver. If arg is
MUXID_ALL, then all STREAMs that were connected to fildes shall be
disconnected. As in I_LINK, this command requires acknowledgement.
The ioctl() function with the I_UNLINK command shall fail
if:
- ENXIO
- Hangup received on fildes.
- ETIME
- Timeout before acknowledgement message was received at STREAM head.
- EAGAIN or
ENOSR
-
Unable to allocate buffers for the acknowledgement message.
- EINVAL
- Invalid multiplexer ID number.
An I_UNLINK can also fail while waiting for the multiplexing
driver to acknowledge the request if a message indicating an error or a
hangup is received at the STREAM head of fildes. In addition, an
error code can be returned in the positive or negative acknowledgement
message. For these cases, I_UNLINK shall fail with errno set to the
value in the message.
- I_PLINK
- Creates a persistent connection between two STREAMs, where
fildes is the file descriptor of the STREAM connected to the
multiplexing driver, and arg is the file descriptor of the STREAM
connected to another driver. This call shall create a persistent
connection which can exist even if the file descriptor fildes
associated with the upper STREAM to the multiplexing driver is closed. The
STREAM designated by arg gets connected via a persistent connection
below the multiplexing driver. I_PLINK requires the multiplexing driver to
send an acknowledgement message to the STREAM head. This call shall return
a multiplexer ID number (an identifier that may be used to disconnect the
multiplexer; see I_PUNLINK) on success, and -1 on failure.
The ioctl() function with the I_PLINK command shall fail
if:
- ENXIO
- Hangup received on fildes.
- ETIME
- Timeout before acknowledgement message was received at STREAM head.
- EAGAIN or
ENOSR
-
Unable to allocate STREAMS storage to perform the I_PLINK.
- EBADF
- The arg argument is not a valid, open file descriptor.
- EINVAL
- The fildes argument does not support multiplexing; or arg is
not a STREAM or is already connected downstream from a multiplexer; or the
specified I_PLINK operation would connect the STREAM head in more than one
place in the multiplexed STREAM.
An I_PLINK can also fail while waiting for the multiplexing driver
to acknowledge the request, if a message indicating an error or a hangup is
received at the STREAM head of fildes. In addition, an error code can
be returned in the positive or negative acknowledgement message. For these
cases, I_PLINK shall fail with errno set to the value in the
message.
- I_PUNLINK
- Disconnects the two STREAMs specified by fildes and arg from
a persistent connection. The fildes argument is the file descriptor
of the STREAM connected to the multiplexing driver. The arg
argument is the multiplexer ID number that was returned by the I_PLINK
ioctl() command when a STREAM was connected downstream from the
multiplexing driver. If arg is MUXID_ALL, then all STREAMs which
are persistent connections to fildes shall be disconnected. As in
I_PLINK, this command requires the multiplexing driver to acknowledge the
request.
The ioctl() function with the I_PUNLINK command shall fail
if:
- ENXIO
- Hangup received on fildes.
- ETIME
- Timeout before acknowledgement message was received at STREAM head.
- EAGAIN or
ENOSR
-
Unable to allocate buffers for the acknowledgement message.
- EINVAL
- Invalid multiplexer ID number.
An I_PUNLINK can also fail while waiting for the multiplexing
driver to acknowledge the request if a message indicating an error or a
hangup is received at the STREAM head of fildes. In addition, an
error code can be returned in the positive or negative acknowledgement
message. For these cases, I_PUNLINK shall fail with errno set to the
value in the message.