








               BBuuiillddiinngg NNeettBBSSDD KKeerrnneellss wwiitthh CCoonnffiigg


             _S_a_m_u_e_l _J_. _L_e_f_f_l_e_r _a_n_d _M_i_c_h_a_e_l _J_. _K_a_r_e_l_s


                            _A_B_S_T_R_A_C_T

          This  document  describes  the use of _c_o_n_f_i_g(1) to
     configure and create bootable NetBSD system images.  It
     discusses  the  structure of system configuration files
     and how to configure systems with non-standard hardware
     configurations.   Sections describing the preferred way
     to add new code to the  system  and  how  the  system's
     autoconfiguration  process  operates  are included.  An
     appendix contains a summary of the rules  used  by  the
     system  in  calculating  the size of system data struc-
     tures, and also indicates some of the  standard  system
     size limitations and how to change them.  Other config-
     uration options are also listed.


     Revised July 5, 1993

     Revised for NetBSD beginning July 5, 2014






11..  IINNTTRROODDUUCCTTIIOONN

     _C_o_n_f_i_g is a tool used in building  BSD  kernel  images.   It
takes a file describing the tunable parameter settings, features,
and drivers to include, and generates a collection of files which
are  then  used to build a copy of the kernel appropriate to that
configuration.  _C_o_n_f_i_g simplifies system maintenance by isolating
system dependencies in a single, easy to understand, file.

     This  document  describes  the  content and format of system
configuration files and the rules which  must  be  followed  when
creating  these  files.   Example  configuration  files  are con-
structed and discussed.

     Later sections suggest guidelines to be  used  in  modifying
system source and explain some of the inner workings of the auto-
configuration process.  Appendix D summarizes the rules  used  in
calculating  the  most important system data structures and indi-
cates some inherent system data structure size  limitations  (and










Command Reference Documents   Building NetBSD Kernels with Config


how to go about modifying them).

22..  CCOONNFFIIGGUURRAATTIIOONN FFIILLEE CCOONNTTEENNTTSS

     A  system  configuration must include at least the following
pieces of information:

+o  machine type

+o  cpu type

+o  system identification

+o  timezone

+o  maximum number of users

+o  location of the root file system

+o  available hardware

     _C_o_n_f_i_g allows multiple system images to be generated from  a
single  configuration  description.  Each system image is config-
ured for identical hardware, but may have different locations for
the root file system and, possibly, other system devices.

22..11..  MMaacchhiinnee ttyyppee

     The _m_a_c_h_i_n_e _t_y_p_e indicates if the system is going to operate
on  a  DEC  VAX-11[+]  computer,  or  some other machine on which
NetBSD operates.  The machine type is used to locate certain data
files  which  are machine specific, and also to select rules used
in constructing the resultant configuration files.

22..22..  CCppuu ttyyppee

     The _c_p_u _t_y_p_e indicates which, of possibly  many,  cpu's  the
system  is  to  operate  on.  For example, if the system is being
configured for a VAX-11, it could  be  running  on  a  VAX  8600,
VAX-11/780,  VAX-11/750,  VAX-11/730  or MicroVAX II.  (Other VAX
cpu types, including the 8650, 785 and 725, are configured  using
the  cpu designation for compatible machines introduced earlier.)
Specifying more than one cpu type implies that the system  should
be  configured  to  run  on any of the cpu's specified.  For some
types of machines this is not possible and _c_o_n_f_i_g  will  print  a
diagnostic indicating such.

22..33..  SSyysstteemm iiddeennttiiffiiccaattiioonn

     The  _s_y_s_t_e_m _i_d_e_n_t_i_f_i_c_a_t_i_o_n is a moniker attached to the sys-
tem, and often the machine on which the system is  to  run.   For
-----------
[+] DEC, VAX, UNIBUS, MASSBUS and MicroVAX are  trade-
marks of Digital Equipment Corporation.









Building NetBSD Kernels with Config   Command Reference Documents


example,  at  Berkeley we have machines named Ernie (Co-VAX), Kim
(No-VAX), and so on.  The system identifier selected is  used  to
create a global C ``#define'' which may be used to isolate system
dependent pieces of code in the  kernel.   For  example,  Ernie's
Varian driver used to be special cased because its interrupt vec-
tors were wired together.  The code in the  driver  which  under-
stood  how to handle this non-standard hardware configuration was
conditionally compiled in only if the system was for Ernie.

     The system identifier ``GENERIC'' is given to a system which
will  run  on any cpu of a particular machine type; it should not
otherwise be used for a system identifier.

22..44..  TTiimmeezzoonnee

     The timezone in which the system is to run is used to define
the  information  returned  by  the  _g_e_t_t_i_m_e_o_f_d_a_y(2) system call.
This value is specified as the number of hours east  or  west  of
GMT.   Negative  numbers indicate a value east of GMT.  The time-
zone specification may also indicate the type of daylight savings
time rules to be applied.

22..55..  MMaaxxiimmuumm nnuummbbeerr ooff uusseerrss

     The  system  allocates  many  system data structures at boot
time based on the maximum number of users the  system  will  sup-
port.  This number is normally between 8 and 40, depending on the
hardware and expected job mix.  The rules used to calculate  sys-
tem data structures are discussed in Appendix D.

22..66..  RRoooott ffiillee ssyysstteemm llooccaattiioonn

     When  the system boots it must know the location of the root
of the file system tree.  This location and the  part(s)  of  the
disk(s)  to  be used for paging and swapping must be specified in
order to create a  complete  configuration  description.   _C_o_n_f_i_g
uses  many  rules to calculate default locations for these items;
these are described in Appendix B.

     When a generic system is configured, the root file system is
left  undefined  until  the  system is booted.  In this case, the
root file system need not be specified, only that the system is a
generic system.

22..77..  HHaarrddwwaarree ddeevviicceess

     When  the  system boots it goes through an _a_u_t_o_c_o_n_f_i_g_u_r_a_t_i_o_n
phase.  During this period, the system  searches  for  all  those
hardware  devices which the system builder has indicated might be
present.  This probing sequence requires certain pieces of infor-
mation  such  as  register  addresses, bus interconnects, etc.  A
system's hardware may be configured in a very flexible manner  or
be  specified without any flexibility whatsoever.  Most people do
not configure hardware devices into the system  unless  they  are









Command Reference Documents   Building NetBSD Kernels with Config


currently  present  on  the machine, expect them to be present in
the near future, or are simply guarding against a hardware  fail-
ure  somewhere else at the site (it is often wise to configure in
extra disks in case  an  emergency  requires  moving  one  off  a
machine which has hardware problems).

     The  specification  of hardware devices usually occupies the
majority of the configuration file.  As such, a large portion  of
this  document  will be spent understanding it.  Section 6.3 con-
tains a description  of  the  autoconfiguration  process,  as  it
applies  to  those  planning to write, or modify existing, device
drivers.

22..88..  PPsseeuuddoo ddeevviicceess

     Several system facilities are configured in  a  manner  like
that  used  for hardware devices although they are not associated
with specific hardware.  These system options are  configured  as
_p_s_e_u_d_o_-_d_e_v_i_c_e_s.   Some pseudo devices allow an optional parameter
that sets the limit on the number of instances of the device that
are active simultaneously.

22..99..  SSyysstteemm ooppttiioonnss

     Other  than  the  mandatory  pieces of information described
above, it is also possible to  include  various  optional  system
facilities or to modify system behavior and/or limits.  For exam-
ple, NetBSD can be configured to support binary compatibility for
programs  built  under Linux and FreeBSD.  Also, optional support
is provided for disk quotas and tracing the  performance  of  the
virtual  memory subsystem.  Any optional facilities to be config-
ured into the system are specified  in  the  configuration  file.
The  resultant  files  generated  by  _c_o_n_f_i_g  will  automatically
include the necessary pieces of the system.

33..  SSYYSSTTEEMM BBUUIILLDDIINNGG PPRROOCCEESSSS

     In this section we consider the steps necessary to  build  a
bootable system image.  We assume the system source is located in
the ``/usr/src'' directory and that,  initially,  the  system  is
being configured from source code.

     Under  normal  circumstances there are 5 steps in building a
system.

1) Create a configuration file for the system.

2) Make a directory for the system to be constructed in.

3) Run _c_o_n_f_i_g on the configuration file  to  generate  the  files
   required to compile and load the system image.

4) Construct  the  source code interdependency rules for the con-
   figured system with _m_a_k_e _d_e_p_e_n_d using _m_a_k_e(1).









Building NetBSD Kernels with Config   Command Reference Documents


5) Compile and link the system with _m_a_k_e.

     Steps 1 and 2 are usually done only  once.   When  a  system
configuration  changes  it usually suffices to just run _c_o_n_f_i_g on
the modified configuration file, rebuild the source  code  depen-
dencies,  and  remake the system.  Sometimes, however, configura-
tion dependencies may not be noticed in which case it  is  neces-
sary  to  clean out the object files saved in the system's direc-
tory; this will be discussed later.

33..11..  CCrreeaattiinngg aa ccoonnffiigguurraattiioonn ffiillee

     Configuration  files  normally  reside  in   the   directory
``conf''  in  the architecture-specific subtree of the kernel for
the machine type in use.  (For example, configuration  files  for
64-bit x86 machines live in ``/usr/src/sys/arch/amd64/conf''.)  A
configuration file is  most  easily  constructed  by  copying  an
existing configuration file and modifying it.  The NetBSD distri-
bution contains assorted standard configuration files for differ-
ent  machine  types  and varieties.  Start with ``GENERIC'' if no
other is more appropriate.

     The configuration file must have the same name as the direc-
