summaryrefslogtreecommitdiff
path: root/share/doc/psd
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2010-07-01 20:04:11 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2010-07-01 20:04:11 +0000
commit61135645c205feedcb7d51656c429a07b405ec8e (patch)
tree8a92aa56b9c2055b80bc23c4e549a21b989aed6c /share/doc/psd
parent7c9275d132808298c9c7fbfdd44770f4ff8a32ac (diff)
remove old documentation
Diffstat (limited to 'share/doc/psd')
-rw-r--r--share/doc/psd/05.sysman/0.t290
-rw-r--r--share/doc/psd/05.sysman/1.0.t54
-rw-r--r--share/doc/psd/05.sysman/1.1.t213
-rw-r--r--share/doc/psd/05.sysman/1.2.t270
-rw-r--r--share/doc/psd/05.sysman/1.3.t252
-rw-r--r--share/doc/psd/05.sysman/1.4.t135
-rw-r--r--share/doc/psd/05.sysman/1.5.t223
-rw-r--r--share/doc/psd/05.sysman/1.6.t133
-rw-r--r--share/doc/psd/05.sysman/1.7.t98
-rw-r--r--share/doc/psd/05.sysman/2.0.t81
-rw-r--r--share/doc/psd/05.sysman/2.1.t136
-rw-r--r--share/doc/psd/05.sysman/2.2.t468
-rw-r--r--share/doc/psd/05.sysman/2.3.t410
-rw-r--r--share/doc/psd/05.sysman/2.4.t172
-rw-r--r--share/doc/psd/05.sysman/2.5.t37
-rw-r--r--share/doc/psd/05.sysman/Makefile12
-rw-r--r--share/doc/psd/05.sysman/a.t233
-rw-r--r--share/doc/psd/05.sysman/spell.ok332
-rw-r--r--share/doc/psd/20.ipctut/Makefile17
-rw-r--r--share/doc/psd/20.ipctut/dgramread.c81
-rw-r--r--share/doc/psd/20.ipctut/dgramsend.c78
-rw-r--r--share/doc/psd/20.ipctut/fig2.pic79
-rw-r--r--share/doc/psd/20.ipctut/fig2.xfig100
-rw-r--r--share/doc/psd/20.ipctut/fig3.pic71
-rw-r--r--share/doc/psd/20.ipctut/fig3.xfig100
-rw-r--r--share/doc/psd/20.ipctut/fig8.pic81
-rw-r--r--share/doc/psd/20.ipctut/fig8.xfig116
-rw-r--r--share/doc/psd/20.ipctut/pipe.c72
-rw-r--r--share/doc/psd/20.ipctut/socketpair.c75
-rw-r--r--share/doc/psd/20.ipctut/strchkread.c104
-rw-r--r--share/doc/psd/20.ipctut/streamread.c100
-rw-r--r--share/doc/psd/20.ipctut/streamwrite.c79
-rw-r--r--share/doc/psd/20.ipctut/tutor.me937
-rw-r--r--share/doc/psd/20.ipctut/udgramread.c78
-rw-r--r--share/doc/psd/20.ipctut/udgramsend.c66
-rw-r--r--share/doc/psd/20.ipctut/ustreamread.c94
-rw-r--r--share/doc/psd/20.ipctut/ustreamwrite.c69
-rw-r--r--share/doc/psd/21.ipc/0.t91
-rw-r--r--share/doc/psd/21.ipc/1.t104
-rw-r--r--share/doc/psd/21.ipc/2.t712
-rw-r--r--share/doc/psd/21.ipc/3.t407
-rw-r--r--share/doc/psd/21.ipc/4.t512
-rw-r--r--share/doc/psd/21.ipc/5.t1665
-rw-r--r--share/doc/psd/21.ipc/Makefile14
-rw-r--r--share/doc/psd/21.ipc/spell.ok347
-rw-r--r--share/doc/psd/Makefile16
46 files changed, 3 insertions, 9811 deletions
diff --git a/share/doc/psd/05.sysman/0.t b/share/doc/psd/05.sysman/0.t
deleted file mode 100644
index 1b9c6faf9eb..00000000000
--- a/share/doc/psd/05.sysman/0.t
+++ /dev/null
@@ -1,290 +0,0 @@
-.\" $OpenBSD: 0.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)0.t 8.1 (Berkeley) 6/8/93
-.\"
-.if n .ND
-.TL
-Berkeley Software Architecture Manual
-.br
-4.4BSD Edition
-.AU
-William Joy, Robert Fabry,
-.AU
-Samuel Leffler, M. Kirk McKusick,
-.AU
-Michael Karels
-.AI
-Computer Systems Research Group
-Computer Science Division
-Department of Electrical Engineering and Computer Science
-University of California, Berkeley
-Berkeley, CA 94720
-.EH 'PSD:5-%''4.4BSD Architecture Manual'
-.OH '4.4BSD Architecture Manual''PSD:5-%'
-.AB
-.FS
-* UNIX is a trademark of Bell Laboratories.
-.FE
-This document summarizes the facilities
-provided by the 4.4BSD version of the UNIX\|* operating system.
-It does not attempt to act as a tutorial for use of the system
-nor does it attempt to explain or justify the design of the
-system facilities.
-It gives neither motivation nor implementation details,
-in favor of brevity.
-.PP
-The first section describes the basic kernel functions
-provided to a UNIX process: process naming and protection,
-memory management, software interrupts,
-object references (descriptors), time and statistics functions,
-and resource controls.
-These facilities, as well as facilities for
-bootstrap, shutdown and process accounting,
-are provided solely by the kernel.
-.PP
-The second section describes the standard system
-abstractions for
-files and file systems,
-communication,
-terminal handling,
-and process control and debugging.
-These facilities are implemented by the operating system or by
-network server processes.
-.AE
-.LP
-.bp
-.ft B
-.br
-.sv 2
-.ce
-TABLE OF CONTENTS
-.ft R
-.LP
-.sp 1
-.nf
-.B "Introduction."
-.LP
-.if t .sp .5v
-.nf
-.B "0. Notation and types"
-.LP
-.if t .sp .5v
-.nf
-.B "1. Kernel primitives"
-.LP
-.if t .sp .5v
-.nf
-.nf
-\fB1.1. Processes and protection\fP
-1.1.1. Host and process identifiers
-1.1.2. Process creation and termination
-1.1.3. User and group ids
-1.1.4. Process groups
-.LP
-.nf
-\fB1.2. Memory management\fP
-1.2.1. Text, data and stack
-1.2.2. Mapping pages
-1.2.3. Page protection control
-1.2.4. Giving and getting advice
-1.2.5. Protection primitives
-.LP
-.if t .sp .5v
-.nf
-\fB1.3. Signals\fP
-1.3.1. Overview
-1.3.2. Signal types
-1.3.3. Signal handlers
-1.3.4. Sending signals
-1.3.5. Protecting critical sections
-1.3.6. Signal stacks
-.LP
-.if t .sp .5v
-.nf
-\fB1.4. Timing and statistics\fP
-1.4.1. Real time
-1.4.2. Interval time
-.LP
-.if t .sp .5v
-.nf
-\fB1.5. Descriptors\fP
-1.5.1. The reference table
-1.5.2. Descriptor properties
-1.5.3. Managing descriptor references
-1.5.4. Multiplexing requests
-1.5.5. Descriptor wrapping
-.LP
-.if t .sp .5v
-.nf
-\fB1.6. Resource controls\fP
-1.6.1. Process priorities
-1.6.2. Resource utilization
-1.6.3. Resource limits
-.LP
-.if t .sp .5v
-.nf
-\fB1.7. System operation support\fP
-1.7.1. Bootstrap operations
-1.7.2. Shutdown operations
-1.7.3. Accounting
-.bp
-.LP
-.if t .sp .5v
-.sp 1
-.nf
-\fB2. System facilities\fP
-.LP
-.if t .sp .5v
-.nf
-\fB2.1. Generic operations\fP
-2.1.1. Read and write
-2.1.2. Input/output control
-2.1.3. Non-blocking and asynchronous operations
-.LP
-.if t .sp .5v
-.nf
-\fB2.2. File system\fP
-2.2.1 Overview
-2.2.2. Naming
-2.2.3. Creation and removal
-2.2.3.1. Directory creation and removal
-2.2.3.2. File creation
-2.2.3.3. Creating references to devices
-2.2.3.4. Portal creation
-2.2.3.6. File, device, and portal removal
-2.2.4. Reading and modifying file attributes
-2.2.5. Links and renaming
-2.2.6. Extension and truncation
-2.2.7. Checking accessibility
-2.2.8. Locking
-2.2.9. Disc quotas
-.LP
-.if t .sp .5v
-.nf
-\fB2.3. Interprocess communication\fP
-2.3.1. Interprocess communication primitives
-2.3.1.1.\0 Communication domains
-2.3.1.2.\0 Socket types and protocols
-2.3.1.3.\0 Socket creation, naming and service establishment
-2.3.1.4.\0 Accepting connections
-2.3.1.5.\0 Making connections
-2.3.1.6.\0 Sending and receiving data
-2.3.1.7.\0 Scatter/gather and exchanging access rights
-2.3.1.8.\0 Using read and write with sockets
-2.3.1.9.\0 Shutting down halves of full-duplex connections
-2.3.1.10.\0 Socket and protocol options
-2.3.2. UNIX domain
-2.3.2.1. Types of sockets
-2.3.2.2. Naming
-2.3.2.3. Access rights transmission
-2.3.3. INTERNET domain
-2.3.3.1. Socket types and protocols
-2.3.3.2. Socket naming
-2.3.3.3. Access rights transmission
-2.3.3.4. Raw access
-.LP
-.if t .sp .5v
-.nf
-\fB2.4. Terminals and devices\fP
-2.4.1. Terminals
-2.4.1.1. Terminal input
-2.4.1.1.1 Input modes
-2.4.1.1.2 Interrupt characters
-2.4.1.1.3 Line editing
-2.4.1.2. Terminal output
-2.4.1.3. Terminal control operations
-2.4.1.4. Terminal hardware support
-2.4.2. Structured devices
-2.4.3. Unstructured devices
-.LP
-.if t .sp .5v
-.nf
-\fB2.5. Process control and debugging\fP
-.LP
-.if t .sp .5v
-.nf
-\fBI. Summary of facilities\fP
-.LP
-.de sh
-.ds RH \\$1
-.bp
-.NH \\*(ss
-\s+2\\$1\s0
-.PP
-.PP
-..
-.bp
-.ds ss 1
-.de _d
-.if t .ta .6i 2.1i 2.6i
-.\" 2.94 went to 2.6, 3.64 to 3.30
-.if n .ta .84i 2.6i 3.30i
-..
-.de _f
-.if t .ta .5i 1.25i 2.5i 3.5i
-.\" 3.5i went to 3.8i
-.if n .ta .7i 1.75i 3.8i 4.8i
-..
-.nr H1 -1
-.sh "Notation and types
-.PP
-The notation used to describe system calls is a variant of a
-C language call, consisting of a prototype call followed by
-declaration of parameters and results.
-An additional keyword \fBresult\fP, not part of the normal C language,
-is used to indicate which of the declared entities receive results.
-As an example, consider the \fIread\fP call, as described in
-section 2.1:
-.DS
-cc = read(fd, buf, nbytes);
-result int cc; int fd; result char *buf; int nbytes;
-.DE
-The first line shows how the \fIread\fP routine is called, with
-three parameters.
-As shown on the second line \fIcc\fP is an integer and \fIread\fP also
-returns information in the parameter \fIbuf\fP.
-.PP
-Description of all error conditions arising from each system call
-is not provided here; they appear in the programmer's manual.
-In particular, when accessed from the C language,
-many calls return a characteristic \-1 value
-when an error occurs, returning the error code in the global variable
-\fIerrno\fP.
-Other languages may present errors in different ways.
-.PP
-A number of system standard types are defined in the include file
-.I <sys/types.h>
-and used in the specifications here and in many C programs.
-These include \fBcaddr_t\fP giving a memory address (typically as
-a character pointer),
-\fBoff_t\fP giving a file offset (typically as a long integer),
-and a set of unsigned types \fBu_char\fP, \fBu_short\fP, \fBu_int\fP
-and \fBu_long\fP, shorthand names for \fBunsigned char\fP, \fBunsigned
-short\fP, etc.
diff --git a/share/doc/psd/05.sysman/1.0.t b/share/doc/psd/05.sysman/1.0.t
deleted file mode 100644
index dd3ff53a7c0..00000000000
--- a/share/doc/psd/05.sysman/1.0.t
+++ /dev/null
@@ -1,54 +0,0 @@
-.\" $OpenBSD: 1.0.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.0.t 8.1 (Berkeley) 6/8/93
-.\"
-.ds ss 1
-.sh "Kernel primitives
-.PP
-The facilities available to a UNIX user process are logically
-divided into two parts: kernel facilities directly implemented by
-UNIX code running in the operating system, and system facilities
-implemented either by the system, or in cooperation with a
-\fIserver process\fP. These kernel facilities are described in
-this section 1.
-.PP
-The facilities implemented in the kernel are those which define the
-\fIUNIX virtual machine\fP in which each process runs.
-Like many real machines, this virtual machine has memory management hardware,
-an interrupt facility, timers and counters. The UNIX
-virtual machine also allows access to files and other objects through a set of
-\fIdescriptors\fP. Each descriptor resembles a device controller,
-and supports a set of operations. Like devices on real machines, some
-of which are internal to the machine and some of which are external,
-parts of the descriptor machinery are built-in to the operating system, while
-other parts are often implemented in server processes on other machines.
-The facilities provided through the descriptor machinery are described in
-section 2.
-.ds ss 2
diff --git a/share/doc/psd/05.sysman/1.1.t b/share/doc/psd/05.sysman/1.1.t
deleted file mode 100644
index a00944b4612..00000000000
--- a/share/doc/psd/05.sysman/1.1.t
+++ /dev/null
@@ -1,213 +0,0 @@
-.\" $OpenBSD: 1.1.t,v 1.4 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.1.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Processes and protection
-.NH 3
-Host and process identifiers
-.PP
-Each UNIX host has associated with it a 32-bit host id, and a host
-name of up to 256 characters (as defined by MAXHOSTNAMELEN in
-\fI<sys/param.h>\fP).
-These are set (by a privileged user)
-and returned by the calls:
-.DS
-sethostid(hostid)
-long hostid;
-
-hostid = gethostid();
-result long hostid;
-
-sethostname(name, len)
-char *name; int len;
-
-len = gethostname(buf, buflen)
-result int len; result char *buf; int buflen;
-.DE
-On each host runs a set of \fIprocesses\fP.
-Each process is largely independent of other processes,
-having its own protection domain, address space, timers, and
-an independent set of references to system or user implemented objects.
-.PP
-Each process in a host is named by an integer
-called the \fIprocess id\fP. This number is
-in the range 1-30000
-and is returned by
-the \fIgetpid\fP routine:
-.DS
-pid = getpid();
-result int pid;
-.DE
-On each UNIX host this identifier is guaranteed to be unique;
-in a multi-host environment, the (hostid, process id) pairs are
-guaranteed unique.
-.NH 3
-Process creation and termination
-.PP
-A new process is created by making a logical duplicate of an
-existing process:
-.DS
-pid = fork();
-result int pid;
-.DE
-The \fIfork\fP call returns twice, once in the parent process, where
-\fIpid\fP is the process identifier of the child,
-and once in the child process where \fIpid\fP is 0.
-The parent-child relationship induces a hierarchical structure on
-the set of processes in the system.
-.PP
-A process may terminate by executing an \fIexit\fP call:
-.DS
-exit(status)
-int status;
-.DE
-returning 8 bits of exit status to its parent.
-.PP
-When a child process exits or
-terminates abnormally, the parent process receives
-information about any
-event which caused termination of the child process. A
-second call provides a non-blocking interface and may also be used
-to retrieve information about resources consumed by the process during its
-lifetime.
-.DS
-#include <sys/wait.h>
-
-pid = wait(astatus);
-result int pid; result union wait *astatus;
-
-pid = wait3(astatus, options, arusage);
-result int pid; result union waitstatus *astatus;
-int options; result struct rusage *arusage;
-.DE
-.PP
-A process can overlay itself with the memory image of another process,
-passing the newly created process a set of parameters, using the call:
-.DS
-execve(name, argv, envp)
-char *name, **argv, **envp;
-.DE
-The specified \fIname\fP must be a file which is in a format recognized
-by the system, either a binary executable file or a file which causes
-the execution of a specified interpreter program to process its contents.
-.NH 3
-User and group ids
-.PP
-Each process in the system has associated with it two user-id's:
-a \fIreal user id\fP and a \fIeffective user id\fP, both 16 bit
-unsigned integers (type \fBuid_t\fP).
-Each process has an \fIreal accounting group id\fP and an \fIeffective
-accounting group id\fP and a set of
-\fIaccess group id's\fP. The group id's are 16 bit unsigned integers
-(type \fBgid_t\fP).
-Each process may be in several different access groups, with the maximum
-concurrent number of access groups a system compilation parameter,
-the constant NGROUPS in the file \fI<sys/param.h>\fP,
-guaranteed to be at least 8.
-.PP
-The real and effective user ids associated with a process are returned by:
-.DS
-ruid = getuid();
-result uid_t ruid;
-
-euid = geteuid();
-result uid_t euid;
-.DE
-the real and effective accounting group ids by:
-.DS
-rgid = getgid();
-result gid_t rgid;
-
-egid = getegid();
-result gid_t egid;
-.DE
-The access group id set is returned by a \fIgetgroups\fP call*:
-.DS
-ngroups = getgroups(gidsetsize, gidset);
-result int ngroups; int gidsetsize; result int gidset[gidsetsize];
-.DE
-.FS
-* The type of the gidset array in getgroups and setgroups
-remains integer for compatibility with 4.2BSD.
-It may change to \fBgid_t\fP in future releases.
-.FE
-.PP
-The user and group id's
-are assigned at login time using the \fIsetreuid\fP, \fIsetregid\fP,
-and \fIsetgroups\fP calls:
-.DS
-setreuid(ruid, euid);
-int ruid, euid;
-
-setregid(rgid, egid);
-int rgid, egid;
-
-setgroups(gidsetsize, gidset)
-int gidsetsize; int gidset[gidsetsize];
-.DE
-The \fIsetreuid\fP call sets both the real and effective user-id's,
-while the \fIsetregid\fP call sets both the real
-and effective accounting group id's.
-Unless the caller is the super-user, \fIruid\fP
-must be equal to either the current real or effective user-id,
-and \fIrgid\fP equal to either the current real or effective
-accounting group id. The \fIsetgroups\fP call is restricted
-to the super-user.
-.NH 3
-Process groups
-.PP
-Each process in the system is also normally associated with a \fIprocess
-group\fP. The group of processes in a process group is sometimes
-referred to as a \fIjob\fP and manipulated by high-level system
-software (such as the shell).
-The current process group of a process is returned by the
-\fIgetpgrp\fP call:
-.DS
-pgrp = getpgrp(pid);
-result int pgrp; int pid;
-.DE
-When a process is in a specific process group it may receive
-software interrupts affecting the group, causing the group to
-suspend or resume execution or to be interrupted or terminated.
-In particular, a system terminal has a process group and only processes
-which are in the process group of the terminal may read from the
-terminal, allowing arbitration of terminals among several different jobs.
-.PP
-The process group associated with a process may be changed by
-the \fIsetpgrp\fP call:
-.DS
-setpgrp(pid, pgrp);
-int pid, pgrp;
-.DE
-Newly created processes are assigned process id's distinct from all
-processes and process groups, and the same process group as their
-parent. A normal (unprivileged) process may set its process group equal
-to its process id. A privileged process may set the process group of any
-process to any value.
diff --git a/share/doc/psd/05.sysman/1.2.t b/share/doc/psd/05.sysman/1.2.t
deleted file mode 100644
index 1a74d8c0b40..00000000000
--- a/share/doc/psd/05.sysman/1.2.t
+++ /dev/null
@@ -1,270 +0,0 @@
-.\" $OpenBSD: 1.2.t,v 1.4 2003/10/30 14:53:58 jmc Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.2.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Memory management\(dg
-.NH 3
-Text, data and stack
-.PP
-.FS
-\(dg This section represents the interface planned for later
-releases of the system. Of the calls described in this section,
-only \fIsbrk\fP and \fIgetpagesize\fP are included in 4.3BSD.
-.FE
-Each process begins execution with three logical areas of memory
-called text, data and stack.
-The text area is read-only and shared, while the data and stack
-areas are private to the process. Both the data and stack areas may
-be extended and contracted on program request. The call
-.DS
-addr = sbrk(incr);
-result caddr_t addr; int incr;
-.DE
-changes the size of the data area by \fIincr\fP bytes and
-returns the new end of the data area, while
-.DS
-addr = sstk(incr);
-result caddr_t addr; int incr;
-.DE
-changes the size of the stack area.
-The stack area is also automatically extended as needed.
-On the VAX the text and data areas are adjacent in the P0 region,
-while the stack section is in the P1 region, and grows downward.
-.NH 3
-Mapping pages
-.PP
-The system supports sharing of data between processes
-by allowing pages to be mapped into memory. These mapped
-pages may be \fIshared\fP with other processes or \fIprivate\fP
-to the process.
-Protection and sharing options are defined in \fI<sys/mman.h>\fP as:
-.DS
-.ta \w'#define\ \ 'u +\w'MAP_HASSEMAPHORE\ \ 'u +\w'0x0080\ \ 'u
-/* protections are chosen from these bits, or-ed together */
-#define PROT_READ 0x04 /* pages can be read */
-#define PROT_WRITE 0x02 /* pages can be written */
-#define PROT_EXEC 0x01 /* pages can be executed */
-.DE
-.DS
-.ta \w'#define\ \ 'u +\w'MAP_HASSEMAPHORE\ \ 'u +\w'0x0080\ \ 'u
-/* flags contain mapping type, sharing type and options */
-/* mapping type; choose one */
-#define MAP_FILE 0x0001 /* mapped from a file or device */
-#define MAP_ANON 0x0002 /* allocated from memory, swap space */
-#define MAP_TYPE 0x000f /* mask for type field */
-.DE
-.DS
-.ta \w'#define\ \ 'u +\w'MAP_HASSEMAPHORE\ \ 'u +\w'0x0080\ \ 'u
-/* sharing types; choose one */
-#define MAP_SHARED 0x0010 /* share changes */
-#define MAP_PRIVATE 0x0000 /* changes are private */
-.DE
-.DS
-.ta \w'#define\ \ 'u +\w'MAP_HASSEMAPHORE\ \ 'u +\w'0x0080\ \ 'u
-/* other flags */
-#define MAP_FIXED 0x0020 /* map addr must be exactly as requested */
-#define MAP_INHERIT 0x0040 /* region is retained after exec */
-#define MAP_HASSEMAPHORE 0x0080 /* region may contain semaphores */
-#define MAP_NOPREALLOC 0x0100 /* do not preallocate space */
-.DE
-The cpu-dependent size of a page is returned by the
-\fIgetpagesize\fP system call:
-.DS
-pagesize = getpagesize();
-result int pagesize;
-.DE
-.LP
-The call:
-.DS
-maddr = mmap(addr, len, prot, flags, fd, pos);
-result caddr_t maddr; caddr_t addr; int *len, prot, flags, fd; off_t pos;
-.DE
-causes the pages starting at \fIaddr\fP and continuing
-for at most \fIlen\fP bytes to be mapped from the object represented by
-descriptor \fIfd\fP, starting at byte offset \fIpos\fP.
-The starting address of the region is returned;
-for the convenience of the system,
-it may differ from that supplied
-unless the MAP_FIXED flag is given,
-in which case the exact address will be used or the call will fail.
-The actual amount mapped is returned in \fIlen\fP.
-The \fIaddr\fP, \fIlen\fP, and \fIpos\fP parameters
-must all be multiples of the pagesize.
-A successful \fImmap\fP will delete any previous mapping
-in the allocated address range.
-The parameter \fIprot\fP specifies the accessibility
-of the mapped pages.
-The parameter \fIflags\fP specifies
-the type of object to be mapped,
-mapping options, and
-whether modifications made to
-this mapped copy of the page
-are to be kept \fIprivate\fP, or are to be \fIshared\fP with
-other references.
-Possible types include MAP_FILE,
-mapping a regular file or character-special device memory,
-and MAP_ANON, which maps memory not associated with any specific file.
-The file descriptor used for creating MAP_ANON regions is used only
-for naming, and may be given as \-1 if no name
-is associated with the region.\(dd
-.FS
-\(dd The current design does not allow a process
-to specify the location of swap space.
-In the future we may define an additional mapping type, MAP_SWAP,
-in which the file descriptor argument specifies a file
-or device to which swapping should be done.
-.FE
-The MAP_INHERIT flag allows a region to be inherited after an \fIexec\fP.
-The MAP_HASSEMAPHORE flag allows special handling for
-regions that may contain semaphores.
-The MAP_NOPREALLOC flag allows processes to allocate regions whose
-virtual address space, if fully allocated,
-would exceed the available memory plus swap resources.
-Such regions may get a SIGSEGV signal if they page fault and resources
-are not available to service their request;
-typically they would free up some resources via \fIunmap\fP so that
-when they return from the signal the page
-fault could be successfully completed.
-.PP
-A facility is provided to synchronize a mapped region with the file
-it maps; the call
-.DS
-msync(addr, len);
-caddr_t addr; int len;
-.DE
-writes any modified pages back to the filesystem and updates
-the file modification time.
-If \fIlen\fP is 0, all modified pages within the region containing \fIaddr\fP
-will be flushed;
-if \fIlen\fP is non-zero, only the pages containing \fIaddr\fP and \fIlen\fP
-succeeding locations will be examined.
-Any required synchronization of memory caches
-will also take place at this time.
-Filesystem operations on a file that is mapped for shared modifications
-are unpredictable except after an \fImsync\fP.
-.PP
-A mapping can be removed by the call
-.DS
-munmap(addr, len);
-caddr_t addr; int len;
-.DE
-This call deletes the mappings for the specified address range,
-and causes further references to addresses within the range
-to generate invalid memory references.
-.NH 3
-Page protection control
-.PP
-A process can control the protection of pages using the call
-.DS
-mprotect(addr, len, prot);
-caddr_t addr; int len, prot;
-.DE
-This call changes the specified pages to have protection \fIprot\fP\|.
-Not all implementations will guarantee protection on a page basis;
-the granularity of protection changes may be as large as an entire region.
-.NH 3
-Giving and getting advice
-.PP
-A process that has knowledge of its memory behavior may
-use the \fImadvise\fP call:
-.DS
-madvise(addr, len, behav);
-caddr_t addr; int len, behav;
-.DE
-\fIBehav\fP describes expected behavior, as given
-in \fI<sys/mman.h>\fP:
-.DS
-.ta \w'#define\ \ 'u +\w'MADV_SEQUENTIAL\ \ 'u +\w'00\ \ \ \ 'u
-#define MADV_NORMAL 0 /* no further special treatment */
-#define MADV_RANDOM 1 /* expect random page references */
-#define MADV_SEQUENTIAL 2 /* expect sequential references */
-#define MADV_WILLNEED 3 /* will need these pages */
-#define MADV_DONTNEED 4 /* don't need these pages */
-#define MADV_SPACEAVAIL 5 /* insure that resources are reserved */
-.DE
-Finally, a process may obtain information about whether pages are
-core resident by using the call
-.DS
-mincore(addr, len, vec)
-caddr_t addr; int len; result char *vec;
-.DE
-Here the current core residency of the pages is returned
-in the character array \fIvec\fP, with a value of 1 meaning
-that the page is in-core.
-.NH 3
-Synchronization primitives
-.PP
-Primitives are provided for synchronization using semaphores in shared memory.
-Semaphores must lie within a MAP_SHARED region with at least modes
-PROT_READ and PROT_WRITE.
-The MAP_HASSEMAPHORE flag must have been specified when the region was created.
-To acquire a lock a process calls:
-.DS
-value = mset(sem, wait)
-result int value; semaphore *sem; int wait;
-.DE
-\fIMset\fP indivisibly tests and sets the semaphore \fIsem\fP.
-If the previous value is zero, the process has acquired the lock
-and \fImset\fP returns true immediately.
-Otherwise, if the \fIwait\fP flag is zero,
-failure is returned.
-If \fIwait\fP is true and the previous value is non-zero,
-\fImset\fP relinquishes the processor until notified that it should retry.
-.LP
-To release a lock a process calls:
-.DS
-mclear(sem)
-semaphore *sem;
-.DE
-\fIMclear\fP indivisibly tests and clears the semaphore \fIsem\fP.
-If the ``WANT'' flag is zero in the previous value,
-\fImclear\fP returns immediately.
-If the ``WANT'' flag is non-zero in the previous value,
-\fImclear\fP arranges for waiting processes to retry before returning.
-.PP
-Two routines provide services analogous to the kernel
-\fIsleep\fP and \fIwakeup\fP functions interpreted in the domain of
-shared memory.
-A process may relinquish the processor by calling \fImsleep\fP
-with a set semaphore:
-.DS
-msleep(sem)
-semaphore *sem;
-.DE
-If the semaphore is still set when it is checked by the kernel,
-the process will be put in a sleeping state
-until some other process issues an \fImwakeup\fP for the same semaphore
-within the region using the call:
-.DS
-mwakeup(sem)
-semaphore *sem;
-.DE
-An \fImwakeup\fP may awaken all sleepers on the semaphore,
-or may awaken only the next sleeper on a queue.
diff --git a/share/doc/psd/05.sysman/1.3.t b/share/doc/psd/05.sysman/1.3.t
deleted file mode 100644
index 30c70fff70d..00000000000
--- a/share/doc/psd/05.sysman/1.3.t
+++ /dev/null
@@ -1,252 +0,0 @@
-.\" $OpenBSD: 1.3.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.3.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Signals
-.PP
-.NH 3
-Overview
-.PP
-The system defines a set of \fIsignals\fP that may be delivered
-to a process. Signal delivery resembles the occurrence of a hardware
-interrupt: the signal is blocked from further occurrence,
-the current process context is saved, and a new one
-is built. A process may specify
-the \fIhandler\fP to which a signal is delivered, or specify that
-the signal is to be \fIblocked\fP or \fIignored\fP. A process may
-also specify that a
-\fIdefault\fP action is to be taken when signals occur.
-.PP
-Some signals
-will cause a process to exit when they are not caught. This
-may be accompanied by creation of a \fIcore\fP image file, containing
-the current memory image of the process for use in post-mortem debugging.
-A process may choose to have signals delivered on a special
-stack, so that sophisticated software stack manipulations are possible.
-.PP
-All signals have the same \fIpriority\fP. If multiple signals
-are pending simultaneously, the order in which they are delivered
-to a process is implementation specific. Signal routines execute
-with the signal that caused their invocation \fIblocked\fP, but other
-signals may yet occur. Mechanisms are provided whereby critical sections
-of code may protect themselves against the occurrence of specified signals.
-.NH 3
-Signal types
-.PP
-The signals defined by the system fall into one of
-five classes: hardware conditions,
-software conditions, input/output notification, process control, or
-resource control.
-The set of signals is defined in the file \fI<signal.h>\fP.
-.PP
-Hardware signals are derived from exceptional conditions which
-may occur during
-execution. Such signals include SIGFPE representing floating
-point and other arithmetic exceptions, SIGILL for illegal instruction
-execution, SIGSEGV for addresses outside the currently assigned
-area of memory, and SIGBUS for accesses that violate memory
-protection constraints.
-Other, more cpu-specific hardware signals exist,
-such as those for the various customer-reserved instructions on
-the VAX (SIGIOT, SIGEMT, and SIGTRAP).
-.PP
-Software signals reflect interrupts generated by user request:
-SIGINT for the normal interrupt signal; SIGQUIT for the more
-powerful \fIquit\fP signal, that normally causes a core image
-to be generated; SIGHUP and SIGTERM that cause graceful
-process termination, either because a user has ``hung up'', or
-by user or program request; and SIGKILL, a more powerful termination
-signal which a process cannot catch or ignore.
-Programs may define their own asynchronous events using SIGUSR1
-and SIGUSR2.
-Other software signals (SIGALRM, SIGVTALRM, SIGPROF)
-indicate the expiration of interval timers.
-.PP
-A process can request notification via a SIGIO signal
-when input or output is possible
-on a descriptor, or when a \fInon-blocking\fP operation completes.
-A process may request to receive a SIGURG signal when an
-urgent condition arises.
-.PP
-A process may be \fIstopped\fP by a signal sent to it or the members
-of its process group. The SIGSTOP signal is a powerful stop
-signal, because it cannot be caught. Other stop signals
-SIGTSTP, SIGTTIN, and SIGTTOU are used when a user request, input
-request, or output request respectively is the reason for stopping the process.
-A SIGCONT signal is sent to a process when it is
-continued from a stopped state.
-Processes may receive notification with a SIGCHLD signal when
-a child process changes state, either by stopping or by terminating.
-.PP
-Exceeding resource limits may cause signals to be generated.
-SIGXCPU occurs when a process nears its CPU time limit and SIGXFSZ
-warns that the limit on file size creation has been reached.
-.NH 3
-Signal handlers
-.PP
-A process has a handler associated with each signal.
-The handler controls the way the signal is delivered.
-The call
-.DS
-#include <signal.h>
-
-._f
-struct sigvec {
- int (*sv_handler)();
- int sv_mask;
- int sv_flags;
-};
-
-sigvec(signo, sv, osv)
-int signo; struct sigvec *sv; result struct sigvec *osv;
-.DE
-assigns interrupt handler address \fIsv_handler\fP to signal \fIsigno\fP.
-Each handler address
-specifies either an interrupt routine for the signal, that the
-signal is to be ignored,
-or that a default action (usually process termination) is to occur
-if the signal occurs.
-The constants
-SIG_IGN and SIG_DEF used as values for \fIsv_handler\fP
-cause ignoring or defaulting of a condition.
-The \fIsv_mask\fP value specifies the
-signal mask to be used when the handler is invoked; it implicitly includes
-the signal which invoked the handler.
-Signal masks include one bit for each signal;
-the mask for a signal \fIsigno\fP is provided by the macro
-\fIsigmask\fP(\fIsigno\fP), from \fI<signal.h>\fP.
-\fISv_flags\fP specifies whether system calls should be
-restarted if the signal handler returns and
-whether the handler should operate on the normal run-time
-stack or a special signal stack (see below). If \fIosv\fP
-is non-zero, the previous signal vector is returned.
-.PP
-When a signal condition arises for a process, the signal
-is added to a set of signals pending for the process.
-If the signal is not currently \fIblocked\fP by the process
-then it will be delivered. The process of signal delivery
-adds the signal to be delivered and those signals
-specified in the associated signal
-handler's \fIsv_mask\fP to a set of those \fImasked\fP
-for the process, saves the current process context,
-and places the process in the context of the signal
-handling routine. The call is arranged so that if the signal
-handling routine exits normally the signal mask will be restored
-and the process will resume execution in the original context.
-If the process wishes to resume in a different context, then
-it must arrange to restore the signal mask itself.
-.PP
-The mask of \fIblocked\fP signals is independent of handlers for
-signals. It delays signals from being delivered much as a
-raised hardware interrupt priority level delays hardware interrupts.
-Preventing an interrupt from occurring by changing the handler is analogous to
-disabling a device from further interrupts.
-.PP
-The signal handling routine \fIsv_handler\fP is called by a C call
-of the form
-.DS
-(*sv_handler)(signo, code, scp);
-int signo; long code; struct sigcontext *scp;
-.DE
-The \fIsigno\fP gives the number of the signal that occurred, and
-the \fIcode\fP, a word of information supplied by the hardware.
-The \fIscp\fP parameter is a pointer to a machine-dependent
-structure containing the information for restoring the
-context before the signal.
-.NH 3
-Sending signals
-.PP
-A process can send a signal to another process or group of processes
-with the calls:
-.DS
-kill(pid, signo)
-int pid, signo;
-
-killpgrp(pgrp, signo)
-int pgrp, signo;
-.DE
-Unless the process sending the signal is privileged,
-it must have the same effective user id as the process receiving the signal.
-.PP
-Signals are also sent implicitly from a terminal device to the
-process group associated with the terminal when certain input characters
-are typed.
-.NH 3
-Protecting critical sections
-.PP
-To block a section of code against one or more signals, a \fIsigblock\fP
-call may be used to add a set of signals to the existing mask, returning
-the old mask:
-.DS
-oldmask = sigblock(mask);
-result long oldmask; long mask;
-.DE
-The old mask can then be restored later with \fIsigsetmask\fP\|,
-.DS
-oldmask = sigsetmask(mask);
-result long oldmask; long mask;
-.DE
-The \fIsigblock\fP call can be used to read the current mask
-by specifying an empty \fImask\fP\|.
-.PP
-It is possible to check conditions with some signals blocked,
-and then to pause waiting for a signal and restoring the mask, by using:
-.DS
-sigpause(mask);
-long mask;
-.DE
-.NH 3
-Signal stacks
-.PP
-Applications that maintain complex or fixed size stacks can use
-the call
-.DS
-._f
-struct sigstack {
- caddr_t ss_sp;
- int ss_onstack;
-};
-
-sigstack(ss, oss)
-struct sigstack *ss; result struct sigstack *oss;
-.DE
-to provide the system with a stack based at \fIss_sp\fP for delivery
-of signals. The value \fIss_onstack\fP indicates whether the
-process is currently on the signal stack,
-a notion maintained in software by the system.
-.PP
-When a signal is to be delivered, the system checks whether
-the process is on a signal stack. If not, then the process is switched
-to the signal stack for delivery, with the return from the signal
-arranged to restore the previous stack.
-.PP
-If the process wishes to take a non-local exit from the signal routine,
-or run code from the signal stack that uses a different stack,
-a \fIsigstack\fP call should be used to reset the signal stack.
diff --git a/share/doc/psd/05.sysman/1.4.t b/share/doc/psd/05.sysman/1.4.t
deleted file mode 100644
index 97ca282c077..00000000000
--- a/share/doc/psd/05.sysman/1.4.t
+++ /dev/null
@@ -1,135 +0,0 @@
-.\" $OpenBSD: 1.4.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.4.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Timers
-.NH 3
-Real time
-.PP
-The system's notion of the current Greenwich time and the current time
-zone is set and returned by the call by the calls:
-.DS
-#include <sys/time.h>
-
-settimeofday(tvp, tzp);
-struct timeval *tp;
-struct timezone *tzp;
-
-gettimeofday(tp, tzp);
-result struct timeval *tp;
-result struct timezone *tzp;
-.DE
-where the structures are defined in \fI<sys/time.h>\fP as:
-.DS
-._f
-struct timeval {
- long tv_sec; /* seconds since Jan 1, 1970 */
- long tv_usec; /* and microseconds */
-};
-
-struct timezone {
- int tz_minuteswest; /* of Greenwich */
- int tz_dsttime; /* type of dst correction to apply */
-};
-.DE
-The precision of the system clock is hardware dependent.
-Earlier versions of UNIX contained only a 1-second resolution version
-of this call, which remains as a library routine:
-.DS
-time(tvsec)
-result long *tvsec;
-.DE
-returning only the tv_sec field from the \fIgettimeofday\fP call.
-.NH 3
-Interval time
-.PP
-The system provides each process with three interval timers,
-defined in \fI<sys/time.h>\fP:
-.DS
-._d
-#define ITIMER_REAL 0 /* real time intervals */
-#define ITIMER_VIRTUAL 1 /* virtual time intervals */
-#define ITIMER_PROF 2 /* user and system virtual time */
-.DE
-The ITIMER_REAL timer decrements
-in real time. It could be used by a library routine to
-maintain a wakeup service queue. A SIGALRM signal is delivered
-when this timer expires.
-.PP
-The ITIMER_VIRTUAL timer decrements in process virtual time.
-It runs only when the process is executing. A SIGVTALRM signal
-is delivered when it expires.
-.PP
-The ITIMER_PROF timer decrements both in process virtual time and when
-the system is running on behalf of the process.
-It is designed to be used by processes to statistically profile
-their execution.
-A SIGPROF signal is delivered when it expires.
-.PP
-A timer value is defined by the \fIitimerval\fP structure:
-.DS
-._f
-struct itimerval {
- struct timeval it_interval; /* timer interval */
- struct timeval it_value; /* current value */
-};
-.DE
-and a timer is set or read by the call:
-.DS
-getitimer(which, value);
-int which; result struct itimerval *value;
-
-setitimer(which, value, ovalue);
-int which; struct itimerval *value; result struct itimerval *ovalue;
-.DE
-The third argument to \fIsetitimer\fP specifies an optional structure
-to receive the previous contents of the interval timer.
-A timer can be disabled by specifying a timer value of 0.
-.PP
-The system rounds argument timer intervals to be not less than the
-resolution of its clock. This clock resolution can be determined
-by loading a very small value into a timer and reading the timer back to
-see what value resulted.
-.PP
-The \fIalarm\fP system call of earlier versions of UNIX is provided
-as a library routine using the ITIMER_REAL timer. The process
-profiling facilities of earlier versions of UNIX
-remain because
-it is not always possible to guarantee
-the automatic restart of system calls after
-receipt of a signal.
-The \fIprofil\fP call arranges for the kernel to begin gathering
-execution statistics for a process:
-.DS
-profil(buf, bufsize, offset, scale);
-result char *buf; int bufsize, offset, scale;
-.DE
-This begins sampling of the program counter, with statistics maintained
-in the user-provided buffer.
diff --git a/share/doc/psd/05.sysman/1.5.t b/share/doc/psd/05.sysman/1.5.t
deleted file mode 100644
index 9371b7d8fb9..00000000000
--- a/share/doc/psd/05.sysman/1.5.t
+++ /dev/null
@@ -1,223 +0,0 @@
-.\" $OpenBSD: 1.5.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.5.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh Descriptors
-.PP
-.NH 3
-The reference table
-.PP
-Each process has access to resources through
-\fIdescriptors\fP. Each descriptor is a handle allowing
-the process to reference objects such as files, devices
-and communications links.
-.PP
-Rather than allowing processes direct access to descriptors, the system
-introduces a level of indirection, so that descriptors may be shared
-between processes. Each process has a \fIdescriptor reference table\fP,
-containing pointers to the actual descriptors. The descriptors
-themselves thus have multiple references, and are reference counted by the
-system.
-.PP
-Each process has a fixed size descriptor reference table, where
-the size is returned by the \fIgetdtablesize\fP call:
-.DS
-nds = getdtablesize();
-result int nds;
-.DE
-and guaranteed to be at least 20. The entries in the descriptor reference
-table are referred to by small integers; for example if there
-are 20 slots they are numbered 0 to 19.
-.NH 3
-Descriptor properties
-.PP
-Each descriptor has a logical set of properties maintained
-by the system and defined by its \fItype\fP.
-Each type supports a set of operations;
-some operations, such as reading and writing, are common to several
-abstractions, while others are unique.
-The generic operations applying to many of these types are described
-in section 2.1. Naming contexts, files and directories are described in
-section 2.2. Section 2.3 describes communications domains and sockets.
-Terminals and (structured and unstructured) devices are described
-in section 2.4.
-.NH 3
-Managing descriptor references
-.PP
-A duplicate of a descriptor reference may be made by doing
-.DS
-new = dup(old);
-result int new; int old;
-.DE
-returning a copy of descriptor reference \fIold\fP indistinguishable from
-the original. The \fInew\fP chosen by the system will be the
-smallest unused descriptor reference slot.
-A copy of a descriptor reference may be made in a specific slot
-by doing
-.DS
-dup2(old, new);
-int old, new;
-.DE
-The \fIdup2\fP call causes the system to deallocate the descriptor reference
-current occupying slot \fInew\fP, if any, replacing it with a reference
-to the same descriptor as old.
-This deallocation is also performed by:
-.DS
-close(old);
-int old;
-.DE
-.NH 3
-Multiplexing requests
-.PP
-The system provides a
-standard way to do
-synchronous and asynchronous multiplexing of operations.
-.PP
-Synchronous multiplexing is performed by using the \fIselect\fP call
-to examine the state of multiple descriptors simultaneously,
-and to wait for state changes on those descriptors.
-Sets of descriptors of interest are specified as bit masks,
-as follows:
-.DS
-#include <sys/types.h>
-
-nds = select(nd, in, out, except, tvp);
-result int nds; int nd; result fd_set *in, *out, *except;
-struct timeval *tvp;
-
-FD_ZERO(&fdset);
-FD_SET(fd, &fdset);
-FD_CLR(fd, &fdset);
-FD_ISSET(fd, &fdset);
-int fs; fs_set fdset;
-.DE
-The \fIselect\fP call examines the descriptors
-specified by the
-sets \fIin\fP, \fIout\fP and \fIexcept\fP, replacing
-the specified bit masks by the subsets that select true for input,
-output, and exceptional conditions respectively (\fInd\fP
-indicates the number of file descriptors specified by the bit masks).
-If any descriptors meet the following criteria,
-then the number of such descriptors is returned in \fInds\fP and the
-bit masks are updated.
-.if n .ds bu *
-.if t .ds bu \(bu
-.IP \*(bu
-A descriptor selects for input if an input oriented operation
-such as \fIread\fP or \fIreceive\fP is possible, or if a
-connection request may be accepted (see section 2.3.1.4).
-.IP \*(bu
-A descriptor selects for output if an output oriented operation
-such as \fIwrite\fP or \fIsend\fP is possible, or if an operation
-that was ``in progress'', such as connection establishment,
-has completed (see section 2.1.3).
-.IP \*(bu
-A descriptor selects for an exceptional condition if a condition
-that would cause a SIGURG signal to be generated exists (see section 1.3.2),
-or other device-specific events have occurred.
-.LP
-If none of the specified conditions is true, the operation
-waits for one of the conditions to arise,
-blocking at most the amount of time specified by \fItvp\fP.
-If \fItvp\fP is given as 0, the \fIselect\fP waits indefinitely.
-.PP
-Options affecting I/O on a descriptor
-may be read and set by the call:
-.DS
-._d
-dopt = fcntl(d, cmd, arg)
-result int dopt; int d, cmd, arg;
-
-/* interesting values for cmd */
-#define F_SETFL 3 /* set descriptor options */
-#define F_GETFL 4 /* get descriptor options */
-#define F_SETOWN 5 /* set descriptor owner (pid/pgrp) */
-#define F_GETOWN 6 /* get descriptor owner (pid/pgrp) */
-.DE
-The F_SETFL \fIcmd\fP may be used to set a descriptor in
-non-blocking I/O mode and/or enable signaling when I/O is
-possible. F_SETOWN may be used to specify a process or process
-group to be signaled when using the latter mode of operation
-or when urgent indications arise.
-.PP
-Operations on non-blocking descriptors will
-either complete immediately,
-note an error EWOULDBLOCK,
-partially complete an input or output operation returning a partial count,
-or return an error EINPROGRESS noting that the requested operation is
-in progress.
-A descriptor which has signalling enabled will cause the specified process
-and/or process group
-be signaled, with a SIGIO for input, output, or in-progress
-operation complete, or
-a SIGURG for exceptional conditions.
-.PP
-For example, when writing to a terminal
-using non-blocking output,
-the system will accept only as much data as there is buffer space for
-and return; when making a connection on a \fIsocket\fP, the operation may
-return indicating that the connection establishment is ``in progress''.
-The \fIselect\fP facility can be used to determine when further
-output is possible on the terminal, or when the connection establishment
-attempt is complete.
-.NH 3
-Descriptor wrapping.\(dg
-.PP
-.FS
-\(dg The facilities described in this section are not included
-in 4.3BSD.
-.FE
-A user process may build descriptors of a specified type by
-\fIwrapping\fP a communications channel with a system supplied protocol
-translator:
-.DS
-new = wrap(old, proto)
-result int new; int old; struct dprop *proto;
-.DE
-Operations on the descriptor \fIold\fP are then translated by the
-system provided protocol translator into requests on the underlying
-object \fIold\fP in a way defined by the protocol.
-The protocols supported by the kernel may vary from system to system
-and are described in the programmers manual.
-.PP
-Protocols may be based on communications multiplexing or a rights-passing
-style of handling multiple requests made on the same object. For instance,
-a protocol for implementing a file abstraction may or may not include
-locally generated ``read-ahead'' requests. A protocol that provides for
-read-ahead may provide higher performance but have a more difficult
-implementation.
-.PP
-Another example is the terminal driving facilities. Normally a terminal
-is associated with a communications line, and the terminal type
-and standard terminal access protocol are wrapped around a synchronous
-communications line and given to the user. If a virtual terminal
-is required, the terminal driver can be wrapped around a communications
-link, the other end of which is held by a virtual terminal protocol
-interpreter.
diff --git a/share/doc/psd/05.sysman/1.6.t b/share/doc/psd/05.sysman/1.6.t
deleted file mode 100644
index ad5bc980d15..00000000000
--- a/share/doc/psd/05.sysman/1.6.t
+++ /dev/null
@@ -1,133 +0,0 @@
-.\" $OpenBSD: 1.6.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.6.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Resource controls
-.NH 3
-Process priorities
-.PP
-The system gives CPU scheduling priority to processes that have not used
-CPU time recently. This tends to favor interactive processes and
-processes that execute only for short periods.
-It is possible to determine the priority currently
-assigned to a process, process group, or the processes of a specified user,
-or to alter this priority using the calls:
-.DS
-._d
-#define PRIO_PROCESS 0 /* process */
-#define PRIO_PGRP 1 /* process group */
-#define PRIO_USER 2 /* user id */
-
-prio = getpriority(which, who);
-result int prio; int which, who;
-
-setpriority(which, who, prio);
-int which, who, prio;
-.DE
-The value \fIprio\fP is in the range \-20 to 20.
-The default priority is 0; lower priorities cause more
-favorable execution.
-The \fIgetpriority\fP call returns the highest priority (lowest numerical value)
-enjoyed by any of the specified processes.
-The \fIsetpriority\fP call sets the priorities of all of the
-specified processes to the specified value.
-Only the super-user may lower priorities.
-.NH 3
-Resource utilization
-.PP
-The resources used by a process are returned by a \fIgetrusage\fP call,
-returning information in a structure defined in \fI<sys/resource.h>\fP:
-.DS
-._d
-#define RUSAGE_SELF 0 /* usage by this process */
-#define RUSAGE_CHILDREN -1 /* usage by all children */
-
-getrusage(who, rusage)
-int who; result struct rusage *rusage;
-
-._f
-struct rusage {
- struct timeval ru_utime; /* user time used */
- struct timeval ru_stime; /* system time used */
- int ru_maxrss; /* maximum core resident set size: kbytes */
- int ru_ixrss; /* integral shared memory size (kbytes*sec) */
- int ru_idrss; /* unshared data memory size */
- int ru_isrss; /* unshared stack memory size */
- int ru_minflt; /* page-reclaims */
- int ru_majflt; /* page faults */
- int ru_nswap; /* swaps */
- int ru_inblock; /* block input operations */
- int ru_oublock; /* block output operations */
- int ru_msgsnd; /* messages sent */
- int ru_msgrcv; /* messages received */
- int ru_nsignals; /* signals received */
- int ru_nvcsw; /* voluntary context switches */
- int ru_nivcsw; /* involuntary context switches */
-};
-.DE
-The \fIwho\fP parameter specifies whose resource usage is to be returned.
-The resources used by the current process, or by all
-the terminated children of the current process may be requested.
-.NH 3
-Resource limits
-.PP
-The resources of a process for which limits are controlled by the
-kernel are defined in \fI<sys/resource.h>\fP, and controlled by the
-\fIgetrlimit\fP and \fIsetrlimit\fP calls:
-.DS
-._d
-#define RLIMIT_CPU 0 /* cpu time in milliseconds */
-#define RLIMIT_FSIZE 1 /* maximum file size */
-#define RLIMIT_DATA 2 /* maximum data segment size */
-#define RLIMIT_STACK 3 /* maximum stack segment size */
-#define RLIMIT_CORE 4 /* maximum core file size */
-#define RLIMIT_RSS 5 /* maximum resident set size */
-
-#define RLIM_NLIMITS 6
-
-#define RLIM_INFINITY 0x7f\&f\&f\&f\&f\&f\&f
-
-._f
-struct rlimit {
- int rlim_cur; /* current (soft) limit */
- int rlim_max; /* hard limit */
-};
-
-getrlimit(resource, rlp)
-int resource; result struct rlimit *rlp;
-
-setrlimit(resource, rlp)
-int resource; struct rlimit *rlp;
-.DE
-.PP
-Only the super-user can raise the maximum limits.
-Other users may only
-alter \fIrlim_cur\fP within the range from 0 to \fIrlim_max\fP
-or (irreversibly) lower \fIrlim_max\fP.
diff --git a/share/doc/psd/05.sysman/1.7.t b/share/doc/psd/05.sysman/1.7.t
deleted file mode 100644
index 2a37599ec52..00000000000
--- a/share/doc/psd/05.sysman/1.7.t
+++ /dev/null
@@ -1,98 +0,0 @@
-.\" $OpenBSD: 1.7.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.7.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "System operation support
-.PP
-Unless noted otherwise,
-the calls in this section are permitted only to a privileged user.
-.NH 3
-Bootstrap operations
-.PP
-The call
-.DS
-mount(blkdev, dir, ronly);
-char *blkdev, *dir; int ronly;
-.DE
-extends the UNIX name space. The \fImount\fP call specifies
-a block device \fIblkdev\fP containing a UNIX file system
-to be made available starting at \fIdir\fP. If \fIronly\fP is
-set then the file system is read-only; writes to the file system
-will not be permitted and access times will not be updated
-when files are referenced.
-\fIDir\fP is normally a name in the root directory.
-.PP
-The call
-.DS
-swapon(blkdev, size);
-char *blkdev; int size;
-.DE
-specifies a device to be made available for paging and swapping.
-.PP
-.NH 3
-Shutdown operations
-.PP
-The call
-.DS
-unmount(dir);
-char *dir;
-.DE
-unmounts the file system mounted on \fIdir\fP.
-This call will succeed only if the file system is
-not currently being used.
-.PP
-The call
-.DS
-sync();
-.DE
-schedules input/output to clean all system buffer caches.
-(This call does not require privileged status.)
-.PP
-The call
-.DS
-reboot(how)
-int how;
-.DE
-causes a machine halt or reboot. The call may request a reboot
-by specifying \fIhow\fP as RB_AUTOBOOT, or that the machine be halted
-with RB_HALT. These constants are defined in \fI<sys/reboot.h>\fP.
-.NH 3
-Accounting
-.PP
-The system optionally keeps an accounting record in a file
-for each process that exits on the system.
-The format of this record is beyond the scope of this document.
-The accounting may be enabled to a file \fIname\fP by doing
-.DS
-acct(path);
-char *path;
-.DE
-If \fIpath\fP is null, then accounting is disabled. Otherwise,
-the named file becomes the accounting file.
diff --git a/share/doc/psd/05.sysman/2.0.t b/share/doc/psd/05.sysman/2.0.t
deleted file mode 100644
index 1707608ede5..00000000000
--- a/share/doc/psd/05.sysman/2.0.t
+++ /dev/null
@@ -1,81 +0,0 @@
-.\" $OpenBSD: 2.0.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.0.t 8.1 (Berkeley) 6/8/93
-.\"
-.ds ss 1
-.sh "System facilities
-This section discusses the system facilities that
-are not considered part of the kernel.
-.PP
-The system abstractions described are:
-.IP "Directory contexts
-.br
-A directory context is a position in the UNIX file system name
-space. Operations on files and other named objects in a file system are
-always specified relative to such a context.
-.IP "Files
-.br
-Files are used to store uninterpreted sequence of bytes on which
-random access \fIreads\fP and \fIwrites\fP may occur.
-Pages from files may also be mapped into process address space.\(dg
-A directory may be read as a file.
-.FS
-\(dg Support for mapping files is not included in the 4.3 release.
-.FE
-.IP "Communications domains
-.br
-A communications domain represents
-an interprocess communications environment, such as the communications
-facilities of the UNIX system,
-communications in the INTERNET, or the resource sharing protocols
-and access rights of a resource sharing system on a local network.
-.IP "Sockets
-.br
-A socket is an endpoint of communication and the focal
-point for IPC in a communications domain. Sockets may be created in pairs,
-or given names and used to rendezvous with other sockets
-in a communications domain, accepting connections from these
-sockets or exchanging messages with them. These operations model
-a labeled or unlabeled communications graph, and can be used in a
-wide variety of communications domains. Sockets can have different
-\fItypes\fP\| to provide different semantics of communication,
-increasing the flexibility of the model.
-.IP "Terminals and other devices
-.br
-Devices include
-terminals, providing input editing and interrupt generation
-and output flow control and editing, magnetic tapes,
-disks and other peripherals. They often support the generic
-\fIread\fP and \fIwrite\fP operations as well as a number of \fIioctl\fP\|s.
-.IP "Processes
-.br
-Process descriptors provide facilities for control and debugging of
-other processes.
-.ds ss 2
diff --git a/share/doc/psd/05.sysman/2.1.t b/share/doc/psd/05.sysman/2.1.t
deleted file mode 100644
index 1b6342ce5e3..00000000000
--- a/share/doc/psd/05.sysman/2.1.t
+++ /dev/null
@@ -1,136 +0,0 @@
-.\" $OpenBSD: 2.1.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.1.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Generic operations
-.PP
-.PP
-Many system abstractions support the
-operations \fIread\fP, \fIwrite\fP and \fIioctl\fP. We describe
-the basics of these common primitives here.
-Similarly, the mechanisms whereby normally synchronous operations
-may occur in a non-blocking or asynchronous fashion are
-common to all system-defined abstractions and are described here.
-.NH 3
-Read and write
-.PP
-The \fIread\fP and \fIwrite\fP system calls can be applied
-to communications channels, files, terminals and devices.
-They have the form:
-.DS
-cc = read(fd, buf, nbytes);
-result int cc; int fd; result caddr_t buf; int nbytes;
-
-cc = write(fd, buf, nbytes);
-result int cc; int fd; caddr_t buf; int nbytes;
-.DE
-The \fIread\fP call transfers as much data as possible from the
-object defined by \fIfd\fP to the buffer at address \fIbuf\fP of
-size \fInbytes\fP. The number of bytes transferred is
-returned in \fIcc\fP, which is \-1 if a return occurred before
-any data was transferred because of an error or use of non-blocking
-operations.
-.PP
-The \fIwrite\fP call transfers data from the buffer to the
-object defined by \fIfd\fP. Depending on the type of \fIfd\fP,
-it is possible that the \fIwrite\fP call will accept some portion
-of the provided bytes; the user should resubmit the other bytes
-in a later request in this case.
-Error returns because of interrupted or otherwise incomplete operations
-are possible.
-.PP
-Scattering of data on input or gathering of data for output
-is also possible using an array of input/output vector descriptors.
-The type for the descriptors is defined in \fI<sys/uio.h>\fP as:
-.DS
-._f
-struct iovec {
- caddr_t iov_msg; /* base of a component */
- int iov_len; /* length of a component */
-};
-.DE
-The calls using an array of descriptors are:
-.DS
-cc = readv(fd, iov, iovlen);
-result int cc; int fd; struct iovec *iov; int iovlen;
-
-cc = writev(fd, iov, iovlen);
-result int cc; int fd; struct iovec *iov; int iovlen;
-.DE
-Here \fIiovlen\fP is the count of elements in the \fIiov\fP array.
-.NH 3
-Input/output control
-.PP
-Control operations on an object are performed by the \fIioctl\fP
-operation:
-.DS
-ioctl(fd, request, buffer);
-int fd, request; caddr_t buffer;
-.DE
-This operation causes the specified \fIrequest\fP to be performed
-on the object \fIfd\fP. The \fIrequest\fP parameter specifies
-whether the argument buffer is to be read, written, read and written,
-or is not needed, and also the size of the buffer, as well as the
-request.
-Different descriptor types and subtypes within descriptor types
-may use distinct \fIioctl\fP requests. For example,
-operations on terminals control flushing of input and output
-queues and setting of terminal parameters; operations on
-disks cause formatting operations to occur; operations on tapes
-control tape positioning.
-.PP
-The names for basic control operations are defined in \fI<sys/ioctl.h>\fP.
-.NH 3
-Non-blocking and asynchronous operations
-.PP
-A process that wishes to do non-blocking operations on one of
-its descriptors sets the descriptor in non-blocking mode as
-described in section 1.5.4. Thereafter the \fIread\fP call will
-return a specific EWOULDBLOCK error indication if there is no data to be
-\fIread\fP. The process may
-\fIselect\fP the associated descriptor to determine when a read is
-possible.
-.PP
-Output attempted when a descriptor can accept less than is requested
-will either accept some of the provided data, returning a shorter than normal
-length, or return an error indicating that the operation would block.
-More output can be performed as soon as a \fIselect\fP call indicates
-the object is writeable.
-.PP
-Operations other than data input or output
-may be performed on a descriptor in a non-blocking fashion.
-These operations will return with a characteristic error indicating
-that they are in progress
-if they cannot complete immediately. The descriptor
-may then be \fIselect\fPed for \fIwrite\fP to find out
-when the operation has been completed. When \fIselect\fP indicates
-the descriptor is writeable, the operation has completed.
-Depending on the nature of the descriptor and the operation,
-additional activity may be started or the new state may be tested.
diff --git a/share/doc/psd/05.sysman/2.2.t b/share/doc/psd/05.sysman/2.2.t
deleted file mode 100644
index 6b63fe82889..00000000000
--- a/share/doc/psd/05.sysman/2.2.t
+++ /dev/null
@@ -1,468 +0,0 @@
-.\" $OpenBSD: 2.2.t,v 1.4 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.2.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "File system
-.NH 3
-Overview
-.PP
-The file system abstraction provides access to a hierarchical
-file system structure.
-The file system contains directories (each of which may contain
-other sub-directories) as well as files and references to other
-objects such as devices and inter-process communications sockets.
-.PP
-Each file is organized as a linear array of bytes. No record
-boundaries or system related information is present in
-a file.
-Files may be read and written in a random-access fashion.
-The user may read the data in a directory as though
-it were an ordinary file to determine the names of the contained files,
-but only the system may write into the directories.
-The file system stores only a small amount of ownership, protection and usage
-information with a file.
-.NH 3
-Naming
-.PP
-The file system calls take \fIpath name\fP arguments.
-These consist of a zero or more component \fIfile names\fP
-separated by ``/\^'' characters, where each file name
-is up to 255 ASCII characters excluding null and ``/\^''.
-.PP
-Each process always has two naming contexts: one for the
-root directory of the file system and one for the
-current working directory. These are used
-by the system in the filename translation process.
-If a path name begins with a ``/\^'', it is called
-a full path name and interpreted relative to the root directory context.
-If the path name does not begin with a ``/\^'' it is called
-a relative path name and interpreted relative to the current directory
-context.
-.PP
-The system limits
-the total length of a path name to 1024 characters.
-.PP
-The file name ``..'' in each directory refers to
-the parent directory of that directory.
-The parent directory of the root of the file system is always that directory.
-.PP
-The calls
-.DS
-chdir(path);
-char *path;
-
-chroot(path)
-char *path;
-.DE
-change the current working directory and root directory context of a process.
-Only the super-user can change the root directory context of a process.
-.NH 3
-Creation and removal
-.PP
-The file system allows directories, files, special devices,
-and ``portals'' to be created and removed from the file system.
-.NH 4
-Directory creation and removal
-.PP
-A directory is created with the \fImkdir\fP system call:
-.DS
-mkdir(path, mode);
-char *path; int mode;
-.DE
-where the mode is defined as for files (see below).
-Directories are removed with the \fIrmdir\fP system call:
-.DS
-rmdir(path);
-char *path;
-.DE
-A directory must be empty if it is to be deleted.
-.NH 4
-File creation
-.PP
-Files are created with the \fIopen\fP system call,
-.DS
-fd = open(path, oflag, mode);
-result int fd; char *path; int oflag, mode;
-.DE
-The \fIpath\fP parameter specifies the name of the
-file to be created. The \fIoflag\fP parameter must
-include O_CREAT from below to cause the file to be created.
-Bits for \fIoflag\fP are
-defined in \fI<sys/file.h>\fP:
-.DS
-._d
-#define O_RDONLY 000 /* open for reading */
-#define O_WRONLY 001 /* open for writing */
-#define O_RDWR 002 /* open for read & write */
-#define O_NDELAY 004 /* non-blocking open */
-#define O_APPEND 010 /* append on each write */
-#define O_CREAT 01000 /* open with file create */
-#define O_TRUNC 02000 /* open with truncation */
-#define O_EXCL 04000 /* error on create if file exists */
-.DE
-.PP
-One of O_RDONLY, O_WRONLY and O_RDWR should be specified,
-indicating what types of operations are desired to be performed
-on the open file. The operations will be checked against the user's
-access rights to the file before allowing the \fIopen\fP to succeed.
-Specifying O_APPEND causes writes to automatically append to the
-file.
-The flag O_CREAT causes the file to be created if it does not
-exist, owned by the current user
-and the group of the containing directory.
-The protection for the new file is specified in \fImode\fP.
-The file mode is used as a three digit octal number.
-Each digit encodes read access as 4, write access as 2 and execute
-access as 1, or'ed together. The 0700 bits describe owner
-access, the 070 bits describe the access rights for processes in the same
-group as the file, and the 07 bits describe the access rights
-for other processes.
-.PP
-If the open specifies to create the file with O_EXCL
-and the file already exists, then the \fIopen\fP will fail
-without affecting the file in any way. This provides a
-simple exclusive access facility.
-If the file exists but is a symbolic link, the open will fail
-regardless of the existence of the file specified by the link.
-.NH 4
-Creating references to devices
-.PP
-The file system allows entries which reference peripheral devices.
-Peripherals are distinguished as \fIblock\fP or \fIcharacter\fP
-devices according by their ability to support block-oriented
-operations.
-Devices are identified by their ``major'' and ``minor''
-device numbers. The major device number determines the kind
-of peripheral it is, while the minor device number indicates
-one of possibly many peripherals of that kind.
-Structured devices have all operations performed internally
-in ``block'' quantities while
-unstructured devices often have a number of
-special \fIioctl\fP operations, and may have input and output
-performed in varying units.
-The \fImknod\fP call creates special entries:
-.DS
-mknod(path, mode, dev);
-char *path; int mode, dev;
-.DE
-where \fImode\fP is formed from the object type
-and access permissions. The parameter \fIdev\fP is a configuration
-dependent parameter used to identify specific character or
-block I/O devices.
-.NH 4
-Portal creation\(dg
-.PP
-.FS
-\(dg The \fIportal\fP call is not implemented in 4.3BSD.
-.FE
-The call
-.DS
-fd = portal(name, server, param, dtype, protocol, domain, socktype)
-result int fd; char *name, *server, *param; int dtype, protocol;
-int domain, socktype;
-.DE
-places a \fIname\fP in the file system name space that causes connection to a
-server process when the name is used.
-The portal call returns an active portal in \fIfd\fP as though an
-access had occurred to activate an inactive portal, as now described.
-.PP
-When an inactive portal is accessed, the system sets up a socket
-of the specified \fIsocktype\fP in the specified communications
-\fIdomain\fP (see section 2.3), and creates the \fIserver\fP process,
-giving it the specified \fIparam\fP as argument to help it identify
-the portal, and also giving it the newly created socket as descriptor
-number 0. The accessor of the portal will create a socket in the same
-\fIdomain\fP and \fIconnect\fP to the server. The user will then
-\fIwrap\fP the socket in the specified \fIprotocol\fP to create an object of
-the required descriptor type \fIdtype\fP and proceed with the
-operation which was in progress before the portal was encountered.
-.PP
-While the server process holds the socket (which it received as \fIfd\fP
-from the \fIportal\fP call on descriptor 0 at activation) further references
-will result in connections being made to the same socket.
-.NH 4
-File, device, and portal removal
-.PP
-A reference to a file, special device or portal may be removed with the
-\fIunlink\fP call,
-.DS
-unlink(path);
-char *path;
-.DE
-The caller must have write access to the directory in which
-the file is located for this call to be successful.
-.NH 3
-Reading and modifying file attributes
-.PP
-Detailed information about the attributes of a file
-may be obtained with the calls:
-.DS
-#include <sys/stat.h>
-
-stat(path, stb);
-char *path; result struct stat *stb;
-
-fstat(fd, stb);
-int fd; result struct stat *stb;
-.DE
-The \fIstat\fP structure includes the file
-type, protection, ownership, access times,
-size, and a count of hard links.
-If the file is a symbolic link, then the status of the link
-itself (rather than the file the link references)
-may be found using the \fIlstat\fP call:
-.DS
-lstat(path, stb);
-char *path; result struct stat *stb;
-.DE
-.PP
-Newly created files are assigned the user id of the
-process that created it and the group id of the directory
-in which it was created. The ownership of a file may
-be changed by either of the calls
-.DS
-chown(path, owner, group);
-char *path; int owner, group;
-
-fchown(fd, owner, group);
-int fd, owner, group;
-.DE
-.PP
-In addition to ownership, each file has three levels of access
-protection associated with it. These levels are owner relative,
-group relative, and global (all users and groups). Each level
-of access has separate indicators for read permission, write
-permission, and execute permission.
-The protection bits associated with a file may be set by either
-of the calls:
-.DS
-chmod(path, mode);
-char *path; int mode;
-
-fchmod(fd, mode);
-int fd, mode;
-.DE
-where \fImode\fP is a value indicating the new protection
-of the file, as listed in section 2.2.3.2.
-.PP
-Finally, the access and modify times on a file may be set by the call:
-.DS
-utimes(path, tvp)
-char *path; struct timeval *tvp[2];
-.DE
-This is particularly useful when moving files between media, to
-preserve relationships between the times the file was modified.
-.NH 3
-Links and renaming
-.PP
-Links allow multiple names for a file
-to exist. Links exist independently of the file linked to.
-.PP
-Two types of links exist, \fIhard\fP links and \fIsymbolic\fP
-links. A hard link is a reference counting mechanism that
-allows a file to have multiple names within the same file
-system. Symbolic links cause string substitution
-during the pathname interpretation process.
-.PP
-Hard links and symbolic links have different
-properties. A hard link insures the target
-file will always be accessible, even after its original
-directory entry is removed; no such guarantee exists for a symbolic link.
-Symbolic links can span file systems boundaries.
-.PP
-The following calls create a new link, named \fIpath2\fP,
-to \fIpath1\fP:
-.DS
-link(path1, path2);
-char *path1, *path2;
-
-symlink(path1, path2);
-char *path1, *path2;
-.DE
-The \fIunlink\fP primitive may be used to remove
-either type of link.
-.PP
-If a file is a symbolic link, the ``value'' of the
-link may be read with the \fIreadlink\fP call,
-.DS
-len = readlink(path, buf, bufsize);
-result int len; result char *path, *buf; int bufsize;
-.DE
-This call returns, in \fIbuf\fP, the null-terminated string
-substituted into pathnames passing through \fIpath\fP\|.
-.PP
-Atomic renaming of file system resident objects is possible
-with the \fIrename\fP call:
-.DS
-rename(oldname, newname);
-char *oldname, *newname;
-.DE
-where both \fIoldname\fP and \fInewname\fP must be
-in the same file system.
-If \fInewname\fP exists and is a directory, then it must be empty.
-.NH 3
-Extension and truncation
-.PP
-Files are created with zero length and may be extended
-simply by writing or appending to them. While a file is
-open the system maintains a pointer into the file
-indicating the current location in the file associated with
-the descriptor. This pointer may be moved about in the
-file in a random access fashion.
-To set the current offset into a file, the \fIlseek\fP
-call may be used,
-.DS
-oldoffset = lseek(fd, offset, type);
-result off_t oldoffset; int fd; off_t offset; int type;
-.DE
-where \fItype\fP is given in \fI<sys/file.h>\fP as one of:
-.DS
-._d
-#define SEEK_SET 0 /* set file offset to offset */
-#define SEEK_CUR 1 /* set file offset to current plus offset */
-#define SEEK_CUR 2 /* set file offset to EOF plus offset */
-.DE
-The call ``lseek(fd, 0, SEEK_CUR)''
-returns the current offset into the file.
-.PP
-Files may have ``holes'' in them. Holes are void areas in the
-linear extent of the file where data has never been
-written. These may be created by seeking to
-a location in a file past the current end-of-file and writing.
-Holes are treated by the system as zero valued bytes.
-.PP
-A file may be truncated with either of the calls:
-.DS
-truncate(path, length);
-char *path; int length;
-
-ftruncate(fd, length);
-int fd, length;
-.DE
-reducing the size of the specified file to \fIlength\fP bytes.
-.NH 3
-Checking accessibility
-.PP
-A process running with
-different real and effective user ids
-may interrogate the accessibility of a file to the
-real user by using
-the \fIaccess\fP call:
-.DS
-accessible = access(path, how);
-result int accessible; char *path; int how;
-.DE
-Here \fIhow\fP is constructed by or'ing the following bits, defined
-in \fI<sys/file.h>\fP:
-.DS
-._d
-#define F_OK 0 /* file exists */
-#define X_OK 1 /* file is executable */
-#define W_OK 2 /* file is writable */
-#define R_OK 4 /* file is readable */
-.DE
-The presence or absence of advisory locks does not affect the
-result of \fIaccess\fP\|.
-.NH 3
-Locking
-.PP
-The file system provides basic facilities that allow cooperating processes
-to synchronize their access to shared files. A process may
-place an advisory \fIread\fP or \fIwrite\fP lock on a file,
-so that other cooperating processes may avoid interfering
-with the process' access. This simple mechanism
-provides locking with file granularity. More granular
-locking can be built using the IPC facilities to provide a lock
-manager.
-The system does not force processes to obey the locks;
-they are of an advisory nature only.
-.PP
-Locking is performed after an \fIopen\fP call by applying the
-\fIflock\fP primitive,
-.DS
-flock(fd, how);
-int fd, how;
-.DE
-where the \fIhow\fP parameter is formed from bits defined in \fI<sys/file.h>\fP:
-.DS
-._d
-#define LOCK_SH 1 /* shared lock */
-#define LOCK_EX 2 /* exclusive lock */
-#define LOCK_NB 4 /* don't block when locking */
-#define LOCK_UN 8 /* unlock */
-.DE
-Successive lock calls may be used to increase or
-decrease the level of locking. If an object is currently
-locked by another process when a \fIflock\fP call is made,
-the caller will be blocked until the current lock owner
-releases the lock; this may be avoided by including LOCK_NB
-in the \fIhow\fP parameter.
-Specifying LOCK_UN removes all locks associated with the descriptor.
-Advisory locks held by a process are automatically deleted when
-the process terminates.
-.NH 3
-Disk quotas
-.PP
-As an optional facility, each file system may be requested to
-impose limits on a user's disk usage.
-Two quantities are limited: the total amount of disk space which
-a user may allocate in a file system and the total number of files
-a user may create in a file system. Quotas are expressed as
-\fIhard\fP limits and \fIsoft\fP limits. A hard limit is
-always imposed; if a user would exceed a hard limit, the operation
-which caused the resource request will fail. A soft limit results
-in the user receiving a warning message, but with allocation succeeding.
-Facilities are provided to turn soft limits into hard limits if a
-user has exceeded a soft limit for an unreasonable period of time.
-.PP
-To enable disk quotas on a file system the \fIsetquota\fP call
-is used:
-.DS
-setquota(special, file)
-char *special, *file;
-.DE
-where \fIspecial\fP refers to a structured device file where
-a mounted file system exists, and
-\fIfile\fP refers to a disk quota file (residing on the file
-system associated with \fIspecial\fP) from which user quotas
-should be obtained. The format of the disk quota file is
-implementation dependent.
-.PP
-To manipulate disk quotas the \fIquota\fP call is provided:
-.DS
-#include <sys/quota.h>
-
-quota(cmd, uid, arg, addr)
-int cmd, uid, arg; caddr_t addr;
-.DE
-The indicated \fIcmd\fP is applied to the user ID \fIuid\fP.
-The parameters \fIarg\fP and \fIaddr\fP are command specific.
-The file \fI<sys/quota.h>\fP contains definitions pertinent to the
-use of this call.
diff --git a/share/doc/psd/05.sysman/2.3.t b/share/doc/psd/05.sysman/2.3.t
deleted file mode 100644
index f733f81d9b1..00000000000
--- a/share/doc/psd/05.sysman/2.3.t
+++ /dev/null
@@ -1,410 +0,0 @@
-.\" $OpenBSD: 2.3.t,v 1.4 2007/06/25 15:57:28 jmc Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.3.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Interprocess communications
-.NH 3
-Interprocess communication primitives
-.NH 4
-Communication domains
-.PP
-The system provides access to an extensible set of
-communication \fIdomains\fP. A communication domain
-is identified by a manifest constant defined in the
-file \fI<sys/socket.h>\fP.
-Important standard domains supported by the system are the ``unix''
-domain, AF_UNIX, for communication within the system, the ``Internet''
-domain for communication in the DARPA Internet, AF_INET,
-and the ``NS'' domain, AF_NS, for communication
-using the Xerox Network Systems protocols.
-Other domains can be added to the system.
-.NH 4
-Socket types and protocols
-.PP
-Within a domain, communication takes place between communication endpoints
-known as \fIsockets\fP. Each socket has the potential to exchange
-information with other sockets of an appropriate type within the domain.
-.PP
-Each socket has an associated
-abstract type, which describes the semantics of communication using that
-socket. Properties such as reliability, ordering, and prevention
-of duplication of messages are determined by the type.
-The basic set of socket types is defined in \fI<sys/socket.h>\fP:
-.DS
-/* Standard socket types */
-._d
-#define SOCK_DGRAM 1 /* datagram */
-#define SOCK_STREAM 2 /* virtual circuit */
-#define SOCK_RAW 3 /* raw socket */
-#define SOCK_RDM 4 /* reliably-delivered message */
-#define SOCK_SEQPACKET 5 /* sequenced packets */
-.DE
-The SOCK_DGRAM type models the semantics of datagrams in network communication:
-messages may be lost or duplicated and may arrive out-of-order.
-A datagram socket may send messages to and receive messages from multiple
-peers.
-The SOCK_RDM type models the semantics of reliable datagrams: messages
-arrive unduplicated and in-order, the sender is notified if
-messages are lost.
-The \fIsend\fP and \fIreceive\fP operations (described below)
-generate reliable/unreliable datagrams.
-The SOCK_STREAM type models connection-based virtual circuits: two-way
-byte streams with no record boundaries.
-Connection setup is required before data communication may begin.
-The SOCK_SEQPACKET type models a connection-based,
-full-duplex, reliable, sequenced packet exchange;
-the sender is notified if messages are lost, and messages are never
-duplicated or presented out-of-order.
-Users of the last two abstractions may use the facilities for
-out-of-band transmission to send out-of-band data.
-.PP
-SOCK_RAW is used for unprocessed access to internal network layers
-and interfaces; it has no specific semantics.
-.PP
-Other socket types can be defined.
-.PP
-Each socket may have a specific \fIprotocol\fP associated with it.
-This protocol is used within the domain to provide the semantics
-required by the socket type.
-Not all socket types are supported by each domain;
-support depends on the existence and the implementation
-of a suitable protocol within the domain.
-For example, within the ``Internet'' domain, the SOCK_DGRAM type may be
-implemented by the UDP user datagram protocol, and the SOCK_STREAM
-type may be implemented by the TCP transmission control protocol, while
-no standard protocols to provide SOCK_RDM or SOCK_SEQPACKET sockets exist.
-.NH 4
-Socket creation, naming and service establishment
-.PP
-Sockets may be \fIconnected\fP or \fIunconnected\fP. An unconnected
-socket descriptor is obtained by the \fIsocket\fP call:
-.DS
-s = socket(domain, type, protocol);
-result int s; int domain, type, protocol;
-.DE
-The socket domain and type are as described above,
-and are specified using the definitions from \fI<sys/socket.h>\fP.
-The protocol may be given as 0, meaning any suitable protocol.
-One of several possible protocols may be selected using identifiers
-obtained from a library routine, \fIgetprotobyname\fP.
-.PP
-An unconnected socket descriptor of a connection-oriented type
-may yield a connected socket descriptor
-in one of two ways: either by actively connecting to another socket,
-or by becoming associated with a name in the communications domain and
-\fIaccepting\fP a connection from another socket.
-Datagram sockets need not establish connections before use.
-.PP
-To accept connections or to receive datagrams,
-a socket must first have a binding
-to a name (or address) within the communications domain.
-Such a binding may be established by a \fIbind\fP call:
-.DS
-bind(s, name, namelen);
-int s; struct sockaddr *name; int namelen;
-.DE
-Datagram sockets may have default bindings established when first
-sending data if not explicitly bound earlier.
-In either case,
-a socket's bound name may be retrieved with a \fIgetsockname\fP call:
-.DS
-getsockname(s, name, namelen);
-int s; result struct sockaddr *name; result int *namelen;
-.DE
-while the peer's name can be retrieved with \fIgetpeername\fP:
-.DS
-getpeername(s, name, namelen);
-int s; result struct sockaddr *name; result int *namelen;
-.DE
-Domains may support sockets with several names.
-.NH 4
-Accepting connections
-.PP
-Once a binding is made to a connection-oriented socket,
-it is possible to \fIlisten\fP for connections:
-.DS
-listen(s, backlog);
-int s, backlog;
-.DE
-The \fIbacklog\fP specifies the maximum count of connections
-that can be simultaneously queued awaiting acceptance.
-.PP
-An \fIaccept\fP call:
-.DS
-t = accept(s, name, anamelen);
-result int t; int s; result struct sockaddr *name; result int *anamelen;
-.DE
-returns a descriptor for a new, connected, socket
-from the queue of pending connections on \fIs\fP.
-If no new connections are queued for acceptance,
-the call will wait for a connection unless non-blocking I/O has been enabled.
-.NH 4
-Making connections
-.PP
-An active connection to a named socket is made by the \fIconnect\fP call:
-.DS
-connect(s, name, namelen);
-int s; struct sockaddr *name; int namelen;
-.DE
-Although datagram sockets do not establish connections,
-the \fIconnect\fP call may be used with such sockets
-to create an \fIassociation\fP with the foreign address.
-The address is recorded for use in future \fIsend\fP calls,
-which then need not supply destination addresses.
-Datagrams will be received only from that peer,
-and asynchronous error reports may be received.
-.PP
-It is also possible to create connected pairs of sockets without
-using the domain's name space to rendezvous; this is done with the
-\fIsocketpair\fP call\(dg:
-.FS
-\(dg 4.3BSD supports \fIsocketpair\fP creation only in the ``unix''
-communication domain.
-.FE
-.DS
-socketpair(domain, type, protocol, sv);
-int domain, type, protocol; result int sv[2];
-.DE
-Here the returned \fIsv\fP descriptors correspond to those obtained with
-\fIaccept\fP and \fIconnect\fP.
-.PP
-The call
-.DS
-pipe(pv)
-result int pv[2];
-.DE
-creates a pair of SOCK_STREAM sockets in the UNIX domain,
-with pv[0] only writable and pv[1] only readable.
-.NH 4
-Sending and receiving data
-.PP
-Messages may be sent from a socket by:
-.DS
-cc = sendto(s, buf, len, flags, to, tolen);
-result int cc; int s; caddr_t buf; int len, flags; caddr_t to; int tolen;
-.DE
-if the socket is not connected or:
-.DS
-cc = send(s, buf, len, flags);
-result int cc; int s; caddr_t buf; int len, flags;
-.DE
-if the socket is connected.
-The corresponding receive primitives are:
-.DS
-msglen = recvfrom(s, buf, len, flags, from, fromlenaddr);
-result int msglen; int s; result caddr_t buf; int len, flags;
-result caddr_t from; result int *fromlenaddr;
-.DE
-and
-.DS
-msglen = recv(s, buf, len, flags);
-result int msglen; int s; result caddr_t buf; int len, flags;
-.DE
-.PP
-In the unconnected case,
-the parameters \fIto\fP and \fItolen\fP
-specify the destination or source of the message, while
-the \fIfrom\fP parameter stores the source of the message,
-and \fI*fromlenaddr\fP initially gives the size of the \fIfrom\fP
-buffer and is updated to reflect the true length of the \fIfrom\fP
-address.
-.PP
-All calls cause the message to be received in or sent from
-the message buffer of length \fIlen\fP bytes, starting at address \fIbuf\fP.
-The \fIflags\fP specify
-peeking at a message without reading it or sending or receiving
-high-priority out-of-band messages, as follows:
-.DS
-._d
-#define MSG_PEEK 0x1 /* peek at incoming message */
-#define MSG_OOB 0x2 /* process out-of-band data */
-.DE
-.NH 4
-Scatter/gather and exchanging access rights
-.PP
-It is possible scatter and gather data and to exchange access rights
-with messages. When either of these operations is involved,
-the number of parameters to the call becomes large.
-Thus the system defines a message header structure, in \fI<sys/socket.h>\fP,
-which can be
-used to conveniently contain the parameters to the calls:
-.DS
-.if t .ta .5i 1.25i 2i 2.7i
-.if n ._f
-struct msghdr {
- caddr_t msg_name; /* optional address */
- int msg_namelen; /* size of address */
- struct iov *msg_iov; /* scatter/gather array */
- int msg_iovlen; /* # elements in msg_iov */
- caddr_t msg_accrights; /* access rights sent/received */
- int msg_accrightslen; /* size of msg_accrights */
-};
-.DE
-Here \fImsg_name\fP and \fImsg_namelen\fP specify the source or destination
-address if the socket is unconnected; \fImsg_name\fP may be given as
-a null pointer if no names are desired or required.
-The \fImsg_iov\fP and \fImsg_iovlen\fP describe the scatter/gather
-locations, as described in section 2.1.3.
-Access rights to be sent along with the message are specified
-in \fImsg_accrights\fP, which has length \fImsg_accrightslen\fP.
-In the ``unix'' domain these are an array of integer descriptors,
-taken from the sending process and duplicated in the receiver.
-.PP
-This structure is used in the operations \fIsendmsg\fP and \fIrecvmsg\fP:
-.DS
-sendmsg(s, msg, flags);
-int s; struct msghdr *msg; int flags;
-
-msglen = recvmsg(s, msg, flags);
-result int msglen; int s; result struct msghdr *msg; int flags;
-.DE
-.NH 4
-Using read and write with sockets
-.PP
-The normal UNIX \fIread\fP and \fIwrite\fP calls may be
-applied to connected sockets and translated into \fIsend\fP and \fIreceive\fP
-calls from or to a single area of memory and discarding any rights
-received. A process may operate on a virtual circuit socket, a terminal
-or a file with blocking or non-blocking input/output
-operations without distinguishing the descriptor type.
-.NH 4
-Shutting down halves of full-duplex connections
-.PP
-A process that has a full-duplex socket such as a virtual circuit
-and no longer wishes to read from or write to this socket can
-give the call:
-.DS
-shutdown(s, direction);
-int s, direction;
-.DE
-where \fIdirection\fP is 0 to not read further, 1 to not
-write further, or 2 to completely shut the connection down.
-If the underlying protocol supports unidirectional or bidirectional shutdown,
-this indication will be passed to the peer.
-For example, a shutdown for writing might produce an end-of-file
-condition at the remote end.
-.NH 4
-Socket and protocol options
-.PP
-Sockets, and their underlying communication protocols, may
-support \fIoptions\fP. These options may be used to manipulate
-implementation- or protocol-specific facilities.
-The \fIgetsockopt\fP
-and \fIsetsockopt\fP calls are used to control options:
-.DS
-getsockopt(s, level, optname, optval, optlen)
-int s, level, optname; result caddr_t optval; result int *optlen;
-
-setsockopt(s, level, optname, optval, optlen)
-int s, level, optname; caddr_t optval; int optlen;
-.DE
-The option \fIoptname\fP is interpreted at the indicated
-protocol \fIlevel\fP for socket \fIs\fP. If a value is specified
-with \fIoptval\fP and \fIoptlen\fP, it is interpreted by
-the software operating at the specified \fIlevel\fP. The \fIlevel\fP
-SOL_SOCKET is reserved to indicate options maintained
-by the socket facilities. Other \fIlevel\fP values indicate
-a particular protocol which is to act on the option request;
-these values are normally interpreted as a ``protocol number''.
-.NH 3
-UNIX domain
-.PP
-This section describes briefly the properties of the UNIX communications
-domain.
-.NH 4
-Types of sockets
-.PP
-In the UNIX domain,
-the SOCK_STREAM abstraction provides pipe-like
-facilities, while SOCK_DGRAM provides (usually)
-reliable message-style communications.
-.NH 4
-Naming
-.PP
-Socket names are strings and may appear in the UNIX file
-system name space through portals\(dg.
-.FS
-\(dg The 4.3BSD implementation of the UNIX domain embeds
-bound sockets in the UNIX file system name space;
-this may change in future releases.
-.FE
-.NH 4
-Access rights transmission
-.PP
-The ability to pass UNIX descriptors with messages in this domain
-allows migration of service within the system and allows
-user processes to be used in building system facilities.
-.NH 3
-INTERNET domain
-.PP
-This section describes briefly how the Internet domain is
-mapped to the model described in this section. More
-information will be found in the document describing the
-network implementation in 4.3BSD.
-.NH 4
-Socket types and protocols
-.PP
-SOCK_STREAM is supported by the Internet TCP protocol;
-SOCK_DGRAM by the UDP protocol.
-Each is layered atop the transport-level Internet Protocol (IP).
-The Internet Control Message Protocol is implemented atop/beside IP
-and is accessible via a raw socket.
-The SOCK_SEQPACKET
-has no direct Internet family analogue; a protocol
-based on one from the XEROX NS family and layered on
-top of IP could be implemented to fill this gap.
-.NH 4
-Socket naming
-.PP
-Sockets in the Internet domain have names composed of the 32 bit
-Internet address, and a 16 bit port number.
-Options may be used to
-provide IP source routing or security options.
-The 32-bit address is composed of network and host parts;
-the network part is variable in size and is frequency encoded.
-The host part may optionally be interpreted as a subnet field
-plus the host on subnet; this is enabled by setting a network address
-mask at boot time.
-.NH 4
-Access rights transmission
-.PP
-No access rights transmission facilities are provided in the Internet domain.
-.NH 4
-Raw access
-.PP
-The Internet domain allows the super-user access to the raw facilities
-of IP.
-These interfaces are modeled as SOCK_RAW sockets.
-Each raw socket is associated with one IP protocol number,
-and receives all traffic received for that protocol.
-This allows administrative and debugging
-functions to occur,
-and enables user-level implementations of special-purpose protocols
-such as inter-gateway routing protocols.
diff --git a/share/doc/psd/05.sysman/2.4.t b/share/doc/psd/05.sysman/2.4.t
deleted file mode 100644
index 3a7ccedcdca..00000000000
--- a/share/doc/psd/05.sysman/2.4.t
+++ /dev/null
@@ -1,172 +0,0 @@
-.\" $OpenBSD: 2.4.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.4.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Terminals and Devices
-.NH 3
-Terminals
-.PP
-Terminals support \fIread\fP and \fIwrite\fP I/O operations,
-as well as a collection of terminal specific \fIioctl\fP operations,
-to control input character interpretation and editing,
-and output format and delays.
-.NH 4
-Terminal input
-.PP
-Terminals are handled according to the underlying communication
-characteristics such as baud rate and required delays,
-and a set of software parameters.
-.NH 5
-Input modes
-.PP
-A terminal is in one of three possible modes: \fIraw\fP, \fIcbreak\fP,
-or \fIcooked\fP.
-In raw mode all input is passed through to the
-reading process immediately and without interpretation.
-In cbreak mode, the handler interprets input only by looking
-for characters that cause interrupts or output flow control;
-all other characters are made available as in raw mode.
-In cooked mode, input
-is processed to provide standard line-oriented local editing functions,
-and input is presented on a line-by-line basis.
-.NH 5
-Interrupt characters
-.PP
-Interrupt characters are interpreted by the terminal handler only in
-cbreak and cooked modes, and
-cause a software interrupt to be sent to all processes in the process
-group associated with the terminal. Interrupt characters exist
-to send SIGINT
-and SIGQUIT signals,
-and to stop a process group
-with the SIGTSTP signal either immediately, or when
-all input up to the stop character has been read.
-.NH 5
-Line editing
-.PP
-When the terminal is in cooked mode, editing of an input line
-is performed. Editing facilities allow deletion of the previous
-character or word, or deletion of the current input line.
-In addition, a special character may be used to reprint the current
-input line after some number of editing operations have been applied.
-.PP
-Certain other characters are interpreted specially when a process is
-in cooked mode. The \fIend of line\fP character determines
-the end of an input record. The \fIend of file\fP character simulates
-an end of file occurrence on terminal input. Flow control is provided
-by \fIstop output\fP and \fIstart output\fP control characters. Output
-may be flushed with the \fIflush output\fP character; and a \fIliteral
-character\fP may be used to force literal input of the immediately
-following character in the input line.
-.PP
-Input characters may be echoed to the terminal as they are received.
-Non-graphic ASCII input characters may be echoed as a two-character
-printable representation, ``^character.''
-.NH 4
-Terminal output
-.PP
-On output, the terminal handler provides some simple formatting services.
-These include converting the carriage return character to the
-two character return-linefeed sequence,
-inserting delays after certain standard control characters,
-expanding tabs, and providing translations
-for upper-case only terminals.
-.NH 4
-Terminal control operations
-.PP
-When a terminal is first opened it is initialized to a standard
-state and configured with a set of standard control, editing,
-and interrupt characters. A process
-may alter this configuration with certain
-control operations, specifying parameters in a standard structure:\(dg
-.FS
-\(dg The control interface described here is an internal interface only
-in 4.3BSD. Future releases will probably use a modified interface
-based on currently-proposed standards.
-.FE
-.DS
-._f
-struct ttymode {
- short tt_ispeed; /* input speed */
- int tt_iflags; /* input flags */
- short tt_ospeed; /* output speed */
- int tt_oflags; /* output flags */
-};
-.DE
-and ``special characters'' are specified with the
-\fIttychars\fP structure,
-.DS
-._f
-struct ttychars {
- char tc_erasec; /* erase char */
- char tc_killc; /* erase line */
- char tc_intrc; /* interrupt */
- char tc_quitc; /* quit */
- char tc_startc; /* start output */
- char tc_stopc; /* stop output */
- char tc_eofc; /* end-of-file */
- char tc_brkc; /* input delimiter (like nl) */
- char tc_suspc; /* stop process signal */
- char tc_dsuspc; /* delayed stop process signal */
- char tc_rprntc; /* reprint line */
- char tc_flushc; /* flush output (toggles) */
- char tc_werasc; /* word erase */
- char tc_lnextc; /* literal next character */
-};
-.DE
-.NH 4
-Terminal hardware support
-.PP
-The terminal handler allows a user to access basic
-hardware related functions; e.g. line speed,
-modem control, parity, and stop bits. A special signal,
-SIGHUP, is automatically
-sent to processes in a terminal's process
-group when a carrier transition is detected. This is
-normally associated with a user hanging up on a modem
-controlled terminal line.
-.NH 3
-Structured devices
-.PP
-Structures devices are typified by disks and magnetic
-tapes, but may represent any random-access device.
-The system performs read-modify-write type buffering actions on block
-devices to allow them to be read and written in a totally random
-access fashion like ordinary files.
-File systems are normally created in block devices.
-.NH 3
-Unstructured devices
-.PP
-Unstructured devices are those devices which
-do not support block structure. Familiar unstructured devices
-are raw communications lines (with
-no terminal handler), raster plotters, magnetic tape and disks unfettered
-by buffering and permitting large block input/output and positioning
-and formatting commands.
diff --git a/share/doc/psd/05.sysman/2.5.t b/share/doc/psd/05.sysman/2.5.t
deleted file mode 100644
index b2dda7a1bbc..00000000000
--- a/share/doc/psd/05.sysman/2.5.t
+++ /dev/null
@@ -1,37 +0,0 @@
-.\" $OpenBSD: 2.5.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.5.t 8.1 (Berkeley) 6/8/93
-.\"
-.sh "Process and kernel descriptors
-.PP
-The status of the facilities in this section is still under discussion.
-The \fIptrace\fP facility of earlier UNIX systems
-remains in 4.3BSD.
-Planned enhancements would allow a descriptor-based process control facility.
diff --git a/share/doc/psd/05.sysman/Makefile b/share/doc/psd/05.sysman/Makefile
deleted file mode 100644
index e6ad009e7ab..00000000000
--- a/share/doc/psd/05.sysman/Makefile
+++ /dev/null
@@ -1,12 +0,0 @@
-# $OpenBSD: Makefile,v 1.2 2001/02/03 08:15:04 niklas Exp $
-
-
-DIR= psd/05.sysman
-SRCS= 0.t 1.0.t 1.1.t 1.2.t 1.3.t 1.4.t 1.5.t 1.6.t 1.7.t \
- 2.0.t 2.1.t 2.2.t 2.3.t 2.4.t 2.5.t a.t
-MACROS= -ms
-
-paper.ps: ${SRCS}
- ${TBL} ${SRCS} | ${ROFF} > ${.TARGET}
-
-.include <bsd.doc.mk>
diff --git a/share/doc/psd/05.sysman/a.t b/share/doc/psd/05.sysman/a.t
deleted file mode 100644
index 00e08d0cce0..00000000000
--- a/share/doc/psd/05.sysman/a.t
+++ /dev/null
@@ -1,233 +0,0 @@
-.\" $OpenBSD: a.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1983, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)a.t 8.1 (Berkeley) 6/8/93
-.\"
-.ds RH Summary of facilities
-.bp
-.SH
-\s+2I. Summary of facilities\s0
-.PP
-.de h
-.br
-.if n .ne 8
-\fB\\$1 \\$2\fP
-.br
-..
-.nr H1 0
-.NH
-Kernel primitives
-.LP
-.h 1.1. "Process naming and protection
-.in +5
-.TS
-lw(1.6i) aw(3i).
-sethostid set UNIX host id
-gethostid get UNIX host id
-sethostname set UNIX host name
-gethostname get UNIX host name
-getpid get process id
-fork create new process
-exit terminate a process
-execve execute a different process
-getuid get user id
-geteuid get effective user id
-setreuid set real and effective user id's
-getgid get accounting group id
-getegid get effective accounting group id
-getgroups get access group set
-setregid set real and effective group id's
-setgroups set access group set
-getpgrp get process group
-setpgrp set process group
-.TE
-.in -5
-.h 1.2 "Memory management
-.in +5
-.TS
-lw(1.6i) aw(3i).
-<sys/mman.h> memory management definitions
-sbrk change data section size
-sstk\(dg change stack section size
-.FS
-\(dg Not supported in 4.3BSD.
-.FE
-getpagesize get memory page size
-mmap\(dg map pages of memory
-msync\(dg flush modified mapped pages to filesystem
-munmap\(dg unmap memory
-mprotect\(dg change protection of pages
-madvise\(dg give memory management advice
-mincore\(dg determine core residency of pages
-msleep\(dg sleep on a lock
-mwakeup\(dg wakeup process sleeping on a lock
-.TE
-.in -5
-.h 1.3 "Signals
-.in +5
-.TS
-lw(1.6i) aw(3i).
-<signal.h> signal definitions
-sigvec set handler for signal
-kill send signal to process
-killpgrp send signal to process group
-sigblock block set of signals
-sigsetmask restore set of blocked signals
-sigpause wait for signals
-sigstack set software stack for signals
-.TE
-.in -5
-.h 1.4 "Timing and statistics
-.in +5
-.TS
-lw(1.6i) aw(3i).
-<sys/time.h> time-related definitions
-gettimeofday get current time and timezone
-settimeofday set current time and timezone
-getitimer read an interval timer
-setitimer get and set an interval timer
-profil profile process
-.TE
-.in -5
-.h 1.5 "Descriptors
-.in +5
-.TS
-lw(1.6i) aw(3i).
-getdtablesize descriptor reference table size
-dup duplicate descriptor
-dup2 duplicate to specified index
-close close descriptor
-select multiplex input/output
-fcntl control descriptor options
-wrap\(dg wrap descriptor with protocol
-.FS
-\(dg Not supported in 4.3BSD.
-.FE
-.TE
-.in -5
-.h 1.6 "Resource controls
-.in +5
-.TS
-lw(1.6i) aw(3i).
-<sys/resource.h> resource-related definitions
-getpriority get process priority
-setpriority set process priority
-getrusage get resource usage
-getrlimit get resource limitations
-setrlimit set resource limitations
-.TE
-.in -5
-.h 1.7 "System operation support
-.in +5
-.TS
-lw(1.6i) aw(3i).
-mount mount a device file system
-swapon add a swap device
-umount umount a file system
-sync flush system caches
-reboot reboot a machine
-acct specify accounting file
-.TE
-.in -5
-.NH
-System facilities
-.LP
-.h 2.1 "Generic operations
-.in +5
-.TS
-lw(1.6i) aw(3i).
-read read data
-write write data
-<sys/uio.h> scatter-gather related definitions
-readv scattered data input
-writev gathered data output
-<sys/ioctl.h> standard control operations
-ioctl device control operation
-.TE
-.in -5
-.h 2.2 "File system
-.PP
-Operations marked with a * exist in two forms: as shown,
-operating on a file name, and operating on a file descriptor,
-when the name is preceded with a ``f''.
-.in +5
-.TS
-lw(1.6i) aw(3i).
-<sys/file.h> file system definitions
-chdir change directory
-chroot change root directory
-mkdir make a directory
-rmdir remove a directory
-open open a new or existing file
-mknod make a special file
-portal\(dg make a portal entry
-unlink remove a link
-stat* return status for a file
-lstat returned status of link
-chown* change owner
-chmod* change mode
-utimes change access/modify times
-link make a hard link
-symlink make a symbolic link
-readlink read contents of symbolic link
-rename change name of file
-lseek reposition within file
-truncate* truncate file
-access determine accessibility
-flock lock a file
-.TE
-.in -5
-.h 2.3 "Communications
-.in +5
-.TS
-lw(1.6i) aw(3i).
-<sys/socket.h> standard definitions
-socket create socket
-bind bind socket to name
-getsockname get socket name
-listen allow queuing of connections
-accept accept a connection
-connect connect to peer socket
-socketpair create pair of connected sockets
-sendto send data to named socket
-send send data to connected socket
-recvfrom receive data on unconnected socket
-recv receive data on connected socket
-sendmsg send gathered data and/or rights
-recvmsg receive scattered data and/or rights
-shutdown partially close full-duplex connection
-getsockopt get socket option
-setsockopt set socket option
-.TE
-.in -5
-.h 2.4 "Terminals, block and character devices
-.in +5
-.in -5
-.h 2.5 "Processes and kernel hooks
-.in -5
diff --git a/share/doc/psd/05.sysman/spell.ok b/share/doc/psd/05.sysman/spell.ok
deleted file mode 100644
index b0cbd9ce9cf..00000000000
--- a/share/doc/psd/05.sysman/spell.ok
+++ /dev/null
@@ -1,332 +0,0 @@
-AF
-ANON
-AUTOBOOT
-Behav
-CLR
-DEF
-DGRAM
-DONTNEED
-Datagram
-Datagrams
-EINPROGRESS
-EWOULDBLOCK
-EXCL
-FD
-FSIZE
-Fabry
-GETFL
-GETOWN
-HASSEMAPHORE
-HASSEMPHORE
-IGN
-INCR
-INET
-IP
-IPC
-ISSET
-ITIMER
-Karels
-Leffler
-MADV
-MAXHOSTNAMELEN
-MSG
-Manual''PS1:6
-McKusick
-Mclear
-Mset
-NB
-NDELAY
-NGROUPS
-NLIMITS
-NOEXTEND
-NS
-OOB
-PGRP
-PRIO
-PROT
-PS1:6
-RB
-RDM
-RDONLY
-RDWR
-RH
-RLIM
-RLIMIT
-RSS
-RUSAGE
-SEQPACKET
-SETFL
-SETOWN
-SIG
-SIGALRM
-SIGBUS
-SIGCHLD
-SIGCONT
-SIGEMT
-SIGFPE
-SIGHUP
-SIGILL
-SIGINT
-SIGIO
-SIGIOT
-SIGKILL
-SIGPROF
-SIGQUIT
-SIGSEGV
-SIGSTOP
-SIGTERM
-SIGTRAP
-SIGTSTP
-SIGTTIN
-SIGTTOU
-SIGURG
-SIGUSR1
-SIGUSR2
-SIGVTALRM
-SIGXCPU
-SIGXFSZ
-Sem
-Sv
-TCP
-TRUNC
-UDP
-VAX
-WILLNEED
-WRONLY
-XTND
-accessor
-accrights
-accrightslen
-addr
-anamelen
-arg
-argv
-arusage
-astatus
-behav
-blkdev
-brkc
-bu
-buf
-buflen
-bufsize
-caddr
-cbreak
-chroot
-cmd
-datagram
-datagrams
-dev
-dopt
-dprop
-ds
-dst
-dsttime
-dsuspc
-dtype
-dup2
-egid
-envp
-eofc
-erasec
-errno
-euid
-fchmod
-fchown
-fcntl
-fd
-fdset
-file.h
-filename
-filesystem
-flushc
-fromlenaddr
-fs
-fstat
-ftruncate
-getdtablesize
-getegid
-geteuid
-getgid
-getgroups
-gethostid
-gethostname
-getitimer
-getpagesize
-getpeername
-getpriority
-getprotobyname
-getrlimit
-getrusage
-getsockname
-getsockopt
-gettimeofday
-gid
-gidset
-gidsetsize
-hostid
-idrss
-iflags
-inblock
-incr
-intrc
-ioctl.h
-iov
-iovec
-iovlen
-ispeed
-isrss
-itimerval
-ixrss
-kbytes
-killc
-killpgrp
-len
-linefeed
-lnextc
-lstat
-maddr
-madvise
-majflt
-maxrss
-mclear
-mincore
-minflt
-minuteswest
-mman.h
-mmap
-mprotect
-mremap
-mset
-msg
-msghdr
-msglen
-msgrcv
-msgsnd
-msleep
-msync
-munmap
-mwakeup
-namelen
-nbytes
-nd
-nds
-newname
-ngroups
-nivcsw
-nl
-nsignals
-nswap
-nvcsw
-oflag
-oflags
-oldmask
-oldname
-oldoffset
-onstack
-optlen
-optname
-optval
-or'ed
-or'ing
-ospeed
-oss
-osv
-oublock
-ovalue
-pagesize
-param
-param.h
-path1
-path2
-pathname
-pathnames
-pgrp
-pid
-pos
-prio
-prot
-proto
-pv
-quitc
-quota.h
-readlink
-readv
-reboot.h
-recv
-recvfrom
-recvmsg
-resource.h
-rgid
-rlim
-rlimit
-rlp
-ronly
-rprntc
-ru
-ruid
-rusage
-sbrk
-scp
-sem
-sendmsg
-sendto
-setgroups
-sethostid
-sethostname
-setitimer
-setpriority
-setquota
-setregid
-setreuid
-setrlimit
-setsockopt
-settimeofday
-sigblock
-sigcontext
-sigmask
-signal.h
-signo
-sigpause
-sigsetmask
-sigstack
-sigvec
-sockaddr
-socket.h
-socketpair
-socktype
-sp
-ss
-sstk
-startc
-stat.h
-stb
-stopc
-suspc
-sv
-sw
-symlink
-ta
-time.h
-timeval
-timezone
-tolen
-tt
-ttychars
-ttymode
-tv
-tvp
-tvsec
-types.h
-tz
-tzp
-uid
-uio.h
-umount
-usec
-vec
-wait.h
-waitstatus
-werasc
-writeable
-writev
diff --git a/share/doc/psd/20.ipctut/Makefile b/share/doc/psd/20.ipctut/Makefile
deleted file mode 100644
index 9efbe0d1773..00000000000
--- a/share/doc/psd/20.ipctut/Makefile
+++ /dev/null
@@ -1,17 +0,0 @@
-# $OpenBSD: Makefile,v 1.3 2004/02/01 14:22:45 jmc Exp $
-
-
-DIR= psd/20.ipctut
-SRCS= tutor.me
-MACROS= -me
-EXTRA= dgramread.c dgramsend.c fig2.pic fig3.pic fig8.pic pipe.c \
- socketpair.c strchkread.c streamread.c streamwrite.c \
- udgramread.c udgramsend.c ustreamread.c ustreamwrite.c
-
-paper.ps: ${SRCS} ${EXTRA}
- ${SOELIM} ${SRCS} | ${PIC} | ${TBL} | ${ROFF} > ${.TARGET}
-
-paper.txt: ${SRCS} ${EXTRA}
- ${SOELIM} ${SRCS} | ${PIC} | ${TBL} | ${ROFF} -Tascii > ${.TARGET}
-
-.include <bsd.doc.mk>
diff --git a/share/doc/psd/20.ipctut/dgramread.c b/share/doc/psd/20.ipctut/dgramread.c
deleted file mode 100644
index b4994a408f0..00000000000
--- a/share/doc/psd/20.ipctut/dgramread.c
+++ /dev/null
@@ -1,81 +0,0 @@
-.\" $OpenBSD: dgramread.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)dgramread.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <stdio.h>
-
-/*
- * In the included file <netinet/in.h> a sockaddr_in is defined as follows:
- * struct sockaddr_in {
- * short sin_family;
- * u_short sin_port;
- * struct in_addr sin_addr;
- * char sin_zero[8];
- * };
- *
- * This program creates a datagram socket, binds a name to it, then reads
- * from the socket.
- */
-main()
-{
- int sock, length;
- struct sockaddr_in name;
- char buf[1024];
-
- /* Create socket from which to read. */
- sock = socket(AF_INET, SOCK_DGRAM, 0);
- if (sock < 0) {
- perror("opening datagram socket");
- exit(1);
- }
- /* Create name with wildcards. */
- name.sin_family = AF_INET;
- name.sin_addr.s_addr = INADDR_ANY;
- name.sin_port = 0;
- if (bind(sock, &name, sizeof(name))) {
- perror("binding datagram socket");
- exit(1);
- }
- /* Find assigned port value and print it out. */
- length = sizeof(name);
- if (getsockname(sock, &name, &length)) {
- perror("getting socket name");
- exit(1);
- }
- printf("Socket has port #%d\en", ntohs(name.sin_port));
- /* Read from the socket */
- if (read(sock, buf, 1024) < 0)
- perror("receiving datagram packet");
- printf("-->%s\en", buf);
- close(sock);
-}
diff --git a/share/doc/psd/20.ipctut/dgramsend.c b/share/doc/psd/20.ipctut/dgramsend.c
deleted file mode 100644
index b24b26b1388..00000000000
--- a/share/doc/psd/20.ipctut/dgramsend.c
+++ /dev/null
@@ -1,78 +0,0 @@
-.\" $OpenBSD: dgramsend.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)dgramsend.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <netdb.h>
-#include <stdio.h>
-
-#define DATA "The sea is calm tonight, the tide is full . . ."
-
-/*
- * Here I send a datagram to a receiver whose name I get from the command
- * line arguments. The form of the command line is dgramsend hostname
- * portnumber
- */
-
-main(argc, argv)
- int argc;
- char *argv[];
-{
- int sock;
- struct sockaddr_in name;
- struct hostent *hp, *gethostbyname();
-
- /* Create socket on which to send. */
- sock = socket(AF_INET, SOCK_DGRAM, 0);
- if (sock < 0) {
- perror("opening datagram socket");
- exit(1);
- }
- /*
- * Construct name, with no wildcards, of the socket to send to.
- * Getnostbyname() returns a structure including the network address
- * of the specified host. The port number is taken from the command
- * line.
- */
- hp = gethostbyname(argv[1]);
- if (hp == 0) {
- fprintf(stderr, "%s: unknown host\n", argv[1]);
- exit(2);
- }
- bcopy(hp->h_addr, &name.sin_addr, hp->h_length);
- name.sin_family = AF_INET;
- name.sin_port = htons(atoi(argv[2]));
- /* Send message. */
- if (sendto(sock, DATA, sizeof(DATA), 0, &name, sizeof(name)) < 0)
- perror("sending datagram message");
- close(sock);
-}
diff --git a/share/doc/psd/20.ipctut/fig2.pic b/share/doc/psd/20.ipctut/fig2.pic
deleted file mode 100644
index b4ce7ea619b..00000000000
--- a/share/doc/psd/20.ipctut/fig2.pic
+++ /dev/null
@@ -1,79 +0,0 @@
-.\" $OpenBSD: fig2.pic,v 1.2 2001/02/03 08:15:05 niklas Exp $
-.\"
-.\" Copyright (c) 1993
-.\" The Regents of the University of California. All rights reserved.
-.\"
-.\" @(#)fig2.pic 8.1 (Berkeley) 8/14/93
-.PS
-.ps
-.ps 10
-arc at 5.407,4.723 from 5.375,4.838 to 5.362,4.612 cw
-arc at 5.907,7.973 from 5.875,8.088 to 5.862,7.862 cw
-line from 5.963,5.513 to 6.925,5.513
-line from 5.963,5.650 to 6.925,5.650
-line from 5.963,5.787 to 6.925,5.787
-line from 5.963,5.912 to 6.925,5.912
-line from 5.963,6.050 to 6.925,6.050
-line from 5.963,6.200 to 6.925,6.200 to 6.925,5.375 to 5.963,5.375 to 5.963,6.200
-ellipse at 6.388,6.713 wid 0.475 ht 0.475
-line from 6.388,6.463 to 6.388,6.200
-line from 3.150,6.200 to 4.112,6.200 to 4.112,5.375 to 3.150,5.375 to 3.150,6.200
-line from 3.150,6.050 to 4.112,6.050
-line from 3.150,5.912 to 4.112,5.912
-line from 3.150,5.787 to 4.112,5.787
-line from 3.150,5.650 to 4.112,5.650
-line from 3.150,5.513 to 4.112,5.513
-ellipse at 3.575,6.713 wid 0.475 ht 0.475
-line from 3.575,6.463 to 3.575,6.200
-line from 3.650,8.762 to 4.612,8.762
-line from 3.650,8.900 to 4.612,8.900
-line from 3.650,9.037 to 4.612,9.037
-line from 3.650,9.162 to 4.612,9.162
-line from 3.650,9.300 to 4.612,9.300
-line from 3.650,9.450 to 4.612,9.450 to 4.612,8.625 to 3.650,8.625 to 3.650,9.450
-ellipse at 4.075,9.963 wid 0.475 ht 0.475
-ellipse at 3.950,4.725 wid 0.225 ht 0.225
-ellipse at 4.450,7.975 wid 0.225 ht 0.225
-dashwid = 0.037i
-line dotted from 1.925,7.513 to 8.238,7.513
-line from 6.050,6.138 to 5.737,6.138 to 5.737,4.700 to 5.550,4.700
-line from 5.650,4.725 to 5.550,4.700 to 5.650,4.675
-line from 6.050,6.013 to 4.050,4.888
-line from 4.125,4.958 to 4.050,4.888 to 4.149,4.915
-line from 3.975,6.000 to 4.525,5.987 to 3.925,4.875
-line from 3.950,4.975 to 3.925,4.875 to 3.994,4.951
-line from 3.975,6.112 to 5.650,6.112 to 5.650,4.750 to 5.550,4.763
-line from 5.652,4.775 to 5.550,4.763 to 5.646,4.725
-line from 4.075,9.713 to 4.075,9.450
-line from 4.475,9.363 to 6.150,9.363 to 6.150,8.000 to 6.050,8.012
-line from 6.152,8.025 to 6.050,8.012 to 6.146,7.975
-line from 4.475,9.250 to 5.025,9.238 to 4.425,8.125
-line from 4.450,8.225 to 4.425,8.125 to 4.494,8.201
-.ps
-.ps 20
-line from 4.362,4.775 to 4.162,4.725 to 4.362,4.675
-line from 4.162,4.725 to 4.838,4.725
-.ps
-.ps 10
-line from 3.962,4.600 to 5.375,4.600
-line from 3.950,4.838 to 5.375,4.838
-line from 4.450,8.088 to 5.875,8.088
-line from 4.463,7.850 to 5.875,7.850
-.ps
-.ps 20
-line from 4.862,8.025 to 4.662,7.975 to 4.862,7.925
-line from 4.662,7.975 to 5.338,7.975
-.ps
-.ps 11
-.ft
-.ft R
-"Child" at 6.362,7.106
-.ps
-.ps 12
-"Parent" at 3.362,7.096 ljust
-"Parent" at 3.862,10.346 ljust
-"PIPE" at 4.987,4.671 ljust
-"PIPE" at 5.425,7.921 ljust
-.ps
-.ft
-.PE
diff --git a/share/doc/psd/20.ipctut/fig2.xfig b/share/doc/psd/20.ipctut/fig2.xfig
deleted file mode 100644
index 59b46be37b8..00000000000
--- a/share/doc/psd/20.ipctut/fig2.xfig
+++ /dev/null
@@ -1,100 +0,0 @@
-#FIG 2.0
-80 2
-5 1 0 1 0 0 0 0 0.000 0 0 0 432.554 462.170 430 453 442 461 429 471
-5 1 0 1 0 0 0 0 0.000 0 0 0 472.554 202.170 470 193 482 201 469 211
-6 414 279 589 424
-6 473 340 557 414
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 399 554 399 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 388 554 388 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 377 554 377 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 367 554 367 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 356 554 356 9999 9999
-2 2 0 1 0 0 0 0 0.000 0 0
- 477 344 554 344 554 410 477 410 477 344 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 511 303 19 19 511 303 525 317
-2 1 0 1 0 0 0 0 0.000 0 0
- 511 323 511 344 9999 9999
--6
-6 189 279 364 424
-6 248 340 332 414
-2 2 0 1 0 0 0 0 0.000 0 0
- 252 344 329 344 329 410 252 410 252 344 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 356 329 356 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 367 329 367 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 377 329 377 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 388 329 388 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 399 329 399 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 286 303 19 19 286 303 300 317
-2 1 0 1 0 0 0 0 0.000 0 0
- 286 323 286 344 9999 9999
--6
-6 288 80 372 154
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 139 369 139 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 128 369 128 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 117 369 117 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 107 369 107 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 96 369 96 9999 9999
-2 2 0 1 0 0 0 0 0.000 0 0
- 292 84 369 84 369 150 292 150 292 84 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 326 43 19 19 326 43 340 57
-1 3 0 1 0 0 0 0 0.000 1 0.000 316 462 9 9 316 462 322 469
-1 3 0 1 0 0 0 0 0.000 1 0.000 356 202 9 9 356 202 362 209
-2 1 2 1 0 0 0 0 3.000 0 0
- 154 239 659 239 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 349 459 349 459 464 444 464 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 359 324 449 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 318 360 362 361 314 450 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 318 351 452 351 452 460 444 459 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 326 63 326 84 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 358 91 492 91 492 200 484 199 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 358 100 402 101 354 190 9999 9999
-2 1 0 2 0 0 0 0 0.000 0 1
- 0 0 2.000 8.000 16.000
- 333 462 387 462 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 317 472 430 472 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 316 453 430 453 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 356 193 470 193 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 357 212 470 212 9999 9999
-2 1 0 2 0 0 0 0 0.000 0 1
- 0 0 2.000 8.000 16.000
- 373 202 427 202 9999 9999
-4 1 0 11 0 0 0 0.000 1 7 24 509 274 Child
-4 0 0 12 0 0 0 0.000 1 9 33 269 275 Parent
-4 0 0 12 0 0 0 0.000 1 9 33 309 15 Parent
-4 0 0 12 0 0 0 0.000 1 9 26 399 469 PIPE
-4 0 0 12 0 0 0 0.000 1 9 26 434 209 PIPE
diff --git a/share/doc/psd/20.ipctut/fig3.pic b/share/doc/psd/20.ipctut/fig3.pic
deleted file mode 100644
index 6f2adcdf8f2..00000000000
--- a/share/doc/psd/20.ipctut/fig3.pic
+++ /dev/null
@@ -1,71 +0,0 @@
-.\" $OpenBSD: fig3.pic,v 1.2 2001/02/03 08:15:05 niklas Exp $
-.\"
-.\" Copyright (c) 1993
-.\" The Regents of the University of California. All rights reserved.
-.\"
-.\" @(#)fig3.pic 8.1 (Berkeley) 8/14/93
-.PS
-.ps
-.ps 10
-ellipse at 5.787,8.012 wid 0.275 ht 0.275
-ellipse at 4.175,8.012 wid 0.275 ht 0.275
-dashwid = 0.037i
-line dotted from 5.550,8.012 to 4.362,8.012
-line from 4.462,8.037 to 4.362,8.012 to 4.462,7.987
-line dotted from 4.362,7.950 to 5.550,7.950
-line from 5.450,7.925 to 5.550,7.950 to 5.450,7.975
-ellipse at 3.737,4.763 wid 0.275 ht 0.275
-ellipse at 5.350,4.763 wid 0.275 ht 0.275
-line dotted from 3.925,4.700 to 5.112,4.700
-line from 5.013,4.675 to 5.112,4.700 to 5.013,4.725
-line dotted from 5.112,4.763 to 3.925,4.763
-line from 4.025,4.788 to 3.925,4.763 to 4.025,4.737
-line from 5.963,5.513 to 6.925,5.513
-line from 5.963,5.650 to 6.925,5.650
-line from 5.963,5.787 to 6.925,5.787
-line from 5.963,5.912 to 6.925,5.912
-line from 5.963,6.050 to 6.925,6.050
-line from 5.963,6.200 to 6.925,6.200 to 6.925,5.375 to 5.963,5.375 to 5.963,6.200
-ellipse at 6.388,6.713 wid 0.475 ht 0.475
-line from 6.388,6.463 to 6.388,6.200
-line from 3.150,6.200 to 4.112,6.200 to 4.112,5.375 to 3.150,5.375 to 3.150,6.200
-line from 3.150,6.050 to 4.112,6.050
-line from 3.150,5.912 to 4.112,5.912
-line from 3.150,5.787 to 4.112,5.787
-line from 3.150,5.650 to 4.112,5.650
-line from 3.150,5.513 to 4.112,5.513
-ellipse at 3.575,6.713 wid 0.475 ht 0.475
-line from 3.575,6.463 to 3.575,6.200
-line from 3.650,8.762 to 4.612,8.762
-line from 3.650,8.900 to 4.612,8.900
-line from 3.650,9.037 to 4.612,9.037
-line from 3.650,9.162 to 4.612,9.162
-line from 3.650,9.300 to 4.612,9.300
-line from 3.650,9.450 to 4.612,9.450 to 4.612,8.625 to 3.650,8.625 to 3.650,9.450
-ellipse at 4.075,9.963 wid 0.475 ht 0.475
-line from 3.975,6.112 to 5.650,6.112 to 5.650,4.750 to 5.550,4.763
-line from 5.652,4.775 to 5.550,4.763 to 5.646,4.725
-line from 6.050,6.138 to 5.737,6.138 to 5.737,4.700 to 5.550,4.700
-line from 5.650,4.725 to 5.550,4.700 to 5.650,4.675
-line dotted from 1.925,7.513 to 8.238,7.513
-line from 6.050,6.013 to 4.050,4.888
-line from 4.125,4.958 to 4.050,4.888 to 4.149,4.915
-line from 3.975,6.000 to 4.525,5.987 to 3.925,4.875
-line from 3.950,4.975 to 3.925,4.875 to 3.994,4.951
-line from 4.075,9.713 to 4.075,9.450
-line from 4.475,9.363 to 6.150,9.363 to 6.150,8.000 to 6.050,8.012
-line from 6.152,8.025 to 6.050,8.012 to 6.146,7.975
-line from 4.475,9.250 to 5.025,9.238 to 4.425,8.125
-line from 4.450,8.225 to 4.425,8.125 to 4.494,8.201
-.ps
-.ps 11
-.ft
-.ft R
-"Child" at 6.362,7.106
-.ps
-.ps 12
-"Parent" at 3.362,7.096 ljust
-"Parent" at 3.862,10.346 ljust
-.ps
-.ft
-.PE
diff --git a/share/doc/psd/20.ipctut/fig3.xfig b/share/doc/psd/20.ipctut/fig3.xfig
deleted file mode 100644
index ed65b70bd18..00000000000
--- a/share/doc/psd/20.ipctut/fig3.xfig
+++ /dev/null
@@ -1,100 +0,0 @@
-#FIG 2.0
-80 2
-6 309 184 479 214
-1 3 0 1 0 0 0 0 0.000 1 0.000 463 199 11 11 463 199 468 209
-1 3 0 1 0 0 0 0 0.000 1 0.000 334 199 11 11 334 199 339 209
-2 1 2 1 0 0 0 0 3.000 1 0
- 0 0 1.000 4.000 8.000
- 444 199 349 199 9999 9999
-2 1 2 1 0 0 0 0 3.000 1 0
- 0 0 1.000 4.000 8.000
- 349 204 444 204 9999 9999
--6
-6 274 444 444 474
-1 3 0 1 0 0 0 0 0.000 1 0.000 299 459 11 11 299 459 304 469
-1 3 0 1 0 0 0 0 0.000 1 0.000 428 459 11 11 428 459 433 469
-2 1 2 1 0 0 0 0 3.000 1 0
- 0 0 1.000 4.000 8.000
- 314 464 409 464 9999 9999
-2 1 2 1 0 0 0 0 3.000 1 0
- 0 0 1.000 4.000 8.000
- 409 459 314 459 9999 9999
--6
-6 414 279 589 424
-6 473 340 557 414
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 399 554 399 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 388 554 388 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 377 554 377 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 367 554 367 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 356 554 356 9999 9999
-2 2 0 1 0 0 0 0 0.000 0 0
- 477 344 554 344 554 410 477 410 477 344 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 511 303 19 19 511 303 525 317
-2 1 0 1 0 0 0 0 0.000 0 0
- 511 323 511 344 9999 9999
--6
-6 189 279 364 424
-6 248 340 332 414
-2 2 0 1 0 0 0 0 0.000 0 0
- 252 344 329 344 329 410 252 410 252 344 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 356 329 356 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 367 329 367 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 377 329 377 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 388 329 388 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 399 329 399 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 286 303 19 19 286 303 300 317
-2 1 0 1 0 0 0 0 0.000 0 0
- 286 323 286 344 9999 9999
--6
-6 288 80 372 154
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 139 369 139 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 128 369 128 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 117 369 117 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 107 369 107 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 292 96 369 96 9999 9999
-2 2 0 1 0 0 0 0 0.000 0 0
- 292 84 369 84 369 150 292 150 292 84 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 326 43 19 19 326 43 340 57
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 318 351 452 351 452 460 444 459 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 349 459 349 459 464 444 464 9999 9999
-2 1 2 1 0 0 0 0 3.000 0 0
- 154 239 659 239 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 359 324 449 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 318 360 362 361 314 450 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 326 63 326 84 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 358 91 492 91 492 200 484 199 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 358 100 402 101 354 190 9999 9999
-4 1 0 11 0 0 0 0.000 1 7 24 509 274 Child
-4 0 0 12 0 0 0 0.000 1 9 33 269 275 Parent
-4 0 0 12 0 0 0 0.000 1 9 33 309 15 Parent
diff --git a/share/doc/psd/20.ipctut/fig8.pic b/share/doc/psd/20.ipctut/fig8.pic
deleted file mode 100644
index 4b1b37675fa..00000000000
--- a/share/doc/psd/20.ipctut/fig8.pic
+++ /dev/null
@@ -1,81 +0,0 @@
-.\" $OpenBSD: fig8.pic,v 1.2 2001/02/03 08:15:05 niklas Exp $
-.\"
-.\" Copyright (c) 1993
-.\" The Regents of the University of California. All rights reserved.
-.\"
-.\" @(#)fig8.pic 8.1 (Berkeley) 8/14/93
-.PS
-.ps
-.ps 11
-.ft
-.ft R
-"Process 1" at 3.800,7.106 rjust
-"Process 2" at 6.612,7.106 rjust
-.ps
-.ps 10
-line from 3.150,6.200 to 4.112,6.200 to 4.112,5.375 to 3.150,5.375 to 3.150,6.200
-line from 3.150,6.050 to 4.112,6.050
-line from 3.150,5.912 to 4.112,5.912
-line from 3.150,5.787 to 4.112,5.787
-line from 3.150,5.650 to 4.112,5.650
-line from 3.150,5.513 to 4.112,5.513
-ellipse at 3.575,6.713 wid 0.475 ht 0.475
-line from 3.575,6.463 to 3.575,6.200
-line from 5.963,5.513 to 6.925,5.513
-line from 5.963,5.650 to 6.925,5.650
-line from 5.963,5.787 to 6.925,5.787
-line from 5.963,5.912 to 6.925,5.912
-line from 5.963,6.050 to 6.925,6.050
-line from 5.963,6.200 to 6.925,6.200 to 6.925,5.375 to 5.963,5.375 to 5.963,6.200
-ellipse at 6.388,6.713 wid 0.475 ht 0.475
-line from 6.388,6.463 to 6.388,6.200
-line from 3.087,8.637 to 4.050,8.637
-line from 3.087,8.775 to 4.050,8.775
-line from 3.087,8.912 to 4.050,8.912
-line from 3.087,9.037 to 4.050,9.037
-line from 3.087,9.175 to 4.050,9.175
-line from 3.087,9.325 to 4.050,9.325 to 4.050,8.500 to 3.087,8.500 to 3.087,9.325
-ellipse at 3.513,9.838 wid 0.475 ht 0.475
-line from 3.513,9.588 to 3.513,9.325
-line from 5.900,9.325 to 6.862,9.325 to 6.862,8.500 to 5.900,8.500 to 5.900,9.325
-line from 5.900,9.175 to 6.862,9.175
-line from 5.900,9.037 to 6.862,9.037
-line from 5.900,8.912 to 6.862,8.912
-line from 5.900,8.775 to 6.862,8.775
-line from 5.900,8.637 to 6.862,8.637
-ellipse at 6.325,9.838 wid 0.475 ht 0.475
-line from 6.325,9.588 to 6.325,9.325
-.ps
-.ps 11
-"Process 2" at 6.550,10.231 rjust
-"Process 1" at 3.737,10.231 rjust
-.ps
-.ps 10
-ellipse at 6.112,4.888 wid 0.275 ht 0.275
-ellipse at 5.350,4.763 wid 0.275 ht 0.275
-ellipse at 3.737,4.763 wid 0.275 ht 0.275
-ellipse at 4.550,7.950 wid 0.275 ht 0.275
-ellipse at 5.487,7.950 wid 0.275 ht 0.275
-line from 6.050,6.013 to 5.175,6.013 to 5.987,5.013
-line from 5.905,5.074 to 5.987,5.013 to 5.944,5.106
-line from 6.050,6.138 to 5.737,6.138 to 5.737,4.700 to 5.550,4.700
-line from 5.650,4.725 to 5.550,4.700 to 5.650,4.675
-dashwid = 0.037i
-line dotted from 1.925,7.513 to 8.238,7.513
-line from 3.975,6.000 to 4.525,5.987 to 3.925,4.875
-line from 3.950,4.975 to 3.925,4.875 to 3.994,4.951
-line dotted from 5.112,4.763 to 3.925,4.763
-line from 4.025,4.788 to 3.925,4.763 to 4.025,4.737
-line dotted from 3.925,4.700 to 5.112,4.700
-line from 5.013,4.675 to 5.112,4.700 to 5.013,4.725
-line from 6.050,9.012 to 5.487,9.012 to 5.487,8.137
-line from 5.462,8.237 to 5.487,8.137 to 5.513,8.237
-line from 3.737,9.137 to 4.550,9.137 to 4.550,8.137
-line from 4.525,8.237 to 4.550,8.137 to 4.575,8.237
-.ps
-.ps 11
-"NAME" at 6.737,4.918 rjust
-"NAME" at 6.112,8.043 rjust
-.ps
-.ft
-.PE
diff --git a/share/doc/psd/20.ipctut/fig8.xfig b/share/doc/psd/20.ipctut/fig8.xfig
deleted file mode 100644
index f1a52576857..00000000000
--- a/share/doc/psd/20.ipctut/fig8.xfig
+++ /dev/null
@@ -1,116 +0,0 @@
-#FIG 2.0
-80 2
-6 224 254 589 279
-4 2 0 11 0 0 0 0.000 1 7 38 304 274 Process 1
-4 2 0 11 0 0 0 0.000 1 7 38 529 274 Process 2
--6
-6 189 279 364 424
-6 248 340 332 414
-2 2 0 1 0 0 0 0 0.000 0 0
- 252 344 329 344 329 410 252 410 252 344 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 356 329 356 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 367 329 367 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 377 329 377 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 388 329 388 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 252 399 329 399 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 286 303 19 19 286 303 300 317
-2 1 0 1 0 0 0 0 0.000 0 0
- 286 323 286 344 9999 9999
--6
-6 414 279 589 424
-6 473 340 557 414
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 399 554 399 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 388 554 388 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 377 554 377 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 367 554 367 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 477 356 554 356 9999 9999
-2 2 0 1 0 0 0 0 0.000 0 0
- 477 344 554 344 554 410 477 410 477 344 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 511 303 19 19 511 303 525 317
-2 1 0 1 0 0 0 0 0.000 0 0
- 511 323 511 344 9999 9999
--6
-6 184 29 359 174
-6 243 90 327 164
-2 1 0 1 0 0 0 0 0.000 0 0
- 247 149 324 149 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 247 138 324 138 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 247 127 324 127 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 247 117 324 117 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 247 106 324 106 9999 9999
-2 2 0 1 0 0 0 0 0.000 0 0
- 247 94 324 94 324 160 247 160 247 94 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 281 53 19 19 281 53 295 67
-2 1 0 1 0 0 0 0 0.000 0 0
- 281 73 281 94 9999 9999
--6
-6 409 29 584 174
-6 468 90 552 164
-2 2 0 1 0 0 0 0 0.000 0 0
- 472 94 549 94 549 160 472 160 472 94 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 472 106 549 106 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 472 117 549 117 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 472 127 549 127 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 472 138 549 138 9999 9999
-2 1 0 1 0 0 0 0 0.000 0 0
- 472 149 549 149 9999 9999
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 506 53 19 19 506 53 520 67
-2 1 0 1 0 0 0 0 0.000 0 0
- 506 73 506 94 9999 9999
--6
-6 219 4 584 29
-4 2 0 11 0 0 0 0.000 1 7 38 524 24 Process 2
-4 2 0 11 0 0 0 0.000 1 7 38 299 24 Process 1
--6
-1 3 0 1 0 0 0 0 0.000 1 0.000 489 449 11 11 489 449 494 459
-1 3 0 1 0 0 0 0 0.000 1 0.000 428 459 11 11 428 459 433 469
-1 3 0 1 0 0 0 0 0.000 1 0.000 299 459 11 11 299 459 304 469
-1 3 0 1 0 0 0 0 0.000 1 0.000 364 204 11 11 364 204 369 214
-1 3 0 1 0 0 0 0 0.000 1 0.000 439 204 11 11 439 204 444 214
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 359 414 359 479 439 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 349 459 349 459 464 444 464 9999 9999
-2 1 2 1 0 0 0 0 3.000 0 0
- 154 239 659 239 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 318 360 362 361 314 450 9999 9999
-2 1 2 1 0 0 0 0 3.000 1 0
- 0 0 1.000 4.000 8.000
- 409 459 314 459 9999 9999
-2 1 2 1 0 0 0 0 3.000 1 0
- 0 0 1.000 4.000 8.000
- 314 464 409 464 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 484 119 439 119 439 189 9999 9999
-2 1 0 1 0 0 0 0 0.000 1 0
- 0 0 1.000 4.000 8.000
- 299 109 364 109 364 189 9999 9999
-4 2 0 11 0 0 0 0.000 1 7 32 539 449 NAME
-4 2 0 11 0 0 0 0.000 1 7 32 489 199 NAME
diff --git a/share/doc/psd/20.ipctut/pipe.c b/share/doc/psd/20.ipctut/pipe.c
deleted file mode 100644
index cfdb0b6a0ff..00000000000
--- a/share/doc/psd/20.ipctut/pipe.c
+++ /dev/null
@@ -1,72 +0,0 @@
-.\" $OpenBSD: pipe.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)pipe.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <stdio.h>
-
-#define DATA "Bright star, would I were steadfast as thou art . . ."
-
-/*
- * This program creates a pipe, then forks. The child communicates to the
- * parent over the pipe. Notice that a pipe is a one-way communications
- * device. I can write to the output socket (sockets[1], the second socket
- * of the array returned by pipe()) and read from the input socket
- * (sockets[0]), but not vice versa.
- */
-
-main()
-{
- int sockets[2], child;
-
- /* Create a pipe */
- if (pipe(sockets) < 0) {
- perror("opening stream socket pair");
- exit(10);
- }
-
- if ((child = fork()) == -1)
- perror("fork");
- else if (child) {
- char buf[1024];
-
- /* This is still the parent. It reads the child's message. */
- close(sockets[1]);
- if (read(sockets[0], buf, 1024) < 0)
- perror("reading message");
- printf("-->%s\en", buf);
- close(sockets[0]);
- } else {
- /* This is the child. It writes a message to its parent. */
- close(sockets[0]);
- if (write(sockets[1], DATA, sizeof(DATA)) < 0)
- perror("writing message");
- close(sockets[1]);
- }
-}
diff --git a/share/doc/psd/20.ipctut/socketpair.c b/share/doc/psd/20.ipctut/socketpair.c
deleted file mode 100644
index 6222e5935d8..00000000000
--- a/share/doc/psd/20.ipctut/socketpair.c
+++ /dev/null
@@ -1,75 +0,0 @@
-.\" $OpenBSD: socketpair.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)socketpair.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <stdio.h>
-
-#define DATA1 "In Xanadu, did Kublai Khan . . ."
-#define DATA2 "A stately pleasure dome decree . . ."
-
-/*
- * This program creates a pair of connected sockets then forks and
- * communicates over them. This is very similar to communication with pipes,
- * however, socketpairs are two-way communications objects. Therefore I can
- * send messages in both directions.
- */
-
-main()
-{
- int sockets[2], child;
- char buf[1024];
-
- if (socketpair(AF_UNIX, SOCK_STREAM, 0, sockets) < 0) {
- perror("opening stream socket pair");
- exit(1);
- }
-
- if ((child = fork()) == -1)
- perror("fork");
- else if (child) { /* This is the parent. */
- close(sockets[0]);
- if (read(sockets[1], buf, 1024, 0) < 0)
- perror("reading stream message");
- printf("-->%s\en", buf);
- if (write(sockets[1], DATA2, sizeof(DATA2)) < 0)
- perror("writing stream message");
- close(sockets[1]);
- } else { /* This is the child. */
- close(sockets[1]);
- if (write(sockets[0], DATA1, sizeof(DATA1)) < 0)
- perror("writing stream message");
- if (read(sockets[0], buf, 1024, 0) < 0)
- perror("reading stream message");
- printf("-->%s\en", buf);
- close(sockets[0]);
- }
-}
diff --git a/share/doc/psd/20.ipctut/strchkread.c b/share/doc/psd/20.ipctut/strchkread.c
deleted file mode 100644
index cc045debab2..00000000000
--- a/share/doc/psd/20.ipctut/strchkread.c
+++ /dev/null
@@ -1,104 +0,0 @@
-.\" $OpenBSD: strchkread.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)strchkread.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <sys/time.h>
-#include <netinet/in.h>
-#include <netdb.h>
-#include <stdio.h>
-#define TRUE 1
-
-/*
- * This program uses select() to check that someone is trying to connect
- * before calling accept().
- */
-
-main()
-{
- int sock, length;
- struct sockaddr_in server;
- int msgsock;
- char buf[1024];
- int rval;
- fd_set ready;
- struct timeval to;
-
- /* Create socket */
- sock = socket(AF_INET, SOCK_STREAM, 0);
- if (sock < 0) {
- perror("opening stream socket");
- exit(1);
- }
- /* Name socket using wildcards */
- server.sin_family = AF_INET;
- server.sin_addr.s_addr = INADDR_ANY;
- server.sin_port = 0;
- if (bind(sock, &server, sizeof(server))) {
- perror("binding stream socket");
- exit(1);
- }
- /* Find out assigned port number and print it out */
- length = sizeof(server);
- if (getsockname(sock, &server, &length)) {
- perror("getting socket name");
- exit(1);
- }
- printf("Socket has port #%d\en", ntohs(server.sin_port));
-
- /* Start accepting connections */
- listen(sock, 5);
- do {
- FD_ZERO(&ready);
- FD_SET(sock, &ready);
- to.tv_sec = 5;
- if (select(sock + 1, &ready, 0, 0, &to) < 0) {
- perror("select");
- continue;
- }
- if (FD_ISSET(sock, &ready)) {
- msgsock = accept(sock, (struct sockaddr *)0, (int *)0);
- if (msgsock == -1)
- perror("accept");
- else do {
- bzero(buf, sizeof(buf));
- if ((rval = read(msgsock, buf, 1024)) < 0)
- perror("reading stream message");
- else if (rval == 0)
- printf("Ending connection\en");
- else
- printf("-->%s\en", buf);
- } while (rval > 0);
- close(msgsock);
- } else
- printf("Do something else\en");
- } while (TRUE);
-}
diff --git a/share/doc/psd/20.ipctut/streamread.c b/share/doc/psd/20.ipctut/streamread.c
deleted file mode 100644
index 2d339e29a71..00000000000
--- a/share/doc/psd/20.ipctut/streamread.c
+++ /dev/null
@@ -1,100 +0,0 @@
-.\" $OpenBSD: streamread.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)streamread.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <netdb.h>
-#include <stdio.h>
-#define TRUE 1
-
-/*
- * This program creates a socket and then begins an infinite loop. Each time
- * through the loop it accepts a connection and prints out messages from it.
- * When the connection breaks, or a termination message comes through, the
- * program accepts a new connection.
- */
-
-main()
-{
- int sock, length;
- struct sockaddr_in server;
- int msgsock;
- char buf[1024];
- int rval;
- int i;
-
- /* Create socket */
- sock = socket(AF_INET, SOCK_STREAM, 0);
- if (sock < 0) {
- perror("opening stream socket");
- exit(1);
- }
- /* Name socket using wildcards */
- server.sin_family = AF_INET;
- server.sin_addr.s_addr = INADDR_ANY;
- server.sin_port = 0;
- if (bind(sock, &server, sizeof(server))) {
- perror("binding stream socket");
- exit(1);
- }
- /* Find out assigned port number and print it out */
- length = sizeof(server);
- if (getsockname(sock, &server, &length)) {
- perror("getting socket name");
- exit(1);
- }
- printf("Socket has port #%d\en", ntohs(server.sin_port));
-
- /* Start accepting connections */
- listen(sock, 5);
- do {
- msgsock = accept(sock, 0, 0);
- if (msgsock == -1)
- perror("accept");
- else do {
- bzero(buf, sizeof(buf));
- if ((rval = read(msgsock, buf, 1024)) < 0)
- perror("reading stream message");
- i = 0;
- if (rval == 0)
- printf("Ending connection\en");
- else
- printf("-->%s\en", buf);
- } while (rval != 0);
- close(msgsock);
- } while (TRUE);
- /*
- * Since this program has an infinite loop, the socket "sock" is
- * never explicitly closed. However, all sockets will be closed
- * automatically when a process is killed or terminates normally.
- */
-}
diff --git a/share/doc/psd/20.ipctut/streamwrite.c b/share/doc/psd/20.ipctut/streamwrite.c
deleted file mode 100644
index 22282cdb24f..00000000000
--- a/share/doc/psd/20.ipctut/streamwrite.c
+++ /dev/null
@@ -1,79 +0,0 @@
-.\" $OpenBSD: streamwrite.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)streamwrite.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <netdb.h>
-#include <stdio.h>
-
-#define DATA "Half a league, half a league . . ."
-
-/*
- * This program creates a socket and initiates a connection with the socket
- * given in the command line. One message is sent over the connection and
- * then the socket is closed, ending the connection. The form of the command
- * line is streamwrite hostname portnumber
- */
-
-main(argc, argv)
- int argc;
- char *argv[];
-{
- int sock;
- struct sockaddr_in server;
- struct hostent *hp, *gethostbyname();
- char buf[1024];
-
- /* Create socket */
- sock = socket(AF_INET, SOCK_STREAM, 0);
- if (sock < 0) {
- perror("opening stream socket");
- exit(1);
- }
- /* Connect socket using name specified by command line. */
- server.sin_family = AF_INET;
- hp = gethostbyname(argv[1]);
- if (hp == 0) {
- fprintf(stderr, "%s: unknown host\n", argv[1]);
- exit(2);
- }
- bcopy(hp->h_addr, &server.sin_addr, hp->h_length);
- server.sin_port = htons(atoi(argv[2]));
-
- if (connect(sock, &server, sizeof(server)) < 0) {
- perror("connecting stream socket");
- exit(1);
- }
- if (write(sock, DATA, sizeof(DATA)) < 0)
- perror("writing on stream socket");
- close(sock);
-}
diff --git a/share/doc/psd/20.ipctut/tutor.me b/share/doc/psd/20.ipctut/tutor.me
deleted file mode 100644
index 6afafec92ac..00000000000
--- a/share/doc/psd/20.ipctut/tutor.me
+++ /dev/null
@@ -1,937 +0,0 @@
-.\" $OpenBSD: tutor.me,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)tutor.me 8.1 (Berkeley) 8/14/93
-.\"
-.oh 'Introductory 4.4BSD IPC''PSD:20-%'
-.eh 'PSD:20-%''Introductory 4.4BSD IPC'
-.rs
-.sp 2
-.sz 14
-.ft B
-.ce 2
-An Introductory 4.4BSD
-Interprocess Communication Tutorial
-.sz 10
-.sp 2
-.ce
-.i "Stuart Sechrest"
-.ft
-.sp
-.ce 4
-Computer Science Research Group
-Computer Science Division
-Department of Electrical Engineering and Computer Science
-University of California, Berkeley
-.sp 2
-.ce
-.i ABSTRACT
-.sp
-.(c
-.pp
-Berkeley UNIX\(dg 4.4BSD offers several choices for interprocess communication.
-To aid the programmer in developing programs which are comprised of
-cooperating
-processes, the different choices are discussed and a series of example
-programs are presented. These programs
-demonstrate in a simple way the use of pipes, socketpairs, sockets
-and the use of datagram and stream communication. The intent of this
-document is to present a few simple example programs, not to describe the
-networking system in full.
-.)c
-.sp 2
-.(f
-\(dg\|UNIX is a trademark of AT&T Bell Laboratories.
-.)f
-.b
-.sh 1 "Goals"
-.r
-.pp
-Facilities for interprocess communication (IPC) and networking
-were a major addition to UNIX in the Berkeley UNIX 4.2BSD release.
-These facilities required major additions and some changes
-to the system interface.
-The basic idea of this interface is to make IPC similar to file I/O.
-In UNIX a process has a set of I/O descriptors, from which one reads
-and to which one writes.
-Descriptors may refer to normal files, to devices (including terminals),
-or to communication channels.
-The use of a descriptor has three phases: its creation,
-its use for reading and writing, and its destruction. By using descriptors
-to write files, rather than simply naming the target file in the write
-call, one gains a surprising amount of flexibility. Often, the program that
-creates a descriptor will be different from the program that uses the
-descriptor. For example the shell can create a descriptor for the output
-of the `ls'
-command that will cause the listing to appear in a file rather than
-on a terminal.
-Pipes are another form of descriptor that have been used in UNIX
-for some time.
-Pipes allow one-way data transmission from one process
-to another; the two processes and the pipe must be set up by a common
-ancestor.
-.pp
-The use of descriptors is not the only communication interface
-provided by UNIX.
-The signal mechanism sends a tiny amount of information from one
-process to another.
-The signaled process receives only the signal type,
-not the identity of the sender,
-and the number of possible signals is small.
-The signal semantics limit the flexibility of the signaling mechanism
-as a means of interprocess communication.
-.pp
-The identification of IPC with I/O is quite longstanding in UNIX and
-has proved quite successful. At first, however, IPC was limited to
-processes communicating within a single machine. With Berkeley UNIX
-4.2BSD this expanded to include IPC between machines. This expansion
-has necessitated some change in the way that descriptors are created.
-Additionally, new possibilities for the meaning of read and write have
-been admitted. Originally the meanings, or semantics, of these terms
-were fairly simple. When you wrote something it was delivered. When
-you read something, you were blocked until the data arrived.
-Other possibilities exist,
-however. One can write without full assurance of delivery if one can
-check later to catch occasional failures. Messages can be kept as
-discrete units or merged into a stream.
-One can ask to read, but insist on not waiting if nothing is immediately
-available. These new possibilities are allowed in the Berkeley UNIX IPC
-interface.
-.pp
-Thus Berkeley UNIX 4.4BSD offers several choices for IPC.
-This paper presents simple examples that illustrate some of
-the choices.
-The reader is presumed to be familiar with the C programming language
-[Kernighan & Ritchie 1978],
-but not necessarily with the system calls of the UNIX system or with
-processes and interprocess communication.
-The paper reviews the notion of a process and the types of
-communication that are supported by Berkeley UNIX 4.4BSD.
-A series of examples are presented that create processes that communicate
-with one another. The programs show different ways of establishing
-channels of communication.
-Finally, the calls that actually transfer data are reviewed.
-To clearly present how communication can take place,
-the example programs have been cleared of anything that
-might be construed as useful work.
-They can, therefore, serve as models
-for the programmer trying to construct programs which are comprised of
-cooperating processes.
-.b
-.sh 1 "Processes"
-.pp
-A \fIprogram\fP is both a sequence of statements and a rough way of referring
-to the computation that occurs when the compiled statements are run.
-A \fIprocess\fP can be thought of as a single line of control in a program.
-Most programs execute some statements, go through a few loops, branch in
-various directions and then end. These are single process programs.
-Programs can also have a point where control splits into two independent lines,
-an action called \fIforking.\fP
-In UNIX these lines can never join again. A call to the system routine
-\fIfork()\fP, causes a process to split in this way.
-The result of this call is that two independent processes will be
-running, executing exactly the same code.
-Memory values will be the same for all values set before the fork, but,
-subsequently, each version will be able to change only the
-value of its own copy of each variable.
-Initially, the only difference between the two will be the value returned by
-\fIfork().\fP The parent will receive a process id for the child,
-the child will receive a zero.
-Calls to \fIfork(),\fP
-therefore, typically precede, or are included in, an if-statement.
-.pp
-A process views the rest of the system through a private table of descriptors.
-The descriptors can represent open files or sockets (sockets are communication
-objects that will be discussed below). Descriptors are referred to
-by their index numbers in the table. The first three descriptors are often
-known by special names, \fI stdin, stdout\fP and \fIstderr\fP.
-These are the standard input, output and error.
-When a process forks, its descriptor table is copied to the child.
-Thus, if the parent's standard input is being taken from a terminal
-(devices are also treated as files in UNIX), the child's input will
-be taken from the
-same terminal. Whoever reads first will get the input. If, before forking,
-the parent changes its standard input so that it is reading from a
-new file, the child will take its input from the new file. It is
-also possible to take input from a socket, rather than from a file.
-.b
-.sh 1 "Pipes"
-.r
-.pp
-Most users of UNIX know that they can pipe the output of a
-program ``prog1'' to the input of another, ``prog2,'' by typing the command
-\fI``prog1 | prog2.''\fP
-This is called ``piping'' the output of one program
-to another because the mechanism used to transfer the output is called a
-pipe.
-When the user types a command, the command is read by the shell, which
-decides how to execute it. If the command is simple, for example,
-.i "``prog1,''"
-the shell forks a process, which executes the program, prog1, and then dies.
-The shell waits for this termination and then prompts for the next
-command.
-If the command is a compound command,
-.i "``prog1 | prog2,''"
-the shell creates two processes connected by a pipe. One process
-runs the program, prog1, the other runs prog2. The pipe is an I/O
-mechanism with two ends, or sockets. Data that is written into one socket
-can be read from the other.
-.(z
-.ft CW
-.so pipe.c
-.ft
-.ce 1
-Figure 1\ \ Use of a pipe
-.)z
-.pp
-Since a program specifies its input and output only by the descriptor table
-indices, which appear as variables or constants,
-the input source and output destination can be changed without
-changing the text of the program.
-It is in this way that the shell is able to set up pipes. Before executing
-prog1, the process can close whatever is at \fIstdout\fP
-and replace it with one
-end of a pipe. Similarly, the process that will execute prog2 can substitute
-the opposite end of the pipe for
-\fIstdin.\fP
-.pp
-Let us now examine a program that creates a pipe for communication between
-its child and itself (Figure 1).
-A pipe is created by a parent process, which then forks.
-When a process forks, the parent's descriptor table is copied into
-the child's.
-.pp
-In Figure 1, the parent process makes a call to the system routine
-\fIpipe().\fP
-This routine creates a pipe and places descriptors for the sockets
-for the two ends of the pipe in the process's descriptor table.
-\fIPipe()\fP
-is passed an array into which it places the index numbers of the
-sockets it created.
-The two ends are not equivalent. The socket whose index is
-returned in the low word of the array is opened for reading only,
-while the socket in the high end is opened only for writing.
-This corresponds to the fact that the standard input is the first
-descriptor of a process's descriptor table and the standard output
-is the second. After creating the pipe, the parent creates the child
-with which it will share the pipe by calling \fIfork().\fP
-Figure 2 illustrates the effect of a fork.
-The parent process's descriptor table points to both ends of the pipe.
-After the fork, both parent's and child's descriptor tables point to
-the pipe.
-The child can then use the pipe to send a message to the parent.
-.(z
-.so fig2.pic
-.ce 2
-Figure 2\ \ Sharing a pipe between parent and child
-.ce 0
-.)z
-.pp
-Just what is a pipe?
-It is a one-way communication mechanism, with one end opened
-for reading and the other end for writing.
-Therefore, parent and child need to agree on which way to turn
-the pipe, from parent to child or the other way around.
-Using the same pipe for communication both from parent to child and
-from child to parent would be possible (since both processes have
-references to both ends), but very complicated.
-If the parent and child are to have a two-way conversation,
-the parent creates two pipes, one for use in each direction.
-(In accordance with their plans, both parent and child in the example above
-close the socket that they will not use. It is not required that unused
-descriptors be closed, but it is good practice.)
-A pipe is also a \fIstream\fP communication mechanism; that
-is, all messages sent through the pipe are placed in order
-and reliably delivered. When the reader asks for a certain
-number of bytes from this
-stream, he is given as many bytes as are available, up
-to the amount of the request. Note that these bytes may have come from
-the same call to \fIwrite()\fR or from several calls to \fIwrite()\fR
-which were concatenated.
-.b
-.sh 1 "Socketpairs"
-.r
-.pp
-Berkeley UNIX 4.4BSD provides a slight generalization of pipes. A pipe is a
-pair of connected sockets for one-way stream communication. One may
-obtain a pair of connected sockets for two-way stream communication
-by calling the routine \fIsocketpair().\fP
-The program in Figure 3 calls \fIsocketpair()\fP
-to create such a connection. The program uses the link for
-communication in both directions. Since socketpairs are
-an extension of pipes, their use resembles that of pipes.
-Figure 4 illustrates the result of a fork following a call to
-\fIsocketpair().\fP
-.pp
-\fISocketpair()\fP
-takes as
-arguments a specification of a domain, a style of communication, and a
-protocol.
-These are the parameters shown in the example.
-Domains and protocols will be discussed in the next section.
-Briefly,
-a domain is a space of names that may be bound
-to sockets and implies certain other conventions.
-Currently, socketpairs have only been implemented for one
-domain, called the UNIX domain.
-The UNIX domain uses UNIX path names for naming sockets.
-It only allows communication
-between sockets on the same machine.
-.pp
-Note that the header files
-.i "<sys/socket.h>"
-and
-.i "<sys/types.h>."
-are required in this program.
-The constants AF_UNIX and SOCK_STREAM are defined in
-.i "<sys/socket.h>,"
-which in turn requires the file
-.i "<sys/types.h>"
-for some of its definitions.
-.(z
-.ft CW
-.so socketpair.c
-.ft
-.ce 1
-Figure 3\ \ Use of a socketpair
-.)z
-.(z
-.so fig3.pic
-.ce 1
-Figure 4\ \ Sharing a socketpair between parent and child
-.)z
-.b
-.sh 1 "Domains and Protocols"
-.r
-.pp
-Pipes and socketpairs are a simple solution for communicating between
-a parent and child or between child processes.
-What if we wanted to have processes that have no common ancestor
-with whom to set up communication?
-Neither standard UNIX pipes nor socketpairs are
-the answer here, since both mechanisms require a common ancestor to
-set up the communication.
-We would like to have two processes separately create sockets
-and then have messages sent between them. This is often the
-case when providing or using a service in the system. This is
-also the case when the communicating processes are on separate machines.
-In Berkeley UNIX 4.4BSD one can create individual sockets, give them names and
-send messages between them.
-.pp
-Sockets created by different programs use names to refer to one another;
-names generally must be translated into addresses for use.
-The space from which an address is drawn is referred to as a
-.i domain.
-There are several domains for sockets.
-Two that will be used in the examples here are the UNIX domain (or AF_UNIX,
-for Address Format UNIX) and the Internet domain (or AF_INET).
-UNIX domain IPC is an experimental facility in 4.2BSD and 4.3BSD.
-In the UNIX domain, a socket is given a path name within the file system
-name space.
-A file system node is created for the socket and other processes may
-then refer to the socket by giving the proper pathname.
-UNIX domain names, therefore, allow communication between any two processes
-that work in the same file system.
-The Internet domain is the UNIX implementation of the DARPA Internet
-standard protocols IP/TCP/UDP.
-Addresses in the Internet domain consist of a machine network address
-and an identifying number, called a port.
-Internet domain names allow communication between machines.
-.pp
-Communication follows some particular ``style.''
-Currently, communication is either through a \fIstream\fP
-or by \fIdatagram.\fP
-Stream communication implies several things. Communication takes
-place across a connection between two sockets. The communication
-is reliable, error-free, and, as in pipes, no message boundaries are
-kept. Reading from a stream may result in reading the data sent from
-one or several calls to \fIwrite()\fP
-or only part of the data from a single call, if there is not enough room
-for the entire message, or if not all the data from a large message
-has been transferred.
-The protocol implementing such a style will retransmit messages
-received with errors. It will also return error messages if one tries to
-send a message after the connection has been broken.
-Datagram communication does not use connections. Each message is
-addressed individually. If the address is correct, it will generally
-be received, although this is not guaranteed. Often datagrams are
-used for requests that require a response from the
-recipient. If no response
-arrives in a reasonable amount of time, the request is repeated.
-The individual datagrams will be kept separate when they are read, that
-is, message boundaries are preserved.
-.pp
-The difference in performance between the two styles of communication is
-generally less important than the difference in semantics. The
-performance gain that one might find in using datagrams must be weighed
-against the increased complexity of the program, which must now concern
-itself with lost or out of order messages. If lost messages may simply be
-ignored, the quantity of traffic may be a consideration. The expense
-of setting up a connection is best justified by frequent use of the connection.
-Since the performance of a protocol changes as it is tuned for different
-situations, it is best to seek the most up-to-date information when
-making choices for a program in which performance is crucial.
-.pp
-A protocol is a set of rules, data formats and conventions that regulate the
-transfer of data between participants in the communication.
-In general, there is one protocol for each socket type (stream,
-datagram, etc.) within each domain.
-The code that implements a protocol
-keeps track of the names that are bound to sockets,
-sets up connections and transfers data between sockets,
-perhaps sending the data across a network.
-This code also keeps track of the names that are bound to sockets.
-It is possible for several protocols, differing only in low level
-details, to implement the same style of communication within
-a particular domain. Although it is possible to select
-which protocol should be used, for nearly all uses it is sufficient to
-request the default protocol. This has been done in all of the example
-programs.
-.pp
-One specifies the domain, style and protocol of a socket when
-it is created. For example, in Figure 5a the call to \fIsocket()\fP
-causes the creation of a datagram socket with the default protocol
-in the UNIX domain.
-.b
-.sh 1 "Datagrams in the UNIX Domain"
-.r
-.(z
-.ft CW
-.so udgramread.c
-.ft
-.ce 1
-Figure 5a\ \ Reading UNIX domain datagrams
-.)z
-.pp
-Let us now look at two programs that create sockets separately.
-The programs in Figures 5a and 5b use datagram communication
-rather than a stream.
-The structure used to name UNIX domain sockets is defined
-in the file \fI<sys/un.h>.\fP
-The definition has also been included in the example for clarity.
-.pp
-Each program creates a socket with a call to \fIsocket().\fP
-These sockets are in the UNIX domain.
-Once a name has been decided upon it is attached to a socket by the
-system call \fIbind().\fP
-The program in Figure 5a uses the name ``socket'',
-which it binds to its socket.
-This name will appear in the working directory of the program.
-The routines in Figure 5b use its
-socket only for sending messages. It does not create a name for
-the socket because no other process has to refer to it.
-.(z
-.ft CW
-.so udgramsend.c
-.ft
-.ce 1
-Figure 5b\ \ Sending a UNIX domain datagrams
-.)z
-.pp
-Names in the UNIX domain are path names. Like file path names they may
-be either absolute (e.g. ``/dev/imaginary'') or relative (e.g. ``socket'').
-Because these names are used to allow processes to rendezvous, relative
-path names can pose difficulties and should be used with care.
-When a name is bound into the name space, a file (inode) is allocated in the
-file system. If
-the inode is not deallocated, the name will continue to exist even after
-the bound socket is closed. This can cause subsequent runs of a program
-to find that a name is unavailable, and can cause
-directories to fill up with these
-objects. The names are removed by calling \fIunlink()\fP or using
-the \fIrm\fP\|(1) command.
-Names in the UNIX domain are only used for rendezvous. They are not used
-for message delivery once a connection is established. Therefore, in
-contrast with the Internet domain, unbound sockets need not be (and are
-not) automatically given addresses when they are connected.
-.pp
-There is no established means of communicating names to interested
-parties. In the example, the program in Figure 5b gets the
-name of the socket to which it will send its message through its
-command line arguments. Once a line of communication has been created,
-one can send the names of additional, perhaps new, sockets over the link.
-Facilities will have to be built that will make the distribution of
-names less of a problem than it now is.
-.b
-.sh 1 "Datagrams in the Internet Domain"
-.r
-.(z
-.ft CW
-.so dgramread.c
-.ft
-.ce 1
-Figure 6a\ \ Reading Internet domain datagrams
-.)z
-.pp
-The examples in Figure 6a and 6b are very close to the previous example
-except that the socket is in the Internet domain.
-The structure of Internet domain addresses is defined in the file
-\fI<netinet/in.h>\fP.
-Internet addresses specify a host address (a 32-bit number)
-and a delivery slot, or port, on that
-machine. These ports are managed by the system routines that implement
-a particular protocol.
-Unlike UNIX domain names, Internet socket names are not entered into
-the file system and, therefore,
-they do not have to be unlinked after the socket has been closed.
-When a message must be sent between machines it is sent to
-the protocol routine on the destination machine, which interprets the
-address to determine to which socket the message should be delivered.
-Several different protocols may be active on
-the same machine, but, in general, they will not communicate with one another.
-As a result, different protocols are allowed to use the same port numbers.
-Thus, implicitly, an Internet address is a triple including a protocol as
-well as the port and machine address.
-An \fIassociation\fP is a temporary or permanent specification
-of a pair of communicating sockets.
-An association is thus identified by the tuple
-<\fIprotocol, local machine address, local port,
-remote machine address, remote port\fP>.
-An association may be transient when using datagram sockets;
-the association actually exists during a \fIsend\fP operation.
-.(z
-.ft CW
-.so dgramsend.c
-.ft
-.ce 1
-Figure 6b\ \ Sending an Internet domain datagram
-.)z
-.pp
-The protocol for a socket is chosen when the socket is created. The
-local machine address for a socket can be any valid network address of the
-machine, if it has more than one, or it can be the wildcard value
-INADDR_ANY.
-The wildcard value is used in the program in Figure 6a.
-If a machine has several network addresses, it is likely
-that messages sent to any of the addresses should be deliverable to
-a socket. This will be the case if the wildcard value has been chosen.
-Note that even if the wildcard value is chosen, a program sending messages
-to the named socket must specify a valid network address. One can be willing
-to receive from ``anywhere,'' but one cannot send a message ``anywhere.''
-The program in Figure 6b is given the destination host name as a command
-line argument.
-To determine a network address to which it can send the message, it looks
-up
-the host address by the call to \fIgethostbyname()\fP.
-The returned structure includes the host's network address,
-which is copied into the structure specifying the
-destination of the message.
-.pp
-The port number can be thought of as the number of a mailbox, into
-which the protocol places one's messages. Certain daemons, offering
-certain advertised services, have reserved
-or ``well-known'' port numbers. These fall in the range
-from 1 to 1023. Higher numbers are available to general users.
-Only servers need to ask for a particular number.
-The system will assign an unused port number when an address
-is bound to a socket.
-This may happen when an explicit \fIbind\fP
-call is made with a port number of 0, or
-when a \fIconnect\fP or \fIsend\fP
-is performed on an unbound socket.
-Note that port numbers are not automatically reported back to the user.
-After calling \fIbind(),\fP asking for port 0, one may call
-\fIgetsockname()\fP to discover what port was actually assigned.
-The routine \fIgetsockname()\fP
-will not work for names in the UNIX domain.
-.pp
-The format of the socket address is specified in part by standards within the
-Internet domain. The specification includes the order of the bytes in
-the address. Because machines differ in the internal representation
-they ordinarily use
-to represent integers, printing out the port number as returned by
-\fIgetsockname()\fP may result in a misinterpretation. To
-print out the number, it is necessary to use the routine \fIntohs()\fP
-(for \fInetwork to host: short\fP) to convert the number from the
-network representation to the host's representation. On some machines,
-such as 68000-based machines, this is a null operation. On others,
-such as VAXes, this results in a swapping of bytes. Another routine
-exists to convert a short integer from the host format to the network format,
-called \fIhtons()\fP; similar routines exist for long integers.
-For further information, refer to the
-entry for \fIbyteorder\fP in section 3 of the manual.
-.b
-.sh 1 "Connections"
-.r
-.pp
-To send data between stream sockets (having communication style SOCK_STREAM),
-the sockets must be connected.
-Figures 7a and 7b show two programs that create such a connection.
-The program in 7a is relatively simple.
-To initiate a connection, this program simply creates
-a stream socket, then calls \fIconnect()\fP,
-specifying the address of the socket to which
-it wishes its socket connected. Provided that the target socket exists and
-is prepared to handle a connection, connection will be complete,
-and the program can begin to send
-messages. Messages will be delivered in order without message
-boundaries, as with pipes. The connection is destroyed when either
-socket is closed (or soon thereafter). If a process persists
-in sending messages after the connection is closed, a SIGPIPE signal
-is sent to the process by the operating system. Unless explicit action
-is taken to handle the signal (see the manual page for \fIsignal\fP
-or \fIsigvec\fP),
-the process will terminate and the shell
-will print the message ``broken pipe.''
-.(z
-.ft CW
-.so streamwrite.c
-.ft
-.ce 1
-Figure 7a\ \ Initiating an Internet domain stream connection
-.)z
-.(z
-.ft CW
-.so streamread.c
-.ft
-.ce 1
-Figure 7b\ \ Accepting an Internet domain stream connection
-.sp 2
-.ft CW
-.so strchkread.c
-.ft
-.ce 1
-Figure 7c\ \ Using select() to check for pending connections
-.)z
-.(z
-.so fig8.pic
-.sp
-.ce 1
-Figure 8\ \ Establishing a stream connection
-.)z
-.pp
-Forming a connection is asymmetrical; one process, such as the
-program in Figure 7a, requests a connection with a particular socket,
-the other process accepts connection requests.
-Before a connection can be accepted a socket must be created and an address
-bound to it. This
-situation is illustrated in the top half of Figure 8. Process 2
-has created a socket and bound a port number to it. Process 1 has created an
-unnamed socket.
-The address bound to process 2's socket is then made known to process 1 and,
-perhaps to several other potential communicants as well.
-If there are several possible communicants,
-this one socket might receive several requests for connections.
-As a result, a new socket is created for each connection. This new socket
-is the endpoint for communication within this process for this connection.
-A connection may be destroyed by closing the corresponding socket.
-.pp
-The program in Figure 7b is a rather trivial example of a server. It
-creates a socket to which it binds a name, which it then advertises.
-(In this case it prints out the socket number.) The program then calls
-\fIlisten()\fP for this socket.
-Since several clients may attempt to connect more or less
-simultaneously, a queue of pending connections is maintained in the system
-address space. \fIListen()\fP
-marks the socket as willing to accept connections and initializes the queue.
-When a connection is requested, it is listed in the queue. If the
-queue is full, an error status may be returned to the requester.
-The maximum length of this queue is specified by the second argument of
-\fIlisten()\fP; the maximum length is limited by the system.
-Once the listen call has been completed, the program enters
-an infinite loop. On each pass through the loop, a new connection is
-accepted and removed from the queue, and, hence, a new socket for the
-connection is created. The bottom half of Figure 8 shows the result of
-Process 1 connecting with the named socket of Process 2, and Process 2
-accepting the connection. After the connection is created, the
-service, in this case printing out the messages, is performed and the
-connection socket closed. The \fIaccept()\fP
-call will take a pending connection
-request from the queue if one is available, or block waiting for a request.
-Messages are read from the connection socket.
-Reads from an active connection will normally block until data is available.
-The number of bytes read is returned. When a connection is destroyed,
-the read call returns immediately. The number of bytes returned will
-be zero.
-.pp
-The program in Figure 7c is a slight variation on the server in Figure 7b.
-It avoids blocking when there are no pending connection requests by
-calling \fIselect()\fP
-to check for pending requests before calling \fIaccept().\fP
-This strategy is useful when connections may be received
-on more than one socket, or when data may arrive on other connected
-sockets before another connection request.
-.pp
-The programs in Figures 9a and 9b show a program using stream communication
-in the UNIX domain. Streams in the UNIX domain can be used for this sort
-of program in exactly the same way as Internet domain streams, except for
-the form of the names and the restriction of the connections to a single
-file system. There are some differences, however, in the functionality of
-streams in the two domains, notably in the handling of
-\fIout-of-band\fP data (discussed briefly below). These differences
-are beyond the scope of this paper.
-.(z
-.ft CW
-.so ustreamwrite.c
-.ft
-.ce 1
-Figure 9a\ \ Initiating a UNIX domain stream connection
-.sp 2
-.ft CW
-.so ustreamread.c
-.ft
-.ce 1
-Figure 9b\ \ Accepting a UNIX domain stream connection
-.)z
-.b
-.sh 1 "Reads, Writes, Recvs, etc."
-.r
-.pp
-UNIX 4.4BSD has several system calls for reading and writing information.
-The simplest calls are \fIread() \fP and \fIwrite().\fP \fIWrite()\fP
-takes as arguments the index of a descriptor, a pointer to a buffer
-containing the data and the size of the data.
-The descriptor may indicate either a file or a connected socket.
-``Connected'' can mean either a connected stream socket (as described
-in Section 8) or a datagram socket for which a \fIconnect()\fP
-call has provided a default destination (see the \fIconnect()\fP manual page).
-\fIRead()\fP also takes a descriptor that indicates either a file or a socket.
-\fIWrite()\fP requires a connected socket since no destination is
-specified in the parameters of the system call.
-\fIRead()\fP can be used for either a connected or an unconnected socket.
-These calls are, therefore, quite flexible and may be used to
-write applications that require no assumptions about the source of
-their input or the destination of their output.
-There are variations on \fIread() \fP and \fIwrite()\fP
-that allow the source and destination of the input and output to use
-several separate buffers, while retaining the flexibility to handle
-both files and sockets. These are \fIreadv()\fP and \fI writev(),\fP
-for read and write \fIvector.\fP
-.pp
-It is sometimes necessary to send high priority data over a
-connection that may have unread low priority data at the
-other end. For example, a user interface process may be interpreting
-commands and sending them on to another process through a stream connection.
-The user interface may have filled the stream with as yet unprocessed
-requests when the user types
-a command to cancel all outstanding requests.
-Rather than have the high priority data wait
-to be processed after the low priority data, it is possible to
-send it as \fIout-of-band\fP
-(OOB) data. The notification of pending OOB data results in the generation of
-a SIGURG signal, if this signal has been enabled (see the manual
-page for \fIsignal\fP or \fIsigvec\fP).
-See [Leffler 1986] for a more complete description of the OOB mechanism.
-There are a pair of calls similar to \fIread\fP and \fIwrite\fP
-that allow options, including sending
-and receiving OOB information; these are \fI send()\fP
-and \fIrecv().\fP
-These calls are used only with sockets; specifying a descriptor for a file will
-result in the return of an error status. These calls also allow
-\fIpeeking\fP at data in a stream.
-That is, they allow a process to read data without removing the data from
-the stream. One use of this facility is to read ahead in a stream
-to determine the size of the next item to be read.
-When not using these options, these calls have the same functions as
-\fIread()\fP and \fIwrite().\fP
-.pp
-To send datagrams, one must be allowed to specify the destination.
-The call \fIsendto()\fP
-takes a destination address as an argument and is therefore used for
-sending datagrams. The call \fIrecvfrom()\fP
-is often used to read datagrams, since this call returns the address
-of the sender, if it is available, along with the data.
-If the identity of the sender does not matter, one may use \fIread()\fP
-or \fIrecv().\fP
-.pp
-Finally, there are a pair of calls that allow the sending and
-receiving of messages from multiple buffers, when the address of the
-recipient must be specified. These are \fIsendmsg()\fP and
-\fIrecvmsg().\fP
-These calls are actually quite general and have other uses,
-including, in the UNIX domain, the transmission of a file descriptor from one
-process to another.
-.pp
-The various options for reading and writing are shown in Figure 10,
-together with their parameters. The parameters for each system call
-reflect the differences in function of the different calls.
-In the examples given in this paper, the calls \fIread()\fP and
-\fIwrite()\fP have been used whenever possible.
-.(z
-.ft CW
- /*
- * The variable descriptor may be the descriptor of either a file
- * or of a socket.
- */
- cc = read(descriptor, buf, nbytes)
- int cc, descriptor; char *buf; int nbytes;
-
- /*
- * An iovec can include several source buffers.
- */
- cc = readv(descriptor, iov, iovcnt)
- int cc, descriptor; struct iovec *iov; int iovcnt;
-
- cc = write(descriptor, buf, nbytes)
- int cc, descriptor; char *buf; int nbytes;
-
- cc = writev(descriptor, iovec, ioveclen)
- int cc, descriptor; struct iovec *iovec; int ioveclen;
-
- /*
- * The variable ``sock'' must be the descriptor of a socket.
- * Flags may include MSG_OOB and MSG_PEEK.
- */
- cc = send(sock, msg, len, flags)
- int cc, sock; char *msg; int len, flags;
-
- cc = sendto(sock, msg, len, flags, to, tolen)
- int cc, sock; char *msg; int len, flags;
- struct sockaddr *to; int tolen;
-
- cc = sendmsg(sock, msg, flags)
- int cc, sock; struct msghdr msg[]; int flags;
-
- cc = recv(sock, buf, len, flags)
- int cc, sock; char *buf; int len, flags;
-
- cc = recvfrom(sock, buf, len, flags, from, fromlen)
- int cc, sock; char *buf; int len, flags;
- struct sockaddr *from; int *fromlen;
-
- cc = recvmsg(sock, msg, flags)
- int cc, socket; struct msghdr msg[]; int flags;
-.ft
-.sp 1
-.ce 1
-Figure 10\ \ Varieties of read and write commands
-.)z
-.b
-.sh 1 "Choices"
-.r
-.pp
-This paper has presented examples of some of the forms
-of communication supported by
-Berkeley UNIX 4.4BSD. These have been presented in an order chosen for
-ease of presentation. It is useful to review these options emphasizing the
-factors that make each attractive.
-.pp
-Pipes have the advantage of portability, in that they are supported in all
-UNIX systems. They also are relatively
-simple to use. Socketpairs share this simplicity and have the additional
-advantage of allowing bidirectional communication. The major shortcoming
-of these mechanisms is that they require communicating processes to be
-descendants of a common process. They do not allow intermachine communication.
-.pp
-The two communication domains, UNIX and Internet, allow processes with no common
-ancestor to communicate.
-Of the two, only the Internet domain allows
-communication between machines.
-This makes the Internet domain a necessary
-choice for processes running on separate machines.
-.pp
-The choice between datagrams and stream communication is best made by
-carefully considering the semantic and performance
-requirements of the application.
-Streams can be both advantageous and disadvantageous. One disadvantage
-is that a process is only allowed a limited number of open streams,
-as there are usually only 64 entries available in the open descriptor
-table. This can cause problems if a single server must talk with a large
-number of clients.
-Another is that for delivering a short message the stream setup and
-teardown time can be unnecessarily long. Weighed against this are
-the reliability built into the streams. This will often be the
-deciding factor in favor of streams.
-.b
-.sh 1 "What to do Next"
-.r
-.pp
-Many of the examples presented here can serve as models for multiprocess
-programs and for programs distributed across several machines.
-In developing a new multiprocess program, it is often easiest to
-first write the code to create the processes and communication paths.
-After this code is debugged, the code specific to the application can
-be added.
-.pp
-An introduction to the UNIX system and programming using UNIX system calls
-can be found in [Kernighan and Pike 1984].
-Further documentation of the Berkeley UNIX 4.4BSD IPC mechanisms can be
-found in [Leffler et al. 1986].
-More detailed information about particular calls and protocols
-is provided in sections
-2, 3 and 4 of the
-UNIX Programmer's Manual [CSRG 1986].
-In particular the following manual pages are relevant:
-.(b
-.TS
-l l.
-creating and naming sockets socket(2), bind(2)
-establishing connections listen(2), accept(2), connect(2)
-transferring data read(2), write(2), send(2), recv(2)
-addresses inet(4F)
-protocols tcp(4P), udp(4P).
-.TE
-.)b
-.(b
-.sp
-.b
-Acknowledgements
-.pp
-I would like to thank Sam Leffler and Mike Karels for their help in
-understanding the IPC mechanisms and all the people whose comments
-have helped in writing and improving this report.
-.pp
-This work was sponsored by the Defense Advanced Research Projects Agency
-(DoD), ARPA Order No. 4031, monitored by the Naval Electronics Systems
-Command under contract No. N00039-C-0235.
-The views and conclusions contained in this document are those of the
-author and should not be interpreted as representing official policies,
-either expressed or implied, of the Defense Research Projects Agency
-or of the US Government.
-.)b
-.(b
-.sp
-.b
-References
-.r
-.sp
-.ls 1
-B.W. Kernighan & R. Pike, 1984,
-.i "The UNIX Programming Environment."
-Englewood Cliffs, N.J.: Prentice-Hall.
-.sp
-.ls 1
-B.W. Kernighan & D.M. Ritchie, 1978,
-.i "The C Programming Language,"
-Englewood Cliffs, N.J.: Prentice-Hall.
-.sp
-.ls 1
-S.J. Leffler, R.S. Fabry, W.N. Joy, P. Lapsley, S. Miller & C. Torek, 1986,
-.i "An Advanced 4.4BSD Interprocess Communication Tutorial."
-Computer Systems Research Group,
-Department of Electrical Engineering and Computer Science,
-University of California, Berkeley.
-.sp
-.ls 1
-Computer Systems Research Group, 1986,
-.i "UNIX Programmer's Manual, 4.4 Berkeley Software Distribution."
-Computer Systems Research Group,
-Department of Electrical Engineering and Computer Science,
-University of California, Berkeley.
-.)b
diff --git a/share/doc/psd/20.ipctut/udgramread.c b/share/doc/psd/20.ipctut/udgramread.c
deleted file mode 100644
index c55fdce8a1b..00000000000
--- a/share/doc/psd/20.ipctut/udgramread.c
+++ /dev/null
@@ -1,78 +0,0 @@
-.\" $OpenBSD: udgramread.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)udgramread.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <sys/un.h>
-
-/*
- * In the included file <sys/un.h> a sockaddr_un is defined as follows
- * struct sockaddr_un {
- * short sun_family;
- * char sun_path[108];
- * };
- */
-
-#include <stdio.h>
-
-#define NAME "socket"
-
-/*
- * This program creates a UNIX domain datagram socket, binds a name to it,
- * then reads from the socket.
- */
-main()
-{
- int sock, length;
- struct sockaddr_un name;
- char buf[1024];
-
- /* Create socket from which to read. */
- sock = socket(AF_UNIX, SOCK_DGRAM, 0);
- if (sock < 0) {
- perror("opening datagram socket");
- exit(1);
- }
- /* Create name. */
- name.sun_family = AF_UNIX;
- strcpy(name.sun_path, NAME);
- if (bind(sock, &name, sizeof(struct sockaddr_un))) {
- perror("binding name to datagram socket");
- exit(1);
- }
- printf("socket -->%s\en", NAME);
- /* Read from the socket */
- if (read(sock, buf, 1024) < 0)
- perror("receiving datagram packet");
- printf("-->%s\en", buf);
- close(sock);
- unlink(NAME);
-}
diff --git a/share/doc/psd/20.ipctut/udgramsend.c b/share/doc/psd/20.ipctut/udgramsend.c
deleted file mode 100644
index aa1b1160aa3..00000000000
--- a/share/doc/psd/20.ipctut/udgramsend.c
+++ /dev/null
@@ -1,66 +0,0 @@
-.\" $OpenBSD: udgramsend.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)udgramsend.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <sys/un.h>
-#include <stdio.h>
-
-#define DATA "The sea is calm tonight, the tide is full . . ."
-
-/*
- * Here I send a datagram to a receiver whose name I get from the command
- * line arguments. The form of the command line is udgramsend pathname
- */
-
-main(argc, argv)
- int argc;
- char *argv[];
-{
- int sock;
- struct sockaddr_un name;
-
- /* Create socket on which to send. */
- sock = socket(AF_UNIX, SOCK_DGRAM, 0);
- if (sock < 0) {
- perror("opening datagram socket");
- exit(1);
- }
- /* Construct name of socket to send to. */
- name.sun_family = AF_UNIX;
- strcpy(name.sun_path, argv[1]);
- /* Send message. */
- if (sendto(sock, DATA, sizeof(DATA), 0,
- &name, sizeof(struct sockaddr_un)) < 0) {
- perror("sending datagram message");
- }
- close(sock);
-}
diff --git a/share/doc/psd/20.ipctut/ustreamread.c b/share/doc/psd/20.ipctut/ustreamread.c
deleted file mode 100644
index 423a6644e48..00000000000
--- a/share/doc/psd/20.ipctut/ustreamread.c
+++ /dev/null
@@ -1,94 +0,0 @@
-.\" $OpenBSD: ustreamread.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)ustreamread.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <sys/un.h>
-#include <stdio.h>
-
-#define NAME "socket"
-
-/*
- * This program creates a socket in the UNIX domain and binds a name to it.
- * After printing the socket's name it begins a loop. Each time through the
- * loop it accepts a connection and prints out messages from it. When the
- * connection breaks, or a termination message comes through, the program
- * accepts a new connection.
- */
-main()
-{
- int sock, msgsock, rval;
- struct sockaddr_un server;
- char buf[1024];
-
- /* Create socket */
- sock = socket(AF_UNIX, SOCK_STREAM, 0);
- if (sock < 0) {
- perror("opening stream socket");
- exit(1);
- }
- /* Name socket using file system name */
- server.sun_family = AF_UNIX;
- strcpy(server.sun_path, NAME);
- if (bind(sock, &server, sizeof(struct sockaddr_un))) {
- perror("binding stream socket");
- exit(1);
- }
- printf("Socket has name %s\en", server.sun_path);
- /* Start accepting connections */
- listen(sock, 5);
- for (;;) {
- msgsock = accept(sock, 0, 0);
- if (msgsock == -1)
- perror("accept");
- else do {
- bzero(buf, sizeof(buf));
- if ((rval = read(msgsock, buf, 1024)) < 0)
- perror("reading stream message");
- else if (rval == 0)
- printf("Ending connection\en");
- else
- printf("-->%s\en", buf);
- } while (rval > 0);
- close(msgsock);
- }
- /*
- * The following statements are not executed, because they follow an
- * infinite loop. However, most ordinary programs will not run
- * forever. In the UNIX domain it is necessary to tell the file
- * system that one is through using NAME. In most programs one uses
- * the call unlink() as below. Since the user will have to kill this
- * program, it will be necessary to remove the name by a command from
- * the shell.
- */
- close(sock);
- unlink(NAME);
-}
diff --git a/share/doc/psd/20.ipctut/ustreamwrite.c b/share/doc/psd/20.ipctut/ustreamwrite.c
deleted file mode 100644
index 0edf9e3f880..00000000000
--- a/share/doc/psd/20.ipctut/ustreamwrite.c
+++ /dev/null
@@ -1,69 +0,0 @@
-.\" $OpenBSD: ustreamwrite.c,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)ustreamwrite.c 8.1 (Berkeley) 6/8/93
-.\"
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <sys/un.h>
-#include <stdio.h>
-
-#define DATA "Half a league, half a league . . ."
-
-/*
- * This program connects to the socket named in the command line and sends a
- * one line message to that socket. The form of the command line is
- * ustreamwrite pathname
- */
-main(argc, argv)
- int argc;
- char *argv[];
-{
- int sock;
- struct sockaddr_un server;
- char buf[1024];
-
- /* Create socket */
- sock = socket(AF_UNIX, SOCK_STREAM, 0);
- if (sock < 0) {
- perror("opening stream socket");
- exit(1);
- }
- /* Connect socket using name specified by command line. */
- server.sun_family = AF_UNIX;
- strcpy(server.sun_path, argv[1]);
-
- if (connect(sock, &server, sizeof(struct sockaddr_un)) < 0) {
- close(sock);
- perror("connecting stream socket");
- exit(1);
- }
- if (write(sock, DATA, sizeof(DATA)) < 0)
- perror("writing on stream socket");
-}
diff --git a/share/doc/psd/21.ipc/0.t b/share/doc/psd/21.ipc/0.t
deleted file mode 100644
index 04739794e10..00000000000
--- a/share/doc/psd/21.ipc/0.t
+++ /dev/null
@@ -1,91 +0,0 @@
-.\" $OpenBSD: 0.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)0.t 8.1 (Berkeley) 6/8/93
-.\"
-.EH 'PSD:21-%''Advanced 4.4BSD IPC Tutorial'
-.OH 'Advanced 4.4BSD IPC Tutorial''PSD:21-%'
-.ds lq ``
-.ds rq ''
-.de DT
-.if t .ta .5i 1.25i 2.5i 3.75i
-.\" 3.5i went to 3.8i
-.if n .ta .7i 1.75i 3.8i
-..
-.bd S B 3
-.TL
-An Advanced 4.4BSD Interprocess Communication Tutorial
-.AU
-Samuel J. Leffler
-.AU
-Robert S. Fabry
-.AU
-William N. Joy
-.AU
-Phil Lapsley
-.AI
-Computer Systems Research Group
-Department of Electrical Engineering and Computer Science
-University of California, Berkeley
-Berkeley, California 94720
-.sp 2
-.AU
-Steve Miller
-.AU
-Chris Torek
-.AI
-Heterogeneous Systems Laboratory
-Department of Computer Science
-University of Maryland, College Park
-College Park, Maryland 20742
-.de IR
-\fI\\$1\fP\\$2
-..
-.de UX
-UNIX\\$1
-..
-.AB
-.PP
-.FS
-* \s-2UNIX\s0 is a trademark of UNIX System Laboratories, Inc.
-in the US and some other countries.
-.FE
-This document provides an introduction to the interprocess
-communication facilities included in the
-4.4BSD release of the
-.UX *
-system.
-.PP
-It discusses the overall model for interprocess communication
-and introduces the interprocess communication primitives
-which have been added to the system. The majority of the
-document considers the use of these primitives in developing
-applications. The reader is expected to be familiar with
-the C programming language as all examples are written in C.
-.AE
diff --git a/share/doc/psd/21.ipc/1.t b/share/doc/psd/21.ipc/1.t
deleted file mode 100644
index 653d94dde11..00000000000
--- a/share/doc/psd/21.ipc/1.t
+++ /dev/null
@@ -1,104 +0,0 @@
-.\" $OpenBSD: 1.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)1.t 8.1 (Berkeley) 8/14/93
-.\"
-.\".ds LH "4.4BSD IPC Primer
-.\".ds RH Introduction
-.\".ds RF "Leffler/Fabry/Joy
-.\".ds LF "\*(DY
-.\".ds CF "
-.nr H1 1
-.LP
-.bp
-.LG
-.B
-.ce
-1. INTRODUCTION
-.sp 2
-.R
-.NL
-One of the most important additions to UNIX in 4.2BSD was interprocess
-communication.
-These facilities were the result of
-more than two years of discussion and research. The facilities
-provided in 4.2BSD incorporated many of the ideas from current
-research, while trying to maintain the UNIX philosophy of
-simplicity and conciseness.
-The 4.3BSD release of Berkeley UNIX
-improved upon some of the IPC facilities
-while providing an upward-compatible interface.
-4.4BSD adds support for ISO protocols and IP multicasting.
-The BSD interprocess communication
-facilities have become a defacto standard for UNIX.
-.PP
-UNIX has previously been very weak in the area of interprocess
-communication. Prior to the 4BSD facilities, the only
-standard mechanism which allowed two processes to communicate were
-pipes (the mpx files which were part of Version 7 were
-experimental). Unfortunately, pipes are very restrictive
-in that
-the two communicating processes must be related through a
-common ancestor.
-Further, the semantics of pipes makes them almost impossible
-to maintain in a distributed environment.
-.PP
-Earlier attempts at extending the IPC facilities of UNIX have
-met with mixed reaction. The majority of the problems have
-been related to the fact that these facilities have been tied to
-the UNIX file system, either through naming or implementation.
-Consequently, the IPC facilities provided in 4.2BSD were
-designed as a totally independent subsystem. The BSD IPC
-allows processes to rendezvous in many ways.
-Processes may rendezvous through a UNIX file system-like
-name space (a space where all names are path names)
-as well as through a
-network name space. In fact, new name spaces may
-be added at a future time with only minor changes visible
-to users. Further, the communication facilities
-have been extended to include more than the simple byte stream
-provided by a pipe. These extensions have resulted
-in a completely new part of the system which users will need
-time to familiarize themselves with. It is likely that as
-more use is made of these facilities they will be refined;
-only time will tell.
-.PP
-This document provides a high-level description
-of the IPC facilities in 4.4BSD and their use.
-It is designed to complement the manual pages for the IPC primitives
-by examples of their use.
-The remainder of this document is organized in four sections.
-Section 2 introduces the IPC-related system calls and the basic model
-of communication. Section 3 describes some of the supporting
-library routines users may find useful in constructing distributed
-applications. Section 4 is concerned with the client/server model
-used in developing applications and includes examples of the
-two major types of servers. Section 5 delves into advanced topics
-which sophisticated users are likely to encounter when using
-the IPC facilities.
diff --git a/share/doc/psd/21.ipc/2.t b/share/doc/psd/21.ipc/2.t
deleted file mode 100644
index 082def348a8..00000000000
--- a/share/doc/psd/21.ipc/2.t
+++ /dev/null
@@ -1,712 +0,0 @@
-.\" $OpenBSD: 2.t,v 1.5 2003/08/12 20:44:57 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)2.t 8.1 (Berkeley) 8/14/93
-.\"
-.\".ds RH "Basics
-.bp
-.nr H1 2
-.nr H2 0
-.\" The next line is a major hack to get around internal changes in the groff
-.\" implementation of .NH.
-.nr nh*hl 1
-.bp
-.LG
-.B
-.ce
-2. BASICS
-.sp 2
-.R
-.NL
-.PP
-The basic building block for communication is the \fIsocket\fP.
-A socket is an endpoint of communication to which a name may
-be \fIbound\fP. Each socket in use has a \fItype\fP
-and one or more associated processes. Sockets exist within
-\fIcommunication domains\fP.
-A communication domain is an
-abstraction introduced to bundle common properties of
-processes communicating through sockets.
-One such property is the scheme used to name sockets. For
-example, in the UNIX communication domain sockets are
-named with UNIX path names; e.g. a
-socket may be named \*(lq/dev/foo\*(rq. Sockets normally
-exchange data only with
-sockets in the same domain (it may be possible to cross domain
-boundaries, but only if some translation process is
-performed). The
-4.4BSD IPC facilities support four separate communication domains:
-the UNIX domain, for on-system communication;
-the Internet domain, which is used by
-processes which communicate
-using the Internet standard communication protocols;
-the NS domain, which is used by processes which
-communicate using the Xerox standard communication
-protocols*;
-.FS
-* See \fIInternet Transport Protocols\fP, Xerox System Integration
-Standard (XSIS)028112 for more information. This document is
-almost a necessity for one trying to write NS applications.
-.FE
-and the ISO OSI protocols, which are not documented in this tutorial.
-The underlying communication
-facilities provided by these domains have a significant influence
-on the internal system implementation as well as the interface to
-socket facilities available to a user. An example of the
-latter is that a socket \*(lqoperating\*(rq in the UNIX domain
-sees a subset of the error conditions which are possible
-when operating in the Internet (or NS) domain.
-.NH 2
-Socket types
-.PP
-Sockets are
-typed according to the communication properties visible to a
-user.
-Processes are presumed to communicate only between sockets of
-the same type, although there is
-nothing that prevents communication between sockets of different
-types should the underlying communication
-protocols support this.
-.PP
-Four types of sockets currently are available to a user.
-A \fIstream\fP socket provides for the bidirectional, reliable,
-sequenced, and unduplicated flow of data without record boundaries.
-Aside from the bidirectionality of data flow, a pair of connected
-stream sockets provides an interface nearly identical to that of pipes\(dg.
-.FS
-\(dg In the UNIX domain, in fact, the semantics are identical and,
-as one might expect, pipes have been implemented internally
-as simply a pair of connected stream sockets.
-.FE
-.PP
-A \fIdatagram\fP socket supports bidirectional flow of data which
-is not promised to be sequenced, reliable, or unduplicated.
-That is, a process
-receiving messages on a datagram socket may find messages duplicated,
-and, possibly,
-in an order different from the order in which it was sent.
-An important characteristic of a datagram
-socket is that record boundaries in data are preserved. Datagram
-sockets closely model the facilities found in many contemporary
-packet switched networks such as the Ethernet.
-.PP
-A \fIraw\fP socket provides users access to
-the underlying communication
-protocols which support socket abstractions.
-These sockets are normally datagram oriented, though their
-exact characteristics are dependent on the interface provided by
-the protocol. Raw sockets are not intended for the general user; they
-have been provided mainly for those interested in developing new
-communication protocols, or for gaining access to some of the more
-esoteric facilities of an existing protocol. The use of raw sockets
-is considered in section 5.
-.PP
-A \fIsequenced packet\fP socket is similar to a stream socket,
-with the exception that record boundaries are preserved. This
-interface is provided only as part of the NS socket abstraction,
-and is very important in most serious NS applications.
-Sequenced-packet sockets allow the user to manipulate the
-SPP or IDP headers on a packet or a group of packets either
-by writing a prototype header along with whatever data is
-to be sent, or by specifying a default header to be used with
-all outgoing data, and allows the user to receive the headers
-on incoming packets. The use of these options is considered in
-section 5.
-.PP
-Another potential socket type which has interesting properties is
-the \fIreliably delivered
-message\fP socket.
-The reliably delivered message socket has
-similar properties to a datagram socket, but with
-reliable delivery. There is currently no support for this
-type of socket, but a reliably delivered message protocol
-similar to Xerox's Packet Exchange Protocol (PEX) may be
-simulated at the user level. More information on this topic
-can be found in section 5.
-.NH 2
-Socket creation
-.PP
-To create a socket the \fIsocket\fP system call is used:
-.DS
-s = socket(domain, type, protocol);
-.DE
-This call requests that the system create a socket in the specified
-\fIdomain\fP and of the specified \fItype\fP. A particular protocol may
-also be requested. If the protocol is left unspecified (a value
-of 0), the system will select an appropriate protocol from those
-protocols which comprise the communication domain and which
-may be used to support the requested socket type. The user is
-returned a descriptor (a small integer number) which may be used
-in later system calls which operate on sockets. The domain is specified as
-one of the manifest constants defined in the file <\fIsys/socket.h\fP>.
-For the UNIX domain the constant is AF_UNIX*; for the Internet
-.FS
-* The manifest constants are named AF_whatever as they indicate
-the ``address format'' to use in interpreting names.
-.FE
-domain AF_INET; and for the NS domain, AF_NS.
-The socket types are also defined in this file
-and one of SOCK_STREAM, SOCK_DGRAM, SOCK_RAW, or SOCK_SEQPACKET
-must be specified.
-To create a stream socket in the Internet domain the following
-call might be used:
-.DS
-s = socket(AF_INET, SOCK_STREAM, 0);
-.DE
-This call would result in a stream socket being created with the TCP
-protocol providing the underlying communication support. To
-create a datagram socket for on-machine use the call might
-be:
-.DS
-s = socket(AF_UNIX, SOCK_DGRAM, 0);
-.DE
-.PP
-The default protocol (used when the \fIprotocol\fP argument to the
-\fIsocket\fP call is 0) should be correct for most every
-situation. However, it is possible to specify a protocol
-other than the default; this will be covered in
-section 5.
-.PP
-There are several reasons a socket call may fail. Aside from
-the rare occurrence of lack of memory (ENOBUFS), a socket
-request may fail due to a request for an unknown protocol
-(EPROTONOSUPPORT), or a request for a type of socket for
-which there is no supporting protocol (EPROTOTYPE).
-.NH 2
-Binding local names
-.PP
-A socket is created without a name. Until a name is bound
-to a socket, processes have no way to reference it and, consequently,
-no messages may be received on it.
-Communicating processes are bound
-by an \fIassociation\fP. In the Internet and NS domains,
-an association
-is composed of local and foreign
-addresses, and local and foreign ports,
-while in the UNIX domain, an association is composed of
-local and foreign path names (the phrase ``foreign pathname''
-means a pathname created by a foreign process, not a pathname
-on a foreign system).
-In most domains, associations must be unique.
-In the Internet domain there
-may never be duplicate <protocol, local address, local port, foreign
-address, foreign port> tuples. UNIX domain sockets need not always
-be bound to a name, but when bound
-there may never be duplicate <protocol, local pathname, foreign
-pathname> tuples.
-The pathnames may not refer to files
-already existing on the system
-in 4.3; the situation may change in future releases.
-.PP
-The \fIbind\fP system call allows a process to specify half of
-an association, <local address, local port>
-(or <local pathname>), while the \fIconnect\fP
-and \fIaccept\fP primitives are used to complete a socket's association.
-.PP
-In the Internet domain,
-binding names to sockets can be fairly complex.
-Fortunately, it is usually not necessary to specifically bind an
-address and port number to a socket, because the
-\fIconnect\fP and \fIsend\fP calls will automatically
-bind an appropriate address if they are used with an
-unbound socket. The process of binding names to NS
-sockets is similar in most ways to that of
-binding names to Internet sockets.
-.PP
-The \fIbind\fP system call is used as follows:
-.DS
-bind(s, name, namelen);
-.DE
-The bound name is a variable length byte string which is interpreted
-by the supporting protocol(s). Its interpretation may vary from
-communication domain to communication domain (this is one of
-the properties which comprise the \*(lqdomain\*(rq).
-As mentioned, in the
-Internet domain names contain an Internet address and port
-number. NS domain names contain an NS address and
-port number. In the UNIX domain, names contain a path name and
-a family, which is always AF_UNIX. If one wanted to bind
-the name \*(lq/tmp/foo\*(rq to a UNIX domain socket, the
-following code would be used*:
-.FS
-* Note that, although the tendency here is to call the \*(lqaddr\*(rq
-structure \*(lqsun\*(rq, doing so would cause problems if the code
-were ever ported to a Sun workstation.
-.FE
-.DS
-#include <sys/un.h>
- ...
-struct sockaddr_un addr;
- ...
-strcpy(addr.sun_path, "/tmp/foo");
-addr.sun_family = AF_UNIX;
-bind(s, (struct sockaddr *) &addr, strlen(addr.sun_path) +
- sizeof (addr.sun_len) + sizeof (addr.sun_family));
-.DE
-Note that in determining the size of a UNIX domain address null
-bytes are not counted, which is why \fIstrlen\fP is used. In
-the current implementation of UNIX domain IPC,
-the file name
-referred to in \fIaddr.sun_path\fP is created as a socket
-in the system file space.
-The caller must, therefore, have
-write permission in the directory where
-\fIaddr.sun_path\fP is to reside, and this file should be deleted by the
-caller when it is no longer needed. Future versions of 4BSD
-may not create this file.
-.PP
-In binding an Internet address things become more
-complicated. The actual call is similar,
-.DS
-#include <sys/types.h>
-#include <netinet/in.h>
- ...
-struct sockaddr_in sin;
- ...
-bind(s, (struct sockaddr *) &sin, sizeof (sin));
-.DE
-but the selection of what to place in the address \fIsin\fP
-requires some discussion. We will come back to the problem
-of formulating Internet addresses in section 3 when
-the library routines used in name resolution are discussed.
-.PP
-Binding an NS address to a socket is even more
-difficult,
-especially since the Internet library routines do not
-work with NS hostnames. The actual call is again similar:
-.DS
-#include <sys/types.h>
-#include <netns/ns.h>
- ...
-struct sockaddr_ns sns;
- ...
-bind(s, (struct sockaddr *) &sns, sizeof (sns));
-.DE
-Again, discussion of what to place in a \*(lqstruct sockaddr_ns\*(rq
-will be deferred to section 3.
-.NH 2
-Connection establishment
-.PP
-Connection establishment is usually asymmetric,
-with one process a \*(lqclient\*(rq and the other a \*(lqserver\*(rq.
-The server, when willing to offer its advertised services,
-binds a socket to a well-known address associated with the service
-and then passively \*(lqlistens\*(rq on its socket.
-It is then possible for an unrelated process to rendezvous
-with the server.
-The client requests services from the server by initiating a
-\*(lqconnection\*(rq to the server's socket.
-On the client side the \fIconnect\fP call is
-used to initiate a connection. Using the UNIX domain, this
-might appear as,
-.DS
-struct sockaddr_un server;
- ...
-connect(s, (struct sockaddr *)&server, strlen(server.sun_path) +
- sizeof (server.sun_family));
-.DE
-while in the Internet domain,
-.DS
-struct sockaddr_in server;
- ...
-connect(s, (struct sockaddr *)&server, sizeof (server));
-.DE
-and in the NS domain,
-.DS
-struct sockaddr_ns server;
- ...
-connect(s, (struct sockaddr *)&server, sizeof (server));
-.DE
-where \fIserver\fP in the example above would contain either the UNIX
-pathname, Internet address and port number, or NS address and
-port number of the server to which the
-client process wishes to speak.
-If the client process's socket is unbound at the time of
-the connect call,
-the system will automatically select and bind a name to
-the socket if necessary; c.f. section 5.4.
-This is the usual way that local addresses are bound
-to a socket.
-.PP
-An error is returned if the connection was unsuccessful
-(any name automatically bound by the system, however, remains).
-Otherwise, the socket is associated with the server and
-data transfer may begin. Some of the more common errors returned
-when a connection attempt fails are:
-.IP ETIMEDOUT
-.br
-After failing to establish a connection for a period of time,
-the system decided there was no point in retrying the
-connection attempt any more. This usually occurs because
-the destination host is down, or because problems in
-the network resulted in transmissions being lost.
-.IP ECONNREFUSED
-.br
-The host refused service for some reason.
-This is usually
-due to a server process
-not being present at the requested name.
-.IP "ENETDOWN or EHOSTDOWN"
-.br
-These operational errors are
-returned based on status information delivered to
-the client host by the underlying communication services.
-.IP "ENETUNREACH or EHOSTUNREACH"
-.br
-These operational errors can occur either because the network
-or host is unknown (no route to the network or host is present),
-or because of status information returned by intermediate
-gateways or switching nodes. Many times the status returned
-is not sufficient to distinguish a network being down from a
-host being down, in which case the system
-indicates the entire network is unreachable.
-.PP
-For the server to receive a client's connection it must perform
-two steps after binding its socket.
-The first is to indicate a willingness to listen for
-incoming connection requests:
-.DS
-listen(s, 5);
-.DE
-The second parameter to the \fIlisten\fP call specifies the maximum
-number of outstanding connections which may be queued awaiting
-acceptance by the server process; this number
-may be limited by the system. Should a connection be
-requested while the queue is full, the connection will not be
-refused, but rather the individual messages which comprise the
-request will be ignored. This gives a harried server time to
-make room in its pending connection queue while the client
-retries the connection request. Had the connection been returned
-with the ECONNREFUSED error, the client would be unable to tell
-if the server was up or not. As it is now it is still possible
-to get the ETIMEDOUT error back, though this is unlikely. The
-backlog figure supplied with the listen call is currently limited
-by the system to a maximum of 5 pending connections on any
-one queue. This avoids the problem of processes hogging system
-resources by setting an infinite backlog, then ignoring
-all connection requests.
-.PP
-With a socket marked as listening, a server may \fIaccept\fP
-a connection:
-.DS
-struct sockaddr_in from;
- ...
-fromlen = sizeof (from);
-newsock = accept(s, (struct sockaddr *)&from, &fromlen);
-.DE
-(For the UNIX domain, \fIfrom\fP would be declared as a
-\fIstruct sockaddr_un\fP, and for the NS domain, \fIfrom\fP
-would be declared as a \fIstruct sockaddr_ns\fP,
-but nothing different would need
-to be done as far as \fIfromlen\fP is concerned. In the examples
-which follow, only Internet routines will be discussed.) A new
-descriptor is returned on receipt of a connection (along with
-a new socket). If the server wishes to find out who its client is,
-it may supply a buffer for the client socket's name. The value-result
-parameter \fIfromlen\fP is initialized by the server to indicate how
-much space is associated with \fIfrom\fP, then modified on return
-to reflect the true size of the name. If the client's name is not
-of interest, the second parameter may be a null pointer.
-.PP
-\fIAccept\fP normally blocks. That is, \fIaccept\fP
-will not return until a connection is available or the system call
-is interrupted by a signal to the process. Further, there is no
-way for a process to indicate it will accept connections from only
-a specific individual, or individuals. It is up to the user process
-to consider who the connection is from and close down the connection
-if it does not wish to speak to the process. If the server process
-wants to accept connections on more than one socket, or wants to avoid blocking
-on the accept call, there are alternatives; they will be considered
-in section 5.
-.NH 2
-Data transfer
-.PP
-With a connection established, data may begin to flow. To send
-and receive data there are a number of possible calls.
-With the peer entity at each end of a connection
-anchored, a user can send or receive a message without specifying
-the peer. As one might expect, in this case, then
-the normal \fIread\fP and \fIwrite\fP system calls are usable,
-.DS
-write(s, buf, sizeof (buf));
-read(s, buf, sizeof (buf));
-.DE
-In addition to \fIread\fP and \fIwrite\fP,
-the new calls \fIsend\fP and \fIrecv\fP
-may be used:
-.DS
-send(s, buf, sizeof (buf), flags);
-recv(s, buf, sizeof (buf), flags);
-.DE
-While \fIsend\fP and \fIrecv\fP are virtually identical to
-\fIread\fP and \fIwrite\fP,
-the extra \fIflags\fP argument is important. The flags,
-defined in \fI<sys/socket.h>\fP, may be
-specified as a non-zero value if one or more
-of the following is required:
-.DS
-.TS
-l l.
-MSG_OOB send/receive out of band data
-MSG_PEEK look at data without reading
-MSG_DONTROUTE send data without routing packets
-.TE
-.DE
-Out of band data is a notion specific to stream sockets, and one
-which we will not immediately consider. The option to have data
-sent without routing applied to the outgoing packets is currently
-used only by the routing table management process, and is
-unlikely to be of interest to the casual user. The ability
-to preview data is, however, of interest. When MSG_PEEK
-is specified with a \fIrecv\fP call, any data present is returned
-to the user, but treated as still \*(lqunread\*(rq. That
-is, the next \fIread\fP or \fIrecv\fP call applied to the socket will
-return the data previously previewed.
-.NH 2
-Discarding sockets
-.PP
-Once a socket is no longer of interest, it may be discarded
-by applying a \fIclose\fP to the descriptor,
-.DS
-close(s);
-.DE
-If data is associated with a socket which promises reliable delivery
-(e.g. a stream socket) when a close takes place, the system will
-continue to attempt to transfer the data.
-However, after a fairly long period of
-time, if the data is still undelivered, it will be discarded.
-Should a user have no use for any pending data, it may
-perform a \fIshutdown\fP on the socket prior to closing it.
-This call is of the form:
-.DS
-shutdown(s, how);
-.DE
-where \fIhow\fP is 0 if the user is no longer interested in reading
-data, 1 if no more data will be sent, or 2 if no data is to
-be sent or received.
-.NH 2
-Connectionless sockets
-.PP
-To this point we have been concerned mostly with sockets which
-follow a connection oriented model. However, there is also
-support for connectionless interactions typical of the datagram
-facilities found in contemporary packet switched networks.
-A datagram socket provides a symmetric interface to data
-exchange. While processes are still likely to be client
-and server, there is no requirement for connection establishment.
-Instead, each message includes the destination address.
-.PP
-Datagram sockets are created as before.
-If a particular local address is needed,
-the \fIbind\fP operation must precede the first data transmission.
-Otherwise, the system will set the local address and/or port
-when data is first sent.
-To send data, the \fIsendto\fP primitive is used,
-.DS
-sendto(s, buf, buflen, flags, (struct sockaddr *)&to, tolen);
-.DE
-The \fIs\fP, \fIbuf\fP, \fIbuflen\fP, and \fIflags\fP
-parameters are used as before.
-The \fIto\fP and \fItolen\fP
-values are used to indicate the address of the intended recipient of the
-message. When
-using an unreliable datagram interface, it is
-unlikely that any errors will be reported to the sender. When
-information is present locally to recognize a message that can
-not be delivered (for instance when a network is unreachable),
-the call will return \-1 and the global value \fIerrno\fP will
-contain an error number.
-.PP
-To receive messages on an unconnected datagram socket, the
-\fIrecvfrom\fP primitive is provided:
-.DS
-recvfrom(s, buf, buflen, flags, (struct sockaddr *)&from, &fromlen);
-.DE
-Once again, the \fIfromlen\fP parameter is handled in
-a value-result fashion, initially containing the size of
-the \fIfrom\fP buffer, and modified on return to indicate
-the actual size of the address from which the datagram was received.
-.PP
-In addition to the two calls mentioned above, datagram
-sockets may also use the \fIconnect\fP call to associate
-a socket with a specific destination address. In this case, any
-data sent on the socket will automatically be addressed
-to the connected peer, and only data received from that
-peer will be delivered to the user. Only one connected
-address is permitted for each socket at one time;
-a second connect will change the destination address,
-and a connect to a null address (family AF_UNSPEC)
-will disconnect.
-Connect requests on datagram sockets return immediately,
-as this simply results in the system recording
-the peer's address (as compared to a stream socket, where a
-connect request initiates establishment of an end to end
-connection). \fIAccept\fP and \fIlisten\fP are not
-used with datagram sockets.
-.PP
-While a datagram socket is connected,
-errors from recent \fIsend\fP calls may be returned
-asynchronously.
-These errors may be reported on subsequent operations
-on the socket,
-or a special socket option used with \fIgetsockopt\fP, SO_ERROR,
-may be used to interrogate the error status.
-A \fIselect\fP for reading or writing will return true
-when an error indication has been received.
-The next operation will return the error, and the error status is cleared.
-Other of the less
-important details of datagram sockets are described
-in section 5.
-.NH 2
-Input/Output multiplexing
-.PP
-One last facility often used in developing applications
-is the ability to multiplex i/o requests among multiple
-sockets and/or files. This is done using the \fIselect\fP
-call:
-.DS
-#include <sys/time.h>
-#include <sys/types.h>
- ...
-
-fd_set readmask, writemask, exceptmask;
-struct timeval timeout;
- ...
-select(nfds, &readmask, &writemask, &exceptmask, &timeout);
-.DE
-\fISelect\fP takes as arguments pointers to three sets, one for
-the set of file descriptors for which the caller wishes to
-be able to read data on, one for those descriptors to which
-data is to be written, and one for which exceptional conditions
-are pending; out-of-band data is the only
-exceptional condition currently implemented by the socket
-If the user is not interested
-in certain conditions (i.e., read, write, or exceptions),
-the corresponding argument to the \fIselect\fP should
-be a null pointer.
-.PP
-Each set is actually a structure containing an array of
-long integer bit masks; the size of the array is set
-by the definition FD_SETSIZE.
-The array is be
-long enough to hold one bit for each of FD_SETSIZE file descriptors.
-.PP
-The macros FD_SET(\fIfd, &mask\fP) and
-FD_CLR(\fIfd, &mask\fP)
-have been provided for adding and removing file descriptor
-\fIfd\fP in the set \fImask\fP. The
-set should be zeroed before use, and
-the macro FD_ZERO(\fI&mask\fP) has been provided
-to clear the set \fImask\fP.
-The parameter \fInfds\fP in the \fIselect\fP call specifies the range
-of file descriptors (i.e. one plus the value of the largest
-descriptor) to be examined in a set.
-.PP
-A timeout value may be specified if the selection
-is not to last more than a predetermined period of time. If
-the fields in \fItimeout\fP are set to 0, the selection takes
-the form of a
-\fIpoll\fP, returning immediately. If the last parameter is
-a null pointer, the selection will block indefinitely*.
-.FS
-* To be more specific, a return takes place only when a
-descriptor is selectable, or when a signal is received by
-the caller, interrupting the system call.
-.FE
-\fISelect\fP normally returns the number of file descriptors selected;
-if the \fIselect\fP call returns due to the timeout expiring, then
-the value 0 is returned.
-If the \fIselect\fP terminates because of an error or interruption,
-a \-1 is returned with the error number in \fIerrno\fP,
-and with the file descriptor masks unchanged.
-.PP
-Assuming a successful return, the three sets will
-indicate which
-file descriptors are ready to be read from, written to, or
-have exceptional conditions pending.
-The status of a file descriptor in a select mask may be
-tested with the \fIFD_ISSET(fd, &mask)\fP macro, which
-returns a non-zero value if \fIfd\fP is a member of the set
-\fImask\fP, and 0 if it is not.
-.PP
-To determine if there are connections waiting
-on a socket to be used with an \fIaccept\fP call,
-\fIselect\fP can be used, followed by
-a \fIFD_ISSET(fd, &mask)\fP macro to check for read
-readiness on the appropriate socket. If \fIFD_ISSET\fP
-returns a non-zero value, indicating permission to read, then a
-connection is pending on the socket.
-.PP
-As an example, to read data from two sockets, \fIs1\fP and
-\fIs2\fP as it is available from each and with a one-second
-timeout, the following code
-might be used:
-.DS
-#include <sys/time.h>
-#include <sys/types.h>
- ...
-fd_set read_template;
-struct timeval wait;
- ...
-for (;;) {
- wait.tv_sec = 1; /* one second */
- wait.tv_usec = 0;
-
- FD_ZERO(&read_template);
-
- FD_SET(s1, &read_template);
- FD_SET(s2, &read_template);
-
- nb = select(MAX(s1, s2) + 1, &read_template, NULL, NULL, &wait);
- if (nb <= 0) {
- \fIAn error occurred during the \fPselect\fI, or
- the \fPselect\fI timed out.\fP
- }
-
- if (FD_ISSET(s1, &read_template)) {
- \fISocket #1 is ready to be read from.\fP
- }
-
- if (FD_ISSET(s2, &read_template)) {
- \fISocket #2 is ready to be read from.\fP
- }
-}
-.DE
-.PP
-In 4.2, the arguments to \fIselect\fP were pointers to integers
-instead of pointers to \fIfd_set\fPs. This type of call
-will still work as long as the number of file descriptors
-being examined is less than the number of bits in an
-integer; however, the methods illustrated above should
-be used in all current programs.
-.PP
-\fISelect\fP provides a synchronous multiplexing scheme.
-Asynchronous notification of output completion, input availability,
-and exceptional conditions is possible through use of the
-SIGIO and SIGURG signals described in section 5.
diff --git a/share/doc/psd/21.ipc/3.t b/share/doc/psd/21.ipc/3.t
deleted file mode 100644
index 42ba6799e26..00000000000
--- a/share/doc/psd/21.ipc/3.t
+++ /dev/null
@@ -1,407 +0,0 @@
-.\" $OpenBSD: 3.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)3.t 8.1 (Berkeley) 6/8/93
-.\"
-.\".ds RH "Network Library Routines
-.bp
-.nr H1 3
-.nr H2 0
-.bp
-.LG
-.B
-.ce
-3. NETWORK LIBRARY ROUTINES
-.sp 2
-.R
-.NL
-.PP
-The discussion in section 2 indicated the possible need to
-locate and construct network addresses when using the
-interprocess communication facilities in a distributed
-environment. To aid in this task a number of routines
-have been added to the standard C run-time library.
-In this section we will consider the new routines provided
-to manipulate network addresses. While the 4.4BSD networking
-facilities support the Internet protocols
-and the Xerox NS protocols,
-most of the routines presented
-in this section do not apply to the NS domain. Unless otherwise
-stated, it should be assumed that the routines presented in this
-section do not apply to the NS domain.
-.PP
-Locating a service on a remote host requires many levels of
-mapping before client and server may
-communicate. A service is assigned a name which is intended
-for human consumption; e.g. \*(lqthe \fIlogin server\fP on host
-monet\*(rq.
-This name, and the name of the peer host, must then be translated
-into network \fIaddresses\fP which are not necessarily suitable
-for human consumption. Finally, the address must then used in locating
-a physical \fIlocation\fP and \fIroute\fP to the service. The
-specifics of these three mappings are likely to vary between
-network architectures. For instance, it is desirable for a network
-to not require hosts to
-be named in such a way that their physical location is known by
-the client host. Instead, underlying services in the network
-may discover the actual location of the host at the time a client
-host wishes to communicate. This ability to have hosts named in
-a location independent manner may induce overhead in connection
-establishment, as a discovery process must take place,
-but allows a host to be physically mobile without requiring it to
-notify its clientele of its current location.
-.PP
-Standard routines are provided for: mapping host names
-to network addresses, network names to network numbers,
-protocol names to protocol numbers, and service names
-to port numbers and the appropriate protocol to
-use in communicating with the server process. The
-file <\fInetdb.h\fP> must be included when using any of these
-routines.
-.NH 2
-Host names
-.PP
-An Internet host name to address mapping is represented by
-the \fIhostent\fP structure:
-.DS
-.if t .ta 0.6i 1.1i 2.6i
-struct hostent {
- char *h_name; /* official name of host */
- char **h_aliases; /* alias list */
- int h_addrtype; /* host address type (e.g., AF_INET) */
- int h_length; /* length of address */
- char **h_addr_list; /* list of addresses, null terminated */
-};
-
-#define h_addr h_addr_list[0] /* first address, network byte order */
-.DE
-The routine \fIgethostbyname\fP(3N) takes an Internet host name
-and returns a \fIhostent\fP structure,
-while the routine \fIgethostbyaddr\fP(3N)
-maps Internet host addresses into a \fIhostent\fP structure.
-.PP
-The official name of the host and its public aliases are
-returned by these routines,
-along with the address type (family) and a null terminated list of
-variable length address. This list of addresses is
-required because it is possible
-for a host to have many addresses, all having the same name.
-The \fIh_addr\fP definition is provided for backward compatibility,
-and is defined to be the first address in the list of addresses
-in the \fIhostent\fP structure.
-.PP
-The database for these calls is provided either by the
-file \fI/etc/hosts\fP (\fIhosts\fP\|(5)),
-or by use of a nameserver, \fInamed\fP\|(8).
-Because of the differences in these databases and their access protocols,
-the information returned may differ.
-When using the host table version of \fIgethostbyname\fP,
-only one address will be returned, but all listed aliases will be included.
-The nameserver version may return alternate addresses,
-but will not provide any aliases other than one given as argument.
-.PP
-Unlike Internet names, NS names are always mapped into host
-addresses by the use of a standard NS \fIClearinghouse service\fP,
-a distributed name and authentication server. The algorithms
-for mapping NS names to addresses via a Clearinghouse are
-rather complicated, and the routines are not part of the
-standard libraries. The user-contributed Courier (Xerox
-remote procedure call protocol) compiler contains routines
-to accomplish this mapping; see the documentation and
-examples provided therein for more information. It is
-expected that almost all software that has to communicate
-using NS will need to use the facilities of
-the Courier compiler.
-.PP
-An NS host address is represented by the following:
-.DS
-union ns_host {
- u_char c_host[6];
- u_short s_host[3];
-};
-
-union ns_net {
- u_char c_net[4];
- u_short s_net[2];
-};
-
-struct ns_addr {
- union ns_net x_net;
- union ns_host x_host;
- u_short x_port;
-};
-.DE
-The following code fragment inserts a known NS address into
-a \fIns_addr\fP:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
- ...
-u_long netnum;
-struct sockaddr_ns dst;
- ...
-bzero((char *)&dst, sizeof(dst));
-
-/*
- * There is no convenient way to assign a long
- * integer to a ``union ns_net'' at present; in
- * the future, something will hopefully be provided,
- * but this is the portable way to go for now.
- * The network number below is the one for the NS net
- * that the desired host (gyre) is on.
- */
-netnum = htonl(2266);
-dst.sns_addr.x_net = *(union ns_net *) &netnum;
-dst.sns_family = AF_NS;
-
-/*
- * host 2.7.1.0.2a.18 == "gyre:Computer Science:UofMaryland"
- */
-dst.sns_addr.x_host.c_host[0] = 0x02;
-dst.sns_addr.x_host.c_host[1] = 0x07;
-dst.sns_addr.x_host.c_host[2] = 0x01;
-dst.sns_addr.x_host.c_host[3] = 0x00;
-dst.sns_addr.x_host.c_host[4] = 0x2a;
-dst.sns_addr.x_host.c_host[5] = 0x18;
-dst.sns_addr.x_port = htons(75);
-.DE
-.NH 2
-Network names
-.PP
-As for host names, routines for mapping network names to numbers,
-and back, are provided. These routines return a \fInetent\fP
-structure:
-.DS
-.DT
-/*
- * Assumption here is that a network number
- * fits in 32 bits -- probably a poor one.
- */
-struct netent {
- char *n_name; /* official name of net */
- char **n_aliases; /* alias list */
- int n_addrtype; /* net address type */
- int n_net; /* network number, host byte order */
-};
-.DE
-The routines \fIgetnetbyname\fP(3N), \fIgetnetbynumber\fP(3N),
-and \fIgetnetent\fP(3N) are the network counterparts to the
-host routines described above. The routines extract their
-information from \fI/etc/networks\fP.
-.PP
-NS network numbers are determined either by asking your local
-Xerox Network Administrator (and hardcoding the information
-into your code), or by querying the Clearinghouse for addresses.
-The internetwork router is the only process
-that needs to manipulate network numbers on a regular basis; if
-a process wishes to communicate with a machine, it should ask the
-Clearinghouse for that machine's address (which will include
-the net number).
-.NH 2
-Protocol names
-.PP
-For protocols, which are defined in \fI/etc/protocols\fP,
-the \fIprotoent\fP structure defines the
-protocol-name mapping
-used with the routines \fIgetprotobyname\fP(3N),
-\fIgetprotobynumber\fP(3N),
-and \fIgetprotoent\fP(3N):
-.DS
-.DT
-struct protoent {
- char *p_name; /* official protocol name */
- char **p_aliases; /* alias list */
- int p_proto; /* protocol number */
-};
-.DE
-.PP
-In the NS domain, protocols are indicated by the "client type"
-field of a IDP header. No protocol database exists; see section
-5 for more information.
-.NH 2
-Service names
-.PP
-Information regarding services is a bit more complicated. A service
-is expected to reside at a specific \*(lqport\*(rq and employ
-a particular communication protocol. This view is consistent with
-the Internet domain, but inconsistent with other network architectures.
-Further, a service may reside on multiple ports.
-If this occurs, the higher level library routines
-will have to be bypassed or extended.
-Services available are contained in the file \fI/etc/services\fP.
-A service mapping is described by the \fIservent\fP structure,
-.DS
-.DT
-struct servent {
- char *s_name; /* official service name */
- char **s_aliases; /* alias list */
- int s_port; /* port number, network byte order */
- char *s_proto; /* protocol to use */
-};
-.DE
-The routine \fIgetservbyname\fP(3N) maps service
-names to a servent structure by specifying a service name and,
-optionally, a qualifying protocol. Thus the call
-.DS
-sp = getservbyname("telnet", (char *) 0);
-.DE
-returns the service specification for a telnet server using
-any protocol, while the call
-.DS
-sp = getservbyname("telnet", "tcp");
-.DE
-returns only that telnet server which uses the TCP protocol.
-The routines \fIgetservbyport\fP(3N) and \fIgetservent\fP(3N) are
-also provided. The \fIgetservbyport\fP routine has an interface similar
-to that provided by \fIgetservbyname\fP; an optional protocol name may
-be specified to qualify lookups.
-.PP
-In the NS domain, services are handled by a central dispatcher
-provided as part of the Courier remote procedure call facilities.
-Again, the reader is referred to the Courier compiler documentation
-and to the Xerox standard*
-.FS
-* \fICourier: The Remote Procedure Call Protocol\fP, XSIS 038112.
-.FE
-for further details.
-.NH 2
-Miscellaneous
-.PP
-With the support routines described above, an Internet application program
-should rarely have to deal directly
-with addresses. This allows
-services to be developed as much as possible in a network independent
-fashion. It is clear, however, that purging all network dependencies
-is very difficult. So long as the user is required to supply network
-addresses when naming services and sockets there will always some
-network dependency in a program. For example, the normal
-code included in client programs, such as the remote login program,
-is of the form shown in Figure 1.
-(This example will be considered in more detail in section 4.)
-.PP
-If we wanted to make the remote login program independent of the
-Internet protocols and addressing scheme we would be forced to add
-a layer of routines which masked the network dependent aspects from
-the mainstream login code. For the current facilities available in
-the system this does not appear to be worthwhile.
-.PP
-Aside from the address-related data base routines, there are several
-other routines available in the run-time library which are of interest
-to users. These are intended mostly to simplify manipulation of
-names and addresses. Table 1 summarizes the routines
-for manipulating variable length byte strings and handling byte
-swapping of network addresses and values.
-.KF
-.DS B
-.TS
-box;
-l | l
-l | l.
-Call Synopsis
-_
-bcmp(s1, s2, n) compare byte-strings; 0 if same, not 0 otherwise
-bcopy(s1, s2, n) copy n bytes from s1 to s2
-bzero(base, n) zero-fill n bytes starting at base
-htonl(val) convert 32-bit quantity from host to network byte order
-htons(val) convert 16-bit quantity from host to network byte order
-ntohl(val) convert 32-bit quantity from network to host byte order
-ntohs(val) convert 16-bit quantity from network to host byte order
-.TE
-.DE
-.ce
-Table 1. C run-time routines.
-.KE
-.PP
-The byte swapping routines are provided because the operating
-system expects addresses to be supplied in network order (aka ``big-endian'' order). On
-``little-endian'' architectures, such as Intel x86 and VAX,
-host byte ordering is different than
-network byte ordering. Consequently,
-programs are sometimes required to byte swap quantities. The
-library routines which return network addresses provide them
-in network order so that they may simply be copied into the structures
-provided to the system. This implies users should encounter the
-byte swapping problem only when \fIinterpreting\fP network addresses.
-For example, if an Internet port is to be printed out the following
-code would be required:
-.DS
-printf("port number %d\en", ntohs(sp->s_port));
-.DE
-On machines where unneeded these routines are defined as null
-macros.
-.DS
-.if t .ta .5i 1.0i 1.5i 2.0i
-.if n .ta .7i 1.4i 2.1i 2.8i
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <stdio.h>
-#include <netdb.h>
- ...
-main(argc, argv)
- int argc;
- char *argv[];
-{
- struct sockaddr_in server;
- struct servent *sp;
- struct hostent *hp;
- int s;
- ...
- sp = getservbyname("login", "tcp");
- if (sp == NULL) {
- fprintf(stderr, "rlogin: tcp/login: unknown service\en");
- exit(1);
- }
- hp = gethostbyname(argv[1]);
- if (hp == NULL) {
- fprintf(stderr, "rlogin: %s: unknown host\en", argv[1]);
- exit(2);
- }
- bzero((char *)&server, sizeof (server));
- bcopy(hp->h_addr, (char *)&server.sin_addr, hp->h_length);
- server.sin_family = hp->h_addrtype;
- server.sin_port = sp->s_port;
- s = socket(AF_INET, SOCK_STREAM, 0);
- if (s < 0) {
- perror("rlogin: socket");
- exit(3);
- }
- ...
- /* Connect does the bind() for us */
-
- if (connect(s, (char *)&server, sizeof (server)) < 0) {
- perror("rlogin: connect");
- exit(5);
- }
- ...
-}
-.DE
-.ce
-Figure 1. Remote login client code.
diff --git a/share/doc/psd/21.ipc/4.t b/share/doc/psd/21.ipc/4.t
deleted file mode 100644
index f770b8faa0f..00000000000
--- a/share/doc/psd/21.ipc/4.t
+++ /dev/null
@@ -1,512 +0,0 @@
-.\" $OpenBSD: 4.t,v 1.3 2003/06/02 23:30:10 millert Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)4.t 8.1 (Berkeley) 6/8/93
-.\"
-.\".ds RH "Client/Server Model
-.bp
-.nr H1 4
-.nr H2 0
-.sp 8i
-.bp
-.LG
-.B
-.ce
-4. CLIENT/SERVER MODEL
-.sp 2
-.R
-.NL
-.PP
-The most commonly used paradigm in constructing distributed applications
-is the client/server model. In this scheme client applications request
-services from a server process. This implies an asymmetry in establishing
-communication between the client and server which has been examined
-in section 2. In this section we will look more closely at the interactions
-between client and server, and consider some of the problems in developing
-client and server applications.
-.PP
-The client and server require a well known set of conventions before
-service may be rendered (and accepted). This set of conventions
-comprises a protocol which must be implemented at both ends of a
-connection. Depending on the situation, the protocol may be symmetric
-or asymmetric. In a symmetric protocol, either side may play the
-master or slave roles. In an asymmetric protocol, one side is
-immutably recognized as the master, with the other as the slave.
-An example of a symmetric protocol is the TELNET protocol used in
-the Internet for remote terminal emulation. An example
-of an asymmetric protocol is the Internet file transfer protocol,
-FTP. No matter whether the specific protocol used in obtaining
-a service is symmetric or asymmetric, when accessing a service there
-is a \*(lqclient process\*(rq and a \*(lqserver process\*(rq. We
-will first consider the properties of server processes, then
-client processes.
-.PP
-A server process normally listens at a well known address for
-service requests. That is, the server process remains dormant
-until a connection is requested by a client's connection
-to the server's address. At such a time
-the server process ``wakes up'' and services the client,
-performing whatever appropriate actions the client requests of it.
-.PP
-Alternative schemes which use a service server
-may be used to eliminate a flock of server processes clogging the
-system while remaining dormant most of the time. For Internet
-servers in 4.4BSD,
-this scheme has been implemented via \fIinetd\fP, the so called
-``internet super-server.'' \fIInetd\fP listens at a variety
-of ports, determined at start-up by reading a configuration file.
-When a connection is requested to a port on which \fIinetd\fP is
-listening, \fIinetd\fP executes the appropriate server program to handle the
-client. With this method, clients are unaware that an
-intermediary such as \fIinetd\fP has played any part in the
-connection. \fIInetd\fP will be described in more detail in
-section 5.
-.PP
-A similar alternative scheme is used by most Xerox services. In general,
-the Courier dispatch process (if used) accepts connections from
-processes requesting services of some sort or another. The client
-processes request a particular <program number, version number, procedure
-number> triple. If the dispatcher knows of such a program, it is
-started to handle the request; if not, an error is reported to the
-client. In this way, only one port is required to service a large
-variety of different requests. Again, the Courier facilities are
-not available without the use and installation of the Courier
-compiler. The information presented in this section applies only
-to NS clients and services that do not use Courier.
-.NH 2
-Servers
-.PP
-In 4.4BSD most servers are accessed at well known Internet addresses
-or UNIX domain names. For
-example, the remote login server's main loop is of the form shown
-in Figure 2.
-.KF
-.if t .ta .5i 1.0i 1.5i 2.0i 2.5i 3.0i 3.5i
-.if n .ta .7i 1.4i 2.1i 2.8i 3.5i 4.2i 4.9i
-.sp 0.5i
-.DS
-main(argc, argv)
- int argc;
- char *argv[];
-{
- int f;
- struct sockaddr_in from;
- struct servent *sp;
-
- sp = getservbyname("login", "tcp");
- if (sp == NULL) {
- fprintf(stderr, "rlogind: tcp/login: unknown service\en");
- exit(1);
- }
- ...
-#ifndef DEBUG
- /* Disassociate server from controlling terminal */
- ...
-#endif
-
- sin.sin_port = sp->s_port; /* Restricted port -- see section 5 */
- ...
- f = socket(AF_INET, SOCK_STREAM, 0);
- ...
- if (bind(f, (struct sockaddr *) &sin, sizeof (sin)) < 0) {
- ...
- }
- ...
- listen(f, 5);
- for (;;) {
- int g, len = sizeof (from);
-
- g = accept(f, (struct sockaddr *) &from, &len);
- if (g < 0) {
- if (errno != EINTR)
- syslog(LOG_ERR, "rlogind: accept: %m");
- continue;
- }
- if (fork() == 0) {
- close(f);
- doit(g, &from);
- }
- close(g);
- }
-}
-.DE
-.ce
-Figure 2. Remote login server.
-.sp 0.5i
-.KE
-.PP
-The first step taken by the server is look up its service
-definition:
-.sp 1
-.nf
-.in +5
-.if t .ta .5i 1.0i 1.5i 2.0i
-.if n .ta .7i 1.4i 2.1i 2.8i
-sp = getservbyname("login", "tcp");
-if (sp == NULL) {
- fprintf(stderr, "rlogind: tcp/login: unknown service\en");
- exit(1);
-}
-.sp 1
-.in -5
-.fi
-The result of the \fIgetservbyname\fP call
-is used in later portions of the code to
-define the Internet port at which it listens for service
-requests (indicated by a connection).
-.KS
-.PP
-Step two is to disassociate the server from the controlling
-terminal of its invoker:
-.DS
- for (i = 0; i < 3; ++i)
- close(i);
-
- open("/", O_RDONLY);
- dup2(0, 1);
- dup2(0, 2);
-
- i = open("/dev/tty", O_RDWR);
- if (i >= 0) {
- ioctl(i, TIOCNOTTY, 0);
- close(i);
- }
-.DE
-.KE
-This step is important as the server will
-likely not want to receive signals delivered to the process
-group of the controlling terminal. Note, however, that
-once a server has disassociated itself it can no longer
-send reports of errors to a terminal, and must log errors
-via \fIsyslog\fP.
-.PP
-Once a server has established a pristine environment, it
-creates a socket and begins accepting service requests.
-The \fIbind\fP call is required to insure the server listens
-at its expected location. It should be noted that the
-remote login server listens at a restricted port number, and must
-therefore be run
-with a user-id of root.
-This concept of a ``restricted port number'' is 4BSD
-specific, and is covered in section 5.
-.PP
-The main body of the loop is fairly simple:
-.DS
-.if t .ta .5i 1.0i 1.5i 2.0i
-.if n .ta .7i 1.4i 2.1i 2.8i
-for (;;) {
- int g, len = sizeof (from);
-
- g = accept(f, (struct sockaddr *)&from, &len);
- if (g < 0) {
- if (errno != EINTR)
- syslog(LOG_ERR, "rlogind: accept: %m");
- continue;
- }
- if (fork() == 0) { /* Child */
- close(f);
- doit(g, &from);
- }
- close(g); /* Parent */
-}
-.DE
-An \fIaccept\fP call blocks the server until
-a client requests service. This call could return a
-failure status if the call is interrupted by a signal
-such as SIGCHLD (to be discussed in section 5). Therefore,
-the return value from \fIaccept\fP is checked to insure
-a connection has actually been established, and
-an error report is logged via \fIsyslog\fP if an error
-has occurred.
-.PP
-With a connection
-in hand, the server then forks a child process and invokes
-the main body of the remote login protocol processing. Note
-how the socket used by the parent for queuing connection
-requests is closed in the child, while the socket created as
-a result of the \fIaccept\fP is closed in the parent. The
-address of the client is also handed the \fIdoit\fP routine
-because it requires it in authenticating clients.
-.NH 2
-Clients
-.PP
-The client side of the remote login service was shown
-earlier in Figure 1.
-One can see the separate, asymmetric roles of the client
-and server clearly in the code. The server is a passive entity,
-listening for client connections, while the client process is
-an active entity, initiating a connection when invoked.
-.PP
-Let us consider more closely the steps taken
-by the client remote login process. As in the server process,
-the first step is to locate the service definition for a remote
-login:
-.DS
-sp = getservbyname("login", "tcp");
-if (sp == NULL) {
- fprintf(stderr, "rlogin: tcp/login: unknown service\en");
- exit(1);
-}
-.DE
-Next the destination host is looked up with a
-\fIgethostbyname\fP call:
-.DS
-hp = gethostbyname(argv[1]);
-if (hp == NULL) {
- fprintf(stderr, "rlogin: %s: unknown host\en", argv[1]);
- exit(2);
-}
-.DE
-With this accomplished, all that is required is to establish a
-connection to the server at the requested host and start up the
-remote login protocol. The address buffer is cleared, then filled
-in with the Internet address of the foreign host and the port
-number at which the login process resides on the foreign host:
-.DS
-bzero((char *)&server, sizeof (server));
-bcopy(hp->h_addr, (char *) &server.sin_addr, hp->h_length);
-server.sin_family = hp->h_addrtype;
-server.sin_port = sp->s_port;
-.DE
-A socket is created, and a connection initiated. Note
-that \fIconnect\fP implicitly performs a \fIbind\fP
-call, since \fIs\fP is unbound.
-.DS
-s = socket(hp->h_addrtype, SOCK_STREAM, 0);
-if (s < 0) {
- perror("rlogin: socket");
- exit(3);
-}
- ...
-if (connect(s, (struct sockaddr *) &server, sizeof (server)) < 0) {
- perror("rlogin: connect");
- exit(4);
-}
-.DE
-The details of the remote login protocol will not be considered here.
-.NH 2
-Connectionless servers
-.PP
-While connection-based services are the norm, some services
-are based on the use of datagram sockets. One, in particular,
-is the \*(lqrwho\*(rq service which provides users with status
-information for hosts connected to a local area
-network. This service, while predicated on the ability to
-\fIbroadcast\fP information to all hosts connected to a particular
-network, is of interest as an example usage of datagram sockets.
-.PP
-A user on any machine running the rwho server may find out
-the current status of a machine with the \fIruptime\fP(1) program.
-The output generated is illustrated in Figure 3.
-.KF
-.DS B
-.TS
-l r l l l l l.
-arpa up 9:45, 5 users, load 1.15, 1.39, 1.31
-cad up 2+12:04, 8 users, load 4.67, 5.13, 4.59
-calder up 10:10, 0 users, load 0.27, 0.15, 0.14
-dali up 2+06:28, 9 users, load 1.04, 1.20, 1.65
-degas up 25+09:48, 0 users, load 1.49, 1.43, 1.41
-ear up 5+00:05, 0 users, load 1.51, 1.54, 1.56
-ernie down 0:24
-esvax down 17:04
-ingres down 0:26
-kim up 3+09:16, 8 users, load 2.03, 2.46, 3.11
-matisse up 3+06:18, 0 users, load 0.03, 0.03, 0.05
-medea up 3+09:39, 2 users, load 0.35, 0.37, 0.50
-merlin down 19+15:37
-miro up 1+07:20, 7 users, load 4.59, 3.28, 2.12
-monet up 1+00:43, 2 users, load 0.22, 0.09, 0.07
-oz down 16:09
-statvax up 2+15:57, 3 users, load 1.52, 1.81, 1.86
-ucbvax up 9:34, 2 users, load 6.08, 5.16, 3.28
-.TE
-.DE
-.ce
-Figure 3. ruptime output.
-.sp
-.KE
-.PP
-Status information for each host is periodically broadcast
-by rwho server processes on each machine. The same server
-process also receives the status information and uses it
-to update a database. This database is then interpreted
-to generate the status information for each host. Servers
-operate autonomously, coupled only by the local network and
-its broadcast capabilities.
-.PP
-Note that the use of broadcast for such a task is fairly inefficient,
-as all hosts must process each message, whether or not using an rwho server.
-Unless such a service is sufficiently universal and is frequently used,
-the expense of periodic broadcasts outweighs the simplicity.
-.PP
-Multicasting is an alternative to broadcasting.
-Setting up multicast sockets is described in Section 5.10.
-.PP
-The rwho server, in a simplified form, is pictured in Figure
-4. There are two separate tasks performed by the server. The
-first task is to act as a receiver of status information broadcast
-by other hosts on the network. This job is carried out in the
-main loop of the program. Packets received at the rwho port
-are interrogated to insure they've been sent by another rwho
-server process, then are time stamped with their arrival time
-and used to update a file indicating the status of the host.
-When a host has not been heard from for an extended period of
-time, the database interpretation routines assume the host is
-down and indicate such on the status reports. This algorithm
-is prone to error as a server may be down while a host is actually
-up, but serves our current needs.
-.KF
-.DS
-.if t .ta .5i 1.0i 1.5i 2.0i
-.if n .ta .7i 1.4i 2.1i 2.8i
-main()
-{
- ...
- sp = getservbyname("who", "udp");
- net = getnetbyname("localnet");
- sin.sin_addr = inet_makeaddr(INADDR_ANY, net);
- sin.sin_port = sp->s_port;
- ...
- s = socket(AF_INET, SOCK_DGRAM, 0);
- ...
- on = 1;
- if (setsockopt(s, SOL_SOCKET, SO_BROADCAST, &on, sizeof(on)) < 0) {
- syslog(LOG_ERR, "setsockopt SO_BROADCAST: %m");
- exit(1);
- }
- bind(s, (struct sockaddr *) &sin, sizeof (sin));
- ...
- signal(SIGALRM, onalrm);
- onalrm();
- for (;;) {
- struct whod wd;
- int cc, whod, len = sizeof (from);
-
- cc = recvfrom(s, (char *)&wd, sizeof (struct whod), 0,
- (struct sockaddr *)&from, &len);
- if (cc <= 0) {
- if (cc < 0 && errno != EINTR)
- syslog(LOG_ERR, "rwhod: recv: %m");
- continue;
- }
- if (from.sin_port != sp->s_port) {
- syslog(LOG_ERR, "rwhod: %d: bad from port",
- ntohs(from.sin_port));
- continue;
- }
- ...
- if (!verify(wd.wd_hostname)) {
- syslog(LOG_ERR, "rwhod: malformed host name from %x",
- ntohl(from.sin_addr.s_addr));
- continue;
- }
- (void) sprintf(path, "%s/whod.%s", RWHODIR, wd.wd_hostname);
- whod = open(path, O_WRONLY | O_CREAT | O_TRUNC, 0666);
- ...
- (void) time(&wd.wd_recvtime);
- (void) write(whod, (char *)&wd, cc);
- (void) close(whod);
- }
-}
-.DE
-.ce
-Figure 4. rwho server.
-.sp
-.KE
-.PP
-The second task performed by the server is to supply information
-regarding the status of its host. This involves periodically
-acquiring system status information, packaging it up in a message
-and broadcasting it on the local network for other rwho servers
-to hear. The supply function is triggered by a timer and
-runs off a signal. Locating the system status
-information is somewhat involved, but uninteresting. Deciding
-where to transmit the resultant packet
-is somewhat problematical, however.
-.PP
-Status information must be broadcast on the local network.
-For networks which do not support the notion of broadcast another
-scheme must be used to simulate or
-replace broadcasting. One possibility is to enumerate the
-known neighbors (based on the status messages received
-from other rwho servers). This, unfortunately,
-requires some bootstrapping information,
-for a server will have no idea what machines are its
-neighbors until it receives status messages from them.
-Therefore, if all machines on a net are freshly booted,
-no machine will have any
-known neighbors and thus never receive, or send, any status information.
-This is the identical problem faced by the routing table management
-process in propagating routing status information. The standard
-solution, unsatisfactory as it may be, is to inform one or more servers
-of known neighbors and request that they always communicate with
-these neighbors. If each server has at least one neighbor supplied
-to it, status information may then propagate through
-a neighbor to hosts which
-are not (possibly) directly neighbors. If the server is able to
-support networks which provide a broadcast capability, as well as
-those which do not, then networks with an
-arbitrary topology may share status information*.
-.FS
-* One must, however, be concerned about \*(lqloops\*(rq.
-That is, if a host is connected to multiple networks, it
-will receive status information from itself. This can lead
-to an endless, wasteful, exchange of information.
-.FE
-.PP
-It is important that software operating in a distributed
-environment not have any site-dependent information compiled into it.
-This would require a separate copy of the server at each host and
-make maintenance a severe headache. 4.4BSD attempts to isolate
-host-specific information from applications by providing system
-calls which return the necessary information*.
-.FS
-* An example of such a system call is the \fIgethostname\fP(2)
-call which returns the host's \*(lqofficial\*(rq name.
-.FE
-A mechanism exists, in the form of an \fIioctl\fP call,
-for finding the collection
-of networks to which a host is directly connected.
-Further, a local network broadcasting mechanism
-has been implemented at the socket level.
-Combining these two features allows a process
-to broadcast on any directly connected local
-network which supports the notion of broadcasting
-in a site independent manner. This allows 4.4BSD
-to solve the problem of deciding how to propagate
-status information in the case of \fIrwho\fP, or
-more generally in broadcasting:
-Such status information is broadcast to connected
-networks at the socket level, where the connected networks
-have been obtained via the appropriate \fIioctl\fP
-calls.
-The specifics of
-such broadcastings are complex, however, and will
-be covered in section 5.
diff --git a/share/doc/psd/21.ipc/5.t b/share/doc/psd/21.ipc/5.t
deleted file mode 100644
index e72f94aa08f..00000000000
--- a/share/doc/psd/21.ipc/5.t
+++ /dev/null
@@ -1,1665 +0,0 @@
-.\" $OpenBSD: 5.t,v 1.4 2005/09/20 20:36:09 krw Exp $
-.\"
-.\" Copyright (c) 1986, 1993
-.\" The Regents of the University of California. 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.
-.\" 3. Neither the name of the University nor the names of its contributors
-.\" may be used to endorse or promote products derived from this software
-.\" without specific prior written permission.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS 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 REGENTS 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.
-.\"
-.\" @(#)5.t 8.1 (Berkeley) 8/14/93
-.\"
-.\".ds RH "Advanced Topics
-.bp
-.nr H1 5
-.nr H2 0
-.LG
-.B
-.ce
-5. ADVANCED TOPICS
-.sp 2
-.R
-.NL
-.PP
-A number of facilities have yet to be discussed. For most users
-of the IPC the mechanisms already
-described will suffice in constructing distributed
-applications. However, others will find the need to utilize some
-of the features which we consider in this section.
-.NH 2
-Out of band data
-.PP
-The stream socket abstraction includes the notion of \*(lqout
-of band\*(rq data. Out of band data is a logically independent
-transmission channel associated with each pair of connected
-stream sockets. Out of band data is delivered to the user
-independently of normal data.
-The abstraction defines that the out of band data facilities
-must support the reliable delivery of at least one
-out of band message at a time. This message may contain at least one
-byte of data, and at least one message may be pending delivery
-to the user at any one time. For communications protocols which
-support only in-band signaling (i.e. the urgent data is
-delivered in sequence with the normal data), the system normally extracts
-the data from the normal data stream and stores it separately.
-This allows users to choose between receiving the urgent data
-in order and receiving it out of sequence without having to
-buffer all the intervening data. It is possible
-to ``peek'' (via MSG_PEEK) at out of band data.
-If the socket has a process group, a SIGURG signal is generated
-when the protocol is notified of its existence.
-A process can set the process group
-or process id to be informed by the SIGURG signal via the
-appropriate \fIfcntl\fP call, as described below for
-SIGIO.
-If multiple sockets may have out of band data awaiting
-delivery, a \fIselect\fP call for exceptional conditions
-may be used to determine those sockets with such data pending.
-Neither the signal nor the select indicate the actual arrival
-of the out-of-band data, but only notification that it is pending.
-.PP
-In addition to the information passed, a logical mark is placed in
-the data stream to indicate the point at which the out
-of band data was sent. The remote login and remote shell
-applications use this facility to propagate signals between
-client and server processes. When a signal
-flushs any pending output from the remote process(es), all
-data up to the mark in the data stream is discarded.
-.PP
-To send an out of band message the MSG_OOB flag is supplied to
-a \fIsend\fP or \fIsendto\fP calls,
-while to receive out of band data MSG_OOB should be indicated
-when performing a \fIrecvfrom\fP or \fIrecv\fP call.
-To find out if the read pointer is currently pointing at
-the mark in the data stream, the SIOCATMARK ioctl is provided:
-.DS
-ioctl(s, SIOCATMARK, &yes);
-.DE
-If \fIyes\fP is a 1 on return, the next read will return data
-after the mark. Otherwise (assuming out of band data has arrived),
-the next read will provide data sent by the client prior
-to transmission of the out of band signal. The routine used
-in the remote login process to flush output on receipt of an
-interrupt or quit signal is shown in Figure 5.
-It reads the normal data up to the mark (to discard it),
-then reads the out-of-band byte.
-.KF
-.DS
-#include <sys/ioctl.h>
-#include <sys/file.h>
- ...
-oob()
-{
- int out = FWRITE, mark;
- char waste[BUFSIZ];
-
- /* flush local terminal output */
- ioctl(1, TIOCFLUSH, (char *)&out);
- for (;;) {
- if (ioctl(rem, SIOCATMARK, &mark) < 0) {
- perror("ioctl");
- break;
- }
- if (mark)
- break;
- (void) read(rem, waste, sizeof (waste));
- }
- if (recv(rem, &mark, 1, MSG_OOB) < 0) {
- perror("recv");
- ...
- }
- ...
-}
-.DE
-.ce
-Figure 5. Flushing terminal I/O on receipt of out of band data.
-.sp
-.KE
-.PP
-A process may also read or peek at the out-of-band data
-without first reading up to the mark.
-This is more difficult when the underlying protocol delivers
-the urgent data in-band with the normal data, and only sends
-notification of its presence ahead of time (e.g., the TCP protocol
-used to implement streams in the Internet domain).
-With such protocols, the out-of-band byte may not yet have arrived
-when a \fIrecv\fP is done with the MSG_OOB flag.
-In that case, the call will return an error of EWOULDBLOCK.
-Worse, there may be enough in-band data in the input buffer
-that normal flow control prevents the peer from sending the urgent data
-until the buffer is cleared.
-The process must then read enough of the queued data
-that the urgent data may be delivered.
-.PP
-Certain programs that use multiple bytes of urgent data and must
-handle multiple urgent signals (e.g., \fItelnet\fP\|(1C))
-need to retain the position of urgent data within the stream.
-This treatment is available as a socket-level option, SO_OOBINLINE;
-see \fIsetsockopt\fP\|(2) for usage.
-With this option, the position of urgent data (the \*(lqmark\*(rq)
-is retained, but the urgent data immediately follows the mark
-within the normal data stream returned without the MSG_OOB flag.
-Reception of multiple urgent indications causes the mark to move,
-but no out-of-band data are lost.
-.NH 2
-Non-Blocking Sockets
-.PP
-It is occasionally convenient to make use of sockets
-which do not block; that is, I/O requests which
-cannot complete immediately and
-would therefore cause the process to be suspended awaiting completion are
-not executed, and an error code is returned.
-Once a socket has been created via
-the \fIsocket\fP call, it may be marked as non-blocking
-by \fIfcntl\fP as follows:
-.DS
-#include <fcntl.h>
- ...
-int s;
- ...
-s = socket(AF_INET, SOCK_STREAM, 0);
- ...
-if (fcntl(s, F_SETFL, FNDELAY) < 0)
- perror("fcntl F_SETFL, FNDELAY");
- exit(1);
-}
- ...
-.DE
-.PP
-When performing non-blocking I/O on sockets, one must be
-careful to check for the error EWOULDBLOCK (stored in the
-global variable \fIerrno\fP), which occurs when
-an operation would normally block, but the socket it
-was performed on is marked as non-blocking.
-In particular, \fIaccept\fP, \fIconnect\fP, \fIsend\fP, \fIrecv\fP,
-\fIread\fP, and \fIwrite\fP can
-all return EWOULDBLOCK, and processes should be prepared
-to deal with such return codes.
-If an operation such as a \fIsend\fP cannot be done in its entirety,
-but partial writes are sensible (for example, when using a stream socket),
-the data that can be sent immediately will be processed,
-and the return value will indicate the amount actually sent.
-.NH 2
-Interrupt driven socket I/O
-.PP
-The SIGIO signal allows a process to be notified
-via a signal when a socket (or more generally, a file
-descriptor) has data waiting to be read. Use of
-the SIGIO facility requires three steps: First,
-the process must set up a SIGIO signal handler
-by use of the \fIsignal\fP or \fIsigvec\fP calls. Second,
-it must set the process id or process group id which is to receive
-notification of pending input to its own process id,
-or the process group id of its process group (note that
-the default process group of a socket is group zero).
-This is accomplished by use of an \fIfcntl\fP call.
-Third, it must enable asynchronous notification of pending I/O requests
-with another \fIfcntl\fP call. Sample code to
-allow a given process to receive information on
-pending I/O requests as they occur for a socket \fIs\fP
-is given in Figure 6. With the addition of a handler for SIGURG,
-this code can also be used to prepare for receipt of SIGURG signals.
-.KF
-.DS
-#include <fcntl.h>
- ...
-int io_handler();
- ...
-signal(SIGIO, io_handler);
-
-/* Set the process receiving SIGIO/SIGURG signals to us */
-
-if (fcntl(s, F_SETOWN, getpid()) < 0) {
- perror("fcntl F_SETOWN");
- exit(1);
-}
-
-/* Allow receipt of asynchronous I/O signals */
-
-if (fcntl(s, F_SETFL, FASYNC) < 0) {
- perror("fcntl F_SETFL, FASYNC");
- exit(1);
-}
-.DE
-.ce
-Figure 6. Use of asynchronous notification of I/O requests.
-.sp
-.KE
-.NH 2
-Signals and process groups
-.PP
-Due to the existence of the SIGURG and SIGIO signals each socket has an
-associated process number, just as is done for terminals.
-This value is initialized to zero,
-but may be redefined at a later time with the F_SETOWN
-\fIfcntl\fP, such as was done in the code above for SIGIO.
-To set the socket's process id for signals, positive arguments
-should be given to the \fIfcntl\fP call. To set the socket's
-process group for signals, negative arguments should be
-passed to \fIfcntl\fP. Note that the process number indicates
-either the associated process id or the associated process
-group; it is impossible to specify both at the same time.
-A similar \fIfcntl\fP, F_GETOWN, is available for determining the
-current process number of a socket.
-.PP
-Another signal which is useful when constructing server processes
-is SIGCHLD. This signal is delivered to a process when any
-child processes have changed state. Normally servers use
-the signal to \*(lqreap\*(rq child processes that have exited
-without explicitly awaiting their termination
-or periodic polling for exit status.
-For example, the remote login server loop shown in Figure 2
-may be augmented as shown in Figure 7.
-.KF
-.DS
-int reaper();
- ...
-signal(SIGCHLD, reaper);
-listen(f, 5);
-for (;;) {
- int g, len = sizeof (from);
-
- g = accept(f, (struct sockaddr *)&from, &len,);
- if (g < 0) {
- if (errno != EINTR)
- syslog(LOG_ERR, "rlogind: accept: %m");
- continue;
- }
- ...
-}
- ...
-#include <wait.h>
-reaper()
-{
- union wait status;
-
- while (wait3(&status, WNOHANG, 0) > 0)
- ;
-}
-.DE
-.sp
-.ce
-Figure 7. Use of the SIGCHLD signal.
-.sp
-.KE
-.PP
-If the parent server process fails to reap its children,
-a large number of \*(lqzombie\*(rq processes may be created.
-.NH 2
-Pseudo terminals
-.PP
-Many programs will not function properly without a terminal
-for standard input and output. Since sockets do not provide
-the semantics of terminals,
-it is often necessary to have a process communicating over
-the network do so through a \fIpseudo-terminal\fP. A pseudo-
-terminal is actually a pair of devices, master and slave,
-which allow a process to serve as an active agent in communication
-between processes and users. Data written on the slave side
-of a pseudo-terminal is supplied as input to a process reading
-from the master side, while data written on the master side are
-processed as terminal input for the slave.
-In this way, the process manipulating
-the master side of the pseudo-terminal has control over the
-information read and written on the slave side
-as if it were manipulating the keyboard and reading the screen
-on a real terminal.
-The purpose of this abstraction is to
-preserve terminal semantics over a network connection\(em
-that is, the slave side appears as a normal terminal to
-any process reading from or writing to it.
-.PP
-For example, the remote
-login server uses pseudo-terminals for remote login sessions.
-A user logging in to a machine across the network is provided
-a shell with a slave pseudo-terminal as standard input, output,
-and error. The server process then handles the communication
-between the programs invoked by the remote shell and the user's
-local client process.
-When a user sends a character that generates an interrupt
-on the remote machine that flushes terminal output,
-the pseudo-terminal generates a control message for the server process.
-The server then sends an out of band message
-to the client process to signal a flush of data at the real terminal
-and on the intervening data buffered in the network.
-.PP
-Under 4.4BSD, the name of the slave side of a pseudo-terminal is of the form
-\fI/dev/ttyxy\fP, where \fIx\fP is a single letter
-starting at `p' and continuing to `t'.
-\fIy\fP is a hexadecimal digit (i.e., a single
-character in the range 0 through 9 or `a' through `f').
-The master side of a pseudo-terminal is \fI/dev/ptyxy\fP,
-where \fIx\fP and \fIy\fP correspond to the
-slave side of the pseudo-terminal.
-.PP
-In general, the method of obtaining a pair of master and
-slave pseudo-terminals is to
-find a pseudo-terminal which
-is not currently in use.
-The master half of a pseudo-terminal is a single-open device;
-thus, each master may be opened in turn until an open succeeds.
-The slave side of the pseudo-terminal is then opened,
-and is set to the proper terminal modes if necessary.
-The process then \fIfork\fPs; the child closes
-the master side of the pseudo-terminal, and \fIexec\fPs the
-appropriate program. Meanwhile, the parent closes the
-slave side of the pseudo-terminal and begins reading and
-writing from the master side. Sample code making use of
-pseudo-terminals is given in Figure 8; this code assumes
-that a connection on a socket \fIs\fP exists, connected
-to a peer who wants a service of some kind, and that the
-process has disassociated itself from any previous controlling terminal.
-.KF
-.DS
-gotpty = 0;
-for (c = 'p'; !gotpty && c <= 's'; c++) {
- line = "/dev/ptyXX";
- line[sizeof("/dev/pty")-1] = c;
- line[sizeof("/dev/ptyp")-1] = '0';
- if (stat(line, &statbuf) < 0)
- break;
- for (i = 0; i < 16; i++) {
- line[sizeof("/dev/ptyp")-1] = "0123456789abcdef"[i];
- master = open(line, O_RDWR);
- if (master > 0) {
- gotpty = 1;
- break;
- }
- }
-}
-if (!gotpty) {
- syslog(LOG_ERR, "All network ports in use");
- exit(1);
-}
-
-line[sizeof("/dev/")-1] = 't';
-slave = open(line, O_RDWR); /* \fIslave\fP is now slave side */
-if (slave < 0) {
- syslog(LOG_ERR, "Cannot open slave pty %s", line);
- exit(1);
-}
-
-ioctl(slave, TIOCGETP, &b); /* Set slave tty modes */
-b.sg_flags = CRMOD|XTABS|ANYP;
-ioctl(slave, TIOCSETP, &b);
-
-i = fork();
-if (i < 0) {
- syslog(LOG_ERR, "fork: %m");
- exit(1);
-} else if (i) { /* Parent */
- close(slave);
- ...
-} else { /* Child */
- (void) close(s);
- (void) close(master);
- dup2(slave, 0);
- dup2(slave, 1);
- dup2(slave, 2);
- if (slave > 2)
- (void) close(slave);
- ...
-}
-.DE
-.ce
-Figure 8. Creation and use of a pseudo terminal
-.sp
-.KE
-.NH 2
-Selecting specific protocols
-.PP
-If the third argument to the \fIsocket\fP call is 0,
-\fIsocket\fP will select a default protocol to use with
-the returned socket of the type requested.
-The default protocol is usually correct, and alternate choices are not
-usually available.
-However, when using ``raw'' sockets to communicate directly with
-lower-level protocols or hardware interfaces,
-the protocol argument may be important for setting up demultiplexing.
-For example, raw sockets in the Internet family may be used to implement
-a new protocol above IP, and the socket will receive packets
-only for the protocol specified.
-To obtain a particular protocol one determines the protocol number
-as defined within the communication domain. For the Internet
-domain one may use one of the library routines
-discussed in section 3, such as \fIgetprotobyname\fP:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <netdb.h>
- ...
-pp = getprotobyname("newtcp");
-s = socket(AF_INET, SOCK_STREAM, pp->p_proto);
-.DE
-This would result in a socket \fIs\fP using a stream
-based connection, but with protocol type of ``newtcp''
-instead of the default ``tcp.''
-.PP
-In the NS domain, the available socket protocols are defined in
-<\fInetns/ns.h\fP>. To create a raw socket for Xerox Error Protocol
-messages, one might use:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
- ...
-s = socket(AF_NS, SOCK_RAW, NSPROTO_ERROR);
-.DE
-.NH 2
-Address binding
-.PP
-As was mentioned in section 2,
-binding addresses to sockets in the Internet and NS domains can be
-fairly complex. As a brief reminder, these associations
-are composed of local and foreign
-addresses, and local and foreign ports. Port numbers are
-allocated out of separate spaces, one for each system and one
-for each domain on that system.
-Through the \fIbind\fP system call, a
-process may specify half of an association, the
-<local address, local port> part, while the
-\fIconnect\fP
-and \fIaccept\fP
-primitives are used to complete a socket's association by
-specifying the <foreign address, foreign port> part.
-Since the association is created in two steps the association
-uniqueness requirement indicated previously could be violated unless
-care is taken. Further, it is unrealistic to expect user
-programs to always know proper values to use for the local address
-and local port since a host may reside on multiple networks and
-the set of allocated port numbers is not directly accessible
-to a user.
-.PP
-To simplify local address binding in the Internet domain the notion of a
-\*(lqwildcard\*(rq address has been provided. When an address
-is specified as INADDR_ANY (a manifest constant defined in
-<netinet/in.h>), the system interprets the address as
-\*(lqany valid address\*(rq. For example, to bind a specific
-port number to a socket, but leave the local address unspecified,
-the following code might be used:
-.DS
-#include <sys/types.h>
-#include <netinet/in.h>
- ...
-struct sockaddr_in sin;
- ...
-s = socket(AF_INET, SOCK_STREAM, 0);
-sin.sin_family = AF_INET;
-sin.sin_addr.s_addr = htonl(INADDR_ANY);
-sin.sin_port = htons(MYPORT);
-bind(s, (struct sockaddr *) &sin, sizeof (sin));
-.DE
-Sockets with wildcarded local addresses may receive messages
-directed to the specified port number, and sent to any
-of the possible addresses assigned to a host. For example,
-if a host has addresses 128.32.0.4 and 10.0.0.78, and a socket is bound as
-above, the process will be
-able to accept connection requests which are addressed to
-128.32.0.4 or 10.0.0.78.
-If a server process wished to only allow hosts on a
-given network connect to it, it would bind
-the address of the host on the appropriate network.
-.PP
-In a similar fashion, a local port may be left unspecified
-(specified as zero), in which case the system will select an
-appropriate port number for it. This shortcut will work
-both in the Internet and NS domains. For example, to
-bind a specific local address to a socket, but to leave the
-local port number unspecified:
-.DS
-hp = gethostbyname(hostname);
-if (hp == NULL) {
- ...
-}
-bcopy(hp->h_addr, (char *) sin.sin_addr, hp->h_length);
-sin.sin_port = htons(0);
-bind(s, (struct sockaddr *) &sin, sizeof (sin));
-.DE
-The system selects the local port number based on two criteria.
-The first is that on 4BSD systems,
-Internet ports below IPPORT_RESERVED (1024) (for the Xerox domain,
-0 through 3000) are reserved
-for privileged users (i.e., the super user);
-Internet ports above IPPORT_USERRESERVED (50000) are reserved
-for non-privileged servers. The second is
-that the port number is not currently bound to some other
-socket. In order to find a free Internet port number in the privileged
-range the \fIrresvport\fP library routine may be used as follows
-to return a stream socket in with a privileged port number:
-.DS
-int lport = IPPORT_RESERVED \- 1;
-int s;
-\&...
-s = rresvport(&lport);
-if (s < 0) {
- if (errno == EAGAIN)
- fprintf(stderr, "socket: all ports in use\en");
- else
- perror("rresvport: socket");
- ...
-}
-.DE
-The restriction on allocating ports was done to allow processes
-executing in a \*(lqsecure\*(rq environment to perform authentication
-based on the originating address and port number. For example,
-the \fIrlogin\fP(1) command allows users to log in across a network
-without being asked for a password, if two conditions hold:
-First, the name of the system the user
-is logging in from is in the file
-\fI/etc/hosts.equiv\fP on the system he is logging
-in to (or the system name and the user name are in
-the user's \fI.rhosts\fP file in the user's home
-directory), and second, that the user's rlogin
-process is coming from a privileged port on the machine from which he is
-logging. The port number and network address of the
-machine from which the user is logging in can be determined either
-by the \fIfrom\fP result of the \fIaccept\fP call, or
-from the \fIgetpeername\fP call.
-.PP
-In certain cases the algorithm used by the system in selecting
-port numbers is unsuitable for an application. This is because
-associations are created in a two step process. For example,
-the Internet file transfer protocol, FTP, specifies that data
-connections must always originate from the same local port. However,
-duplicate associations are avoided by connecting to different foreign
-ports. In this situation the system would disallow binding the
-same local address and port number to a socket if a previous data
-connection's socket still existed. To override the default port
-selection algorithm, an option call must be performed prior
-to address binding:
-.DS
- ...
-int on = 1;
- ...
-setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on));
-bind(s, (struct sockaddr *) &sin, sizeof (sin));
-.DE
-With the above call, local addresses may be bound which
-are already in use. This does not violate the uniqueness
-requirement as the system still checks at connect time to
-be sure any other sockets with the same local address and
-port do not have the same foreign address and port.
-If the association already exists, the error EADDRINUSE is returned.
-A related socket option, SO_REUSEPORT, which allows completely
-duplicate bindings, is described in the IP multicasting section.
-.NH 2
-Socket Options
-.PP
-It is possible to set and get a number of options on sockets
-via the \fIsetsockopt\fP and \fIgetsockopt\fP system calls.
-These options include such things as marking a socket for
-broadcasting, not to route, to linger on close, etc.
-In addition, there are protocol-specific options for IP and TCP,
-as described in
-.IR ip (4),
-.IR tcp (4),
-and in the section on multicasting below.
-.PP
-The general forms of the calls are:
-.DS
-setsockopt(s, level, optname, optval, optlen);
-.DE
-and
-.DS
-getsockopt(s, level, optname, optval, optlen);
-.DE
-.PP
-The parameters to the calls are as follows: \fIs\fP
-is the socket on which the option is to be applied.
-\fILevel\fP specifies the protocol layer on which the
-option is to be applied; in most cases this is
-the ``socket level'', indicated by the symbolic constant
-SOL_SOCKET, defined in \fI<sys/socket.h>.\fP
-The actual option is specified in \fIoptname\fP, and is
-a symbolic constant also defined in \fI<sys/socket.h>\fP.
-\fIOptval\fP and \fIOptlen\fP point to the value of the
-option (in most cases, whether the option is to be turned
-on or off), and the length of the value of the option,
-respectively.
-For \fIgetsockopt\fP, \fIoptlen\fP is
-a value-result parameter, initially set to the size of
-the storage area pointed to by \fIoptval\fP, and modified
-upon return to indicate the actual amount of storage used.
-.PP
-An example should help clarify things. It is sometimes
-useful to determine the type (e.g., stream, datagram, etc.)
-of an existing socket; programs
-under \fIinetd\fP (described below) may need to perform this
-task. This can be accomplished as follows via the
-SO_TYPE socket option and the \fIgetsockopt\fP call:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-
-int type, size;
-
-size = sizeof (int);
-
-if (getsockopt(s, SOL_SOCKET, SO_TYPE, (char *) &type, &size) < 0) {
- ...
-}
-.DE
-After the \fIgetsockopt\fP call, \fItype\fP will be set
-to the value of the socket type, as defined in
-\fI<sys/socket.h>\fP. If, for example, the socket were
-a datagram socket, \fItype\fP would have the value
-corresponding to SOCK_DGRAM.
-.NH 2
-Broadcasting and determining network configuration
-.PP
-By using a datagram socket, it is possible to send broadcast
-packets on many networks supported by the system.
-The network itself must support broadcast; the system
-provides no simulation of broadcast in software.
-Broadcast messages can place a high load on a network since they force
-every host on the network to service them. Consequently,
-the ability to send broadcast packets has been limited
-to sockets which are explicitly marked as allowing broadcasting.
-Broadcast is typically used for one of two reasons:
-it is desired to find a resource on a local network without prior
-knowledge of its address,
-or important functions such as routing require that information
-be sent to all accessible neighbors.
-.PP
-Multicasting is an alternative to broadcasting.
-Setting up IP multicast sockets is described in the next section.
-.PP
-To send a broadcast message, a datagram socket
-should be created:
-.DS
-s = socket(AF_INET, SOCK_DGRAM, 0);
-.DE
-or
-.DS
-s = socket(AF_NS, SOCK_DGRAM, 0);
-.DE
-The socket is marked as allowing broadcasting,
-.DS
-int on = 1;
-
-setsockopt(s, SOL_SOCKET, SO_BROADCAST, &on, sizeof (on));
-.DE
-and at least a port number should be bound to the socket:
-.DS
-sin.sin_family = AF_INET;
-sin.sin_addr.s_addr = htonl(INADDR_ANY);
-sin.sin_port = htons(MYPORT);
-bind(s, (struct sockaddr *) &sin, sizeof (sin));
-.DE
-or, for the NS domain,
-.DS
-sns.sns_family = AF_NS;
-netnum = htonl(net);
-sns.sns_addr.x_net = *(union ns_net *) &netnum; /* insert net number */
-sns.sns_addr.x_port = htons(MYPORT);
-bind(s, (struct sockaddr *) &sns, sizeof (sns));
-.DE
-The destination address of the message to be broadcast
-depends on the network(s) on which the message is to be broadcast.
-The Internet domain supports a shorthand notation for broadcast
-on the local network, the address INADDR_BROADCAST (defined in
-<\fInetinet/in.h\fP>.
-To determine the list of addresses for all reachable neighbors
-requires knowledge of the networks to which the host is connected.
-Since this information should
-be obtained in a host-independent fashion and may be impossible
-to derive, 4.4BSD provides a method of
-retrieving this information from the system data structures.
-The SIOCGIFCONF \fIioctl\fP call returns the interface
-configuration of a host in the form of a
-single \fIifconf\fP structure; this structure contains
-a ``data area'' which is made up of an array of
-of \fIifreq\fP structures, one for each network interface
-to which the host is connected.
-These structures are defined in
-\fI<net/if.h>\fP as follows:
-.DS
-.if t .ta .5i 1.0i 1.5i 3.5i
-.if n .ta .7i 1.4i 2.1i 3.4i
-struct ifconf {
- int ifc_len; /* size of associated buffer */
- union {
- caddr_t ifcu_buf;
- struct ifreq *ifcu_req;
- } ifc_ifcu;
-};
-
-#define ifc_buf ifc_ifcu.ifcu_buf /* buffer address */
-#define ifc_req ifc_ifcu.ifcu_req /* array of structures returned */
-
-#define IFNAMSIZ 16
-
-struct ifreq {
- char ifr_name[IFNAMSIZ]; /* if name, e.g. "en0" */
- union {
- struct sockaddr ifru_addr;
- struct sockaddr ifru_dstaddr;
- struct sockaddr ifru_broadaddr;
- short ifru_flags;
- caddr_t ifru_data;
- } ifr_ifru;
-};
-
-.if t .ta \w' #define'u +\w' ifr_broadaddr'u +\w' ifr_ifru.ifru_broadaddr'u
-#define ifr_addr ifr_ifru.ifru_addr /* address */
-#define ifr_dstaddr ifr_ifru.ifru_dstaddr /* other end of p-to-p link */
-#define ifr_broadaddr ifr_ifru.ifru_broadaddr /* broadcast address */
-#define ifr_flags ifr_ifru.ifru_flags /* flags */
-#define ifr_data ifr_ifru.ifru_data /* for use by interface */
-.DE
-The actual call which obtains the
-interface configuration is
-.DS
-struct ifconf ifc;
-char buf[BUFSIZ];
-
-ifc.ifc_len = sizeof (buf);
-ifc.ifc_buf = buf;
-if (ioctl(s, SIOCGIFCONF, (char *) &ifc) < 0) {
- ...
-}
-.DE
-After this call \fIbuf\fP will contain one \fIifreq\fP structure for
-each network to which the host is connected, and
-\fIifc.ifc_len\fP will have been modified to reflect the number
-of bytes used by the \fIifreq\fP structures.
-.PP
-For each structure
-there exists a set of ``interface flags'' which tell
-whether the network corresponding to that interface is
-up or down, point to point or broadcast, etc. The
-SIOCGIFFLAGS \fIioctl\fP retrieves these
-flags for an interface specified by an \fIifreq\fP
-structure as follows:
-.DS
-struct ifreq *ifr;
-
-ifr = ifc.ifc_req;
-
-for (n = ifc.ifc_len / sizeof (struct ifreq); --n >= 0; ifr++) {
- /*
- * We must be careful that we don't use an interface
- * devoted to an address family other than those intended;
- * if we were interested in NS interfaces, the
- * AF_INET would be AF_NS.
- */
- if (ifr->ifr_addr.sa_family != AF_INET)
- continue;
- if (ioctl(s, SIOCGIFFLAGS, (char *) ifr) < 0) {
- ...
- }
- /*
- * Skip boring cases.
- */
- if ((ifr->ifr_flags & IFF_UP) == 0 ||
- (ifr->ifr_flags & IFF_LOOPBACK) ||
- (ifr->ifr_flags & (IFF_BROADCAST | IFF_POINTTOPOINT)) == 0)
- continue;
-.DE
-.PP
-Once the flags have been obtained, the broadcast address
-must be obtained. In the case of broadcast networks this is
-done via the SIOCGIFBRDADDR \fIioctl\fP, while for point-to-point networks
-the address of the destination host is obtained with SIOCGIFDSTADDR.
-.DS
-struct sockaddr dst;
-
-if (ifr->ifr_flags & IFF_POINTTOPOINT) {
- if (ioctl(s, SIOCGIFDSTADDR, (char *) ifr) < 0) {
- ...
- }
- bcopy((char *) ifr->ifr_dstaddr, (char *) &dst, sizeof (ifr->ifr_dstaddr));
-} else if (ifr->ifr_flags & IFF_BROADCAST) {
- if (ioctl(s, SIOCGIFBRDADDR, (char *) ifr) < 0) {
- ...
- }
- bcopy((char *) ifr->ifr_broadaddr, (char *) &dst, sizeof (ifr->ifr_broadaddr));
-}
-.DE
-.PP
-After the appropriate \fIioctl\fP's have obtained the broadcast
-or destination address (now in \fIdst\fP), the \fIsendto\fP call may be
-used:
-.DS
- sendto(s, buf, buflen, 0, (struct sockaddr *)&dst, sizeof (dst));
-}
-.DE
-In the above loop one \fIsendto\fP occurs for every
-interface to which the host is connected that supports the notion of
-broadcast or point-to-point addressing.
-If a process only wished to send broadcast
-messages on a given network, code similar to that outlined above
-would be used, but the loop would need to find the
-correct destination address.
-.PP
-Received broadcast messages contain the senders address
-and port, as datagram sockets are bound before
-a message is allowed to go out.
-.NH 2
-IP Multicasting
-.PP
-IP multicasting is the transmission of an IP datagram to a "host
-group", a set of zero or more hosts identified by a single IP
-destination address. A multicast datagram is delivered to all
-members of its destination host group with the same "best-efforts"
-reliability as regular unicast IP datagrams, i.e., the datagram is
-not guaranteed to arrive intact at all members of the destination
-group or in the same order relative to other datagrams.
-.PP
-The membership of a host group is dynamic; that is, hosts may join
-and leave groups at any time. There is no restriction on the
-location or number of members in a host group. A host may be a
-member of more than one group at a time. A host need not be a member
-of a group to send datagrams to it.
-.PP
-A host group may be permanent or transient. A permanent group has a
-well-known, administratively assigned IP address. It is the address,
-not the membership of the group, that is permanent; at any time a
-permanent group may have any number of members, even zero. Those IP
-multicast addresses that are not reserved for permanent groups are
-available for dynamic assignment to transient groups which exist only
-as long as they have members.
-.PP
-In general, a host cannot assume that datagrams sent to any host
-group address will reach only the intended hosts, or that datagrams
-received as a member of a transient host group are intended for the
-recipient. Misdelivery must be detected at a level above IP, using
-higher-level identifiers or authentication tokens. Information
-transmitted to a host group address should be encrypted or governed
-by administrative routing controls if the sender is concerned about
-unwanted listeners.
-.PP
-IP multicasting is currently supported only on AF_INET sockets of type
-SOCK_DGRAM and SOCK_RAW, and only on subnetworks for which the interface
-driver has been modified to support multicasting.
-.PP
-The next subsections describe how to send and receive multicast datagrams.
-.NH 3
-Sending IP Multicast Datagrams
-.PP
-To send a multicast datagram, specify an IP multicast address in the range
-224.0.0.0 to 239.255.255.255 as the destination address
-in a
-.IR sendto (2)
-call.
-.PP
-The definitions required for the multicast-related socket options are
-found in \fI<netinet/in.h>\fP.
-All IP addresses are passed in network byte-order.
-.PP
-By default, IP multicast datagrams are sent with a time-to-live (TTL) of 1,
-which prevents them from being forwarded beyond a single subnetwork. A new
-socket option allows the TTL for subsequent multicast datagrams to be set to
-any value from 0 to 255, in order to control the scope of the multicasts:
-.DS
-u_char ttl;
-setsockopt(sock, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof(ttl));
-.DE
-Multicast datagrams with a TTL of 0 will not be transmitted on any subnet,
-but may be delivered locally if the sending host belongs to the destination
-group and if multicast loopback has not been disabled on the sending socket
-(see below). Multicast datagrams with TTL greater than one may be delivered
-to more than one subnet if there are one or more multicast routers attached
-to the first-hop subnet. To provide meaningful scope control, the multicast
-routers support the notion of TTL "thresholds", which prevent datagrams with
-less than a certain TTL from traversing certain subnets. The thresholds
-enforce the following convention:
-.TS
-center;
-l | l
-l | n.
-_
-Scope Initial TTL
-=
-restricted to the same host 0
-restricted to the same subnet 1
-restricted to the same site 32
-restricted to the same region 64
-restricted to the same continent 128
-unrestricted 255
-_
-.TE
-"Sites" and "regions" are not strictly defined, and sites may be further
-subdivided into smaller administrative units, as a local matter.
-.PP
-An application may choose an initial TTL other than the ones listed above.
-For example, an application might perform an "expanding-ring search" for a
-network resource by sending a multicast query, first with a TTL of 0, and
-then with larger and larger TTLs, until a reply is received, perhaps using
-the TTL sequence 0, 1, 2, 4, 8, 16, 32.
-.PP
-The multicast router
-.IR mrouted (8),
-refuses to forward any
-multicast datagram with a destination address between 224.0.0.0 and
-224.0.0.255, inclusive, regardless of its TTL. This range of addresses is
-reserved for the use of routing protocols and other low-level topology
-discovery or maintenance protocols, such as gateway discovery and group
-membership reporting.
-.PP
-The address 224.0.0.0 is
-guaranteed not to be assigned to any group, and 224.0.0.1 is assigned
-to the permanent group of all IP hosts (including gateways). This is
-used to address all multicast hosts on the directly connected
-network. There is no multicast address (or any other IP address) for
-all hosts on the total Internet. The addresses of other well-known,
-permanent groups are published in the "Assigned Numbers" RFC,
-which is available from the InterNIC.
-.PP
-Each multicast transmission is sent from a single network interface, even if
-the host has more than one multicast-capable interface. (If the host is
-also serving as a multicast router,
-a multicast may be \fIforwarded\fP to interfaces
-other than originating interface, provided that the TTL is greater than 1.)
-The default interface to be used for multicasting is the primary network
-interface on the system.
-A socket option
-is available to override the default for subsequent transmissions from a
-given socket:
-.DS
-struct in_addr addr;
-setsockopt(sock, IPPROTO_IP, IP_MULTICAST_IF, &addr, sizeof(addr));
-.DE
-where "addr" is the local IP address of the desired outgoing interface.
-An address of INADDR_ANY may be used to revert to the default interface.
-The local IP address of an interface can be obtained via the SIOCGIFCONF
-ioctl. To determine if an interface supports multicasting, fetch the
-interface flags via the SIOCGIFFLAGS ioctl and see if the IFF_MULTICAST
-flag is set. (Normal applications should not need to use this option; it
-is intended primarily for multicast routers and other system services
-specifically concerned with internet topology.)
-The SIOCGIFCONF and SIOCGIFFLAGS ioctls are described in the previous section.
-.PP
-If a multicast datagram is sent to a group to which the sending host itself
-belongs (on the outgoing interface), a copy of the datagram is, by default,
-looped back by the IP layer for local delivery. Another socket option gives
-the sender explicit control over whether or not subsequent datagrams are
-looped back:
-.DS
-u_char loop;
-setsockopt(sock, IPPROTO_IP, IP_MULTICAST_LOOP, &loop, sizeof(loop));
-.DE
-where \f2loop\f1 is set to 0 to disable loopback,
-and set to 1 to enable loopback.
-This option
-improves performance for applications that may have no more than one
-instance on a single host (such as a router daemon), by eliminating
-the overhead of receiving their own transmissions. It should generally not
-be used by applications for which there may be more than one instance on a
-single host (such as a conferencing program) or for which the sender does
-not belong to the destination group (such as a time querying program).
-.PP
-A multicast datagram sent with an initial TTL greater than 1 may be delivered
-to the sending host on a different interface from that on which it was sent,
-if the host belongs to the destination group on that other interface. The
-loopback control option has no effect on such delivery.
-.NH 3
-Receiving IP Multicast Datagrams
-.PP
-Before a host can receive IP multicast datagrams, it must become a member
-of one or more IP multicast groups. A process can ask the host to join
-a multicast group by using the following socket option:
-.DS
-struct ip_mreq mreq;
-setsockopt(sock, IPPROTO_IP, IP_ADD_MEMBERSHIP, &mreq, sizeof(mreq))
-.DE
-where "mreq" is the following structure:
-.DS
-struct ip_mreq {
- struct in_addr imr_multiaddr; /* \fImulticast group to join\fP */
- struct in_addr imr_interface; /* \fIinterface to join on\fP */
-}
-.DE
-Every membership is associated with a single interface, and it is possible
-to join the same group on more than one interface. "imr_interface" should
-be INADDR_ANY to choose the default multicast interface, or one of the
-host's local addresses to choose a particular (multicast-capable) interface.
-Up to IP_MAX_MEMBERSHIPS (currently 20) memberships may be added on a
-single socket.
-.PP
-To drop a membership, use:
-.DS
-struct ip_mreq mreq;
-setsockopt(sock, IPPROTO_IP, IP_DROP_MEMBERSHIP, &mreq, sizeof(mreq));
-.DE
-where "mreq" contains the same values as used to add the membership. The
-memberships associated with a socket are also dropped when the socket is
-closed or the process holding the socket is killed. However, more than
-one socket may claim a membership in a particular group, and the host
-will remain a member of that group until the last claim is dropped.
-.PP
-The memberships associated with a socket do not necessarily determine which
-datagrams are received on that socket. Incoming multicast packets are
-accepted by the kernel IP layer if any socket has claimed a membership in the
-destination group of the datagram; however, delivery of a multicast datagram
-to a particular socket is based on the destination port (or protocol type, for
-raw sockets), just as with unicast datagrams.
-To receive multicast datagrams
-sent to a particular port, it is necessary to bind to that local port,
-leaving the local address unspecified (i.e., INADDR_ANY).
-To receive multicast datagrams
-sent to a particular group and port, bind to the local port, with
-the local address set to the multicast group address.
-Once bound to a multicast address, the socket cannot be used for sending data.
-.PP
-More than one process may bind to the same SOCK_DGRAM UDP port
-or the same multicast group and port if the
-.I bind
-call is preceded by:
-.DS
-int on = 1;
-setsockopt(sock, SOL_SOCKET, SO_REUSEPORT, &on, sizeof(on));
-.DE
-All processes sharing the port must enable this option.
-Every incoming multicast or broadcast UDP datagram destined to
-the shared port is delivered to all sockets bound to the port.
-For backwards compatibility reasons, this does not apply to incoming
-unicast datagrams. Unicast
-datagrams are never delivered to more than one socket, regardless of
-how many sockets are bound to the datagram's destination port.
-.PP
-A final multicast-related extension is independent of IP: two new ioctls,
-SIOCADDMULTI and SIOCDELMULTI, are available to add or delete link-level
-(e.g., Ethernet) multicast addresses accepted by a particular interface.
-The address to be added or deleted is passed as a sockaddr structure of
-family AF_UNSPEC, within the standard ifreq structure.
-.PP
-These ioctls are
-for the use of protocols other than IP, and require superuser privileges.
-A link-level multicast address added via SIOCADDMULTI is not automatically
-deleted when the socket used to add it goes away; it must be explicitly
-deleted. It is inadvisable to delete a link-level address that may be
-in use by IP.
-.NH 3
-Sample Multicast Program
-.PP
-The following program sends or receives multicast packets.
-If invoked with one argument, it sends a packet containing the current
-time to an arbitrarily-chosen multicast group and UDP port.
-If invoked with no arguments, it receives and prints these packets.
-Start it as a sender on just one host and as a receiver on all the other hosts.
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <arpa/inet.h>
-#include <time.h>
-#include <stdio.h>
-
-#define EXAMPLE_PORT 60123
-#define EXAMPLE_GROUP "224.0.0.250"
-
-main(argc)
- int argc;
-{
- struct sockaddr_in addr;
- int addrlen, fd, cnt;
- struct ip_mreq mreq;
- char message[50];
-
- fd = socket(AF_INET, SOCK_DGRAM, 0);
- if (fd < 0) {
- perror("socket");
- exit(1);
- }
-
- bzero(&addr, sizeof(addr));
- addr.sin_family = AF_INET;
- addr.sin_addr.s_addr = htonl(INADDR_ANY);
- addr.sin_port = htons(EXAMPLE_PORT);
- addrlen = sizeof(addr);
-
- if (argc > 1) { /* Send */
- addr.sin_addr.s_addr = inet_addr(EXAMPLE_GROUP);
- while (1) {
- time_t t = time(0);
- sprintf(message, "time is %-24.24s", ctime(&t));
- cnt = sendto(fd, message, sizeof(message), 0,
- (struct sockaddr *)&addr, addrlen);
- if (cnt < 0) {
- perror("sendto");
- exit(1);
- }
- sleep(5);
- }
- } else { /* Receive */
- if (bind(fd, (struct sockaddr *)&addr, sizeof(addr)) < 0) {
- perror("bind");
- exit(1);
- }
-
- mreq.imr_multiaddr.s_addr = inet_addr(EXAMPLE_GROUP);
- mreq.imr_interface.s_addr = htonl(INADDR_ANY);
- if (setsockopt(fd, IPPROTO_IP, IP_ADD_MEMBERSHIP,
- &mreq, sizeof(mreq)) < 0) {
- perror("setsockopt mreq");
- exit(1);
- }
-
- while (1) {
- cnt = recvfrom(fd, message, sizeof(message), 0,
- (struct sockaddr *)&addr, &addrlen);
- if (cnt <= 0) {
- if (cnt == 0) {
- break;
- }
- perror("recvfrom");
- exit(1);
- }
- printf("%s: message = \e"%s\e"\en",
- inet_ntoa(addr.sin_addr), message);
- }
- }
-}
-.DE
-.\"----------------------------------------------------------------------
-.NH 2
-NS Packet Sequences
-.PP
-The semantics of NS connections demand that
-the user both be able to look inside the network header associated
-with any incoming packet and be able to specify what should go
-in certain fields of an outgoing packet.
-Using different calls to \fIsetsockopt\fP, it is possible
-to indicate whether prototype headers will be associated by
-the user with each outgoing packet (SO_HEADERS_ON_OUTPUT),
-to indicate whether the headers received by the system should be
-delivered to the user (SO_HEADERS_ON_INPUT), or to indicate
-default information that should be associated with all
-outgoing packets on a given socket (SO_DEFAULT_HEADERS).
-.PP
-The contents of a SPP header (minus the IDP header) are:
-.DS
-.if t .ta \w" #define"u +\w" u_short"u +2.0i
-struct sphdr {
- u_char sp_cc; /* connection control */
-#define SP_SP 0x80 /* system packet */
-#define SP_SA 0x40 /* send acknowledgement */
-#define SP_OB 0x20 /* attention (out of band data) */
-#define SP_EM 0x10 /* end of message */
- u_char sp_dt; /* datastream type */
- u_short sp_sid; /* source connection identifier */
- u_short sp_did; /* destination connection identifier */
- u_short sp_seq; /* sequence number */
- u_short sp_ack; /* acknowledge number */
- u_short sp_alo; /* allocation number */
-};
-.DE
-Here, the items of interest are the \fIdatastream type\fP and
-the \fIconnection control\fP fields. The semantics of the
-datastream type are defined by the application(s) in question;
-the value of this field is, by default, zero, but it can be
-used to indicate things such as Xerox's Bulk Data Transfer
-Protocol (in which case it is set to one). The connection control
-field is a mask of the flags defined just below it. The user may
-set or clear the end-of-message bit to indicate
-that a given message is the last of a given substream type,
-or may set/clear the attention bit as an alternate way to
-indicate that a packet should be sent out-of-band.
-As an example, to associate prototype headers with outgoing
-SPP packets, consider:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
-#include <netns/sp.h>
- ...
-struct sockaddr_ns sns, to;
-int s, on = 1;
-struct databuf {
- struct sphdr proto_spp; /* prototype header */
- char buf[534]; /* max. possible data by Xerox std. */
-} buf;
- ...
-s = socket(AF_NS, SOCK_SEQPACKET, 0);
- ...
-bind(s, (struct sockaddr *) &sns, sizeof (sns));
-setsockopt(s, NSPROTO_SPP, SO_HEADERS_ON_OUTPUT, &on, sizeof(on));
- ...
-buf.proto_spp.sp_dt = 1; /* bulk data */
-buf.proto_spp.sp_cc = SP_EM; /* end-of-message */
-strcpy(buf.buf, "hello world\en");
-sendto(s, (char *) &buf, sizeof(struct sphdr) + strlen("hello world\en"),
- (struct sockaddr *) &to, sizeof(to));
- ...
-.DE
-Note that one must be careful when writing headers; if the prototype
-header is not written with the data with which it is to be associated,
-the kernel will treat the first few bytes of the data as the
-header, with unpredictable results.
-To turn off the above association, and to indicate that packet
-headers received by the system should be passed up to the user,
-one might use:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
-#include <netns/sp.h>
- ...
-struct sockaddr sns;
-int s, on = 1, off = 0;
- ...
-s = socket(AF_NS, SOCK_SEQPACKET, 0);
- ...
-bind(s, (struct sockaddr *) &sns, sizeof (sns));
-setsockopt(s, NSPROTO_SPP, SO_HEADERS_ON_OUTPUT, &off, sizeof(off));
-setsockopt(s, NSPROTO_SPP, SO_HEADERS_ON_INPUT, &on, sizeof(on));
- ...
-.DE
-.PP
-Output is handled somewhat differently in the IDP world.
-The header of an IDP-level packet looks like:
-.DS
-.if t .ta \w'struct 'u +\w" struct ns_addr"u +2.0i
-struct idp {
- u_short idp_sum; /* Checksum */
- u_short idp_len; /* Length, in bytes, including header */
- u_char idp_tc; /* Transport Control (i.e., hop count) */
- u_char idp_pt; /* Packet Type (i.e., level 2 protocol) */
- struct ns_addr idp_dna; /* Destination Network Address */
- struct ns_addr idp_sna; /* Source Network Address */
-};
-.DE
-The primary field of interest in an IDP header is the \fIpacket type\fP
-field. The standard values for this field are (as defined
-in <\fInetns/ns.h\fP>):
-.DS
-.if t .ta \w" #define"u +\w" NSPROTO_ERROR"u +1.0i
-#define NSPROTO_RI 1 /* Routing Information */
-#define NSPROTO_ECHO 2 /* Echo Protocol */
-#define NSPROTO_ERROR 3 /* Error Protocol */
-#define NSPROTO_PE 4 /* Packet Exchange */
-#define NSPROTO_SPP 5 /* Sequenced Packet */
-.DE
-For SPP connections, the contents of this field are
-automatically set to NSPROTO_SPP; for IDP packets,
-this value defaults to zero, which means ``unknown''.
-.PP
-Setting the value of that field with SO_DEFAULT_HEADERS is
-easy:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
-#include <netns/idp.h>
- ...
-struct sockaddr sns;
-struct idp proto_idp; /* prototype header */
-int s, on = 1;
- ...
-s = socket(AF_NS, SOCK_DGRAM, 0);
- ...
-bind(s, (struct sockaddr *) &sns, sizeof (sns));
-proto_idp.idp_pt = NSPROTO_PE; /* packet exchange */
-setsockopt(s, NSPROTO_IDP, SO_DEFAULT_HEADERS, (char *) &proto_idp,
- sizeof(proto_idp));
- ...
-.DE
-.PP
-Using SO_HEADERS_ON_OUTPUT is somewhat more difficult. When
-SO_HEADERS_ON_OUTPUT is turned on for an IDP socket, the socket
-becomes (for all intents and purposes) a raw socket. In this
-case, all the fields of the prototype header (except the
-length and checksum fields, which are computed by the kernel)
-must be filled in correctly in order for the socket to send and
-receive data in a sensible manner. To be more specific, the
-source address must be set to that of the host sending the
-data; the destination address must be set to that of the
-host for whom the data is intended; the packet type must be
-set to whatever value is desired; and the hopcount must be
-set to some reasonable value (almost always zero). It should
-also be noted that simply sending data using \fIwrite\fP
-will not work unless a \fIconnect\fP or \fIsendto\fP call
-is used, in spite of the fact that it is the destination
-address in the prototype header that is used, not the one
-given in either of those calls. For almost
-all IDP applications , using SO_DEFAULT_HEADERS is easier and
-more desirable than writing headers.
-.NH 2
-Three-way Handshake
-.PP
-The semantics of SPP connections indicates that a three-way
-handshake, involving changes in the datastream type, should \(em
-but is not absolutely required to \(em take place before a SPP
-connection is closed. Almost all SPP connections are
-``well-behaved'' in this manner; when communicating with
-any process, it is best to assume that the three-way handshake
-is required unless it is known for certain that it is not
-required. In a three-way close, the closing process
-indicates that it wishes to close the connection by sending
-a zero-length packet with end-of-message set and with
-datastream type 254. The other side of the connection
-indicates that it is OK to close by sending a zero-length
-packet with end-of-message set and datastream type 255. Finally,
-the closing process replies with a zero-length packet with
-substream type 255; at this point, the connection is considered
-closed. The following code fragments are simplified examples
-of how one might handle this three-way handshake at the user
-level; in the future, support for this type of close will
-probably be provided as part of the C library or as part of
-the kernel. The first code fragment below illustrates how a process
-might handle three-way handshake if it sees that the process it
-is communicating with wants to close the connection:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
-#include <netns/sp.h>
- ...
-#ifndef SPPSST_END
-#define SPPSST_END 254
-#define SPPSST_ENDREPLY 255
-#endif
-struct sphdr proto_sp;
-int s;
- ...
-read(s, buf, BUFSIZE);
-if (((struct sphdr *)buf)->sp_dt == SPPSST_END) {
- /*
- * SPPSST_END indicates that the other side wants to
- * close.
- */
- proto_sp.sp_dt = SPPSST_ENDREPLY;
- proto_sp.sp_cc = SP_EM;
- setsockopt(s, NSPROTO_SPP, SO_DEFAULT_HEADERS, (char *)&proto_sp,
- sizeof(proto_sp));
- write(s, buf, 0);
- /*
- * Write a zero-length packet with datastream type = SPPSST_ENDREPLY
- * to indicate that the close is OK with us. The packet that we
- * don't see (because we don't look for it) is another packet
- * from the other side of the connection, with SPPSST_ENDREPLY
- * on it it, too. Once that packet is sent, the connection is
- * considered closed; note that we really ought to retransmit
- * the close for some time if we do not get a reply.
- */
- close(s);
-}
- ...
-.DE
-To indicate to another process that we would like to close the
-connection, the following code would suffice:
-.DS
-#include <sys/types.h>
-#include <sys/socket.h>
-#include <netns/ns.h>
-#include <netns/sp.h>
- ...
-#ifndef SPPSST_END
-#define SPPSST_END 254
-#define SPPSST_ENDREPLY 255
-#endif
-struct sphdr proto_sp;
-int s;
- ...
-proto_sp.sp_dt = SPPSST_END;
-proto_sp.sp_cc = SP_EM;
-setsockopt(s, NSPROTO_SPP, SO_DEFAULT_HEADERS, (char *)&proto_sp,
- sizeof(proto_sp));
-write(s, buf, 0); /* send the end request */
-proto_sp.sp_dt = SPPSST_ENDREPLY;
-setsockopt(s, NSPROTO_SPP, SO_DEFAULT_HEADERS, (char *)&proto_sp,
- sizeof(proto_sp));
-/*
- * We assume (perhaps unwisely)
- * that the other side will send the
- * ENDREPLY, so we'll just send our final ENDREPLY
- * as if we'd seen theirs already.
- */
-write(s, buf, 0);
-close(s);
- ...
-.DE
-.NH 2
-Packet Exchange
-.PP
-The Xerox standard protocols include a protocol that is both
-reliable and datagram-oriented. This protocol is known as
-Packet Exchange (PEX or PE) and, like SPP, is layered on top
-of IDP. PEX is important for a number of things: Courier
-remote procedure calls may be expedited through the use
-of PEX, and many Xerox servers are located by doing a PEX
-``BroadcastForServers'' operation. Although there is no
-implementation of PEX in the kernel,
-it may be simulated at the user level with some clever coding
-and the use of one peculiar \fIgetsockopt\fP. A PEX packet
-looks like:
-.DS
-.if t .ta \w'struct 'u +\w" struct idp"u +2.0i
-/*
- * The packet-exchange header shown here is not defined
- * as part of any of the system include files.
- */
-struct pex {
- struct idp p_idp; /* idp header */
- u_short ph_id[2]; /* unique transaction ID for pex */
- u_short ph_client; /* client type field for pex */
-};
-.DE
-The \fIph_id\fP field is used to hold a ``unique id'' that
-is used in duplicate suppression; the \fIph_client\fP
-field indicates the PEX client type (similar to the packet
-type field in the IDP header). PEX reliability stems from the
-fact that it is an idempotent (``I send a packet to you, you
-send a packet to me'') protocol. Processes on each side of
-the connection may use the unique id to determine if they have
-seen a given packet before (the unique id field differs on each
-packet sent) so that duplicates may be detected, and to indicate
-which message a given packet is in response to. If a packet with
-a given unique id is sent and no response is received in a given
-amount of time, the packet is retransmitted until it is decided
-that no response will ever be received. To simulate PEX, one
-must be able to generate unique ids -- something that is hard to
-do at the user level with any real guarantee that the id is really
-unique. Therefore, a means (via \fIgetsockopt\fP) has been provided
-for getting unique ids from the kernel. The following code fragment
-indicates how to get a unique id:
-.DS
-long uniqueid;
-int s, idsize = sizeof(uniqueid);
- ...
-s = socket(AF_NS, SOCK_DGRAM, 0);
- ...
-/* get id from the kernel -- only on IDP sockets */
-getsockopt(s, NSPROTO_PE, SO_SEQNO, (char *)&uniqueid, &idsize);
- ...
-.DE
-The retransmission and duplicate suppression code required to
-simulate PEX fully is left as an exercise for the reader.
-.NH 2
-Inetd
-.PP
-One of the daemons provided with 4.4BSD is \fIinetd\fP, the
-so called ``internet super-server.''
-Having one daemon listen for requests for many daemons
-instead of having each daemon listen for its own requests
-reduces the number of idle daemons and simplies their implementation.
-.I Inetd
-handles
-two types of services: standard and TCPMUX.
-A standard service has a well-known port assigned to it and
-is listed in
-.I /etc/services
-(see \f2services\f1(5));
-it may be a service that implements an official Internet standard or is a
-BSD-specific service.
-TCPMUX services are nonstandard and do not have a
-well-known port assigned to them.
-They are invoked from
-.I inetd
-when a program connects to the "tcpmux" well-known port and specifies
-the service name.
-This is useful for adding locally-developed servers.
-.PP
-\fIInetd\fP is invoked at boot
-time, and determines from the file \fI/etc/inetd.conf\fP the
-servers for which it is to listen. Once this information has been
-read and a pristine environment created, \fIinetd\fP proceeds
-to create one socket for each service it is to listen for,
-binding the appropriate port number to each socket.
-.PP
-\fIInetd\fP then performs a \fIselect\fP on all these
-sockets for read availability, waiting for somebody wishing
-a connection to the service corresponding to
-that socket. \fIInetd\fP then performs an \fIaccept\fP on
-the socket in question, \fIfork\fPs, \fIdup\fPs the new
-socket to file descriptors 0 and 1 (stdin and
-stdout), closes other open file
-descriptors, and \fIexec\fPs the appropriate server.
-.PP
-Servers making use of \fIinetd\fP are considerably simplified,
-as \fIinetd\fP takes care of the majority of the IPC work
-required in establishing a connection. The server invoked
-by \fIinetd\fP expects the socket connected to its client
-on file descriptors 0 and 1, and may immediately perform
-any operations such as \fIread\fP, \fIwrite\fP, \fIsend\fP,
-or \fIrecv\fP. Indeed, servers may use
-buffered I/O as provided by the ``stdio'' conventions, as
-long as as they remember to use \fIfflush\fP when appropriate.
-.PP
-One call which may be of interest to individuals writing
-servers under \fIinetd\fP is the \fIgetpeername\fP call,
-which returns the address of the peer (process) connected
-on the other end of the socket. For example, to log the
-Internet address in ``dot notation'' (e.g., ``128.32.0.4'')
-of a client connected to a server under
-\fIinetd\fP, the following code might be used:
-.DS
-struct sockaddr_in name;
-int namelen = sizeof (name);
- ...
-if (getpeername(0, (struct sockaddr *)&name, &namelen) < 0) {
- syslog(LOG_ERR, "getpeername: %m");
- exit(1);
-} else
- syslog(LOG_INFO, "Connection from %s", inet_ntoa(name.sin_addr));
- ...
-.DE
-While the \fIgetpeername\fP call is especially useful when
-writing programs to run with \fIinetd\fP, it can be used
-under other circumstances. Be warned, however, that \fIgetpeername\fP will
-fail on UNIX domain sockets.
-.PP
-Standard TCP
-services are assigned unique well-known port numbers in the range of
-0 to 1023 by the
-Internet Assigned Numbers Authority (IANA@ISI.EDU).
-The limited number of ports in this range are
-assigned to official Internet protocols.
-The TCPMUX service allows you to add
-locally-developed protocols without needing an official TCP port assignment.
-The TCPMUX protocol described in RFC-1078 is simple:
-.QP
-``A TCP client connects to a foreign host on TCP port 1. It sends the
-service name followed by a carriage-return line-feed <CRLF>.
-The service name is never case sensitive.
-The server replies with a
-single character indicating positive ("+") or negative ("\-")
-acknowledgment, immediately followed by an optional message of
-explanation, terminated with a <CRLF>. If the reply was positive,
-the selected protocol begins; otherwise the connection is closed.''
-.LP
-In 4.4BSD, the TCPMUX service is built into
-.IR inetd ,
-that is,
-.IR inetd
-listens on TCP port 1 for requests for TCPMUX services listed
-in \f2inetd.conf\f1.
-.IR inetd (8)
-describes the format of TCPMUX entries for \f2inetd.conf\f1.
-.PP
-The following is an example TCPMUX server and its \f2inetd.conf\f1 entry.
-More sophisticated servers may want to do additional processing
-before returning the positive or negative acknowledgement.
-.DS
-#include <sys/types.h>
-#include <stdio.h>
-
-main()
-{
- time_t t;
-
- printf("+Go\er\en");
- fflush(stdout);
- time(&t);
- printf("%d = %s", t, ctime(&t));
- fflush(stdout);
-}
-.DE
-The \f2inetd.conf\f1 entry is:
-.DS
-tcpmux/current_time stream tcp nowait nobody /d/curtime curtime
-.DE
-Here's the portion of the client code that handles the TCPMUX handshake:
-.DS
-char line[BUFSIZ];
-FILE *fp;
- ...
-
-/* Use stdio for reading data from the server */
-fp = fdopen(sock, "r");
-if (fp == NULL) {
- fprintf(stderr, "Can't create file pointer\en");
- exit(1);
-}
-
-/* Send service request */
-sprintf(line, "%s\er\en", "current_time");
-if (write(sock, line, strlen(line)) < 0) {
- perror("write");
- exit(1);
-}
-
-/* Get ACK/NAK response from the server */
-if (fgets(line, sizeof(line), fp) == NULL) {
- if (feof(fp)) {
- die();
- } else {
- fprintf(stderr, "Error reading response\en");
- exit(1);
- }
-}
-
-/* Delete <CR> */
-if ((lp = index(line, '\r')) != NULL) {
- *lp = '\0';
-}
-
-switch (line[0]) {
- case '+':
- printf("Got ACK: %s\en", &line[1]);
- break;
- case '-':
- printf("Got NAK: %s\en", &line[1]);
- exit(0);
- default:
- printf("Got unknown response: %s\en", line);
- exit(1);
-}
-
-/* Get rest of data from the server */
-while ((fgets(line, sizeof(line), fp)) != NULL) {
- fputs(line, stdout);
-}
-.DE
diff --git a/share/doc/psd/21.ipc/Makefile b/share/doc/psd/21.ipc/Makefile
deleted file mode 100644
index 3e32259391a..00000000000
--- a/share/doc/psd/21.ipc/Makefile
+++ /dev/null
@@ -1,14 +0,0 @@
-# $OpenBSD: Makefile,v 1.3 2004/02/01 14:22:45 jmc Exp $
-
-
-DIR= psd/21.ipc
-SRCS= 0.t 1.t 2.t 3.t 4.t 5.t
-MACROS= -ms
-
-paper.ps: ${SRCS}
- ${TBL} ${SRCS} | ${ROFF} > ${.TARGET}
-
-paper.txt: ${SRCS}
- ${TBL} ${SRCS} | ${ROFF} -Tascii > ${.TARGET}
-
-.include <bsd.doc.mk>
diff --git a/share/doc/psd/21.ipc/spell.ok b/share/doc/psd/21.ipc/spell.ok
deleted file mode 100644
index 02b45d4d26d..00000000000
--- a/share/doc/psd/21.ipc/spell.ok
+++ /dev/null
@@ -1,347 +0,0 @@
-4.2bsd
-AF
-ANYP
-BUFSIZ
-BUFSIZE
-BroadcastForServers
-CF
-CLR
-CRMOD
-Clearinghouse
-DARPA
-DESTPORT
-DGRAM
-DONTROUTE
-Datagram
-EADDRINUSE
-EADDRNOTAVAIL
-EAGAIN
-ECONNREFUSED
-EHOSTDOWN
-EHOSTUNREACH
-EINTR
-ENDREPLY
-ENETDOWN
-ENETUNREACH
-ENOBUFS
-EPROTONOSUPPORT
-EPROTOTYPE
-ETIMEDOUT
-EWOULDBLOCK
-Ethernet
-FASYNC
-FCREATE
-FD
-FNDELAY
-FTP
-FTRUNCATE
-FWRITE
-FWRONLY
-Fabry
-GETOWN
-Gethostybyname
-IDP
-IFF
-IFNAMSIZ
-INADDR
-INET
-INFO
-IP
-IPC
-IPPORT
-ISSET
-Inetd
-LF
-LH
-LOOPBACK
-Lapsley
-Leffler
-MSG
-MYADDRESS
-MYPORT
-NS
-NSPROTO
-OB
-OOB
-OOBINLINE
-Optlen
-Optval
-PE
-PEX
-POINTTOPOINT
-PS1:8
-RDONLY
-RDWR
-REUSEADDR
-RF
-RH
-RWHODIR
-SEQNO
-SEQPACKET
-SETFL
-SETOWN
-SETSIZE
-SIGALRM
-SIGCHLD
-SIGIO
-SIGURG
-SIOCATMARK
-SIOCGIFBRDADDR
-SIOCGIFCONF
-SIOCGIFDSTADDR
-SIOCGIFFLAGS
-SIOCGPGRP
-SIOCSPGRP
-SOF
-SP
-SPP
-SPPSST
-Science:UofMaryland
-TCP
-TELNET
-TIOCFLUSH
-TIOCGETP
-TIOCNOTTY
-TIOCSETP
-TRUNC
-Torek
-Tutorial''PS1:8
-USERRESERVED
-VAX
-WNOHANG
-WRONLY
-XSIS
-XTABS
-ack
-addr
-addr.s
-addr.sa
-addr.sun
-addr.x
-addrtype
-alo
-argc
-argv
-arpa
-b.sg
-bcmp
-bcopy
-broadaddr
-buf
-buf.buf
-buf.proto
-buflen
-bzero
-c.f
-cad
-caddr
-calder
-daemons
-dali
-databuf
-datagram
-datastream
-dev
-dna
-doit
-dst
-dst.sin
-dst.sns
-dstaddr
-dt
-dup2
-en0
-endhostent
-endif
-ernie
-errno
-es
-esvax
-exceptmask
-execptfds
-fcntl
-fcntl.h
-fd
-fflush
-file.h
-foo
-fprintf
-from.sin
-fromlen
-gethostbyaddr
-gethostbyname
-gethostbynameandnet
-gethostent
-gethostname
-getnetbyname
-getnetbynumber
-getnetent
-getpeername
-getprotobyname
-getprotobynumber
-getprotoent
-getservbyname
-getservbyport
-getservent
-getsockopt
-goto
-gotpty
-gyre
-gyre:Computer
-hardcoding
-hopcount
-host.c
-hostent
-hostname
-hostnames
-hosts.equiv
-htonl
-htons
-idp
-idp.h
-idp.idp
-idsize
-if.h
-ifc
-ifc.ifc
-ifconf
-ifcu
-ifcu.ifcu
-ifndef
-ifr
-ifreq
-ifru
-ifru.ifru
-in.h
-inet
-inetd
-inetd.conf
-ing
-ingres
-io
-ioctl.h
-ipc
-kim
-len
-localnet
-lport
-lq
-makeaddr
-matisse
-medea
-miro
-monet
-name.sin
-namelen
-nameserver
-nb
-netdb.h
-netent
-netinet
-netns
-netnum
-netof
-newsock
-newtcp
-nfds
-ns
-ns.h
-ntoa
-ntohl
-ntohs
-onalrm
-oob
-optlen
-optname
-optval
-oz
-pathname
-pathnames
-pex
-pgrp
-ph
-pp
-proto
-protoent
-pt
-pty
-ptyXX
-ptyp
-ptyxy
-queueing
-readfds
-readmask
-recv
-recvfrom
-recvtime
-rem
-req
-rhosts
-rlogin
-rlogind
-rq
-rresvport
-ruptime
-rwho
-rwhod
-sendto
-servent
-server.sin
-server.sun
-sethostent
-setsockopt
-sid
-sigvec
-sin.sin
-sizeof
-sna
-snew
-sns
-sns.sns
-sockaddr
-socket.h
-sp
-sp.h
-sp.sp
-sphdr
-spp
-spp.sp
-sprintf
-statbuf
-statvax
-std
-stderr
-stdin
-stdio.h
-stdout
-strcmp
-strcpy
-strlen
-syslog
-ta
-tcp
-telnet
-time.h
-timeval
-tmp
-tolen
-ttyxy
-tuples
-types.h
-ucbvax
-udp
-un
-un.h
-uniqueid
-useable
-usec
-val
-wait.h
-wait.tv
-wd
-wd.wd
-whod
-wildcard
-wildcarded
-writefds
-writemask
diff --git a/share/doc/psd/Makefile b/share/doc/psd/Makefile
index 767d13bdd58..33643dd0b4d 100644
--- a/share/doc/psd/Makefile
+++ b/share/doc/psd/Makefile
@@ -1,8 +1,8 @@
-# $OpenBSD: Makefile,v 1.7 2010/01/04 17:50:39 deraadt Exp $
+# $OpenBSD: Makefile,v 1.8 2010/07/01 20:04:10 tedu Exp $
DOCDIR= /usr/share/doc/psd
-FILES= 00.contents Makefile Title
-SUBDIR= 05.sysman 20.ipctut 21.ipc
+FILES= Makefile
+SUBDIR=
.if exists(12.make)
SUBDIR+= 12.make
.endif
@@ -13,16 +13,6 @@ SUBDIR+= 18.gprof
SUBDIR+= 19.curses
.endif
-Title.ps: ${FILES}
- groff Title > ${.TARGET}
-Title.txt: ${FILES}
- groff -Tascii Title > ${.TARGET}
-
-contents.ps: ${FILES}
- groff -ms 00.contents > ${.TARGET}
-contents.txt: ${FILES}
- groff -Tascii -ms 00.contents > ${.TARGET}
-
beforeinstall:
install -c -o ${DOCOWN} -g ${DOCGRP} -m ${DOCMODE} ${FILES} \
${DESTDIR}${DOCDIR}