739 lines
16 KiB
Groff
739 lines
16 KiB
Groff
|
.\" Copyright (c) 2010, Joerg Wunsch
|
||
|
.\" All rights reserved.
|
||
|
.\"
|
||
|
.\" Redistribution and use in source and binary forms, with or without
|
||
|
.\" modification, are permitted provided that the following conditions
|
||
|
.\" are met:
|
||
|
.\" 1. Redistributions of source code must retain the above copyright
|
||
|
.\" notice, this list of conditions and the following disclaimer.
|
||
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||
|
.\" notice, this list of conditions and the following disclaimer in the
|
||
|
.\" documentation and/or other materials provided with the distribution.
|
||
|
.\"
|
||
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||
|
.\" SUCH DAMAGE.
|
||
|
.\"
|
||
|
.\" $FreeBSD$
|
||
|
.\"
|
||
|
.Dd February 1, 2010
|
||
|
.Dt GPIB 3
|
||
|
.Os
|
||
|
.Sh NAME
|
||
|
.\" .Nm ibask ,
|
||
|
.\" .Nm ibbna ,
|
||
|
.\" .Nm ibcac ,
|
||
|
.Nm ibclr ,
|
||
|
.\" .Nm ibcmd ,
|
||
|
.\" .Nm ibcmda ,
|
||
|
.\" .Nm ibconfig ,
|
||
|
.Nm ibdev ,
|
||
|
.\" .Nm ibdiag ,
|
||
|
.Nm ibdma ,
|
||
|
.Nm ibeos ,
|
||
|
.Nm ibeot ,
|
||
|
.\" .Nm ibevent ,
|
||
|
.\" .Nm ibfind ,
|
||
|
.\" .Nm ibgts ,
|
||
|
.\" .Nm ibist ,
|
||
|
.\" .Nm iblines ,
|
||
|
.\" .Nm ibllo ,
|
||
|
.\" .Nm ibln ,
|
||
|
.Nm ibloc ,
|
||
|
.Nm ibonl ,
|
||
|
.Nm ibpad ,
|
||
|
.\" .Nm ibpct ,
|
||
|
.\" .Nm ibpoke ,
|
||
|
.\" .Nm ibppc ,
|
||
|
.Nm ibrd ,
|
||
|
.\" .Nm ibrda ,
|
||
|
.\" .Nm ibrdf ,
|
||
|
.\" .Nm ibrdkey ,
|
||
|
.\" .Nm ibrpp ,
|
||
|
.\" .Nm ibrsc ,
|
||
|
.\" .Nm ibrsp ,
|
||
|
.\" .Nm ibrsv ,
|
||
|
.Nm ibsad ,
|
||
|
.\" .Nm ibsgnl ,
|
||
|
.Nm ibsic ,
|
||
|
.\" .Nm ibsre ,
|
||
|
.\" .Nm ibsrq ,
|
||
|
.\" .Nm ibstop ,
|
||
|
.Nm ibtmo ,
|
||
|
.\" .Nm ibtrap ,
|
||
|
.Nm ibtrg ,
|
||
|
.\" .Nm ibwait ,
|
||
|
.Nm ibwrt
|
||
|
.\" .Nm ibwrta ,
|
||
|
.\" .Nm ibwrtf ,
|
||
|
.\" .Nm ibwrtkey ,
|
||
|
.\" .Nm ibxtrc
|
||
|
.Nd "GPIB library"
|
||
|
.Sh LIBRARY
|
||
|
.Lb libgpib
|
||
|
.Sh SYNOPSIS
|
||
|
.In gpib.h
|
||
|
.Pp
|
||
|
.Dv extern int ibcnt ,
|
||
|
.Dv iberr ,
|
||
|
.Dv ibsta ;
|
||
|
.Pp
|
||
|
.Ft int
|
||
|
.Fn ibask "int handle" "int option" "int *retval"
|
||
|
.Ft int
|
||
|
.Fn ibbna "int handle" "char *bdname"
|
||
|
.Ft int
|
||
|
.Fn ibcac "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibclr "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibcmd "int handle" "void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibcmda "int handle" "void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibconfig "int handle" "int option" "int value"
|
||
|
.Ft int
|
||
|
.Fn ibdev "int boardID" "int pad" "int sad" "int tmo" "int eot" "int eos"
|
||
|
.Ft int
|
||
|
.Fn ibdiag "int handle" "void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibdma "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibeos "int handle" "int eos"
|
||
|
.Ft int
|
||
|
.Fn ibeot "int handle" "int eot"
|
||
|
.Ft int
|
||
|
.Fn ibevent "int handle" "short *event"
|
||
|
.Ft int
|
||
|
.Fn ibfind "char *bdname"
|
||
|
.Ft int
|
||
|
.Fn ibgts "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibist "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn iblines "int handle" "short *lines"
|
||
|
.Ft int
|
||
|
.Fn ibllo "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibln "int handle" "int padval" "int sadval" "short *listenflag"
|
||
|
.Ft int
|
||
|
.Fn ibloc "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibonl "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibpad "int handle" "int pad"
|
||
|
.Ft int
|
||
|
.Fn ibpct "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibpoke "int handle" "int option" "int value"
|
||
|
.Ft int
|
||
|
.Fn ibppc "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibrd "int handle" "void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibrda "int handle" "void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibrdf "int handle" "char *flname"
|
||
|
.Ft int
|
||
|
.Fn ibrdkey "int handle" "void *buffer" "int cnt"
|
||
|
.Ft int
|
||
|
.Fn ibrpp "int handle" "char *ppr"
|
||
|
.Ft int
|
||
|
.Fn ibrsc "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibrsp "int handle" "char *spr"
|
||
|
.Ft int
|
||
|
.Fn ibrsv "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibsad "int handle" "int sad"
|
||
|
.Ft int
|
||
|
.Fn ibsgnl "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibsic "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibsre "int handle" "int v"
|
||
|
.Ft int
|
||
|
.Fn ibsrq "(*func) void)"
|
||
|
.Ft int
|
||
|
.Fn ibstop "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibtmo "int handle" "int tmo"
|
||
|
.Ft int
|
||
|
.Fn ibtrap "int mask" "int mode"
|
||
|
.Ft int
|
||
|
.Fn ibtrg "int handle"
|
||
|
.Ft int
|
||
|
.Fn ibwait "int handle" "int mask"
|
||
|
.Ft int
|
||
|
.Fn ibwrt "int handle" "const void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibwrta "int handle" "const void *buffer" "long cnt"
|
||
|
.Ft int
|
||
|
.Fn ibwrtf "int handle" "const char *flname"
|
||
|
.Ft int
|
||
|
.Fn ibwrtkey "int handle" "const void *buffer" "int cnt"
|
||
|
.Ft int
|
||
|
.Fn ibxtrc "int handle" "void *buffer" "long cnt"
|
||
|
.Sh DESCRIPTION
|
||
|
The
|
||
|
.Nm
|
||
|
library provides access to the
|
||
|
.Xr gpib 4
|
||
|
kernel devices.
|
||
|
.Ss Variable Description
|
||
|
The variable
|
||
|
.Dv ibcnt
|
||
|
contains the number of bytes transferred in the most recent call to
|
||
|
.Fn ibcmd ,
|
||
|
.Fn ibrd ,
|
||
|
or
|
||
|
.Fn ibwrt .
|
||
|
.Pp
|
||
|
The name
|
||
|
.Dv ibcntl
|
||
|
is an alias for
|
||
|
.Dv ibcnt ,
|
||
|
provided for backwards compatibility.
|
||
|
.Pp
|
||
|
The variable
|
||
|
.Dv iberr
|
||
|
provides an error code for the most recent library call.
|
||
|
The possible error codes are:
|
||
|
.Bl -tag -offset indent -compact
|
||
|
.It EDVR
|
||
|
System error
|
||
|
.It ECIC
|
||
|
Not Active Controller
|
||
|
.It ENOL
|
||
|
Nobody listening
|
||
|
.It EADR
|
||
|
Controller not addressed
|
||
|
.It EARG
|
||
|
Invalid argument
|
||
|
.It ESAC
|
||
|
Not System Controller
|
||
|
.It EABO
|
||
|
I/O Aborted/Time out
|
||
|
.It ENEB
|
||
|
No such controller
|
||
|
.It EOIP
|
||
|
Async I/O in progress
|
||
|
.It ECAP
|
||
|
No such capability
|
||
|
.It EFSO
|
||
|
File system error
|
||
|
.It EBUS
|
||
|
Command byte xfer error
|
||
|
.It ESTB
|
||
|
Serial poll status byte lost
|
||
|
.It ESRQ
|
||
|
SRQ line stuck
|
||
|
.It ETAB
|
||
|
Table problem
|
||
|
.El
|
||
|
.Pp
|
||
|
The variable
|
||
|
.Dv ibsta
|
||
|
contains the controller status.
|
||
|
This is an ORed status value, with the following individual bit names:
|
||
|
.Bl -tag -offset indent -compact
|
||
|
.It ERR
|
||
|
Error
|
||
|
.It TIMO
|
||
|
Timeout
|
||
|
.It END
|
||
|
EOI/EOS
|
||
|
.It SRQI
|
||
|
SRQ
|
||
|
.It RQS
|
||
|
Device requests service
|
||
|
.It SPOLL
|
||
|
Serial Poll
|
||
|
.It EVENT
|
||
|
Event occured
|
||
|
.It CMPL
|
||
|
I/O complete
|
||
|
.It LOK
|
||
|
Lockout
|
||
|
.It REM
|
||
|
Remote
|
||
|
.It CIC
|
||
|
CIC
|
||
|
.It ATN
|
||
|
ATN
|
||
|
.It TACS
|
||
|
Talker
|
||
|
.It LACS
|
||
|
Listener
|
||
|
.It DTAS
|
||
|
Device trigger status
|
||
|
.It DCAS
|
||
|
Device clear state
|
||
|
.El
|
||
|
.Ss Function Description
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibdev
|
||
|
is used to open the GPIB device, and establish the parameters to
|
||
|
communicate with a particular bus device. The device is selected
|
||
|
by its primary address
|
||
|
.Fa pad ,
|
||
|
a numerical value between 0 and 30, possibly additionally by its
|
||
|
secondary address
|
||
|
.Fa sad ,
|
||
|
a numerical value between 96 and 126, or 0 to not use secondary
|
||
|
addressing.
|
||
|
The
|
||
|
.Fa tmo
|
||
|
value specifies the timeout to use when communicating with the device.
|
||
|
This can be any of the constants
|
||
|
.Dv TNONE ,
|
||
|
.Dv T10us ,
|
||
|
.Dv T30us ,
|
||
|
.Dv T100us ,
|
||
|
.Dv T300us ,
|
||
|
.Dv T1ms ,
|
||
|
.Dv T3ms ,
|
||
|
.Dv T10ms ,
|
||
|
.Dv T30ms ,
|
||
|
.Dv T100ms ,
|
||
|
.Dv T300ms ,
|
||
|
.Dv T1s ,
|
||
|
.Dv T3s ,
|
||
|
.Dv T10s ,
|
||
|
.Dv T30s ,
|
||
|
.Dv T100s ,
|
||
|
.Dv T300s ,
|
||
|
or
|
||
|
.Dv T1000s .
|
||
|
The boolean parameter
|
||
|
.Fa eot
|
||
|
specifies whether the bus signal
|
||
|
.Li EOI
|
||
|
(end-or-identify) should be asserted when sending the last byte of a
|
||
|
message to the device.
|
||
|
Finally, the
|
||
|
.Fa eos
|
||
|
parameter determines whether any special character should be used to
|
||
|
identify the end of a device message when transferring messages on the
|
||
|
bus.
|
||
|
The lower 8 bits of
|
||
|
.Fa eos
|
||
|
are interpreted as an end-of-string character,
|
||
|
.Li EOS .
|
||
|
This character can be ORed with the following values:
|
||
|
.Bl -tag -compact -offset indent
|
||
|
.It Dv REOS
|
||
|
When receiving a message byte on the bus that matches the
|
||
|
.Li EOS
|
||
|
character, treat it as if the
|
||
|
.Li EOI
|
||
|
signal were asserted, and stop receiving.
|
||
|
.It Dv XEOS
|
||
|
When transmitting a message byte on the bus that matches the
|
||
|
.Li EOS
|
||
|
character, assert the
|
||
|
.Li EOI
|
||
|
bus signal by the same time, and stop sending.
|
||
|
.It Dv BIN
|
||
|
If set, include all 8 bits of the
|
||
|
.Li EOS
|
||
|
character in the comparison; if unset, compare only 7 bit ASCII
|
||
|
values.
|
||
|
.El
|
||
|
Passing 0 as
|
||
|
.Fa eos
|
||
|
will turn off any special character treatment, allowing for a fully
|
||
|
8-bit transparent communications channel to the device.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibfind
|
||
|
is meant to find the
|
||
|
.Em board index
|
||
|
of a board identified by the name
|
||
|
.Fa bdname .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
All remaining functions take the handle returned by calling
|
||
|
.Fn ibdev
|
||
|
as their first argument
|
||
|
.Fa handle .
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibask
|
||
|
is used to query configuration values that have been set with
|
||
|
.Fn ibconfig .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibbna
|
||
|
is meant to change the access board for the given device to
|
||
|
a new one, named
|
||
|
.Fa bdname .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibcac
|
||
|
is used to become the active controller on the bus, by asserting the
|
||
|
.Li ATN
|
||
|
signal line.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibclr
|
||
|
is used to transmit a
|
||
|
.Em Selected Device Clear
|
||
|
command to the device.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibcmd
|
||
|
is used to directly write
|
||
|
.Fa cnt
|
||
|
GPIB command bytes from a buffer starting at
|
||
|
.Fa buffer
|
||
|
to the device.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibcmda
|
||
|
does the same as
|
||
|
.Fn ibcmd
|
||
|
except it operates asynchronously, so it returns to the caller
|
||
|
immediately.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibconfig
|
||
|
is used to set certain configuration parameters.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibdiag
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibdma
|
||
|
is used to enable or disable DMA transfers.
|
||
|
Parameter
|
||
|
.Fa v
|
||
|
is a boolean parameter indicating DMA transfers are to be used.
|
||
|
Depending on the hardware and operating system configuration, DMA
|
||
|
transfers might not be available for a particular access board.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibeos
|
||
|
configures the end-of-string character.
|
||
|
See
|
||
|
.Fn ibdev
|
||
|
for an explanation.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibeot
|
||
|
configures the assertion of the
|
||
|
.Li EOI
|
||
|
signal line when transmitting the last byte of a message; see
|
||
|
.Fn ibdev
|
||
|
for an explanation.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibevent
|
||
|
is used to obtain an event from the board's event queue.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibgts
|
||
|
makes the current controller the standby controller, by deasserting
|
||
|
the
|
||
|
.Li ATN
|
||
|
signal line.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibist
|
||
|
sets the individual status bits of the controller to the value
|
||
|
.Fa v .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn iblines
|
||
|
returns the status of the control and handshake bus lines into the
|
||
|
area pointed to by
|
||
|
.Fa lines .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibllo
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibln
|
||
|
checks for a listener at the primary address
|
||
|
.Fa padval
|
||
|
and the optional secondary address
|
||
|
.Fa sadval .
|
||
|
If a listener was found, the value pointed to by
|
||
|
.Fa listenflag
|
||
|
will be set to a non-zero value.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibloc
|
||
|
turns the device into local mode.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibonl
|
||
|
is used to close or reinitialize a device handle.
|
||
|
If parameter
|
||
|
.Fa v
|
||
|
is passed as zero, the handle will be closed, and cannot be used
|
||
|
again.
|
||
|
If it is passed as a non-zero value, all parameters of the handle
|
||
|
will be returned to their defaults;
|
||
|
.Em this functionality is currently unsupported.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibpad
|
||
|
is used to change the primary address of the device being communicated
|
||
|
with to
|
||
|
.Fa pad .
|
||
|
See
|
||
|
.Fn ibdev
|
||
|
for an explanation.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibpct
|
||
|
is used to make the device associated with the handle the
|
||
|
controller-in-charge.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibpoke
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibppc
|
||
|
is used to configure the parallel poll response to
|
||
|
.Fa v .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The fucntion
|
||
|
.Fn ibrd
|
||
|
is used to receive
|
||
|
.Fa cnt
|
||
|
bytes from the device, and store it to the address passed as
|
||
|
.Fa buffer .
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrda
|
||
|
behaves similar to
|
||
|
.Fn ibrd
|
||
|
except it operates asynchronously, and returns immediately to the
|
||
|
caller.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrdf
|
||
|
read data from the device, and appends it to the file with the name
|
||
|
.Fa flname .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrdkey
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrpp
|
||
|
performs a parallel poll, and stores the result at the location
|
||
|
pointed to by
|
||
|
.Fa ppr .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrsc
|
||
|
makes the board specified by the handle the
|
||
|
.Em system controller
|
||
|
if the argument
|
||
|
.Fa v
|
||
|
is non-zero.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrsp
|
||
|
conducts a serial poll, and stores the result in the byte pointed
|
||
|
to by
|
||
|
.Fa spr .
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibrsv
|
||
|
sets the serial poll response of the board to
|
||
|
.Fa v ,
|
||
|
possibly requesting service from the controller if the SRQ bit (0x40)
|
||
|
is set.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibsad
|
||
|
changes the secondary address of the device being communicated with to
|
||
|
.Fa sad .
|
||
|
See
|
||
|
.Fn ibdev
|
||
|
for an explanation.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibsgnl
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibsic
|
||
|
asserts the
|
||
|
.Em Interface Clear (IFC)
|
||
|
signal line on the bus for at least 100 microseconds.
|
||
|
This will make all devices attached to the bus to unlisten and untalk.
|
||
|
This function should only be executed on the system controller.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibsre
|
||
|
asserts the
|
||
|
.Em Remote Enable (REN)
|
||
|
signal line on the bus if argument
|
||
|
.Fa v
|
||
|
is non-zero, or deasserts it otherwise.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibsrq
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibstop
|
||
|
stops or aborts any asynchronous I/O operation.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibtmo
|
||
|
reconfigures the communication timeout.
|
||
|
See
|
||
|
.Fn ibdev
|
||
|
for an explanation.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibtrap
|
||
|
is obsolete, and not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibtrg
|
||
|
sends a
|
||
|
.Em Group Execute Trigger (GET)
|
||
|
command to the device.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibwait
|
||
|
waits for a status condition as specified by
|
||
|
.Fa mask .
|
||
|
If
|
||
|
.Fa mask
|
||
|
is given as zero, it returns immediately.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibwrt
|
||
|
is used to send
|
||
|
.Fa cnt
|
||
|
bytes to the device, starting at the address pointed to by
|
||
|
.Fa buffer .
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibwrta
|
||
|
performs the same operation as
|
||
|
.Fn ibwrt
|
||
|
in an asynchronous way, returning immediately to the caller.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibwrtf
|
||
|
opens the file named by
|
||
|
.Fa flname ,
|
||
|
and sends its contents to the device.
|
||
|
.Em This function is currently not implemented.
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibwrtkey
|
||
|
is obsolete, and not implemented
|
||
|
.Pp
|
||
|
The function
|
||
|
.Fn ibxtrc
|
||
|
is obsolete, and not implemented.
|
||
|
.Sh RETURN VALUES
|
||
|
The function
|
||
|
.Fn ibdev
|
||
|
returns a handle to be used for the remaining functions.
|
||
|
Upon failure, -1 is returned.
|
||
|
.Pp
|
||
|
All other functions return the value of the variable
|
||
|
.Dv ibsta .
|
||
|
.Sh DIAGNOSTICS
|
||
|
None.
|
||
|
.Sh COMPATIBILITY
|
||
|
The
|
||
|
.Nm
|
||
|
library tries to be compatible with the Linux GPIB library,
|
||
|
which in turn appears to be compatible with the GPIB library
|
||
|
shipped by National Instruments.
|
||
|
.Sh ERRORS
|
||
|
Errors in the functions above might set
|
||
|
.Dv errno
|
||
|
to one of these values:
|
||
|
.Bl -tag -width Er
|
||
|
.It Bq Er ENOENT
|
||
|
No such file or directory.
|
||
|
.It Bq Er EIO
|
||
|
Input/output error.
|
||
|
.It Bq Er ENXIO
|
||
|
Device not configured.
|
||
|
.It Bq Er E2BIG
|
||
|
Argument list too long.
|
||
|
.It Bq Er ENOMEM
|
||
|
Cannot allocate memory.
|
||
|
.It Bq Er EACCES
|
||
|
Permission denied.
|
||
|
.It Bq Er EFAULT
|
||
|
Bad address.
|
||
|
.It Bq Er EBUSY
|
||
|
Device busy.
|
||
|
.It Bq Er EINVAL
|
||
|
Invalid argument.
|
||
|
.It Bq Er ENFILE
|
||
|
Too many open files in system.
|
||
|
.It Bq Er EMFILE
|
||
|
Too many open files.
|
||
|
.It Bq Er EOPNOTSUPP
|
||
|
Operation not supported.
|
||
|
.El
|
||
|
.Sh SEE ALSO
|
||
|
.Xr gpib 4
|
||
|
.Sh HISTORY
|
||
|
The
|
||
|
.Nm
|
||
|
library was written by
|
||
|
.An Poul-Henning Kamp
|
||
|
and first appeared in
|
||
|
.Fx 5.4 .
|
||
|
.Sh AUTHORS
|
||
|
This manual page was written by
|
||
|
.An J\(:org Wunsch .
|
||
|
.Sh BUGS
|
||
|
Currently, the library can only handle a single
|
||
|
.Xr gpib 4
|
||
|
device with instance number 0.
|
||
|
.Pp
|
||
|
Many functions are currently not implemented, see above for details.
|