tory  in  which  the  configured system is to be built.  Further,
_c_o_n_f_i_g assumes this directory is located  under  the  ``compile''
directory  at  the  same level as the ``conf'' directory in which
it is run.  For example, the generic 64-bit x86 system has a con-
figuration  file  ``/usr/src/sys/arch/amd64/conf/GENERIC'' and an
accompanying   directory   named   ``/usr/src/sys/arch/amd64/com-
pile/GENERIC''.   Although  it  is  not  required that the system
sources and configuration files reside in ``/usr/src,'' the  con-
figuration  and  compilation  procedure  depends  on the relative
locations of directories within that hierarchy, as  most  of  the
system  code and the files created by _c_o_n_f_i_g use pathnames of the
form ``../''.

     When building the configuration file, be sure to include the
items  described  in section 2.  In particular, the machine type,
cpu type, timezone, system identifier, maximum  users,  and  root
device  must  be  specified.   The  specification of the hardware
present may take a bit of work; particularly if your hardware  is
configured  at non-standard places (e.g. device registers located
at funny places or devices not supported by the system).  Section
4 of this document gives a detailed description of the configura-
tion file syntax, section 5 explains  some  sample  configuration
files, and section 6 discusses how to add new devices to the sys-
tem.  If the devices to be configured are not  already  described
in  one  of the existing configuration files you should check the
section 4 manual pages.  For each supported  device,  the  manual
page synopsis entry gives a sample configuration line.

     Once the configuration file is complete, run it through _c_o_n_-
_f_i_g and look for any errors.  Never try and use  a  system  which
_c_o_n_f_i_g  has complained about; the results are unpredictable.  For









Command Reference Documents   Building NetBSD Kernels with Config


the most part, _c_o_n_f_i_g's error diagnostics are  self  explanatory.
It  may  be  the  case that the line numbers given with the error
messages are off by one.

     A successful run of _c_o_n_f_i_g on your configuration  file  will
generate a number of files in the configuration directory.  These
files are:

+o  A file to be used by _m_a_k_e(1) in compiling and loading the sys-
   tem, _M_a_k_e_f_i_l_e.

+o  One  file  for  each  possible  system image for this machine,
   _s_w_a_p_x_x_x_._c, where _x_x_x is the name of the  system  image,  which
   describes where swapping, the root file system, and other mis-
   cellaneous system devices are located.

+o  A collection of header files, one per possible device the sys-
   tem supports, which define the hardware configured.

+o  A  file  containing  the  I/O configuration tables used by the
   system during its _a_u_t_o_c_o_n_f_i_g_u_r_a_t_i_o_n phase, _i_o_c_o_n_f_._c.

+o  An assembly language file of interrupt vectors  which  connect
   interrupts  from the machine's external buses to the main sys-
   tem path for handling interrupts, and  a  file  that  contains
   counters and names for the interrupt vectors.

     Unless  you  have reason to doubt _c_o_n_f_i_g, or are curious how
the system's autoconfiguration scheme  works,  you  should  never
have to look at any of these files.

33..22..  CCoonnssttrruuccttiinngg ssoouurrccee ccooddee ddeeppeennddeenncciieess

     When  _c_o_n_f_i_g  is done generating the files needed to compile
and link your system it will terminate with a message of the form
``Don't forget to run make depend''.  This is a reminder that you
should change over to the configuration directory for the  system
just  configured and type ``make depend'' to build the rules used
by _m_a_k_e to recognize interdependencies in the system source code.
This will insure that any changes to a piece of the system source
code will result in the proper modules being recompiled the  next
time _m_a_k_e is run.

     This  step  is  particularly  important  if  your site makes
changes to the system include files.  The rules generated specify
which  source  code  files  are dependent on which include files.
Without these rules, _m_a_k_e will not recognize when it must rebuild
modules  due  to  the  modification of a system header file.  The
dependency rules are generated by a pass of  the  C  preprocessor
and  reflect  the  global  system  options.   This  step  must be
repeated when the configuration file is  changed  and  _c_o_n_f_i_g  is
used to regenerate the system makefile.











Building NetBSD Kernels with Config   Command Reference Documents


33..33..  BBuuiillddiinngg tthhee ssyysstteemm

     The makefile constructed by _c_o_n_f_i_g should allow a new system
to be rebuilt by simply typing ``make''.  Alternate system  image
names are used when the root file system location and/or swapping
configuration is done in more than one way.  The  makefile  which
_c_o_n_f_i_g  creates has entry points for each system image defined in
the configuration file.  Thus, if you have configured  ``netbsd''
to  be a system with the root file system on an ``hp'' device and
``hknetbsd'' to be a system with  the  root  file  system  on  an
``hk'' device, then ``make netbsd hknetbsd'' will generate binary
images for each.  As the system will generally use the disk  from
which it is loaded as the root filesystem, separate system images
are only required to support different swap configurations.

     Note that the name of a bootable image is different from the
system  identifier.   All  bootable images are configured for the
same system; only the information about the root file system  and
paging devices differ.  (This is described in more detail in sec-
tion 4.)

     The last step in the system building process is to rearrange
certain  commonly  used symbols in the symbol table of the system
image;  the makefile generated by _c_o_n_f_i_g does this  automatically
for  you.   This  is advantageous for programs such as _n_e_t_s_t_a_t(1)
and _v_m_s_t_a_t(1), which run much faster when the symbols  they  need
are located at the front of the symbol table.  Remember also that
many programs expect the currently executing system to  be  named
``/netbsd''.   If  you install a new system and name it something
other than ``/netbsd'', many programs are likely to give  strange
results.

33..44..  SShhaarriinngg oobbjjeecctt mmoodduulleess

     If  you  have  many  systems which are all built on a single
machine there are at least  two  approaches  to  saving  time  in
building  system images.  The best way is to have a single system
image which is run on all machines.  This is attractive since  it
minimizes  disk  space  used and time required to rebuild systems
after making changes.  However, it is often the case that one  or
more  systems  will require a separately configured system image.
This may be due to limited memory (building a  system  with  many
unused  device  drivers  can  be  expensive), or to configuration
requirements (one machine may be a development machine where disk
quotas  are  not  needed,  while  another is a production machine
where they are), etc.  In these cases it is possible  for  common
systems to share relocatable object modules which are not config-
uration dependent.

     To share object modules, a generic system should  be  built.
Then,  for each system configure the system as before, but before
recompiling and linking the system, type ``make  links''  in  the
system  compilation  directory.  This will cause the system to be
searched for source modules  which  are  safe  to  share  between









Command Reference Documents   Building NetBSD Kernels with Config


systems  and  generate symbolic links in the current directory to
the appropriate object modules in the  directory  ``../GENERIC''.
A  shell script, ``makelinks'' is generated with this request and
may be checked for correctness.  The  file  ``/sys/conf/defines''
contains  a  list  of symbols which we believe are safe to ignore
when checking the source code for modules which  may  be  shared.
Note  that  this list includes the definitions used to condition-
ally compile in the virtual memory tracing  facilities,  and  the
trace  point support used only rarely (even at Berkeley).  It may
be necessary to modify this file to reflect  local  needs.   Note
further  that interdependencies which are not directly visible in
the source code are not caught.  This means  that  if  you  place
per-system dependencies in an include file, they will not be rec-
ognized and the shared code may  be  selected  in  an  unexpected
fashion.

33..55..  BBuuiillddiinngg pprrooffiilleedd ssyysstteemmss

     It  is simple to configure a system which will automatically
collect profiling information as it operates.  The profiling data
may  be  collected  with  _k_g_m_o_n(8) and processed with _g_p_r_o_f(1) to
obtain information regarding the  system's  operation.   Profiled
systems maintain histograms of the program counter as well as the
number of invocations of each routine.  The  _g_p_r_o_f  command  will
also  generate  a  dynamic call graph of the executing system and
propagate time spent in each routine along the arcs of  the  call
graph  (consult  the  _g_p_r_o_f  documentation for elaboration).  The
program counter sampling can be driven by the system clock, or if
you  have  an  alternate  real time clock, this can be used.  The
latter is highly recommended, as use of  the  system  clock  will
result in statistical anomalies, and time spent in the clock rou-
tine will not be accurately attributed.

     To configure a profiled system, the --pp option should be sup-
plied  to _c_o_n_f_i_g.  A profiled system is about 5-10% larger in its
text space due to the calls to count the subroutine  invocations.
When  the  system  executes,  the  profiling  data is stored in a
buffer which is 1.2 times the size of the text space.  The  over-
head  for  running a profiled system varies; under normal load we
see anywhere from 5-25% of the system time spent in the profiling
code.

     Note  that  systems  configured  for profiling should not be
shared as described above unless all the other shared systems are



















Building NetBSD Kernels with Config   Command Reference Documents


also to be profiled.

44..  CCOONNFFIIGGUURRAATTIIOONN FFIILLEE SSYYNNTTAAXX

     In this section we consider the specific rules used in writ-
ing a configuration file.  A complete grammar for the input  lan-
guage  can be found in Appendix A and may be of use if you should
have problems with syntax errors.

     A configuration file is broken up into three logical pieces:

+o  configuration parameters global to all system images specified
   in the configuration file,

+o  parameters specific to each system image to be generated, and

+o  device specifications.

44..11..  GGlloobbaall ccoonnffiigguurraattiioonn ppaarraammeetteerrss

     The global configuration parameters are the type of machine,
cpu  types,  options,  timezone,  system  identifier, and maximum
users.  Each is specified with a separate line in the  configura-
tion file.

