PRNIO(4I) 4I PRNIO(4I)
NAME
prnio - generic printer interface
SYNOPSIS
#include <sys/prnio.h>DESCRIPTION
The
prnio generic printer interface defines ioctl commands and data
structures for printer device drivers.
prnio defines and provides facilities for five basic phases of the printing
process:
+o Identification -- Retrieve device information/attributes
+o Setup -- Set device attributes
+o Transfer -- Transfer data to or from the device
+o Cleanup -- Transfer phase conclusion
+o Abort -- Transfer phase interruption
During the Identification phase, the application retrieves a set of device
capabilities and additional information using the PRNIOC_GET_IFCAP,
PRNIOC_GET_STATUS, PRNIOC_GET_TIMEOUTS, PRNIOC_GET_IFINFO, and
PRNIOC_GET_1284_DEVID commands.
During the Setup phase the application sets some interface attributes and
probably resets the printer as described in the PRNIOC_SET_IFCAP,
PRNIOC_SET_TIMEOUTS, and PRNIOC_RESET sections.
During the Transfer phase, data is transferred in a forward (host to
peripheral) or reverse direction (peripheral to host). Transfer is
accomplished using
write(2) and
read(2) system calls. For
prnio compliant
printer drivers, forward transfer support is mandatory, while reverse
transfer support is optional. Applications can also use PRNIOC_GET_STATUS
and PRNIOC_GET_1284_STATUS commands during the transfer to monitor the
device state.
The Cleanup phase is accomplished by closing the device using
close(2).
Device drivers supporting
prnio may set non-zero error code as appropriate.
Applications should explicitly
close(2) a device before exiting and check
errno value.
The Abort phase is accomplished by interrupting the
write(2) and
read(2) system calls. The application can perform some additional cleanup during
the Abort phase as described in PRNIOC_GET_IFCAP section.
IOCTLS
PRNIOC_GET_IFCAP Application can retrieve printer interface capabilities
using this command. The
ioctl(2) argument is a pointer
to
uint_t, a bit field representing a set of properties
and services provided by a printer driver. Set bit
means supported capability. The following values are
defined:
PRN_BIDI When this bit is set, the interface
operates in a bidirectional mode,
instead of forward-only mode.
PRN_HOTPLUG If this bit is set, the interface
allows device hot-plugging.
PRN_1284_DEVID If this bit is set, the device is
capable of returning
1284 device ID
(see PRNIOC_GET_1284_DEVID).
PRN_1284_STATUS If this bit is set, the device driver
can return device status lines (see
PRNIOC_GET_1284_STATUS). Some devices
support this ioctl in unidirectional
mode only.
PRN_TIMEOUTS If this bit is set the peripheral may
stall during the transfer phase and the
driver can timeout and return from the
write(2) and
read(2) returning the
number of bytes that have been
transferred. If PRN_TIMEOUTS is set,
the driver supports this functionality
and the timeout values can be retrieved
and modified via the
PRNIOC_GET_TIMEOUTS and
PRNIOC_SET_TIMEOUTS ioctls. Otherwise,
applications can implement their own
timeouts and abort phase.
PRN_STREAMS This bit impacts the application abort
phase behaviour. If the device claimed
PRN_STREAMS capability, the application
must issue an I_FLUSH
ioctl(2) before
close(2) to dismiss the untransferred
data. Only STREAMS drivers can support
this capability.
PRNIOC_SET_IFCAP This ioctl can be used to change interface capabilities.
The argument is a pointer to
uint_t bit field that is
described in detail in the PRNIOC_GET_IFCAP section.
Capabilities should be set one at a time; otherwise the
command will return EINVAL. The following capabilities
can be changed by this ioctl:
PRN_BIDI When this capability is set, the interface
operates in a bidirectional mode, instead of
forward-only mode. Devices that support only
one mode will not return error; applications
should use PRNIOC_GET_IFCAP to check if the
mode was successfully changed. Because some
capabilities may be altered as a side effect
of changing other capabilities, this command
should be followed by PRNIOC_GET_IFCAP.
PRNIOC_GET_IFINFO This command can be used to retrieve printer interface
info string, which is an arbitrary format string usually
describing the bus type. The argument is a pointer to
struct prn_interface_info as described below.
struct prn_interface_info {
uint_t if_len; /* length of buffer */
uint_t if_rlen; /* actual info length */
char *if_data; /* buffer address */
};
The application allocates a buffer and sets
if_data and
if_len values to its address and length, respectively.
The driver returns the string to this buffer and sets
if_len to its length. If
if_len is less than
if_rlen,
the driver must return the first
if_len bytes of the
string. The application may then repeat the command
with a bigger buffer.
Although
prnio does not limit the contents of the
interface info string, some values are recommended and
defined in <
sys/prnio.h> by the following macros:
PRN_PARALLEL Centronics or
IEEE 1284 compatible devices
PRN_SERIAL EIA-232/EIA-485 serial ports
PRN_USB Universal Serial Bus printers
PRN_1394
IEEE 1394 peripherals
Printer interface info string is for information only:
no implications should be made from its value.
PRNIOC_RESET Some applications may want to reset the printer state
during Setup and/or Cleanup phase using PRNIOC_RESET
command. Reset semantics are device-specific, and in
general, applications using this command should be aware
of the printer type.
Each
prnio compliant driver is required to accept this
request, although performed actions are completely
driver-dependent. More information on the PRNIOC_RESET
implementation for the particular driver is available in
the corresponding man page and printer manual.
PRNIOC_GET_1284_DEVID
This command can be used to retrieve printer device ID
as defined by
IEEE 1284-1994. The
ioctl(2) argument is
a pointer to
struct prn_1284_device_id as described
below.
struct prn_1284_device_id {
uint_t id_len; /* length of buffer */
uint_t id_rlen; /* actual ID length */
char *id_data; /* buffer address */
};
For convenience, the two-byte length field is not
considered part of device ID string and is not returned
in the user buffer. Instead,
id_rlen value shall be set
to (length - 2) by the driver, where length is the ID
length field value. If buffer length is less than
id_rlen, the driver returns the first
id_len bytes of
the ID.
The printer driver must return the most up-to-date value
of the device ID.
PRNIOC_GET_STATUS This command can be used by applications to retrieve
current device status. The argument is a pointer to
uint_t, where the status word is returned. Status is a
combination of the following bits:
PRN_ONLINE For devices that support PRN_HOTPLUG
capability, this bit is set when the device
is online, otherwise the device is offline.
Devices without PRN_HOTPLUG support should
always have this bit set.
PRN_READY This bit indicates if the device is ready to
receive/send data. Applications may use
this bit for an outbound flow control.
PRNIOC_GET_1284_STATUS
Devices that support PRN_1284_STATUS capability accept
this ioctl to retrieve the device status lines defined
in
IEEE 1284 for use in Compatibility mode. The
following bits may be set by the driver:
PRN_1284_NOFAULT Device is not in error state
PRN_1284_SELECT Device is selected
PRN_1284_PE Paper error
PRN_1284_BUSY Device is busy
PRNIOC_GET_TIMEOUTS
This command retrieves current transfer timeout values
for the driver. The argument is a pointer to
struct prn_timeouts as described below.
struct prn_timeouts {
uint_t tmo_forward; /* forward transfer timeout */
uint_t tmo_reverse; /* reverse transfer timeout */
};
tmo_forward and
tmo_reverse define forward and reverse
transfer timeouts in seconds. This command is only
valid for drivers that support PRN_TIMEOUTS capability.
PRNIOC_SET_TIMEOUTS
This command sets current transfer timeout values for
the driver. The argument is a pointer to
struct prn_timeouts. See
PRNIOC_GET_TIMEOUTS for description
of this structure. This command is only valid for
drivers that support PRN_TIMEOUTS capability.
SEE ALSO
close(2),
ioctl(2),
read(2),
write(2),
ecpp(4D),
lp(4D),
usbprn(4D),
attributes(7) IEEE Std 1284-1994.
OmniOS August 31, 2018 OmniOS