Remove more disconnected libgpib items missed in r276214.
Sponsored by: EMC / Isilon Storage Division
This commit is contained in:
parent
92619f554a
commit
cf07362e21
@ -780,7 +780,6 @@
|
||||
.ds doc-str-Lb-libfetch File Transfer Library for URLs (libfetch, \-lfetch)
|
||||
.ds doc-str-Lb-libform Curses Form Library (libform, \-lform)
|
||||
.ds doc-str-Lb-libgeom Userland API Library for kernel GEOM subsystem (libgeom, \-lgeom)
|
||||
.ds doc-str-Lb-libgpib General-Purpose Instrument Bus (GPIB) library (libgpib, \-lgpib)
|
||||
.ds doc-str-Lb-libi386 i386 Architecture Library (libi386, \-li386)
|
||||
.ds doc-str-Lb-libintl Internationalized Message Handling Library (libintl, \-lintl)
|
||||
.ds doc-str-Lb-libipsec IPsec Policy Control Library (libipsec, \-lipsec)
|
||||
|
@ -1732,8 +1732,6 @@ and their results are:
|
||||
.Lb libform
|
||||
.It Li libgeom
|
||||
.Lb libgeom
|
||||
.It Li libgpib
|
||||
.Lb libgpib
|
||||
.It Li libi386
|
||||
.Lb libi386
|
||||
.It Li libintl
|
||||
|
@ -57,7 +57,6 @@ LINE("libfsid", "Filesystem Identification Library (libfsid, \\-lfsid)")
|
||||
LINE("libftpio", "FTP Connection Management Library (libftpio, \\-lftpio)")
|
||||
LINE("libform", "Curses Form Library (libform, \\-lform)")
|
||||
LINE("libgeom", "Userland API Library for Kernel GEOM subsystem (libgeom, \\-lgeom)")
|
||||
LINE("libgpib", "General-Purpose Instrument Bus (GPIB) library (libgpib, \\-lgpib)")
|
||||
LINE("libgpio", "General-Purpose Input Output (GPIO) library (libgpio, \\-lgpio)")
|
||||
LINE("libhammer", "HAMMER Filesystem Userland Library (libhammer, \\-lhammer)")
|
||||
LINE("libi386", "i386 Architecture Library (libi386, \\-li386)")
|
||||
|
@ -1,28 +0,0 @@
|
||||
# $FreeBSD$
|
||||
|
||||
LIB= gpib
|
||||
SHLIB_MAJOR= 3
|
||||
INCS= gpib.h
|
||||
INCSDIR= ${INCLUDEDIR}/gpib
|
||||
SRCS= ibfoo.c
|
||||
|
||||
MAN= gpib.3
|
||||
|
||||
# MLINKS are only provided for functions that are actually
|
||||
# implemented; update this if missing pieces have been filled in.
|
||||
MLINKS+= gpib.3 ibclr.3
|
||||
MLINKS+= gpib.3 ibdev.3
|
||||
MLINKS+= gpib.3 ibdma.3
|
||||
MLINKS+= gpib.3 ibeos.3
|
||||
MLINKS+= gpib.3 ibeot.3
|
||||
MLINKS+= gpib.3 ibloc.3
|
||||
MLINKS+= gpib.3 ibonl.3
|
||||
MLINKS+= gpib.3 ibpad.3
|
||||
MLINKS+= gpib.3 ibrd.3
|
||||
MLINKS+= gpib.3 ibsad.3
|
||||
MLINKS+= gpib.3 ibsic.3
|
||||
MLINKS+= gpib.3 ibtmo.3
|
||||
MLINKS+= gpib.3 ibtrg.3
|
||||
MLINKS+= gpib.3 ibwrt.3
|
||||
|
||||
.include <bsd.lib.mk>
|
@ -1,18 +0,0 @@
|
||||
# $FreeBSD$
|
||||
# Autogenerated - do NOT edit!
|
||||
|
||||
DIRDEPS = \
|
||||
gnu/lib/csu \
|
||||
gnu/lib/libgcc \
|
||||
include \
|
||||
lib/${CSU_DIR} \
|
||||
lib/libc \
|
||||
lib/libcompiler_rt \
|
||||
usr.bin/xinstall.host \
|
||||
|
||||
|
||||
.include <dirdeps.mk>
|
||||
|
||||
.if ${DEP_RELDIR} == ${_DEP_RELDIR}
|
||||
# local dependencies - needed for -jN in clean tree
|
||||
.endif
|
@ -1,741 +0,0 @@
|
||||
.\" 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:
|
||||
.Pp
|
||||
.Bl -tag -width 6n -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:
|
||||
.Pp
|
||||
.Bl -tag -width 6n -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 occurred
|
||||
.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
|
||||
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:
|
||||
.Pp
|
||||
.Bl -tag -width 6n -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
|
||||
.Pp
|
||||
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 function
|
||||
.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.
|
@ -1,33 +0,0 @@
|
||||
/*-
|
||||
* Copyright (c) 2005 Poul-Henning Kamp
|
||||
* 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.
|
||||
*
|
||||
* This file merely redirects to the file in <dev/ieee488/ugpib.h>
|
||||
*
|
||||
* $FreeBSD$
|
||||
*/
|
||||
|
||||
#include <dev/ieee488/ugpib.h>
|
||||
|
||||
#define ibcntl ibcnt
|
@ -1,647 +0,0 @@
|
||||
/*-
|
||||
* Copyright (c) 2005 Poul-Henning Kamp
|
||||
* 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.
|
||||
*
|
||||
* This file merely redirects to the file in <dev/ieee488/ugpib.h>
|
||||
*
|
||||
* $FreeBSD$
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <errno.h>
|
||||
#include <err.h>
|
||||
#include <sys/types.h>
|
||||
#include <fcntl.h>
|
||||
|
||||
#include <dev/ieee488/ugpib.h>
|
||||
#include <dev/ieee488/ibfoo_int.h>
|
||||
|
||||
int ibcnt, iberr, ibsta;
|
||||
|
||||
static int fd = -1;
|
||||
|
||||
static int
|
||||
__ibsubmit(struct ibarg *ap)
|
||||
{
|
||||
int i;
|
||||
|
||||
if (fd < 0)
|
||||
fd = open("/dev/gpib0ib", O_RDWR);
|
||||
if (fd < 0)
|
||||
err(1, "Could not open /dev/gpib0ib");
|
||||
i = ioctl(fd, GPIB_IBFOO, ap);
|
||||
if (i)
|
||||
err(1, "GPIB_IBFOO(%d, 0x%x) failed", ap->__ident, ap->__field);
|
||||
ibcnt = ap->__ibcnt;
|
||||
iberr = ap->__iberr;
|
||||
ibsta = ap->__ibsta;
|
||||
return (ap->__retval);
|
||||
}
|
||||
|
||||
int
|
||||
ibask (int handle, int option, int * retval)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBASK;
|
||||
io.handle = handle;
|
||||
io.option = option;
|
||||
io.retval = retval;
|
||||
io.__field = __F_HANDLE | __F_OPTION | __F_RETVAL;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibbna (int handle, char * bdname)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBBNA;
|
||||
io.handle = handle;
|
||||
io.bdname = bdname;
|
||||
io.__field = __F_HANDLE | __F_BDNAME;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibcac (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBCAC;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibclr (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBCLR;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibcmd (int handle, void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBCMD;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibcmda (int handle, void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBCMDA;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibconfig (int handle, int option, int value)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBCONFIG;
|
||||
io.handle = handle;
|
||||
io.option = option;
|
||||
io.value = value;
|
||||
io.__field = __F_HANDLE | __F_OPTION | __F_VALUE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibdev (int boardID, int pad, int sad, int tmo, int eot, int eos)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBDEV;
|
||||
io.boardID = boardID;
|
||||
io.pad = pad;
|
||||
io.sad = sad;
|
||||
io.tmo = tmo;
|
||||
io.eot = eot;
|
||||
io.eos = eos;
|
||||
io.__field = __F_BOARDID | __F_PAD | __F_SAD | __F_TMO | __F_EOT | __F_EOS;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibdiag (int handle, void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBDIAG;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibdma (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBDMA;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibeos (int handle, int eos)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBEOS;
|
||||
io.handle = handle;
|
||||
io.eos = eos;
|
||||
io.__field = __F_HANDLE | __F_EOS;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibeot (int handle, int eot)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBEOT;
|
||||
io.handle = handle;
|
||||
io.eot = eot;
|
||||
io.__field = __F_HANDLE | __F_EOT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibevent (int handle, short * event)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBEVENT;
|
||||
io.handle = handle;
|
||||
io.event = event;
|
||||
io.__field = __F_HANDLE | __F_EVENT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibfind (char * bdname)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBFIND;
|
||||
io.bdname = bdname;
|
||||
io.__field = __F_BDNAME;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibgts (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBGTS;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibist (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBIST;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
iblines (int handle, short * lines)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBLINES;
|
||||
io.handle = handle;
|
||||
io.lines = lines;
|
||||
io.__field = __F_HANDLE | __F_LINES;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibllo (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBLLO;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibln (int handle, int padval, int sadval, short * listenflag)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBLN;
|
||||
io.handle = handle;
|
||||
io.padval = padval;
|
||||
io.sadval = sadval;
|
||||
io.listenflag = listenflag;
|
||||
io.__field = __F_HANDLE | __F_PADVAL | __F_SADVAL | __F_LISTENFLAG;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibloc (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBLOC;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibonl (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBONL;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibpad (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBPAD;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibpct (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBPCT;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibpoke (int handle, int option, int value)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBPOKE;
|
||||
io.handle = handle;
|
||||
io.option = option;
|
||||
io.value = value;
|
||||
io.__field = __F_HANDLE | __F_OPTION | __F_VALUE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibppc (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBPPC;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrd (int handle, void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRD;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrda (int handle, void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRDA;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrdf (int handle, char * flname)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRDF;
|
||||
io.handle = handle;
|
||||
io.flname = flname;
|
||||
io.__field = __F_HANDLE | __F_FLNAME;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrdkey (int handle, void * buffer, int cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRDKEY;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrpp (int handle, char * ppr)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRPP;
|
||||
io.handle = handle;
|
||||
io.ppr = ppr;
|
||||
io.__field = __F_HANDLE | __F_PPR;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrsc (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRSC;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrsp (int handle, char * spr)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRSP;
|
||||
io.handle = handle;
|
||||
io.spr = spr;
|
||||
io.__field = __F_HANDLE | __F_SPR;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibrsv (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBRSV;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibsad (int handle, int sad)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBSAD;
|
||||
io.handle = handle;
|
||||
io.sad = sad;
|
||||
io.__field = __F_HANDLE | __F_SAD;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibsgnl (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBSGNL;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibsic (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBSIC;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibsre (int handle, int v)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBSRE;
|
||||
io.handle = handle;
|
||||
io.v = v;
|
||||
io.__field = __F_HANDLE | __F_V;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibsrq (ibsrq_t * func)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBSRQ;
|
||||
io.func = func;
|
||||
io.__field = __F_FUNC;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibstop (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBSTOP;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibtmo (int handle, int tmo)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBTMO;
|
||||
io.handle = handle;
|
||||
io.tmo = tmo;
|
||||
io.__field = __F_HANDLE | __F_TMO;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibtrap (int mask, int mode)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBTRAP;
|
||||
io.mask = mask;
|
||||
io.mode = mode;
|
||||
io.__field = __F_MASK | __F_MODE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibtrg (int handle)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBTRG;
|
||||
io.handle = handle;
|
||||
io.__field = __F_HANDLE;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibwait (int handle, int mask)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBWAIT;
|
||||
io.handle = handle;
|
||||
io.mask = mask;
|
||||
io.__field = __F_HANDLE | __F_MASK;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibwrt (int handle, const void *buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBWRT;
|
||||
io.handle = handle;
|
||||
io.buffer = __DECONST(void *, buffer);
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibwrta (int handle, const void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBWRTA;
|
||||
io.handle = handle;
|
||||
io.buffer = __DECONST(void *, buffer);
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibwrtf (int handle, const char *flname)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBWRTF;
|
||||
io.handle = handle;
|
||||
io.flname = __DECONST(void *, flname);
|
||||
io.__field = __F_HANDLE | __F_FLNAME;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibwrtkey (int handle, const void *buffer, int cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBWRTKEY;
|
||||
io.handle = handle;
|
||||
io.buffer = __DECONST(void *, buffer);
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
||||
int
|
||||
ibxtrc (int handle, void * buffer, long cnt)
|
||||
{
|
||||
struct ibarg io;
|
||||
|
||||
io.__ident = __ID_IBXTRC;
|
||||
io.handle = handle;
|
||||
io.buffer = buffer;
|
||||
io.cnt = cnt;
|
||||
io.__field = __F_HANDLE | __F_BUFFER | __F_CNT;
|
||||
return (__ibsubmit(&io));
|
||||
}
|
||||
|
@ -42,7 +42,6 @@ DIRDEPS = \
|
||||
lib/libexpat \
|
||||
lib/libfetch \
|
||||
lib/libgeom \
|
||||
lib/libgpib \
|
||||
lib/libgssapi \
|
||||
lib/libiconv_modules/BIG5 \
|
||||
lib/libiconv_modules/DECHanyu \
|
||||
|
Loading…
Reference in New Issue
Block a user