mmaacchhiinnee _t_y_p_e
     The system is to run on the machine type specified.  No more
     than one machine type can appear in the configuration  file.
     Legal values are vvaaxx and ssuunn.

ccppuu ``_t_y_p_e''
     This  system is to run on the cpu type specified.  More than
     one cpu type specification can  appear  in  a  configuration
     file.   Legal  types  for a vvaaxx machine are VVAAXX88660000, VVAAXX778800,
     VVAAXX775500, VVAAXX773300 and VVAAXX663300 (MicroVAX II).  The 8650 is listed
     as an 8600, the 785 as a 780, and a 725 as a 730.

ooppttiioonnss _o_p_t_i_o_n_l_i_s_t
     Compile  the  listed optional code into the system.  Options
     in this list are separated by commas.  Possible options  are
     listed  at  the  top of the generic makefile.  A line of the
     form ``options FUNNY,HAHA''  generates  global  ``#define''s
     -DFUNNY  -DHAHA in the resultant makefile.  An option may be
     given a value by following its name  with  ``=='',  then  the
     value  enclosed in (double) quotes.  The following are major
     options are currently in use: COMPAT (include code for  com-
     patibility  with 4.1BSD binaries), INET (Internet communica-
     tion protocols), NS (Xerox NS communication protocols),  and
     QUOTA  (enable  disk quotas).  Other kernel options control-
     ling system sizes and  limits  are  listed  in  Appendix  D;
     options  for the network are found in Appendix E.  There are
     additional options which are associated with certain periph-
     eral  devices;  those  are listed in the Synopsis section of
     the manual page for the device.









Command Reference Documents   Building NetBSD Kernels with Config


mmaakkeeooppttiioonnss _o_p_t_i_o_n_l_i_s_t
     Options that are used within the system makefile and  evalu-
     ated  by _m_a_k_e are listed as _m_a_k_e_o_p_t_i_o_n_s.  Options are listed
     with   their   values   with    the    form    ``makeoptions
     name=value,name2=value2.''   The  values must be enclosed in
     double quotes if they include numerals or begin with a dash.

ttiimmeezzoonnee _n_u_m_b_e_r [ ddsstt [ _n_u_m_b_e_r ] ]
     Specifies the timezone used by the system.  This is measured
     in the number of hours your timezone is west of GMT.  EST is
     5  hours  west  of GMT, PST is 8.  Negative numbers indicate
     hours east of GMT.  If you  specify  ddsstt,  the  system  will
     operate under daylight savings time.  An optional integer or
     floating point number may be included to specify a  particu-
     lar  daylight  saving time correction algorithm; the default
     value is 1, indicating the United States.  Other values are:
     2  (Australian style), 3 (Western European), 4 (Middle Euro-
     pean), and 5 (Eastern European).   See  _g_e_t_t_i_m_e_o_f_d_a_y(2)  and
     _c_t_i_m_e(3) for more information.

iiddeenntt _n_a_m_e
     This  system is to be known as _n_a_m_e.  This is usually a cute
     name like ERNIE (short for Ernie  Co-Vax)  or  VAXWELL  (for
     Vaxwell  Smart).   This  value  is defined for use in condi-
     tional compilation, and is also used to locate  an  optional
     list of source files specific to this system.

mmaaxxuusseerrss _n_u_m_b_e_r
     The maximum expected number of simultaneously active user on
     this system is _n_u_m_b_e_r.  This number is used to size  several
     system data structures.

44..22..  SSyysstteemm iimmaaggee ppaarraammeetteerrss

     Multiple  bootable  images may be specified in a single con-
figuration file.  The systems will have the same global  configu-
ration  parameters and devices, but the location of the root file
system and other system specific devices  may  be  different.   A
system image is specified with a ``config'' line:

     ccoonnffiigg _s_y_s_n_a_m_e _c_o_n_f_i_g_-_c_l_a_u_s_e_s

The  _s_y_s_n_a_m_e  field is the name given to the loaded system image;
almost everyone names their  standard  system  image  ``netbsd''.
The configuration clauses are one or more specifications indicat-
ing where the root file system is  located  and  the  number  and
location  of  paging  devices.   The device used by the system to
process argument lists during _e_x_e_c_v_e(2) calls may also be  speci-
fied, though in practice this is almost always selected by _c_o_n_f_i_g
using one of its rules for selecting default locations for system
devices.

     A configuration clause is one of the following










Building NetBSD Kernels with Config   Command Reference Documents


     rroooott [ oonn ] _r_o_o_t_-_d_e_v_i_c_e
     sswwaapp [ oonn ] _s_w_a_p_-_d_e_v_i_c_e [ aanndd _s_w_a_p_-_d_e_v_i_c_e ] ...
     dduummppss [ oonn ] _d_u_m_p_-_d_e_v_i_c_e
     aarrggss [ oonn ] _a_r_g_-_d_e_v_i_c_e

(the  ``on''  is  optional.)   Multiple configuration clauses are
separated by white space; _c_o_n_f_i_g allows specifications to be con-
tinued  across  multiple lines by beginning the continuation line
with a tab character.  The ``root'' clause  specifies  where  the
root  file system is located, the ``swap'' clause indicates swap-
ping and paging area(s), the ``dumps''  clause  can  be  used  to
force  system  dumps  to be taken on a particular device, and the
``args'' clause can be used to specify that  argument  list  pro-
cessing for _e_x_e_c_v_e should be done on a particular device.

     The device names supplied in the clauses may be fully speci-
fied as a device, unit, and file system partition; or underspeci-
fied  in  which  case  _c_o_n_f_i_g  will  use  builtin rules to select
default unit numbers and file system partitions.  The  defaulting
rules  are a bit complicated as they are dependent on the overall
system configuration.  For example, the swap  area  need  not  be
specified  at  all  if the root device is specified; in this case
the swap area is placed in the ``b'' partition of the  same  disk
where  the  root  file  system is located.  Appendix B contains a
complete list of the defaulting rules used  in  selecting  system
configuration devices.

     The device names are translated to the appropriate major and
minor  device  numbers  on  a   per-machine   basis.    A   file,
``/sys/conf/devices.machine''  (where  ``machine'' is the machine
type specified in the configuration  file),  is  used  to  map  a
device  name  to its major block device number.  The minor device
number is calculated using the standard disk partitioning  rules:
on  unit 0, partition ``a'' is minor device 0, partition ``b'' is
minor device 1, and so on; for units other than 0,  add  8  times
the unit number to get the minor device.

     If  the default mapping of device name to major/minor device
number is incorrect for your configuration, it can be replaced by
an  explicit  specification  of  the major/minor device.  This is
done by substituting

     mmaajjoorr _x mmiinnoorr _y

where the device name would normally be found.  For example,

     ccoonnffiigg kernel rroooott oonn mmaajjoorr 99 mmiinnoorr 1

     Normally, the areas configured for swap space are  sized  by
the  system  at  boot time.  If a non-standard size is to be used
for one or more swap areas (less than the full  partition),  this
can also be specified.  To do this, the device name specified for
a swap area should have a ``size'' specification  appended.   For
example,









Command Reference Documents   Building NetBSD Kernels with Config


     ccoonnffiigg kernel rroooott oonn hp0 sswwaapp oonn hp0b ssiizzee 1200

would force swapping to be done in partition ``b'' of ``hp0'' and
the swap partition size would be set to  1200  sectors.   A  swap
area  sized  larger than the associated disk partition is trimmed
to the partition size.

     To create a generic configuration, only  the  clause  ``swap
generic''  should  be  specified; any extra clauses will cause an
error.

44..33..  DDeevviiccee ssppeecciiffiiccaattiioonnss

     Each device attached to a machine must be specified to  _c_o_n_-
_f_i_g so that the system generated will know to probe for it during
the autoconfiguration process carried out at boot time.  Hardware
specified  in  the  configuration need not actually be present on
the machine where the generated system is to be  run.   Only  the
hardware  actually found at boot time will be used by the system.

     The specification of hardware devices in  the  configuration
file parallels the interconnection hierarchy of the machine to be
configured.  On the VAX, this means  that  a  configuration  file
must  indicate  what MASSBUS and UNIBUS adapters are present, and
to which _n_e_x_i they might be connected.*  Similarly,  devices  and
controllers  must be indicated as possibly being connected to one
or more adapters.  A device description may  provide  a  complete
definition  of  the  possible  configuration parameters or it may
leave certain parameters undefined and make the system probe  for
all  the possible values.  The latter allows a single device con-
figuration list to match many possible  physical  configurations.
For example, a disk may be indicated as present at UNIBUS adapter
0, or at any UNIBUS adapter which  the  system  locates  at  boot
time.   The latter scheme, termed _w_i_l_d_c_a_r_d_i_n_g, allows more flexi-
bility in the physical configuration of a system; if a disk  must
be  moved around for some reason, the system will still locate it
at the alternate location.

     A device specification takes one of the following forms:

     mmaasstteerr _d_e_v_i_c_e_-_n_a_m_e _d_e_v_i_c_e_-_i_n_f_o
     ccoonnttrroolllleerr _d_e_v_i_c_e_-_n_a_m_e _d_e_v_i_c_e_-_i_n_f_o [ _i_n_t_e_r_r_u_p_t_-_s_p_e_c ]
     ddeevviiccee _d_e_v_i_c_e_-_n_a_m_e _d_e_v_i_c_e_-_i_n_f_o _i_n_t_e_r_r_u_p_t_-_s_p_e_c
     ddiisskk _d_e_v_i_c_e_-_n_a_m_e _d_e_v_i_c_e_-_i_n_f_o
     ttaappee _d_e_v_i_c_e_-_n_a_m_e _d_e_v_i_c_e_-_i_n_f_o

