1467 lines
37 KiB
Groff
1467 lines
37 KiB
Groff
|
.\"
|
||
|
.\" Copyright 1994 Vrije Universiteit, The Netherlands.
|
||
|
.\" For full copyright and restrictions on use see the file COPYRIGHT in the
|
||
|
.\" top level of the Amoeba distribution.
|
||
|
.\"
|
||
|
.ig
|
||
|
Software: Philip Homburg, 1991
|
||
|
Document: Philip Homburg, Sept 3, 1991
|
||
|
Modified: Greg Sharp and Philip Homburg, March 1992
|
||
|
- merged with udp(L) and made a little more complete.
|
||
|
Greg Sharp, April 1992
|
||
|
- updated keywords for auto index generation
|
||
|
Modified: Kees J. Bot, June 1994
|
||
|
- changed to man(7) format for MINIX 3.
|
||
|
..
|
||
|
.TH IP 4
|
||
|
.SH NAME
|
||
|
ip, eth, psip, udp, tcp \- Internet Protocol server devices and definitions
|
||
|
.SH DESCRIPTION
|
||
|
.de SP
|
||
|
.if t .sp 0.4
|
||
|
.if n .sp
|
||
|
..
|
||
|
The
|
||
|
.BR ip* ,
|
||
|
.BR eth* ,
|
||
|
.BR psip* ,
|
||
|
.BR tcp* ,
|
||
|
and
|
||
|
.B udp*
|
||
|
devices give access to the Internet Protocol (IP) services in MINIX 3.
|
||
|
There can be up to 16 different networks, with 4 network devices each
|
||
|
(a network has either an
|
||
|
.B eth*
|
||
|
or a
|
||
|
.B psip*
|
||
|
device, not both.)
|
||
|
The
|
||
|
.B *
|
||
|
in the device names is a decimal number, so one may see names from
|
||
|
.B ip0
|
||
|
to
|
||
|
.BR ip15 .
|
||
|
A program scanning all networks must try all 16, and not stop if one in
|
||
|
between is missing. One network is the default network. Its devices are
|
||
|
linked to names without numbers.
|
||
|
.PP
|
||
|
The
|
||
|
.B eth*
|
||
|
and
|
||
|
.B psip*
|
||
|
devices give direct access to the network packets at the lowest level.
|
||
|
The
|
||
|
.BR ip* ,
|
||
|
.BR tcp* ,
|
||
|
and
|
||
|
.B udp*
|
||
|
devices give access to IP, TCP, or UDP services.
|
||
|
.PP
|
||
|
Most programs that use TCP/IP use code like the following to access the
|
||
|
proper devices:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
if ((tcp_device= getenv("TCP_DEVICE")) == NULL)
|
||
|
tcp_device= "/dev/tcp";
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The low level networking programs such as
|
||
|
.BR ifconfig (8)
|
||
|
also have options to select the device they are working with. The
|
||
|
convention is:
|
||
|
.PP
|
||
|
.RS
|
||
|
.BI ETH_DEVICE= device
|
||
|
.br
|
||
|
.BI -E " device"
|
||
|
.RS
|
||
|
Device to use as raw ethernet device instead of the default /dev/eth.
|
||
|
.RE
|
||
|
.SP
|
||
|
.BI PSIP_DEVICE= device
|
||
|
.br
|
||
|
.BI -P " device"
|
||
|
.RS
|
||
|
Pseudo IP device to use instead of
|
||
|
.BR /dev/psip .
|
||
|
.RE
|
||
|
.SP
|
||
|
.BI IP_DEVICE= device
|
||
|
.br
|
||
|
.BI -I " device"
|
||
|
.RS
|
||
|
IP device to use instead of
|
||
|
.BR /dev/ip .
|
||
|
.RE
|
||
|
.SP
|
||
|
.BI TCP_DEVICE= device
|
||
|
.br
|
||
|
.BI -T " device"
|
||
|
.RS
|
||
|
TCP device to use instead of
|
||
|
.BR /dev/tcp .
|
||
|
.RE
|
||
|
.SP
|
||
|
.BI UDP_DEVICE= device
|
||
|
.br
|
||
|
.BI -U " device"
|
||
|
.RS
|
||
|
UDP device to use instead of
|
||
|
.BR /dev/udp .
|
||
|
.RE
|
||
|
.RE
|
||
|
.SS Programming
|
||
|
Access to the IP services is provided using filedescriptors to open IP
|
||
|
devices. These open IP channels can be configured with
|
||
|
.BR ioctl (2)
|
||
|
calls, and data can be transferred by calls to
|
||
|
.BR read (2),
|
||
|
and
|
||
|
.BR write (2).
|
||
|
.SS "Types (general)"
|
||
|
.IP <sys/types.h>
|
||
|
.br
|
||
|
Defines
|
||
|
.BR u8_t ,
|
||
|
.BR u16_t ,
|
||
|
.B u32_t
|
||
|
and
|
||
|
.B i32_t
|
||
|
(and
|
||
|
.BR U8_t ,
|
||
|
.BR U16_t ,
|
||
|
.B U32_t
|
||
|
and
|
||
|
.B I32_t
|
||
|
for use in prototypes).
|
||
|
.SS "Types (eth)"
|
||
|
.IP <net/gen/ether.h>
|
||
|
.br
|
||
|
Defines struct ether_addr (\fBether_addr_t\fP) and
|
||
|
.B ether_type_t
|
||
|
and
|
||
|
.B Ether_type_t
|
||
|
for use in prototypes.
|
||
|
.IP <net/gen/eth_io.h>
|
||
|
.br
|
||
|
Defines struct nwio_ethopt (\fBnwio_ethopt_t\fP) and
|
||
|
struct nwio_ethstat (\fBnwio_ethstat_t\fP)
|
||
|
.IP <net/gen/eth_hdr.h>
|
||
|
.br
|
||
|
Defines struct eth_hdr (\fBeth_hdr_t\fP)
|
||
|
.SS "Types (psip)"
|
||
|
.IP <net/gen/psip_hdr.h>
|
||
|
.br
|
||
|
[[[No description available yet.]]]
|
||
|
.IP <net/gen/psip_io.h>
|
||
|
.br
|
||
|
[[[No description available yet.]]]
|
||
|
.SS "Types (ip)"
|
||
|
.IP <net/gen/in.h>
|
||
|
.br
|
||
|
Defines
|
||
|
.BR ipaddr_t ,
|
||
|
.BR ipproto_t
|
||
|
and struct ip_hdropt (\fBip_hdropt_t\fP).
|
||
|
.IP <net/gen/ip_io.h>
|
||
|
.br
|
||
|
Defines struct nwio_ipconf (\fBnwio_ipconf_t\fP) and
|
||
|
struct nwio_ipopt (\fBnwio_ipopt_t\fP)
|
||
|
.IP <net/gen/ip_hdr.h>
|
||
|
.br
|
||
|
Defines struct ip_hdr (\fBip_hdr_t\fP)
|
||
|
.IP <net/gen/route.h>
|
||
|
.br
|
||
|
Defines struct nwio_route (\fBnwio_route_t\fP)
|
||
|
.SS "Types (tcp)"
|
||
|
.IP <net/gen/tcp.h>
|
||
|
.br
|
||
|
Defines
|
||
|
.B tcpport_t
|
||
|
and
|
||
|
.B Tcpport_t
|
||
|
for use in prototypes.
|
||
|
.IP <net/gen/tcp_io.h>
|
||
|
.br
|
||
|
Defines struct nwio_tcpconf (\fBnwio_tcpconf_t\fP),
|
||
|
struct nwio_tcpcl (\fBnwio_tcpcl_t\fP),
|
||
|
struct nwio_tcpatt (\fBnwio_tcpatt_t\fP) and
|
||
|
struct nwio_tcpopt (\fBnwio_tcpopt_t\fP).
|
||
|
.IP <net/gen/tcp_hdr.h>
|
||
|
.br
|
||
|
Defines struct tcp_hdr (\fBtcp_hdr_t\fP) and struct tcp_hdropt
|
||
|
(\fBtcp_hdropt_t\fP).
|
||
|
.SS "Types (udp)"
|
||
|
.IP <net/gen/udp.h>
|
||
|
.br
|
||
|
Defines
|
||
|
.B udpport_t
|
||
|
and
|
||
|
.B Udpport_t
|
||
|
for use in prototypes.
|
||
|
.IP <net/gen/udp_io.h>
|
||
|
.br
|
||
|
Defines struct nwio_udpopt (\fBnwio_udpopt_t\fP).
|
||
|
.IP <net/gen/udp_hdr.h>
|
||
|
.br
|
||
|
Defines struct udp_hdr (\fBudp_hdr_t\fP) and struct udp_io_hdr
|
||
|
(\fBudp_io_hdr_t\fP).
|
||
|
.SS "Byte Order Conversion"
|
||
|
All 16-bit and 32-bit quantities in IP headers must be in network byte
|
||
|
order. The macros described in
|
||
|
.BR hton (3)
|
||
|
can be used to convert these values to and from the byte order used by
|
||
|
the host machine.
|
||
|
.SS "The Internet Checksum"
|
||
|
The
|
||
|
.B oneC_sum
|
||
|
function (see
|
||
|
.BR oneC_sum (3))
|
||
|
is used to calculate the one's complement checksum needed for IP network
|
||
|
packets.
|
||
|
.SS "General Functions"
|
||
|
.PP
|
||
|
.ft B
|
||
|
\fIfd\fP = open(\fItcpip_device\fP, O_RDWR)
|
||
|
.ft R
|
||
|
.PP
|
||
|
This is how one normally obtains a filedescriptor for a new TCP/IP channel.
|
||
|
.I tcpip_device
|
||
|
names one of the TCP/IP devices. The channel may be used both to send or to
|
||
|
receive data.
|
||
|
.PP
|
||
|
.ft B
|
||
|
\fIn\fP = read(\fIfd\fP, \fIbuf\fP, \fIsize\fP)
|
||
|
.ft R
|
||
|
.PP
|
||
|
Receives one packet (low level devices) or a number of bytes (TCP stream).
|
||
|
Returns the the number of bytes placed into
|
||
|
.IR buf ,
|
||
|
or returns -1 with an error code placed into
|
||
|
.BR errno .
|
||
|
.PP
|
||
|
.ft B
|
||
|
\fIn\fP = write(\fIfd\fP, \fIbuf\fP, \fIsize\fP)
|
||
|
.ft R
|
||
|
.PP
|
||
|
Sends one packet (low level devices) or a number of bytes (TCP stream).
|
||
|
Returns
|
||
|
.I size
|
||
|
or -1 with the error code placed into
|
||
|
.BR errno .
|
||
|
The TCP/IP
|
||
|
.B read
|
||
|
and
|
||
|
.B write
|
||
|
functions behave like reads and writes on pipes when it comes to signals.
|
||
|
.SS "ETH Functions"
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOGETHSTAT, &struct nwio_ethstat)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOGETHSTAT
|
||
|
ioctl
|
||
|
returns the Ethernet address and some statistics of the Ethernet server of
|
||
|
the channel
|
||
|
.IR fd .
|
||
|
The result is returned in the nwio_ethstat structure.
|
||
|
The \fBstruct nwio_ethstat\fP is defined in <net/gen/eth_io.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_ethstat
|
||
|
{
|
||
|
ether_addr_t nwes_addr;
|
||
|
eth_stat_t nwes_stat;
|
||
|
} nwio_ethstat_t;
|
||
|
.SP
|
||
|
typedef struct eth_stat
|
||
|
{
|
||
|
unsigned long ets_recvErr, /* # receive errors */
|
||
|
ets_sendErr, /* # send error */
|
||
|
ets_OVW, /* # buffer overwrite warnings,
|
||
|
(packets arrive faster than
|
||
|
can be processed) */
|
||
|
ets_CRCerr, /* # crc errors of read */
|
||
|
ets_frameAll, /* # frames not aligned (# bits
|
||
|
not a multiple of 8) */
|
||
|
ets_missedP, /* # packets missed due to too
|
||
|
slow packet processing */
|
||
|
ets_packetR, /* # packets received */
|
||
|
ets_packetT, /* # packets transmitted */
|
||
|
ets_transDef, /* # transmission deferred (there
|
||
|
was a transmission of an
|
||
|
other station in progress */
|
||
|
ets_collision, /* # collisions */
|
||
|
ets_transAb, /* # transmissions aborted due
|
||
|
to excessive collisions */
|
||
|
ets_carrSense, /* # carrier sense lost */
|
||
|
ets_fifoUnder, /* # fifo underruns (processor
|
||
|
is too busy) */
|
||
|
ets_fifoOver, /* # fifo overruns (processor is
|
||
|
too busy) */
|
||
|
ets_CDheartbeat, /* # times unable to transmit
|
||
|
collision signal */
|
||
|
ets_OWC; /* # times out of window
|
||
|
collision */
|
||
|
} eth_stat_t;
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOSETHOPT, &struct nwio_ethopt)
|
||
|
.ft R
|
||
|
.PP
|
||
|
Before an Ethernet channel can be used to send or receive
|
||
|
Ethernet packets, it has to be configured using the
|
||
|
.B NWIOSETHOPT
|
||
|
ioctl.
|
||
|
The structure
|
||
|
.B nwio_ethopt
|
||
|
is defined in <net/gen/eth_io.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_ethopt
|
||
|
{
|
||
|
u32_t nweo_flags;
|
||
|
ether_addr_t nweo_multi, nweo_rem;
|
||
|
ether_type_t nweo_type;
|
||
|
} nwio_ethopt_t;
|
||
|
.SP
|
||
|
#define NWEO_NOFLAGS 0x0000L
|
||
|
#define NWEO_ACC_MASK 0x0003L
|
||
|
# define NWEO_EXCL 0x00000001L
|
||
|
# define NWEO_SHARED 0x00000002L
|
||
|
# define NWEO_COPY 0x00000003L
|
||
|
#define NWEO_LOC_MASK 0x0010L
|
||
|
# define NWEO_EN_LOC 0x00000010L
|
||
|
# define NWEO_DI_LOC 0x00100000L
|
||
|
#define NWEO_BROAD_MASK 0x0020L
|
||
|
# define NWEO_EN_BROAD 0x00000020L
|
||
|
# define NWEO_DI_BROAD 0x00200000L
|
||
|
#define NWEO_MULTI_MASK 0x0040L
|
||
|
# define NWEO_EN_MULTI 0x00000040L
|
||
|
# define NWEO_DI_MULTI 0x00400000L
|
||
|
#define NWEO_PROMISC_MASK 0x0080L
|
||
|
# define NWEO_EN_PROMISC 0x00000080L
|
||
|
# define NWEO_DI_PROMISC 0x00800000L
|
||
|
#define NWEO_REM_MASK 0x0100L
|
||
|
# define NWEO_REMSPEC 0x00000100L
|
||
|
# define NWEO_REMANY 0x01000000L
|
||
|
#define NWEO_TYPE_MASK 0x0200L
|
||
|
# define NWEO_TYPESPEC 0x00000200L
|
||
|
# define NWEO_TYPEANY 0x02000000L
|
||
|
#define NWEO_RW_MASK 0x1000L
|
||
|
# define NWEO_RWDATONLY 0x00001000L
|
||
|
# define NWEO_RWDATALL 0x10000000L
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The configuration is divided in a number of section (covered by the xx_MASK
|
||
|
macros).
|
||
|
Options can be set in the
|
||
|
.B nweo_flags
|
||
|
field.
|
||
|
The first section (\fBNWEO_ACC_MASK\fP) controls the access to a certain
|
||
|
Ethernet packet type.
|
||
|
If
|
||
|
.B NWEO_EXCL
|
||
|
is selected then this is the only channel that can send or
|
||
|
receive Ethernet packets of the selected type.
|
||
|
If
|
||
|
.B NWEO_SHARED
|
||
|
is selected then multiple channels (which all have to
|
||
|
select
|
||
|
.BR NWEO_SHARED )
|
||
|
can use the same Ethernet type, they all can send
|
||
|
packets but incoming packets will be delivered to at most one of them.
|
||
|
If
|
||
|
.B NWEO_COPY
|
||
|
is selected then multiple channels have access to the same
|
||
|
Ethernet type and all receive a copy of an incoming packet.
|
||
|
.LP
|
||
|
The
|
||
|
.B NWEO_LOC_MASK
|
||
|
flags control the delivery of packets with a destination
|
||
|
address equal to the Ethernet address of the machine.
|
||
|
If
|
||
|
.B NWEO_EN_LOC
|
||
|
is selected then these packets will be delivered and with
|
||
|
.B NWEO_DI_LOC
|
||
|
they will be discarded.
|
||
|
.PP
|
||
|
.BR NWEO_BROAD_MASK ,
|
||
|
.BR NWEO_MULTI_MASK ,
|
||
|
and
|
||
|
.B NWEO_PROMISC_MASK
|
||
|
do the same to broadcast packets,
|
||
|
multicast packets and promiscuous mode packets as
|
||
|
.B NWEO_LOC_MASK
|
||
|
does for local packets.
|
||
|
Except that the precise multicast address is taken from the \fBnweo_multi\fP
|
||
|
field.
|
||
|
.LP
|
||
|
The
|
||
|
.B NWEO_REM_MASK
|
||
|
flags control whether communication is restricted to
|
||
|
single destination or not.
|
||
|
.B NWEO_REMSPEC
|
||
|
restricts sending and receiving of packets to the single
|
||
|
remote computer specified in the \fBnweo_rem\fP field.
|
||
|
.B NWEO_REMANY
|
||
|
allows sending to and receiving from any remote computer.
|
||
|
.PP
|
||
|
.B NWEO_TYPESPEC
|
||
|
restricts sending and receiving of packets to the type
|
||
|
specified in \fBnweo_type\fP.
|
||
|
The type has to be in network byte order (using
|
||
|
.BR hton (3)).
|
||
|
.B NWEO_TYPEANY
|
||
|
allows any type.
|
||
|
.PP
|
||
|
If the Ethernet header is completely specified by the
|
||
|
.B nweo_flags
|
||
|
i.e., all of
|
||
|
.BR NWEO_EN_LOC ,
|
||
|
.BR NWEO_DI_BROAD ,
|
||
|
.BR NWEO_DI_MULTI ,
|
||
|
.BR NWEO_DI_PROMISC ,
|
||
|
.BR NWEO_REMSPEC
|
||
|
and
|
||
|
.B NWEO_TYPESPEC
|
||
|
are
|
||
|
specified, then
|
||
|
.B NWEO_RWDATONLY
|
||
|
can be used to send and receive only the data part of an Ethernet packet.
|
||
|
If
|
||
|
.B NWEO_RWDATALL
|
||
|
is specified then both Ethernet header and data are used.
|
||
|
.SS "PSIP Functions"
|
||
|
.PP
|
||
|
[[[No description available yet.]]]
|
||
|
.SS "IP Functions"
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOGIPCONF, &struct nwio_ipconf)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOGIPCONF
|
||
|
ioctl reports the Internet Address and the netmask.
|
||
|
For the \fInwio_ipconf\fP structure see the \fBNWIOSIPCONF\fP ioctl below.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOGIPOROUTE, &struct nwio_route)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOGIPOROUTE
|
||
|
ioctl can be used to query an IP server about its routing table.
|
||
|
[[[NWIODIPOROUTE, NWIOGIPIROUTE, NWIODIPIROUTE?]]]
|
||
|
The structure \fBnwio_route\fP is defined in <net/gen/route.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_route
|
||
|
{
|
||
|
u32_t nwr_ent_no;
|
||
|
u32_t nwr_ent_count;
|
||
|
ipaddr_t nwr_dest;
|
||
|
ipaddr_t nwr_netmask;
|
||
|
ipaddr_t nwr_gateway;
|
||
|
u32_t nwr_dist;
|
||
|
u32_t nwr_flags;
|
||
|
u32_t nwr_pref;
|
||
|
} nwio_route_t;
|
||
|
.SP
|
||
|
#define NWRF_EMPTY 0
|
||
|
#define NWRF_INUSE 1
|
||
|
#define NWRF_FIXED 2
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The requested entry is taken from \fBnwr_ent_no\fP.
|
||
|
Entries are counted from 0, so the value 0 can be used for an initial query.
|
||
|
The size of the routing table is returned in \fBnwr_ent_count\fP.
|
||
|
The \fBnwr_flags\fP indicates if the entry is in use (\fBNWRF_INUSE\fP) and
|
||
|
if the entry was inserted manually (using \fBNWIOSIPOROUTE\fP) or generated
|
||
|
by the IP server itself.
|
||
|
The route is described by
|
||
|
.BR nwr_dest ,
|
||
|
.BR nwr_netmask ,
|
||
|
.BR nwr_gateway ,
|
||
|
.BR nwr_dist ,
|
||
|
and
|
||
|
.BR nwr_pref .
|
||
|
\fBNwr_dest\fP and \fBnwr_netmask\fP select the destination addresses.
|
||
|
A value of 0.0.0.0 (0x0) in both \fBnwr_dest\fP and \fBnwr_netmask\fP means
|
||
|
every host.
|
||
|
A value of 255.255.255.255 (0xffffffff) in \fBnwr_netmask\fP means a single
|
||
|
host.
|
||
|
Other values of \fBnwr_netmask\fP are netmasks for the network specified
|
||
|
by \fBnwr_dest\fP.
|
||
|
\fBNwr_gateway\fP is gateway that should be used.
|
||
|
\fBNwr_dist\fP is a minimal distance.
|
||
|
Packets with a time to live smaller than \fBnwr_dist\fP will not reach the
|
||
|
destination.
|
||
|
If two routes have equal netmask and distance fields but different
|
||
|
gateways then the gateway with highest value in \fBnwr_pref\fP is used.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOSIPCONF, &struct nwio_ipconf)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOSIPCONF
|
||
|
ioctl can be used to inform the IP server about its Internet Address
|
||
|
and/or its netmask.
|
||
|
Normally an IP server will discover its Internet Address using the RARP
|
||
|
protocol.
|
||
|
.B NWIOSIPCONF
|
||
|
can be used in the case that the RARP failed, or the netmask has to be changed.
|
||
|
Note that higher level protocols (TCP and UDP) assume that the Internet Address
|
||
|
of an IP device does not change, therefore TCP and UDP stop functioning if
|
||
|
the Internet Address is changed.
|
||
|
.PP
|
||
|
The structure \fBnwio_ipconf\fP is defined in <net/gen/ip_io.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_ipconf
|
||
|
{
|
||
|
u32_t nwic_flags;
|
||
|
ipaddr_t nwic_ipaddr;
|
||
|
ipaddr_t nwic_netmask;
|
||
|
} nwio_ipconf_t;
|
||
|
.SP
|
||
|
#define NWIC_NOFLAGS 0x0
|
||
|
#define NWIC_FLAGS 0x3
|
||
|
# define NWIC_IPADDR_SET 0x1
|
||
|
# define NWIC_NETMASK_SET 0x2
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The function of \fBnwio_ipconf\fP depends on the value of \fBnwic_flags\fP.
|
||
|
If
|
||
|
.B NWIC_IPADDR_SET
|
||
|
is set then the Internet Address will be set to
|
||
|
\fBnwic_ipaddr\fP.
|
||
|
If
|
||
|
.B NWIC_NETMASK_SET
|
||
|
is set then the Internet Address will be set to
|
||
|
\fBnwic_netmask\fP.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOSIPOPT, &struct nwio_ipopt)
|
||
|
.ft R
|
||
|
.PP
|
||
|
Before an IP channel can be used, it has to be configured using the
|
||
|
.B NWIOSIPOPT
|
||
|
ioctl.
|
||
|
The structure \fBnwio_ipopt\fP is defined in <net/gen/ip_io.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_ipopt
|
||
|
{
|
||
|
u32_t nwio_flags;
|
||
|
ipaddr_t nwio_rem;
|
||
|
ip_hdropt_t nwio_hdropt;
|
||
|
u8_t nwio_tos;
|
||
|
u8_t nwio_ttl;
|
||
|
u8_t nwio_df;
|
||
|
ipproto_t nwio_proto;
|
||
|
} nwio_ipopt_t;
|
||
|
.SP
|
||
|
#define NWIO_NOFLAGS 0x0000L
|
||
|
#define NWIO_ACC_MASK 0x0003L
|
||
|
# define NWIO_EXCL 0x00000001L
|
||
|
# define NWIO_SHARED 0x00000002L
|
||
|
# define NWIO_COPY 0x00000003L
|
||
|
#define NWIO_LOC_MASK 0x0010L
|
||
|
# define NWIO_EN_LOC 0x00000010L
|
||
|
# define NWIO_DI_LOC 0x00100000L
|
||
|
#define NWIO_BROAD_MASK 0x0020L
|
||
|
# define NWIO_EN_BROAD 0x00000020L
|
||
|
# define NWIO_DI_BROAD 0x00200000L
|
||
|
#define NWIO_REM_MASK 0x0100L
|
||
|
# define NWIO_REMSPEC 0x00000100L
|
||
|
# define NWIO_REMANY 0x01000000L
|
||
|
#define NWIO_PROTO_MASK 0x0200L
|
||
|
# define NWIO_PROTOSPEC 0x00000200L
|
||
|
# define NWIO_PROTOANY 0x02000000L
|
||
|
#define NWIO_HDR_O_MASK 0x0400L
|
||
|
# define NWIO_HDR_O_SPEC 0x00000400L
|
||
|
# define NWIO_HDR_O_ANY 0x04000000L
|
||
|
#define NWIO_RW_MASK 0x1000L
|
||
|
# define NWIO_RWDATONLY 0x00001000L
|
||
|
# define NWIO_RWDATALL 0x10000000L
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The options are divided in several categories:
|
||
|
.BR NWIO_ACC_MASK ,
|
||
|
.BR NWIO_LOC_MASK ,
|
||
|
.BR NWIO_BROAD_MASK ,
|
||
|
.BR NWIO_REM_MASK ,
|
||
|
.BR NWIO_PROTO_MASK ,
|
||
|
.B NWIO_HDR_O_MASK
|
||
|
and
|
||
|
.BR NWIO_RW_MASK .
|
||
|
A channel is configured when one option of each category is set.
|
||
|
.PP
|
||
|
The options covered by
|
||
|
.B NWIO_ACC_MASK
|
||
|
control the number of channels that
|
||
|
can use one IP protocol.
|
||
|
If
|
||
|
.B NWIO_EXCL
|
||
|
is specified then only that channel can use a certain IP protocol.
|
||
|
If
|
||
|
.B NWIO_SHARED
|
||
|
then multiple channels that all have to specify
|
||
|
.B NWIO_SHARED
|
||
|
can use the same IP protocol, but incoming packets will
|
||
|
be delivered to a most one channel.
|
||
|
.B NWIO_COPY
|
||
|
does not impose any restrictions.
|
||
|
Every channel gets a copy of an incoming packet.
|
||
|
.PP
|
||
|
.B NWIO_LOC_MASK
|
||
|
and
|
||
|
.B NWIO_BROAD_MASK
|
||
|
control the delivery of packets.
|
||
|
If
|
||
|
.B NWIO_EN_LOC
|
||
|
is specified then packets that are explicitly send to
|
||
|
the IP server are delivered.
|
||
|
If
|
||
|
.B NWIO_EN_BROAD
|
||
|
is specified then broadcast packets are delivered.
|
||
|
Either one or both of them can be disabled with
|
||
|
.B NWIO_DI_LOC
|
||
|
and
|
||
|
.BR NWIO_DI_BROAD .
|
||
|
.PP
|
||
|
.B NWIO_REMSPEC
|
||
|
can be used to restrict communication to one remote host.
|
||
|
This host is taken from the \fBnwio_rem\fP field.
|
||
|
If any remote host is to be allowed then
|
||
|
.B NWIO_REMANY
|
||
|
can be used.
|
||
|
.PP
|
||
|
.B NWIO_PROTOSPEC
|
||
|
restricts communication to one IP protocol, specified
|
||
|
in \fBnwio_proto\fP.
|
||
|
.B NWIO_PROTOANY
|
||
|
allows any protocol to be sent or received.
|
||
|
.PP
|
||
|
.B NWIO_HDR_O_SPEC
|
||
|
specifies all IP header options in advance.
|
||
|
The values are taken from
|
||
|
.BR nwio_hdropt ,
|
||
|
.BR nwio_tos ,
|
||
|
.BR nwio_ttl ,
|
||
|
and
|
||
|
.BR nwio_df .
|
||
|
\fBNwio_hdropt\fP specifies the IP options that should be present in an
|
||
|
outgoing packet.
|
||
|
\fBIp_hdropt_t\fP is defined in <net/gen/in.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct ip_hdropt
|
||
|
{
|
||
|
u8_t iho_opt_siz;
|
||
|
u8_t iho_data[IP_MAX_HDR_SIZE-IP_MIN_HDR_SIZE];
|
||
|
} ip_hdropt_t;
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The bytes of size \fBiho_opt_siz\fP in \fBiho_data\fP are appended to the IP
|
||
|
header.
|
||
|
\fBNwio_tos\fP specifies the value of the ``type of service'' bits,
|
||
|
\fBnwio_ttl\fP gives the value of the ``time to live'' field and \fBnwio_df\fP
|
||
|
specifies whether fragmentation is disallowed or not.
|
||
|
.B NWIO_HDR_O_ANY
|
||
|
specifies that the header options should be specified at
|
||
|
each write request.
|
||
|
.PP
|
||
|
.B NWIO_RWDATONLY
|
||
|
specifies that the header should be omitted from a
|
||
|
write request.
|
||
|
This option can only be used when all header fields are specified in previous
|
||
|
options:
|
||
|
.BR NWIO_EN_LOC ,
|
||
|
.BR NWIO_DI_BROAD ,
|
||
|
.BR NWIO_REMSPEC ,
|
||
|
.B NWIO_PROTOSPEC
|
||
|
and
|
||
|
.BR NWIO_HDR_O_SPEC .
|
||
|
A read operation will also only return the data part, so the IP options will
|
||
|
be lost.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOSIPOROUTE, &struct nwio_route)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOSIPOROUTE
|
||
|
ioctl adds a route to the routing table.
|
||
|
See \fBNWIOGIPOROUTE\fP above for a description of the \fBnwio_route\fP
|
||
|
structure.
|
||
|
The fields \fBnwr_ent_no\fP and \fBnwr_ent_count\fP are ignored.
|
||
|
.SS "TCP Functions"
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOTCPCONN, &struct nwio_tcpcl)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOTCPCONN
|
||
|
ioctl tries to setup a connection with a remote TCP/IP server.
|
||
|
The channel must be fully configured (see
|
||
|
.BR NWIOSTCPCONF )
|
||
|
and values for the local port, the remote port and the remote address have be
|
||
|
specified using
|
||
|
.B NWTC_LP_SET
|
||
|
or
|
||
|
.BR NWTC_LP_SEL ,
|
||
|
.B NWTC_SET_RA
|
||
|
and
|
||
|
.BR NWTC_SET_RP .
|
||
|
The struct nwio_tcpcl is defined in <net/gen/tcp_io.h> as:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_tcpcl
|
||
|
{
|
||
|
long nwtcl_flags;
|
||
|
long nwtcl_ttl;
|
||
|
} nwio_tcpcl_t;
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
Set the
|
||
|
.B nwtcl_flags
|
||
|
field to zero before the connect or listen call. [[[Further explanation of
|
||
|
nwio_tcpcl?]]]
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOGTCPCONF, &struct nwio_tcpconf)
|
||
|
.ft R
|
||
|
.PP
|
||
|
This call reports the current configuration of a TCP channel.
|
||
|
The
|
||
|
.B nwtc_flags
|
||
|
field shows the status of the
|
||
|
.BR access ,
|
||
|
.BR locport ,
|
||
|
.B remaddr
|
||
|
and
|
||
|
.B remport
|
||
|
fields.
|
||
|
.B Nwtc_locaddr
|
||
|
contains the Internet address of the TCP/IP server.
|
||
|
.B Remaddr
|
||
|
contains the Internet address of the remote TCP/IP server when set with
|
||
|
.B NWTC_SET_RA
|
||
|
or after a successful connect or listen (see
|
||
|
.B NWIOTCPCONN
|
||
|
or
|
||
|
.BR NWIOTCPLISTEN ).
|
||
|
.B Nwio_locport
|
||
|
contains the local TCP/IP port set with
|
||
|
.B NWTC_LP_SET
|
||
|
or the selected port set with
|
||
|
.BR NWTC_LP_SEL .
|
||
|
.B Nwtc_remport
|
||
|
contains the TCP port of the remote TCP/IP server as set with
|
||
|
.B NWIO_SET_RP
|
||
|
or after a successful connect or listen.
|
||
|
.PP
|
||
|
A value of 0 (zero) is reported for
|
||
|
.BR nwtc_remaddr ,
|
||
|
.B nwtc_locport
|
||
|
or
|
||
|
.B nwtc_remport
|
||
|
when no value is set either explicitly or implicitly.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOTCPLISTEN, &struct nwio_tcpcl)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOTCPLISTEN
|
||
|
ioctl waits until a remote TCP/IP server tries to connect to this channel.
|
||
|
The channel has to be configured (see
|
||
|
.BR NWIOSTCPCONF ).
|
||
|
An additional restriction is that the local port
|
||
|
must be set (with
|
||
|
.BR NWTC_LP_SET )
|
||
|
or selected (with
|
||
|
.BR NWTC_LP_SEL ).
|
||
|
When a remote address is set only connections for that host are accepted, and
|
||
|
when a remote port is set only connections from that port are accepted.
|
||
|
After a successful listen
|
||
|
.B NWIOGTCPCONF
|
||
|
can be used to find out what the address and port of the other side are.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOSTCPCONF, &struct nwio_tcpconf)
|
||
|
.ft R
|
||
|
.PP
|
||
|
Before a TCP channel can be used it must configured using the
|
||
|
.B NWIOSTCPCONF
|
||
|
ioctl.
|
||
|
The parameters to
|
||
|
.B NWIOSTCPCONF
|
||
|
are the channel file descriptor and a
|
||
|
.B struct nwio_tcpconf
|
||
|
as defined in <net/gen/tcp_io.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_tcpconf
|
||
|
{
|
||
|
u32_t nwtc_flags;
|
||
|
ipaddr_t nwtc_locaddr;
|
||
|
ipaddr_t nwtc_remaddr;
|
||
|
tcpport_t nwtc_locport;
|
||
|
tcpport_t nwtc_remport;
|
||
|
} nwio_tcpconf_t;
|
||
|
.SP
|
||
|
#define NWTC_NOFLAGS 0x0000L
|
||
|
#define NWTC_ACC_MASK 0x0003L
|
||
|
# define NWTC_EXCL 0x00000001L
|
||
|
# define NWTC_SHARED 0x00000002L
|
||
|
# define NWTC_COPY 0x00000003L
|
||
|
#define NWTC_LOCPORT_MASK 0x0030L
|
||
|
# define NWTC_LP_UNSET 0x00000010L
|
||
|
# define NWTC_LP_SET 0x00000020L
|
||
|
# define NWTC_LP_SEL 0x00000030L
|
||
|
#define NWTC_REMADDR_MASK 0x0100L
|
||
|
# define NWTC_SET_RA 0x00000100L
|
||
|
# define NWTC_UNSET_RA 0x01000000L
|
||
|
#define NWTC_REMPORT_MASK 0x0200L
|
||
|
# define NWTC_SET_RP 0x00000200L
|
||
|
# define NWTC_UNSET_RP 0x02000000L
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
A tcp channel is considered configured when one flag in each category has
|
||
|
been selected.
|
||
|
Thus one of
|
||
|
.BR NWTC_EXCL ,
|
||
|
.B NWTC_SHARED
|
||
|
or
|
||
|
.BR NWTC_COPY ,
|
||
|
one of
|
||
|
.BR NWTC_LP_UNSET ,
|
||
|
.B NWTC_LP_SET
|
||
|
or
|
||
|
.BR NWTC_LP_SEL ,
|
||
|
one of
|
||
|
.B NWTC_SET_RA
|
||
|
or
|
||
|
.BR NWTC_UNSET_RA ,
|
||
|
and one of
|
||
|
.B NWTC_SET_RP
|
||
|
or
|
||
|
.BR NWTC_UNSET_RP .
|
||
|
.PP
|
||
|
The acc flags control the access to a certain TCP port.
|
||
|
.B NWTC_EXCL
|
||
|
means exclusive access.
|
||
|
An attempt to configure a channel will be denied if the same port is specified
|
||
|
as that of a channel that requested exclusive access.
|
||
|
.B NWTC_SHARED
|
||
|
indicates that several channels use the same port but cooperate.
|
||
|
If the shared mode is specified for one channel than all other channel that
|
||
|
use the same port should also be configured with the
|
||
|
.B NWTC_SHARED
|
||
|
flag.
|
||
|
.B NWTC_COPY
|
||
|
is specified when the programmer does not care about other channels.
|
||
|
This is the default.
|
||
|
.PP
|
||
|
The locport flags control which TCP port is used for communication.
|
||
|
.B NWTC_LP_UNSET
|
||
|
indicates the absence of a local port.
|
||
|
This is the default.
|
||
|
.B NWTC_LP_SET
|
||
|
means that the
|
||
|
.B nwtc_locport
|
||
|
field contains the local port to be used by TCP.
|
||
|
This value must be in network byte order (see
|
||
|
.BR hton (3).)
|
||
|
.B NWTC_LP_SEL
|
||
|
requests the TCP server to pick a port.
|
||
|
This port will be in the range from 32768 to 65535 and will be unique.
|
||
|
.LP
|
||
|
The
|
||
|
.B remaddr
|
||
|
flags specify which hosts are acceptable for connections.
|
||
|
.B NWTC_SET_RA
|
||
|
indicates that only connection to the host specified in
|
||
|
.B nwtc_remaddr
|
||
|
are acceptable.
|
||
|
.B Nwtc_remaddr
|
||
|
should be in network byte order (see
|
||
|
.BR hton (3).)
|
||
|
.B NWTC_UNSET_RA
|
||
|
allows every host on the other side of a connection.
|
||
|
This is the default.
|
||
|
.PP
|
||
|
The
|
||
|
.B remport
|
||
|
flags specify which remote ports are acceptable for connections.
|
||
|
.B NWTC_SET_RP
|
||
|
indicates that only the port specified in
|
||
|
.B nwtc_remport
|
||
|
is acceptable.
|
||
|
.B NWTC_UNSET_RP
|
||
|
allows every port on the other side of a connection.
|
||
|
This is the default.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOTCPSHUTDOWN)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOTCPSHUTDOWN
|
||
|
tells the TCP/IP server that no more data will be sent over the channel
|
||
|
specified by
|
||
|
.IR fd .
|
||
|
This command can be issued when the channel is connected to a remote TCP/IP
|
||
|
server.
|
||
|
The TCP/IP server will tell the remote TCP/IP server and the client of the
|
||
|
remote TCP/IP server will receive an end-of-file indication.
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOGTCPOPT, &struct nwio_tcpopt)
|
||
|
.br
|
||
|
ioctl(\fIfd\fP, NWIOSTCPOPT, &struct nwio_tcpopt)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The behaviour of a TCP channel may be changed by setting a number of
|
||
|
options. The TCP options can be obtained with the
|
||
|
.B NWIOGTCPOPT
|
||
|
ioctl and set with the
|
||
|
.B NWIOSTCPOPT
|
||
|
ioctl. The options are passed in a
|
||
|
.B struct nwio_tcpopt
|
||
|
as defined in <net/gen/tcp_io.h>:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_tcpopt
|
||
|
{
|
||
|
u32_t nwto_flags;
|
||
|
} nwio_tcpopt_t;
|
||
|
.SP
|
||
|
#define NWTO_NOFLAG 0x0000L
|
||
|
#define NWTO_SND_URG_MASK 0x0001L
|
||
|
# define NWTO_SND_URG 0x00000001L
|
||
|
# define NWTO_SND_NOTURG 0x00010000L
|
||
|
#define NWTO_RCV_URG_MASK 0x0002L
|
||
|
# define NWTO_RCV_URG 0x00000002L
|
||
|
# define NWTO_RCV_NOTURG 0x00020000L
|
||
|
#define NWTO_BSD_URG_MASK 0x0004L
|
||
|
# define NWTO_BSD_URG 0x00000004L
|
||
|
#define NWTO_DEL_RST_MASK 0x0008L
|
||
|
# define NWTO_DEL_RST 0x00000008L
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The
|
||
|
.B NWTO_SND_URG
|
||
|
option causes bytes written to the channel to be send out as urgent data.
|
||
|
On receiving an
|
||
|
.B EURG
|
||
|
error the
|
||
|
.B NWTO_RCV_URG
|
||
|
option must be set to switch over to reading urgent data. When all urgent
|
||
|
data has been read an
|
||
|
.B ENOURG
|
||
|
error will follow,
|
||
|
indicating that the option must be cleared with
|
||
|
.BR NWTO_RCV_NOTURG .
|
||
|
Alas the BSD implementation of urgent data disagrees with the RFC's, so to
|
||
|
be BSD compatible one must set the
|
||
|
.B NWTO_BSD_URG
|
||
|
option beforehand on a channel that is to send or receive urgent data.
|
||
|
Given that the BSD implementation is the regarded as the TCP/IP standard one
|
||
|
should always use the BSD style. The
|
||
|
.B NWTO_DEL_RST
|
||
|
option delays a failure response on a connect to the same port as the
|
||
|
current open connection. Without this option a connect would fail if
|
||
|
a server is not yet listening. With this option a connect will linger
|
||
|
on until the server starts listening. This option is useful for a server
|
||
|
that opens a connection, tells the remote end the local port number and
|
||
|
then listens (FTP), or for a program that forks off servers for incoming
|
||
|
connections (TELNET). A new connection may come in before a new listen
|
||
|
can be started, so it is nice if the new connect doesn't fail. Use this
|
||
|
option only when it is clearly needed.
|
||
|
.SS "UDP Functions"
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOGUDPOPT, &struct nwio_udpopt)
|
||
|
.ft R
|
||
|
.PP
|
||
|
The
|
||
|
.B NWIOGUDPOPT
|
||
|
ioctl returns the current options that result from the default options
|
||
|
and the options set with
|
||
|
.BR NWIOSUDPOPT .
|
||
|
When
|
||
|
.B NWUO_LP_SEL
|
||
|
or
|
||
|
.B NWUO_LP_SET
|
||
|
is selected the local port is returned in
|
||
|
.BR nwuo_locport .
|
||
|
When
|
||
|
.B NWUO_RP_SET
|
||
|
is selected the remote port is returned in
|
||
|
.BR nwuo_remport .
|
||
|
The local address is always returned in
|
||
|
.BR nwuo_locaddr ,
|
||
|
and when
|
||
|
.B NWUO_RA_SET
|
||
|
is selected the remote address is returned in
|
||
|
.BR nwuo_remaddr .
|
||
|
.PP
|
||
|
.ft B
|
||
|
ioctl(\fIfd\fP, NWIOSUDPOPT, &struct nwio_udpopt)
|
||
|
.ft R
|
||
|
.PP
|
||
|
A UDP channel must be configured using the
|
||
|
.B NWIOSUDPOPT
|
||
|
ioctl before any data can be read or written.
|
||
|
.B NWIOSUDPOPT
|
||
|
takes two parameters, a file descriptor to an open UDP device and
|
||
|
pointer to a
|
||
|
.B nwio_udpopt
|
||
|
structure that describes the requested configuration.
|
||
|
The
|
||
|
.B nwio_udpopt
|
||
|
structure is defined in <net/gen/udp_io.h> as:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct nwio_udpopt
|
||
|
{
|
||
|
unsigned long nwuo_flags;
|
||
|
udpport_t nwuo_locport;
|
||
|
udpport_t nwuo_remport;
|
||
|
ipaddr_t nwuo_locaddr;
|
||
|
ipaddr_t nwuo_remaddr;
|
||
|
} nwio_udpopt_t;
|
||
|
.SP
|
||
|
#define NWUO_NOFLAGS 0x0000L
|
||
|
#define NWUO_ACC_MASK 0x0003L
|
||
|
#define NWUO_EXCL 0x00000001L
|
||
|
#define NWUO_SHARED 0x00000002L
|
||
|
#define NWUO_COPY 0x00000003L
|
||
|
#define NWUO_LOCPORT_MASK 0x000CL
|
||
|
#define NWUO_LP_SEL 0x00000004L
|
||
|
#define NWUO_LP_SET 0x00000008L
|
||
|
#define NWUO_LP_ANY 0x0000000CL
|
||
|
#define NWUO_LOCADDR_MASK 0x0010L
|
||
|
#define NWUO_EN_LOC 0x00000010L
|
||
|
#define NWUO_DI_LOC 0x00100000L
|
||
|
#define NWUO_BROAD_MASK 0x0020L
|
||
|
#define NWUO_EN_BROAD 0x00000020L
|
||
|
#define NWUO_DI_BROAD 0x00200000L
|
||
|
#define NWUO_REMPORT_MASK 0x0100L
|
||
|
#define NWUO_RP_SET 0x00000100L
|
||
|
#define NWUO_RP_ANY 0x01000000L
|
||
|
#define NWUO_REMADDR_MASK 0x0200L
|
||
|
#define NWUO_RA_SET 0x00000200L
|
||
|
#define NWUO_RA_ANY 0x02000000L
|
||
|
#define NWUO_RW_MASK 0x1000L
|
||
|
#define NWUO_RWDATONLY 0x00001000L
|
||
|
#define NWUO_RWDATALL 0x10000000L
|
||
|
#define NWUO_IPOPT_MASK 0x2000L
|
||
|
#define NWUO_EN_IPOPT 0x00002000L
|
||
|
#define NWUO_DI_IPOPT 0x20000000L
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
A UDP channel is considered configured when one flag in each category has been
|
||
|
selected.
|
||
|
Thus one of
|
||
|
.BR NWUO_EXCL ,
|
||
|
.B NWUO_SHARED
|
||
|
or
|
||
|
.BR NWUO_COPY ,
|
||
|
one of
|
||
|
.BR NWUO_LP_SEL ,
|
||
|
.B NWUO_LP_SET
|
||
|
or
|
||
|
.BR NWUO_LP_ANY ,
|
||
|
one of
|
||
|
.B NWUO_EN_LOC
|
||
|
or
|
||
|
.BR NWUO_DI_LOC ,
|
||
|
one of
|
||
|
.BR NWUO_EN_BROAD ,
|
||
|
or
|
||
|
.BR NWUO_DI_BROAD ,
|
||
|
one of
|
||
|
.BR NWUO_RP_SET ,
|
||
|
or
|
||
|
.BR NWUO_RP_ANY ,
|
||
|
one of
|
||
|
.BR NWUO_RA_SET ,
|
||
|
or
|
||
|
.BR NWUO_RA_ANY ,
|
||
|
one of
|
||
|
.BR NWUO_RWDATONLY ,
|
||
|
or
|
||
|
.BR NWUO_RWDATALL ,
|
||
|
and one of
|
||
|
.BR NWUO_EN_IPOPT ,
|
||
|
or
|
||
|
.BR NWUO_DI_IPOPT .
|
||
|
The acc flags control the access to a certain UDP port.
|
||
|
.B NWUO_EXCL
|
||
|
means exclusive access:
|
||
|
no other channel can use this port.
|
||
|
.B NWUO_SHARED
|
||
|
means shared access:
|
||
|
only channels that specify shared access can use this port
|
||
|
and all packets that are received are handed to at most one channel.
|
||
|
.B NWUO_COPY
|
||
|
imposes no access restriction and all channels get a copy of every received
|
||
|
packet for that port.
|
||
|
.PP
|
||
|
The
|
||
|
.B locport
|
||
|
flags control the selection of the UDP port for this channel.
|
||
|
.B NWUO_LP_SEL
|
||
|
requests the server to pick a port.
|
||
|
This port will be in the range from 32768 to 65535 and it will be unique.
|
||
|
.B NWUO_LP_SET
|
||
|
sets the local port to the value of the
|
||
|
.B nwuo_locport
|
||
|
field.
|
||
|
.B NWUO_LP_ANY
|
||
|
does not select a port.
|
||
|
Reception of data is therefore not possible but it is
|
||
|
possible to send data.
|
||
|
.PP
|
||
|
The
|
||
|
.B locaddr
|
||
|
flags control the reception of packets.
|
||
|
.B NWUO_EN_LOC
|
||
|
enables the reception of packets with the local IP address as destination.
|
||
|
.B NWUO_DI_LOC
|
||
|
disables the reception of packet for the local IP address.
|
||
|
.PP
|
||
|
The
|
||
|
.B broad
|
||
|
flags control the reception of broadcast packets.
|
||
|
.B NWUO_EN_BROAD
|
||
|
enables the reception of broadcast packets and
|
||
|
.B NWUO_DI_BROAD
|
||
|
disables the reception of broadcast packets.
|
||
|
.PP
|
||
|
The
|
||
|
.B remport
|
||
|
flags let the client to specify one specific remote UDP port or
|
||
|
to allow any remote port.
|
||
|
.B NWUO_RP_SET
|
||
|
sets the remote UDP port to the value of
|
||
|
.BR nwuo_remport .
|
||
|
Only packets with a matching remote port will be delivered
|
||
|
and all packets will be sent to that port.
|
||
|
.B NWUO_RP_ANY
|
||
|
allows reception of packets form any port and when transmitting packets the
|
||
|
remote port has to be specified.
|
||
|
.PP
|
||
|
The
|
||
|
.B remaddr
|
||
|
flags control the remote IP address.
|
||
|
.B NWUO_RA_SET
|
||
|
sets the remote IP address the value of
|
||
|
.BR nwuo_remaddr .
|
||
|
Only packets from that address will be delivered and all packets will be sent
|
||
|
to that address.
|
||
|
.B NWUO_RA_ANY
|
||
|
allows reception of packets from any host and when transmitting packets the
|
||
|
remote host has to be specified.
|
||
|
.PP
|
||
|
The
|
||
|
.B rw
|
||
|
flags control the format of the data to be sent or received.
|
||
|
With
|
||
|
.B NWUO_RWDATONLY
|
||
|
only the data part of a UDP packet is sent to the server and only the data
|
||
|
part is received from the server.
|
||
|
The
|
||
|
.B NWUO_RWDATALL
|
||
|
mode presents the data part of a UDP packet with a header that contains
|
||
|
the source and destination IP address, source and destination UDP ports,
|
||
|
the IP options, etc.
|
||
|
The server expects such a header in front of the data to be transmitted.
|
||
|
.ig \" Some for Philip to explain properly:
|
||
|
The header is defined in <net/gen/udp_hdr.h> and looks like this:
|
||
|
.PP
|
||
|
.RS
|
||
|
.nf
|
||
|
.if t .ft C
|
||
|
typedef struct udp_io_hdr
|
||
|
{
|
||
|
ipaddr_t uih_src_addr;
|
||
|
ipaddr_t uih_dst_addr;
|
||
|
udpport_t uih_src_port;
|
||
|
udpport_t uih_dst_port;
|
||
|
u16_t uih_ip_opt_len;
|
||
|
u16_t uih_data_len;
|
||
|
} udp_io_hdr_t;
|
||
|
.if t .ft R
|
||
|
.fi
|
||
|
.RE
|
||
|
.PP
|
||
|
The first four fields are the source and destination IP addresses and
|
||
|
ports.
|
||
|
.B Uih_ip_opt_len
|
||
|
is ???.
|
||
|
.B Uih_data_len
|
||
|
should equal the length of the packet data (packet lenght minus the
|
||
|
header.) ???
|
||
|
..
|
||
|
.PP
|
||
|
The
|
||
|
.B ipopt
|
||
|
flags control the delivery and transmission of IP options.
|
||
|
When
|
||
|
.B NWUO_EN_IPOPT
|
||
|
is set IP, options will be delivered and sent.
|
||
|
When
|
||
|
.B NWUO_DI_IPOPT
|
||
|
is set IP option will be stripped from received packets and no IP options will
|
||
|
be sent.
|
||
|
.ig \" MINIX 3 doesn't have this stuff (yet? ever?)
|
||
|
.SS "UDP Library Functions"
|
||
|
.PP
|
||
|
The following routines provide an somewhat easier to use interface to UDP than
|
||
|
the routines described above (\fBtcpip_open\fP, \fBudp_ioc_setopt\fP,
|
||
|
\fBtcpip_read\fP and \fBtcpip_write\fP).
|
||
|
.LP
|
||
|
.sC
|
||
|
errstat
|
||
|
udp_connect(udp_cap, chan_cap, srcport, dstport, dstaddr, flags)
|
||
|
capability *udp_cap;
|
||
|
capability *chan_cap;
|
||
|
udpport_t srcport;
|
||
|
udpport_t dstport;
|
||
|
ipaddr_t dstaddr;
|
||
|
int flags;
|
||
|
.eC
|
||
|
.kW "\fIudp_connect\fP"
|
||
|
\fIUdp_connect\fP combines the functionality of \fItcpip_open\fP and
|
||
|
\fIudp_ioc_setopt\fP.
|
||
|
A pointer to a UDP server capability should be passed in \fIudp_cap\fP, and
|
||
|
the channel capability will be returned in the capability pointed to by
|
||
|
\fIchan_cap\fP.
|
||
|
If \fIsrcport\fP is 0 then an unused port will be selected, otherwise the local
|
||
|
port will be set to \fIsrcport\fP.
|
||
|
If \fIdstport\fP is non-zero then communication will be restricted to remote ports
|
||
|
that equal to \fIdstport\fP, otherwise any data can be sent to or received from
|
||
|
any remote port.
|
||
|
The same thing applies to \fIdstaddr\fP; if \fIdstaddr\fP is non-zero then
|
||
|
only \fIdstaddr\fP can be reached.
|
||
|
Currently no flags are defined so \fIflags\fP should be 0.
|
||
|
.sH
|
||
|
udp_reconnect
|
||
|
.LP
|
||
|
.sC
|
||
|
errstat
|
||
|
udp_reconnect(chan_cap, srcport, dstport, dstaddr, flags)
|
||
|
capability *chan_cap;
|
||
|
udpport_t srcport;
|
||
|
udpport_t dstport;
|
||
|
ipaddr_t dstaddr;
|
||
|
int flags;
|
||
|
.eC
|
||
|
.kW "\fIudp_reconnect\fP"
|
||
|
\fIUdp_reconnect\fP is the same as \fIudp_connect\fP except that an existing
|
||
|
channel capability is (re)used.
|
||
|
.sH
|
||
|
udp_read_msg
|
||
|
.LP
|
||
|
.sC
|
||
|
errstat
|
||
|
udp_read_msg(chan_cap, msg, msglen, actlen, flags)
|
||
|
capability *chan_cap;
|
||
|
char *msg;
|
||
|
int msglen;
|
||
|
int *actlen;
|
||
|
int flags;
|
||
|
.eC
|
||
|
.kW "\fIudp_read_msg\fP"
|
||
|
\fIUdp_read_msg\fP delivers a UDP packet.
|
||
|
The data part of the UDP packet is
|
||
|
prepended with an \fIudp_io_hdr\fP.
|
||
|
The actual length of the possibly truncated packet is returned in \fIactlen\fP.
|
||
|
No flags are defined so \fIflags\fP should be 0.
|
||
|
.sH
|
||
|
udp_write_msg
|
||
|
.LP
|
||
|
.sC
|
||
|
errstat
|
||
|
udp_write_msg(chan_cap, msg, msglen, flags)
|
||
|
capability *chan_cap;
|
||
|
char *msg;
|
||
|
int msglen;
|
||
|
int flags;
|
||
|
.eC
|
||
|
.kW "\fIudp_write_msg\fP"
|
||
|
A UDP packet can be sent with \fIudp_write_msg\fP.
|
||
|
\fIMsg\fP should point to a \fIudp_io_hdr\fP followed by the data part of the
|
||
|
UDP packet.
|
||
|
The \fIuih_dst_addr\fP and \fIuih_dst_port\fP fields of the \fIudp_io_hdr\fP
|
||
|
should be filled in if no values are specified in the \fIudp_connect\fP,
|
||
|
or \fIudp_reconnect\fP.
|
||
|
.sH
|
||
|
udp_close
|
||
|
.LP
|
||
|
.sC
|
||
|
errstat
|
||
|
udp_close(chan_cap, flags)
|
||
|
capability *chan_cap;
|
||
|
int flags;
|
||
|
.eC
|
||
|
.kW "\fIudp_close\fP"
|
||
|
\fIUdp_close\fP cleans up the administration kept by the UDP library but does
|
||
|
not destroy the capability.
|
||
|
The function should be used if the capability is passed to another process
|
||
|
and should continue to exist.
|
||
|
No flags are defined so \fIflags\fP should be 0.
|
||
|
.sH
|
||
|
udp_destroy
|
||
|
.LP
|
||
|
.sC
|
||
|
errstat
|
||
|
udp_destroy(chan_cap, flags)
|
||
|
capability *chan_cap;
|
||
|
int flags;
|
||
|
.eC
|
||
|
.kW "\fIudp_destroy\fP"
|
||
|
\fIUdp_destroy\fP not only cleans up the administration kept by the UDP library
|
||
|
but also destroys the channel capability.
|
||
|
..
|
||
|
.SH FILES
|
||
|
.IP /dev/eth* \w'/dev/psip*mmm'u
|
||
|
Raw ethernet. The numbers in the device names are decimal, so one may see
|
||
|
names from
|
||
|
.B eth0
|
||
|
to
|
||
|
.BR eth15 .
|
||
|
|
||
|
.IP /dev/psip*
|
||
|
First and second Pseudo IP network.
|
||
|
.IP /dev/ip*
|
||
|
IP devices for two ethernets and two Pseudo IP networks.
|
||
|
.IP /dev/tcp*
|
||
|
TCP devices for same four networks.
|
||
|
.IP /dev/udp*
|
||
|
UDP devices.
|
||
|
.IP "/dev/eth, /dev/psip, /dev/ip, /dev/tcp, /dev/udp"
|
||
|
Devices for the default network, links to the devices above.
|
||
|
.B Eth
|
||
|
is only present if ethernet is the default,
|
||
|
.B psip
|
||
|
only for pseudo IP.
|
||
|
.SH "SEE ALSO"
|
||
|
.BR hton (3),
|
||
|
.BR oneC_sum (3),
|
||
|
.BR inet (8),
|
||
|
.BR boot (8).
|
||
|
.SH DIAGNOSTICS
|
||
|
Several errors may be returned by the TCP/IP server. The error code
|
||
|
is found in the
|
||
|
.B errno
|
||
|
variable if the
|
||
|
.BR read ,
|
||
|
.BR write ,
|
||
|
or
|
||
|
.B ioctl
|
||
|
call returns -1. The TCP/IP error codes defined in <errno.h> are, among others:
|
||
|
.IP EPACKSIZE 5c
|
||
|
This indicates an attempt to read or write with a buffer that is too
|
||
|
large or too small.
|
||
|
.IP ENOBUFS
|
||
|
The TCP/IP server has insufficient memory to execute the request.
|
||
|
.IP ENOTTY
|
||
|
This indicates an attempt to execute a command the particular server
|
||
|
does not understand.
|
||
|
For example, a
|
||
|
.B NWIOGTCPCONF
|
||
|
on an ETH channel.
|
||
|
.IP EBADMODE
|
||
|
The request is refused because the channel is not fully configured, in the
|
||
|
wrong state or the parameters are invalid.
|
||
|
.IP ENETUNREACH
|
||
|
The destination network is not reachable.
|
||
|
.IP EHOSTUNREACH
|
||
|
The destination host is not reachable.
|
||
|
.IP EISCONN
|
||
|
The channel is already connected so a second request is refused.
|
||
|
.IP EADDRINUSE
|
||
|
This address is in use.
|
||
|
.IP ECONNREFUSED
|
||
|
The connection is refused by the other side.
|
||
|
.IP ECONNRESET
|
||
|
The connection is reset (non-gracefully terminated) by the other side.
|
||
|
.IP ETIMEDOUT
|
||
|
The connection is terminated due to an expired timer.
|
||
|
.IP EURG
|
||
|
Urgent data is present and the current receive mode does not allow urgent data
|
||
|
to be transferred.
|
||
|
.IP ENOURG
|
||
|
No urgent data is present and a request came for urgent data.
|
||
|
.IP ENOTCONN
|
||
|
The request requires a connected channel and the channel is not connected.
|
||
|
.IP ESHUTDOWN
|
||
|
The connection is shut down.
|
||
|
That is, a
|
||
|
.B NWIOTCPSHUTDOWN
|
||
|
has been executed so no more data can be transmitted.
|
||
|
.IP ENOCONN
|
||
|
The connection does not exist.
|
||
|
.IP EGENERIC
|
||
|
A generic error code for extremely weird cases.
|
||
|
.SH AUTHOR
|
||
|
Philip Homburg (philip@cs.vu.nl)
|
||
|
|
||
|
.\"
|
||
|
.\" $PchId: ip.4,v 1.4 2001/01/08 19:58:14 philip Exp $
|