A ``master'' is a MASSBUS tape controller; a ``controller'' is  a
disk  controller, a UNIBUS tape controller, a MASSBUS adapter, or
a UNIBUS adapter.  A ``device'' is  an  autonomous  device  which
connects  directly  to  a UNIBUS adapter (as opposed to something
-----------
* While VAX-11/750's and VAX-11/730  do  not  actually
have  nexi, the system treats them as having _s_i_m_u_l_a_t_e_d
_n_e_x_i to simplify device configuration.









Building NetBSD Kernels with Config   Command Reference Documents


like a disk which connects through a disk controller).   ``Disk''
and  ``tape'' identify disk drives and tape drives connected to a
``controller'' or ``master.''

     The _d_e_v_i_c_e_-_n_a_m_e is one of  the  standard  device  names,  as
indicated  in  section 4 of the UNIX Programmers Manual, concate-
nated with the _l_o_g_i_c_a_l unit number to be assigned the device (the
_l_o_g_i_c_a_l  unit number may be different than the _p_h_y_s_i_c_a_l unit num-
ber indicated on the front of something like a disk; the  _l_o_g_i_c_a_l
unit number is used to refer to the UNIX device, not the physical
unit number).  For example, ``hp0'' is logical unit 0 of a  MASS-
BUS  storage  device,  even though it might be physical unit 3 on
MASSBUS adapter 1.

     The _d_e_v_i_c_e_-_i_n_f_o clause specifies how the  hardware  is  con-
nected  in the interconnection hierarchy.  On the VAX, UNIBUS and
MASSBUS adapters are connected to the internal system bus through
a  _n_e_x_u_s.   Thus,  one  of  the following specifications would be
used:

     ccoonnttrroolllleerr     mba0      aatt nneexxuuss _x
     ccoonnttrroolllleerr     uba0      aatt nneexxuuss _x

To tie a controller to a specific nexus, ``x'' would be  supplied
as  the number of that nexus; otherwise ``x'' may be specified as
``?'', in which case the system will probe all nexi present look-
ing for the specified controller.

     The remaining interconnections on the VAX are:

+o  a  controller  may  be connected to another controller (e.g. a
   disk controller attached to a UNIBUS adapter),

+o  a master  is  always  attached  to  a  controller  (a  MASSBUS
   adapter),

+o  a  tape  is  always  attached  to  a  master (for MASSBUS tape
   drives),

+o  a disk is always attached to a controller, and

+o  devices are always attached to controllers (e.g.  UNIBUS  con-
   trollers attached to UNIBUS adapters).

The following lines give an example of each of these interconnec-
tions:

     ccoonnttrroolllleerr     hk0       aatt uba0 ...
     mmaasstteerr         ht0       aatt mba0 ...
     ddiisskk           hp0       aatt mba0 ...
     ttaappee           tu0       aatt ht0 ...
     ddiisskk           rk1       aatt hk0 ...
     ddeevviiccee         dz0       aatt uba0 ...










Command Reference Documents   Building NetBSD Kernels with Config


Any piece of hardware which may be connected to a  specific  con-
troller may also be wildcarded across multiple controllers.

     The  final piece of information needed by the system to con-
figure devices is some indication of where or how a  device  will
interrupt.   For  tapes and disks, simply specifying the _s_l_a_v_e or
_d_r_i_v_e number is sufficient to locate the control status  register
for  the  device.   _D_r_i_v_e  numbers  may  be wildcarded on MASSBUS
devices, but not on disks  on  a  UNIBUS  controller.   For  con-
trollers,  the  control status register must be given explicitly,
as well the number of interrupt vectors used and the names of the
routines  to  which they should be bound.  Thus the example lines
given above might be completed as:

     ccoonnttrroolllleerr     hk0       aatt uba0 ccssrr 0177440vveeccttoorr rkintr
     mmaasstteerr         ht0       aatt mba0 ddrriivvee 0
     ddiisskk           hp0       aatt mba0 ddrriivvee ?
     ttaappee           tu0       aatt ht0 ssllaavvee 0
     ddiisskk           rk1       aatt hk0 ddrriivvee 1
     ddeevviiccee         dz0       aatt uba0 ccssrr 0160100vveeccttoorr dzrint dzxint

     Certain device drivers require extra information  passed  to
them  at  boot time to tailor their operation to the actual hard-
ware present.  The line printer driver,  for  example,  needs  to
know  how  many  columns  are  present  on each non-standard line
printer (i.e. a line printer with other than  80  columns).   The
drivers  for  the  terminal multiplexors need to know which lines
are attached to modem lines so that no one will be allowed to use
them  unless  a connection is present.  For this reason, one last
parameter may be specified to a _d_e_v_i_c_e, a _f_l_a_g_s  field.   It  has
the syntax

     ffllaaggss _n_u_m_b_e_r

and is usually placed after the _c_s_r specification.  The _n_u_m_b_e_r is
passed directly to the associated driver.  The  manual  pages  in
section  4  should be consulted to determine how each driver uses
this value (if at all).  Communications  interface  drivers  com-
monly use the flags to indicate whether modem control signals are
in use.

     The exact syntax for each specific device is  given  in  the
Synopsis section of its manual page in section 4 of the manual.

44..44..  PPsseeuuddoo--ddeevviicceess

     A number of drivers and software subsystems are treated like
device drivers without any associated hardware.  To  include  any
of  these pieces, a ``pseudo-device'' specification must be used.
A specification for a pseudo device takes the form

     ppsseeuuddoo--ddeevviiccee  _d_e_v_i_c_e_-_n_a_m_e [ _h_o_w_m_a_n_y ]











Building NetBSD Kernels with Config   Command Reference Documents


     Examples of pseudo devices  are  ppttyy,  the  pseudo  terminal
driver  (where the optional _h_o_w_m_a_n_y value indicates the number of
pseudo terminals to configure, 32 default), and lloooopp,  the  soft-
ware loopback network pseudo-interface.  Other pseudo devices for
the network include iimmpp (required when a CSS or ACC imp  is  con-
figured) and eetthheerr (used by the Address Resolution Protocol on 10
Mb/sec Ethernets).  More information on configuring each of these
can also be found in section 4 of the manual.

55..  SSAAMMPPLLEE CCOONNFFIIGGUURRAATTIIOONN FFIILLEESS

     In  this  section we will consider how to configure a sample
VAX-11/780 system on which the hardware can  be  reconfigured  to
guard  against various hardware mishaps.  We then study the rules
needed to configure a VAX-11/750 to run in a networking  environ-
ment.

55..11..  VVAAXX--1111//778800 SSyysstteemm

     Our  VAX-11/780  is  configured with hardware recommended in
the document ``Hints on Configuring a VAX for 4.2BSD''  (this  is
one of the high-end configurations).  Table 1 lists the pertinent
hardware to be configured.


+---------------------+---------+------------+--------+-----------+
|Item                 | Vendor  | Connection | Name   | Reference |
+---------------------+---------+------------+--------+-----------+
|cpu                  | DEC     |            | VAX780 |           |
|MASSBUS controller   | Emulex  | nexus ?    | mba0   | hp(4)     |
|disk                 | Fujitsu | mba0       | hp0    |           |
|disk                 | Fujitsu | mba0       | hp1    |           |
|MASSBUS controller   | Emulex  | nexus ?    | mba1   |           |
|disk                 | Fujitsu | mba1       | hp2    |           |
|disk                 | Fujitsu | mba1       | hp3    |           |
|UNIBUS adapter       | DEC     | nexus ?    |        |           |
|tape controller      | Emulex  | uba0       | tm0    | tm(4)     |
|tape drive           | Kennedy | tm0        | te0    |           |
|tape drive           | Kennedy | tm0        | te1    |           |
|terminal multiplexor | Emulex  | uba0       | dh0    | dh(4)     |
|terminal multiplexor | Emulex  | uba0       | dh1    |           |
|terminal multiplexor | Emulex  | uba0       | dh2    |           |
+---------------------+---------+------------+--------+-----------+

             Table 1.  VAX-11/780 Hardware support.

We will call this machine ANSEL  and  construct  a  configuration
file one step at a time.

     The first step is to fill in the global configuration param-
eters.  The machine is a VAX, so the _m_a_c_h_i_n_e _t_y_p_e is ``vax''.  We
will  assume  this system will run only on this one processor, so
the _c_p_u _t_y_p_e is ``VAX780''.  The options are empty since this  is
going  to  be  a  ``vanilla''  VAX.   The  system  identifier, as









Command Reference Documents   Building NetBSD Kernels with Config


mentioned before, is ``ANSEL,'' and the maximum number  of  users
we  plan  to support is about 40.  Thus the beginning of the con-
figuration file looks like this:

     #
     # ANSEL VAX (a picture perfect machine)
     #
     machine        vax
     cpu            VAX780
     timezone       8 dst
     ident          ANSEL
     maxusers       40


     To this we must then add the specifications for three system
images.   The  first will be our standard system with the root on
``hp0'' and swapping on the same drive as the root.   The  second
will  have  the  root  file system in the same location, but swap
space interleaved among drives on each controller.  Finally,  the
third  will  be  a generic system, to allow us to boot off any of
the four disk drives.

     config         kernel    root on hp0
     config         hpkernel  root on hp0 swap on hp0 and hp2
     config         genkernel swap generic


     Finally, the hardware must be specified.  Let us first  just
try transcribing the information from Table 1.

     controller     mba0      at nexus ?
     disk           hp0       at mba0 disk 0
     disk           hp1       at mba0 disk 1
     controller     mba1      at nexus ?
     disk           hp2       at mba1 disk 2
     disk           hp3       at mba1 disk 3
     controller     uba0      at nexus ?
     controller     tm0       at uba0 csr 0172520vector tmintr
     tape           te0       at tm0 drive 0
     tape           te1       at tm0 drive 1
     device         dh0       at uba0 csr 0160020vector dhrint dhxint
     device         dm0       at uba0 csr 0170500vector dmintr
     device         dh1       at uba0 csr 0160040vector dhrint dhxint
     device         dh2       at uba0 csr 0160060vector dhrint dhxint


(Oh,  I  forgot  to mention one panel of the terminal multiplexor
has modem control, thus the ``dm0'' device.)

     This will suffice, but leaves us  with  little  flexibility.
Suppose  our  first disk controller were to break.  We would like
to recable the drives normally on the second controller  so  that
all  our disks could still be used without reconfiguring the sys-
tem.  To do this we wildcard the MASSBUS adapter connections  and









Building NetBSD Kernels with Config   Command Reference Documents


also  the slave numbers.  Further, we wildcard the UNIBUS adapter
connections in case we decide some time in the future to purchase
another  adapter  to offload the single UNIBUS we currently have.
The revised device specifications would then be:

     controller     mba0      at nexus ?
     disk           hp0       at mba? disk ?
     disk           hp1       at mba? disk ?
     controller     mba1      at nexus ?
     disk           hp2       at mba? disk ?
     disk           hp3       at mba? disk ?
     controller     uba0      at nexus ?
     controller     tm0       at uba? csr 0172520vector tmintr
     tape           te0       at tm0 drive 0
     tape           te1       at tm0 drive 1
     device         dh0       at uba? csr 0160020vector dhrint dhxint
     device         dm0       at uba? csr 0170500vector dmintr
     device         dh1       at uba? csr 0160040vector dhrint dhxint
     device         dh2       at uba? csr 0160060vector dhrint dhxint


The completed configuration file for ANSEL is shown  in  Appendix
C.

55..22..  VVAAXX--1111//775500 wwiitthh nneettwwoorrkk ssuuppppoorrtt

     Our VAX-11/750 system will be located on two 10Mb/s Ethernet
local area networks and also the DARPA Internet.  The system will
have  a  MASSBUS  drive  for  the root file system and two UNIBUS
drives.  Paging is interleaved among all three drives.   We  have
sold  our  standard  DEC terminal multiplexors since this machine
will be accessed solely through the network.  This machine is not
intended to have a large user community, it does not have a great
deal of memory.  First the global parameters:

     #
     # UCBVAX (Gateway to the world)
     #
     machine        vax
     cpu            "VAX780"
     cpu            "VAX750"
     ident          UCBVAX
     timezone       8 dst
     maxusers       32
     options        INET
     options        NS


     The multiple cpu types allow us to  replace  UCBVAX  with  a
more powerful cpu without reconfiguring the system.  The value of
32 given for the maximum number of users is  done  to  force  the
system  data  structures to be over-allocated.  That is desirable
on this machine because, while it is not expected to support many
users,  it  is  expected  to  perform  a great deal of work.  The









Command Reference Documents   Building NetBSD Kernels with Config


``INET'' indicates that we plan to use the DARPA standard  Inter-
net  protocols  on this machine, and ``NS'' also includes support
for Xerox NS protocols.  Note that  unlike  4.2BSD  configuration
files,  the network protocol options do not require corresponding
pseudo devices.

     The system images and disks are configured next.

     config         kernel    root on hp swap on hp and rk0 and rk1
     config         upkernel  root on up
     config         hkkernel  root on hk swap on rk0 and rk1

     controller     mba0      at nexus ?
     controller     uba0      at nexus ?
     disk           hp0       at mba? drive 0
     disk           hp1       at mba? drive 1
     controller     sc0       at uba? csr 0176700vector upintr
     disk           up0       at sc0 drive 0
     disk           up1       at sc0 drive 1
     controller     hk0       at uba? csr 0177440 vector rkintr
     disk           rk0       at hk0 drive 0
     disk           rk1       at hk0 drive 1


     UCBVAX requires heavy interleaving of  its  paging  area  to
keep  up with all the mail traffic it handles.  The limiting fac-
tor on this system's performance is usually the  number  of  disk
arms,  as opposed to memory or cpu cycles.  The extra UNIBUS con-
troller, ``sc0'', is in case the MASSBUS controller breaks and  a
spare  controller  must be installed (most of our old UNIBUS con-
trollers have been replaced with the newer  MASSBUS  controllers,
so we have a number of these around as spares).

     Finally,  we  add  in the network devices.  Pseudo terminals
are needed to allow users to log in across the network  (remember
the  only hardwired terminal is the console).  The software loop-
back device is used for on-machine communications.   The  connec-
tion to the Internet is through an IMP, this requires yet another
_p_s_e_u_d_o_-_d_e_v_i_c_e (in addition to the actual hardware device used  by
the  IMP  software).   And,  finally,  there are the two Ethernet
devices.  These use a special protocol,  the  Address  Resolution
Protocol  (ARP),  to map between Internet and Ethernet addresses.
Thus, yet another _p_s_e_u_d_o_-_d_e_v_i_c_e is needed.  The additional device
specifications are show below.

     pseudo-device  pty
     pseudo-device  loop
     pseudo-device  imp
     device         acc0      at uba? csr 0167600vector accrint accxint
     pseudo-device  ether
     device         ec0       at uba? csr 0164330vector ecrint eccollide ecxint
     device         il0       at uba? csr 0164000vector ilrint ilcint











Building NetBSD Kernels with Config   Command Reference Documents


The  completed configuration file for UCBVAX is shown in Appendix
C.

55..33..  MMiisscceellllaanneeoouuss ccoommmmeennttss

     It should be noted in these examples that neither system was
configured  to  use disk quotas or the 4.1BSD compatibility mode.
To use these optional facilities, and others, we  would  probably
clean out our current configuration, reconfigure the system, then
recompile and relink the system image(s).  This could, of course,
be  avoided  by  figuring  out which relocatable object files are
affected by the reconfiguration, then reconfiguring and recompil-
ing  only those files affected by the configuration change.  This
technique should be used carefully.

66..  AADDDDIINNGG NNEEWW SSYYSSTTEEMM SSOOFFTTWWAARREE

     This section is not for the novice, it describes some of the
inner workings of the configuration process as well as the perti-
nent parts  of  the  system  autoconfiguration  process.   It  is
intended  to  give  those people who intend to install new device
drivers and/or other system facilities sufficient information  to
do  so  in the manner which will allow others to easily share the
changes.

     This section is broken into four parts:

+o  general guidelines to be followed in modifying system code,

+o  how to add non-standard system facilities to NetBSD, and

+o  how to add a device driver to NetBSD.

66..11..  MMooddiiffyyiinngg ssyysstteemm ccooddee

     If you wish to make site-specific modifications to the  sys-
tem it is best to bracket them with

     #ifdef SITENAME
     ...
     #endif

to allow your source to be easily distributed to others, and also
to simplify _d_i_f_f(1) listings.  It is recommended  that  you  save
the old code with something of the form:

     #ifndef SITENAME
     ...
     #endif


     Machine-specific  code should be placed in existing machine-
specific files, or added as new files in machine-specific  source
directories.     The   use   of   machine-specific   preprocessor









Command Reference Documents   Building NetBSD Kernels with Config


conditionals is discouraged.

66..22..  AAddddiinngg nnoonn--ssttaannddaarrdd ssyysstteemm ffaacciilliittiieess

     This section considers the work needed to  augment  _c_o_n_f_i_g's
data  base files for non-standard system facilities.  _C_o_n_f_i_g uses
a set of files that list the source modules that may be  required
when  building  a system.  The data bases are taken from standard
locations    in    the    system    source     tree,     normally
``/usr/src/sys/conf''.   Three  such  files  may  be used: _f_i_l_e_s,
_f_i_l_e_s.machine, and _f_i_l_e_s.ident.  The first is common to all  sys-
tems,  the second contains files unique to a single machine type,
and the third is an optional list of modules for use  on  a  spe-
cific machine.  This last file may override specifications in the
first two.  The format of the _f_i_l_e_s file has grown somewhat  com-
plex over time.  Entries are normally of the form

     _d_i_r_/_s_o_u_r_c_e_._c   _t_y_p_e  _o_p_t_i_o_n_-_l_i_s_t _m_o_d_i_f_i_e_r_s

for example,

     _v_a_x_u_b_a_/_f_o_o_._c   ooppttiioonnaall  foo  ddeevviiccee--ddrriivveerr

The  _t_y_p_e  is one of ssttaannddaarrdd or ooppttiioonnaall.  Files marked as stan-
dard are included in all system  configurations.   Optional  file
specifications  include a list of one or more system options that
together require the inclusion of this module.   The  options  in
the  list  may be either names of devices that may be in the con-
figuration file, or the names  of  system  options  that  may  be
defined.  An optional file may be listed multiple times with dif-
ferent options; if all of the options for any of the entries  are
satisfied, the module is included.

     If  a file is specified as a _d_e_v_i_c_e_-_d_r_i_v_e_r, any special com-
pilation options for device drivers will be invoked.  On the  VAX
this  results  in  the  use of the --ii option for the C optimizer.
This is required when pointer references are made to memory loca-
tions in the VAX I/O address space.

     Two  other  optional  keywords modify the usage of the file.
_C_o_n_f_i_g understands that certain files  are  used  especially  for
kernel  profiling.   These files are indicated in the _f_i_l_e_s files
with a _p_r_o_f_i_l_i_n_g_-_r_o_u_t_i_n_e keyword.  For example, the current  pro-
filing  subroutines  are  sequestered off in a separate file with
the following entry:

     _s_y_s_/_s_u_b_r___m_c_o_u_n_t_._c   ooppttiioonnaall  pprrooffiilliinngg--rroouuttiinnee

The _p_r_o_f_i_l_i_n_g_-_r_o_u_t_i_n_e keyword forces _c_o_n_f_i_g not  to  compile  the
source file with the --ppgg option.

     The  second keyword which can be of use is the _c_o_n_f_i_g_-_d_e_p_e_n_-
_d_e_n_t keyword.  This causes _c_o_n_f_i_g to compile the indicated module
with  the  global  configuration parameters.  This allows certain









Building NetBSD Kernels with Config   Command Reference Documents


modules, such as _m_a_c_h_d_e_p_._c to size system data  structures  based
on the maximum number of users configured for the system.

66..33..  AAddddiinngg ddeevviiccee ddrriivveerrss ttoo NNeettBBSSDD

     The I/O system and _c_o_n_f_i_g have been designed to easily allow
new device support to be added.  The  system  source  directories
are organized as follows:


     /usr/src/sys/sys               machine independent include files
     /usr/src/sys/kern              machine-independent system source files
     /usr/src/sys/conf              machine-independent configuration data
     /usr/src/sys/net               network-protocol-independent, but network-related code
     /usr/src/sys/netinet           DARPA Internet code
     /usr/src/sys/dev               machine-independent device drivers
     /usr/src/sys/arch              machine-dependent code
     /usr/src/sys/arch/amd64        machine-dependent code for 64-bit x86
     /usr/src/sys/arch/i386         machine-dependent code for 32-bit x86
     /usr/src/sys/arch/x86          machine-dependent code shared between x86 types
     /usr/src/sys/arch/amd64/conf   site configuration files and basic templates
     (and so on)



     Existing  block  and  character  device  drivers for the VAX
reside in ``/usr/src/sys/dev''.  Any new device drivers should be
placed  in  the appropriate source code directory and named so as
not to conflict with existing devices.  Normally, definitions for
things like device registers are placed in a separate file in the
same directory.  For example,  the  ``auixp''  device  driver  is
named  ``auixp.c''  and  its  associated  include  file  is named
``auixpreg.h''. There is also an  ``auixpvar.h''  which  contains
data  structures  and other external declarations that the driver
needs to expose.

     Once the source for the device driver has been placed  in  a
directory,  the  file ``/usr/src/sys/conf/files'' should be modi-
fied.  The _f_i_l_e_s files in the conf directory contain a  line  for
each  C  source  or  binary-only file in the system.  Those files
which    are    machine    independent     are     located     in
``/usr/src/sys/conf/files,'' while machine specific files for the
``foo''  port  are  in  ``/usr/src/sys/arch/foo/conf/files.foo''.
The  ``devices.foo''  file  is  used to map device names to major
block device numbers.  If the device driver being added  provides
support  for  a  new  disk you will want to modify this file (the
format is obvious).

     In addition to including the driver in the  _f_i_l_e_s  file,  it
must also be added to the device configuration tables.  These are
located in ``/sys/vax/conf.c'', or  similar  for  machines  other
than  the VAX.  If you don't understand what to add to this file,
you should study an entry for an existing driver.  Remember  that
the  position  in  the  device  table  specifies the major device









Command Reference Documents   Building NetBSD Kernels with Config


number.    The   block   major   number   is   needed   in    the
``devices.machine'' file if the device is a disk.

     With the configuration information in place, your configura-
tion file appropriately modified, and a system  reconfigured  and
rebooted  you  should  incorporate  the  shell commands needed to
install the  special  files  in  the  file  system  to  the  file
``/dev/MAKEDEV'' or ``/dev/MAKEDEV.local''.  This is discussed in
the document ``Installing and Operating 4.4BSD''.






















































Building NetBSD Kernels with Config   Command Reference Documents


             AAPPPPEENNDDIIXX AA.. CCOONNFFIIGGUURRAATTIIOONN FFIILLEE GGRRAAMMMMAARR


     The following grammar is a compressed  form  of  the  actual
_y_a_c_c(1)  grammar  used  by  _c_o_n_f_i_g  to parse configuration files.
Terminal symbols are  shown  all  in  upper  case,  literals  are
emboldened;  optional clauses are enclosed in brackets, ``['' and
``]'';  zero or more instantiations are denoted with ``*''.

Configuration ::=  [ Spec ;; ]*

Spec ::= Config_spec
     | Device_spec
     | ttrraaccee
     | /* lambda */

/* configuration specifications */

Config_spec ::=  mmaacchhiinnee ID
     | ccppuu ID
     | ooppttiioonnss Opt_list
     | iiddeenntt ID
     | System_spec
     | ttiimmeezzoonnee [ -- ] NUMBER [ ddsstt [ NUMBER ] ]
     | ttiimmeezzoonnee [ -- ] FPNUMBER [ ddsstt [ NUMBER ] ]
     | mmaaxxuusseerrss NUMBER

/* system configuration specifications */

System_spec ::= ccoonnffiigg ID System_parameter [ System_parameter ]*

System_parameter ::=  swap_spec | root_spec | dump_spec | arg_spec

swap_spec ::=  sswwaapp [ oonn ] swap_dev [ aanndd swap_dev ]*

swap_dev ::=  dev_spec [ ssiizzee NUMBER ]

root_spec ::=  rroooott [ oonn ] dev_spec

dump_spec ::=  dduummppss [ oonn ] dev_spec

arg_spec ::=  aarrggss [ oonn ] dev_spec

dev_spec ::=  dev_name | major_minor

major_minor ::=  mmaajjoorr NUMBER mmiinnoorr NUMBER

dev_name ::=  ID [ NUMBER [ ID ] ]

/* option specifications */

Opt_list ::=  Option [ ,, Option ]*

Option ::=  ID [ == Opt_value ]









Command Reference Documents   Building NetBSD Kernels with Config


Opt_value ::=  ID | NUMBER

Mkopt_list ::=  Mkoption [ ,, Mkoption ]*

Mkoption ::=  ID == Opt_value

/* device specifications */

Device_spec ::= ddeevviiccee Dev_name Dev_info Int_spec
     | mmaasstteerr Dev_name Dev_info
     | ddiisskk Dev_name Dev_info
     | ttaappee Dev_name Dev_info
     | ccoonnttrroolllleerr Dev_name Dev_info [ Int_spec ]
     | ppsseeuuddoo--ddeevviiccee Dev [ NUMBER ]

Dev_name ::=  Dev NUMBER

Dev ::=  uubbaa | mmbbaa | ID

Dev_info ::=  Con_info [ Info ]*

Con_info ::=  aatt Dev NUMBER
     | aatt nneexxuuss NUMBER

Info ::=  ccssrr NUMBER
     | ddrriivvee NUMBER
     | ssllaavvee NUMBER
     | ffllaaggss NUMBER

Int_spec ::=  vveeccttoorr ID [ ID ]*
     | pprriioorriittyy NUMBER


LLeexxiiccaall CCoonnvveennttiioonnss

The terminal symbols are loosely defined as:

ID
     One or more alphabetics, either upper  or  lower  case,  and
     underscore, ``_''.

NUMBER
     Approximately  the  C  language specification for an integer
     number.  That is, a leading ``0x'' indicates  a  hexadecimal
     value,  a  leading ``0'' indicates an octal value, otherwise
     the number is expected to be a decimal  value.   Hexadecimal
     numbers may use either upper or lower case alphabetics.

FPNUMBER
     A  floating point number without exponent.  That is a number
     of the form ``nnn.ddd'', where the fractional  component  is
     optional.











Building NetBSD Kernels with Config   Command Reference Documents


In  special  instances a question mark, ``?'', can be substituted
for a ``NUMBER'' token.  This is used to  effect  wildcarding  in
device interconnection specifications.

Comments  in configuration files are indicated by a ``#'' charac-
ter at the beginning of the line; the remainder of  the  line  is
discarded.

A  specification is interpreted as a continuation of the previous
line if the first character of the line is tab.





















































Command Reference Documents   Building NetBSD Kernels with Config


         AAPPPPEENNDDIIXX BB.. RRUULLEESS FFOORR DDEEFFAAUULLTTIINNGG SSYYSSTTEEMM DDEEVVIICCEESS


     When _c_o_n_f_i_g processes a ``config'' rule which does not fully
specify  the  location  of  the root file system, paging area(s),
device for system dumps, and device for argument list  processing
it  applies  a  set of rules to define those values left unspeci-
fied.  The following list of rules are used in defaulting  system
devices.

1) If a root device is not specified, the swap specification must
   indicate a ``generic'' system is to be built.

2) If the root device does not specify a unit number, it defaults
   to unit 0.

3) If the root device does not include a partition specification,
   it defaults to the ``a'' partition.

4) If no swap area is specified, it defaults to the ``b''  parti-
   tion of the root device.

5) If  no  device is specified for processing argument lists, the
   first swap partition is selected.

6) If no device is chosen for system dumps, the first swap parti-
   tion is selected (see below to find out where dumps are placed
   within the partition).

     The  following  table  summarizes  the  default   partitions
selected when a device specification is incomplete, e.g. ``hp0''.


     Type    Partition
     ------------------
     root    ``a''
     swap    ``b''
     args    ``b''
     dumps   ``b''



MMuullttiippllee sswwaapp//ppaaggiinngg aarreeaass

     When multiple swap  partitions  are  specified,  the  system
treats  the  first  specified as a ``primary'' swap area which is
always used.  The remaining partitions are then interleaved  into
the  paging  system  at the time a _s_w_a_p_o_n(2) system call is made.
This is normally done at boot time with a call to _s_w_a_p_o_n(8)  from
the /etc/rc file.













Building NetBSD Kernels with Config   Command Reference Documents


SSyysstteemm dduummppss

     System  dumps  are automatically taken after a system crash,
provided the device driver  for  the  ``dumps''  device  supports
this.  The dump contains the contents of memory, but not the swap
areas.  Normally the dump device is a  disk  in  which  case  the
information is copied to a location at the back of the partition.
The dump is placed in the back of the partition because the  pri-
mary  swap  and dump device are commonly the same device and this
allows the system to be rebooted without immediately  overwriting
the  saved  information.   When  a  dump has occurred, the system
variable _d_u_m_p_s_i_z_e is set to a non-zero value indicating the  size
(in  bytes) of the dump.  The _s_a_v_e_c_o_r_e(8) program then copies the
information from the dump partition to  a  file  in  a  ``crash''
directory  and  also makes a copy of the system which was running
at the time of the crash (usually ``/kernel'').   The  offset  to
the  system dump is defined in the system variable _d_u_m_p_l_o (a sec-
tor offset from the front of the dump partition).   The  _s_a_v_e_c_o_r_e
program  operates by reading the contents of _d_u_m_p_l_o, _d_u_m_p_d_e_v, and
_d_u_m_p_m_a_g_i_c from /dev/kmem, then comparing the value  of  _d_u_m_p_m_a_g_i_c
read  from /dev/kmem to that located in corresponding location in
the dump area of the  dump  partition.   If  a  match  is  found,
_s_a_v_e_c_o_r_e  assumes  a  crash  occurred and reads _d_u_m_p_s_i_z_e from the
dump area of the dump partition.  This  value  is  then  used  in
copying  the system dump.  Refer to _s_a_v_e_c_o_r_e(8) for more informa-
tion about its operation.

     The value _d_u_m_p_l_o is calculated to be

     _d_u_m_p_d_e_v_-_s_i_z_e - _m_e_m_s_i_z_e

where _d_u_m_p_d_e_v_-_s_i_z_e is the size of the disk partition where system
dumps  are to be placed, and _m_e_m_s_i_z_e is the size of physical mem-
ory.  If the disk partition is not large enough to  hold  a  full
dump, _d_u_m_p_l_o is set to 0 (the start of the partition).




























Command Reference Documents   Building NetBSD Kernels with Config


             AAPPPPEENNDDIIXX CC.. SSAAMMPPLLEE CCOONNFFIIGGUURRAATTIIOONN FFIILLEESS


     The  following  configuration files are developed in section
5; they are included here for completeness.


#
# ANSEL VAX (a picture perfect machine)
#
machine        vax
cpu            VAX780
timezone       8 dst
ident          ANSEL
maxusers       40

config         kernel    root on hp0
config         hpkernel  root on hp0 swap on hp0 and hp2
config         genkernel swap generic

controller     mba0      at nexus ?
disk           hp0       at mba? disk ?
disk           hp1       at mba? disk ?
controller     mba1      at nexus ?
disk           hp2       at mba? disk ?
disk           hp3       at mba? disk ?
controller     uba0      at nexus ?
controller     tm0       at uba? csr 0172520vector tmintr
tape           te0       at tm0 drive 0
tape           te1       at tm0 drive 1
device         dh0       at uba? csr 0160020vector dhrint dhxint
device         dm0       at uba? csr 0170500vector dmintr
device         dh1       at uba? csr 0160040vector dhrint dhxint
device         dh2       at uba? csr 0160060vector dhrint dhxint





























Building NetBSD Kernels with Config   Command Reference Documents


#
# UCBVAX - Gateway to the world
#
machine        vax
cpu            "VAX780"
cpu            "VAX750"
ident          UCBVAX
timezone       8 dst
maxusers       32
options        INET
options        NS

config         kernel    root on hp swap on hp and rk0 and rk1
config         upkernel  root on up
config         hkkernel  root on hk swap on rk0 and rk1

controller     mba0      at nexus ?
controller     uba0      at nexus ?
disk           hp0       at mba? drive 0
disk           hp1       at mba? drive 1
controller     sc0       at uba? csr 0176700vector upintr
disk           up0       at sc0 drive 0
disk           up1       at sc0 drive 1
controller     hk0       at uba? csr 0177440vector rkintr
disk           rk0       at hk0 drive 0
disk           rk1       at hk0 drive 1
pseudo-device  pty
pseudo-device  loop
pseudo-device  imp
device         acc0      at uba? csr 0167600vector accrint accxint
pseudo-device  ether
device         ec0       at uba? csr 0164330vector ecrint eccollide ecxint
device         il0       at uba? csr 0164000vector ilrint ilcint






























Command Reference Documents   Building NetBSD Kernels with Config


       AAPPPPEENNDDIIXX DD.. VVAAXX KKEERRNNEELL DDAATTAA SSTTRRUUCCTTUURREE SSIIZZIINNGG RRUULLEESS


     Certain system data structures are  sized  at  compile  time
according  to  the maximum number of simultaneous users expected,
while others are calculated at boot time based  on  the  physical
resources present, e.g. memory.  This appendix lists both sets of
rules and also includes some hints on changing  built-in  limita-
tions on certain data structures.

CCoommppiillee ttiimmee rruulleess

     The  file  _/_s_y_s_/_c_o_n_f_/_p_a_r_a_m_._c  contains  the  definitions  of
almost all data structures sized at compile time.  This  file  is
copied into the directory of each configured system to allow con-
figuration-dependent rules and values to  be  maintained.   (Each
copy  normally depends on the copy in /sys/conf, and global modi-
fications cause the file to be recopied unless  the  makefile  is
modified.)   The  rules  implied  by  its contents are summarized
below (here MAXUSERS refers to the value defined in the  configu-
ration  file in the ``maxusers'' rule).  Most limits are computed
at compile time and stored in global variables for use  by  other
modules; they may generally be patched in the system binary image
before rebooting to test new values.

nnpprroocc
     The maximum number of processes which may be running at  any
     time.   It is referred to in other calculations as NPROC and
     is defined to be

          20 + 8 * MAXUSERS


nntteexxtt
     The maximum number of active shared text segments.  The con-
     stant  is  intended  to allow for network servers and common
     commands that remain in the table.  It is defined as

          36 + MAXUSERS.


nniinnooddee
     The maximum number of files in the file system which may  be
     active at any time.  This includes files in use by users, as
     well as directory files being read or written by the  system
     and  files  associated  with  bound  sockets in the UNIX IPC
     domain.  It is defined as

          (NPROC + 16 + MAXUSERS) + 32


nnffiillee
     The number of ``file table''  structures.   One  file  table
     structure  is used for each open, unshared, file descriptor.









Building NetBSD Kernels with Config   Command Reference Documents


     Multiple file descriptors may reference a single file  table
     entry  when  they  are created through a _d_u_p call, or as the
     result of a _f_o_r_k.  This is defined to be

          16 * (NPROC + 16 + MAXUSERS) / 10 + 32


nnccaalllloouutt
     The number of ``callout'' structures.  One callout structure
     is  used  per  internal system event handled with a timeout.
     Timeouts are used for terminal delays, watchdog routines  in
     device  drivers,  protocol timeout processing, etc.  This is
     defined as

          16 + NPROC


nncclliisstt
     The number of ``c-list'' structures.  C-list structures  are
     used  in  terminal  I/O, and currently each holds 60 charac-
     ters.  Their number is defined as

          60 + 12 * MAXUSERS


nnmmbbcclluusstteerrss
     The maximum number of pages which may be  allocated  by  the
     network.  This is defined as 256 (a quarter megabyte of mem-
     ory) in /sys/h/mbuf.h.  In practice, the network rarely uses
     this  much  memory.  It starts off by allocating 8 kilobytes
     of memory, then requesting more  as  required.   This  value
     represents an upper bound.

nnqquuoottaa
     The  number of ``quota'' structures allocated.  Quota struc-
     tures are present only when disc quotas  are  configured  in
     the  system.  One quota structure is kept per user.  This is
     defined to be

          (MAXUSERS * 9) / 7 + 3


nnddqquuoott
     The number of ``dquot'' structures allocated.  Dquot  struc-
     tures  are  present  only when disc quotas are configured in
     the system.  One dquot structure is required per  user,  per
     active  file system quota.  That is, when a user manipulates
     a file on a file system on which  quotas  are  enabled,  the
     information  regarding the user's quotas on that file system
     must be in-core.  This information is cached,  so  that  not
     all  information must be present in-core all the time.  This
     is defined as











Command Reference Documents   Building NetBSD Kernels with Config


          NINODE + (MAXUSERS * NMOUNT) / 4

     where NMOUNT is the maximum number of  mountable  file  sys-
     tems.

In  addition to the above values, the system page tables (used to
map virtual memory in the kernel's address space)  are  sized  at
compile   time   by   the   SYSPTSIZE   definition  in  the  file
/sys/vax/vmparam.h.  This is defined to be

     20 + MAXUSERS

pages of page tables.  Its definition affects the  size  of  many
data  structures allocated at boot time because it constrains the
amount of virtual memory which may be addressed  by  the  running
system.   This  is  often  the limiting factor in the size of the
buffer cache, in which case a message is printed when the  system
configures at boot time.

RRuunn--ttiimmee ccaallccuullaattiioonnss

     The  most  important  data  structures sized at run-time are
those used in the buffer cache.  Allocation is done by allocating
physical memory (and system virtual memory) immediately after the
system has been started up; look in the file  /sys/vax/machdep.c.
The  amount  of  physical  memory  which  may be allocated to the
buffer cache is constrained  by  the  size  of  the  system  page
tables,  among  other  things.   While the system may calculate a
large amount of memory to be allocated to the  buffer  cache,  if
the  system  page  table is too small to map this physical memory
into the virtual address space of the system, only as much as can
be mapped will be used.

     The  buffer cache is comprised of a number of ``buffer head-
ers'' and a pool of pages  attached  to  these  headers.   Buffer
headers  are divided into two categories: those used for swapping
and paging, and those used for normal file I/O.  The system tries
to  allocate 10% of the first two megabytes and 5% of the remain-
ing available physical memory for the buffer cache (where  _a_v_a_i_l_-
_a_b_l_e  does not count that space occupied by the system's text and
data segments).  If this results in fewer than 16 pages of memory
allocated,  then  16  pages are allocated.  This value is kept in
the initialized variable _b_u_f_p_a_g_e_s so that it may  be  patched  in
the  binary  image  (to allow tuning without recompiling the sys-
tem), or the default may be overridden with a  configuration-file
option.   For  example, the option ooppttiioonnss BBUUFFPPAAGGEESS==""33220000"" causes
3200 pages (3.2M bytes) to be used by the buffer cache.  A suffi-
cient  number  of  file  I/O buffer headers are then allocated to
allow each to hold 2 pages each.  Each buffer maps 8K bytes.   If
the  number  of  buffer pages is larger than can be mapped by the
buffer headers, the number of pages is reduced.   The  number  of
buffer  headers  allocated is stored in the global variable _n_b_u_f,
which may be patched before the system  is  booted.   The  system
option  ooppttiioonnss  NNBBUUFF==""11000000"" forces the allocation of 1000 buffer









Building NetBSD Kernels with Config   Command Reference Documents


headers.  Half as many  swap  I/O  buffer  headers  as  file  I/O
buffers are allocated, but no more than 256.

SSyysstteemm ssiizzee lliimmiittaattiioonnss

     As  distributed,  the  sum of the virtual sizes of the core-
resident processes is limited to 256M bytes.   The  size  of  the
text  segment  of  a  single  process  is currently limited to 6M
bytes.  It may be increased to no greater than the  data  segment
size  limit  (see below) by redefining MAXTSIZ.  This may be done
with  a   configuration   file   option,   e.g.   ooppttiioonnss   MMAAXXTT--
SSIIZZ==""((1100**11002244**11002244))"" to set the limit to 10 million bytes.  Other
per-process limits discussed here may  be  changed  with  similar
options  with  names given in parentheses.  Soft, user-changeable
limits are set to 512K bytes for stack (DFLSSIZ) and 6M bytes for
the  data segment (DFLDSIZ) by default; these may be increased up
to the hard limit with the _s_e_t_r_l_i_m_i_t(2) system  call.   The  data
and stack segment size hard limits are set by a system configura-
tion option to one of 17M, 33M or 64M bytes.  One of these  sizes
is chosen based on the definition of MAXDSIZ; with no option, the
limit   is   17M   bytes;   with   an   option   ooppttiioonnss    MMAAXXDD--
SSIIZZ==""((3322**11002244**11002244))""  (or  any  value  between  17M and 33M), the
limit is increased to 33M  bytes,  and  values  larger  than  33M
result  in  a  limit  of 64M bytes.  You must be careful in doing
this that you have adequate paging space.  As normally configured
,  the  system has 16M or 32M bytes per paging area, depending on
disk size.  The best way to get more space is to  provide  multi-
ple,  thereby  interleaved, paging areas.  Increasing the virtual
memory limits results in interleaving of  swap  space  in  larger
sections (from 500K bytes to 1M or 2M bytes).

     By  default, the virtual memory system allocates enough mem-
ory for system page tables mapping user page tables to allow  256
megabytes  of  simultaneous  active virtual memory.  That is, the
sum of the virtual memory  sizes  of  all  (completely-  or  par-
tially-)  resident  processes  can not exceed this limit.  If the
limit is exceeded, some process(es)  must  be  swapped  out.   To
increase  the  amount of resident virtual space possible, you can
alter the constant USRPTSIZE (in /sys/vax/vmparam.h).  Each  page
of  system page tables allows 8 megabytes of user virtual memory.

     Because the file system block numbers are stored in page ta-
ble  _p_g___b_l_k_n_o  entries, the maximum size of a file system is lim-
ited to 2^24 1024 byte blocks.  Thus no file system can be larger
than 8 gigabytes.

     The  number  of  mountable  file systems is set at 20 by the
definition of NMOUNT in /sys/h/param.h.  This  should  be  suffi-
cient; if not, the value can be increased up to 255.  If you have
many disks, it makes sense to make some of them single file  sys-
tems, and the paging areas don't count in this total.

     The  limit  to  the  number of files that a process may have
open simultaneously is set to 64.   This  limit  is  set  by  the









Command Reference Documents   Building NetBSD Kernels with Config


NOFILE  definition  in /sys/h/param.h.  It may be increased arbi-
trarily, with the caveat that the user  structure  expands  by  5
bytes  for each file, and thus UPAGES (/sys/vax/machparam.h) must
be increased accordingly.

     The amount of physical memory is currently limited to 64  Mb
by  the size of the index fields in the core-map (/sys/h/cmap.h).
The limit may be increased by following instructions in that file
to enlarge those fields.






















































Building NetBSD Kernels with Config   Command Reference Documents


            AAPPPPEENNDDIIXX EE.. NNEETTWWOORRKK CCOONNFFIIGGUURRAATTIIOONN OOPPTTIIOONNSS


     The  network  support  in  the  kernel  is  self-configuring
according to the protocol support options (INET and NS)  and  the
network  hardware discovered during autoconfiguration.  There are
several changes that may be made to  customize  network  behavior
due  to  local  restrictions.   Within the Internet protocol rou-
tines, the following options set in the system configuration file
are supported:

GGAATTEEWWAAYY
     The  machine  is  to be used as a gateway.  This option cur-
     rently makes only minor changes.  First,  the  size  of  the
     network routing hash table is increased.  Secondly, machines
     that have only a single hardware network interface will  not
     forward  IP  packets;  without  this  option, they will also
     refrain from sending any error indication to the  source  of
     unforwardable  packets.   Gateways with only a single inter-
     face are assumed to have missing or broken  interfaces,  and
     will  return  ICMP  unreachable errors to hosts sending them
     packets to be forwarded.

TTCCPP__CCOOMMPPAATT__4422
     This option forces the  system  to  limit  its  initial  TCP
     sequence  numbers to positive numbers.  Without this option,
     4.4BSD systems may have problems  with  TCP  connections  to
     4.2BSD  systems  that  connect but never transfer data.  The
     problem is a bug in the 4.2BSD TCP.

IIPPFFOORRWWAARRDDIINNGG
     Normally, 4.4BSD machines with multiple  network  interfaces
     will  forward  IP  packets received that should be resent to
     another host.  If the line ``options  IPFORWARDING="0"''  is
     in  the system configuration file, IP packet forwarding will
     be disabled.

IIPPSSEENNDDRREEDDIIRREECCTTSS
     When forwarding IP packets,  4.4BSD  IP  will  note  when  a
     packet  is  forwarded  using  the same interface on which it
     arrived.  When this is noted, if the source  machine  is  on
     the  directly-attached  network, an ICMP redirect is sent to
     the source host.  If the packet was forwarded using a  route
     to a host or to a subnet, a host redirect is sent, otherwise
     a network redirect is sent.  The generation of redirects may
     be   inhibited   with  the  configuration  option  ``options
     IPSENDREDIRECTS="0".''

SSUUBBNNEETTSSAARREELLOOCCAALL
     TCP calculates a maximum segment size to use for  each  con-
     nection, and sends no datagrams larger than that size.  This
     size will be no larger than that supported on  the  outgoing
     interface.   Furthermore,  if  the destination is not on the
     local network, the size will be no larger  than  576  bytes.









Command Reference Documents   Building NetBSD Kernels with Config


     For this test, other subnets of a directly-connected subnet-
     ted network are considered  to  be  local  unless  the  line
     ``options  SUBNETSARELOCAL="0"''  is used in the system con-
     figuration file.

The following options are supported by the Xerox NS protocols:

NNSSIIPP
     This option allows NS IDP datagrams to  be  encapsulated  in
     Internet IP packets for transmission to a collaborating NSIP
     host.  This may be used to pass IDP packets through  IP-only
     link layer networks.  See _n_s_i_p(4P) for details.

TTHHRREEEEWWAAYYSSHHAAKKEE
     The  NS  Sequenced Packet Protocol does not require a three-
     way handshake before considering a connection to be  in  the
     established  state.   (A  three-way  handshake consists of a
     connection request, an acknowledgement of the request  along
     with  a symmetrical opening indication, and then an acknowl-
     edgement of the reciprocal  opening  packet.)   This  option
     forces  a three-way handshake before data may be transmitted
     on Sequenced Packet sockets.






































