








            IInnssttaalllliinngg aanndd OOppeerraattiinngg 44..44BBSSDD UUNNIIXX
                        MMaayy 1144,, 11999944


                   _M_a_r_s_h_a_l_l _K_i_r_k _M_c_K_u_s_i_c_k
                        _K_e_i_t_h _B_o_s_t_i_c
                     _M_i_c_h_a_e_l _J_. _K_a_r_e_l_s
                     _S_a_m_u_e_l _J_. _L_e_f_f_l_e_r
              Computer Systems Research Group
 Department of Electrical Engineering and Computer Science
             University of California, Berkeley
                Berkeley, California  94720
                       (415) 642-7780

                        _M_i_k_e _H_i_b_l_e_r
                Center for Software Science
               Department of Computer Science
                     University of Utah
                Salt Lake City, Utah  84112
                       (801) 581-5017


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

          This  document  contains instructions for the
     installation and operation of the  4.4BSD  release
     of  UNIX as distributed by The University of Cali-
     fornia at Berkeley.

          It discusses procedures for  installing  UNIX
     on  a  new  machine, and for upgrading an existing
     4.3BSD UNIX system to the new release.  An  expla-
     nation  of how to lay out filesystems on available
     disks and the space requirements for various parts
     of  the system are given.  A brief overview of the
     major changes to the  system  between  4.3BSD  and
     4.4BSD are outlined.  An explanation of how to set
     up terminal lines and user accounts, and how to do
     system-specific tailoring is provided.  A descrip-
     tion of how to install and  configure  the  4.4BSD
     networking  facilities  is included.  Finally, the
     document  details  system  operation   procedures:
     shutdown  and  startup,  filesystem  backup proce-
     dures, resource control,  performance  monitoring,
     and  procedures  for  recompiling and reinstalling
     system software.














SMM:1-4                 Installing and Operating 4.4BSD UNIX


11..  IInnttrroodduuccttiioonn
     This document explains how to install the 4.4BSD Berke-
ley  version  of UNIX on your system.  The filesystem format
is compatible with 4.3BSD and it will only be necessary  for
you  to  do a full bootstrap procedure if you are installing
the release on a new machine.  The object file  formats  are
completely  different from the System V release, so the most
straightforward procedure for upgrading a System V system is
to do a full bootstrap.
     The  full bootstrap procedure is outlined in section 2;
the process starts with copying a filesystem  image  onto  a
new  disk.   This  filesystem  is  then  booted  and used to
extract the remainder of the  system  binaries  and  sources
from the archives on the tape(s).
     The   technique   for  upgrading  a  4.3BSD  system  is
described in section 3 of this document.  The upgrade proce-
dure  involves  extracting system binaries onto new root and
/usr filesystems and merging local configuration files  into
the  new system.  User filesystems may be upgraded in place.
Most 4.3BSD binaries may be used with 4.4BSD in  the  course
of  the  conversion.   It  is  desirable  to recompile local
sources after the conversion, as the new compiler (GCC) pro-
vides superior code optimization.  Consult section 3.5 for a
description of some of the differences  between  4.3BSD  and
4.4BSD.

11..11..  DDiissttrriibbuuttiioonn ffoorrmmaatt
     The distribution comes in two formats:

     (3)   6250bpi 2400' 9-track magnetic tapes, or
     (1)   8mm Exabyte tape

     If you have the facilities, we ssttrroonnggllyy recommend copy-
ing the magnetic tape(s) in the distribution  kit  to  guard
against  disaster.   The  tapes  contain 10240-byte records.
There are interspersed tape marks; end-of-tape  is  signaled
by  a  double  end-of-file.   The  first file on the tape is
architecture dependent.  Additional  files  on  the  tape(s)
contain  tape  archive  images  of  the  system binaries and
sources (see _t_a_r(1)1).  See the tape label for a description
of the contents and format of each individual tape.

11..22..  UUNNIIXX ddeevviiccee nnaammiinngg
     Device  names  have  a  different  syntax  depending on
whether you are talking to the standalone system or  a  run-
ning UNIX kernel.  The standalone system syntax is currently
architecture dependent  and  is  described  in  the  various
architecture specific sections as applicable.  When not run-
ning standalone, devices are  available  via  files  in  the
/dev/ directory.  The file name typically encodes the device
-----------
  1 References of the form  _X(Y)  mean  the  entry
named  _X  in  section Y of the ``UNIX Programmer's
Manual''.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                 SMM:1-5


type, its logical unit and a  partition  within  that  unit.
For  example,  /dev/sd2b  refers  to  the  second  partition
(``b'') of SCSI (``sd'') drive number ``2'', while /dev/rmt0
refers to the raw (``r'') interface of 9-track tape (``mt'')
unit ``0''.
     The mapping of physical  addressing  information  (e.g.
controller, target) to a logical unit number is dependent on
the system configuration.  In all simple cases, where only a
single  controller  is  present,  a drive with physical unit
number 0 (e.g., as determined  by  its  unit  specification,
either  unit  plug  or  other  selection  mechanism) will be
called unit 0 in its UNIX file name.  This is not,  however,
strictly necessary, since the system has a level of indirec-
tion in this naming.  If there are multiple controllers, the
disk  unit  numbers  will  normally  be counted sequentially
across controllers.  This can be taken advantage of to  make
the  system less dependent on the interconnect topology, and
to make reconfiguration after hardware failure easier.
     Each UNIX physical disk is divided into at most 8 logi-
cal  disk  partitions, each of which may occupy any consecu-
tive cylinder range on the physical device.   The  cylinders
occupied  by the 8 partitions for each drive type are speci-
fied initially in the  disk  description  file  /etc/disktab
(c.f.   _d_i_s_k_t_a_b(5)).  The partition information and descrip-
tion of the drive geometry are written in one of  the  first
sectors  of  each  disk with the _d_i_s_k_l_a_b_e_l(8) program.  Each
partition may be used for either a raw data area such  as  a
paging  area  or  to store a UNIX filesystem.  It is conven-
tional for the first partition on a disk to be used to store
a root filesystem, from which UNIX may be bootstrapped.  The
second partition is traditionally used as a paging area, and
the  rest  of the disk is divided into spaces for additional
``mounted filesystems'' by use of  one  or  more  additional
partitions.

11..33..  UUNNIIXX ddeevviicceess:: bblloocckk aanndd rraaww
     UNIX  makes a distinction between ``block'' and ``raw''
(character) devices.  Each disk has a block device interface
where  the  system makes the device byte addressable and you
can write a single byte in the middle of the disk.  The sys-
tem  will read out the data from the disk sector, insert the
byte you gave it and put the modified data back.  The  disks
with  the  names  /dev/xx0[a-h],  etc.,  are  block devices.
There are also raw devices available.  These have names like
/dev/rxx0[a-h],  the  ``r''  here standing for ``raw''.  Raw
devices bypass the buffer cache and use DMA directly to/from
the  program's  I/O buffers; they are normally restricted to
full-sector transfers.  In the bootstrap procedures we  will
often  suggest  using the raw devices, because these tend to
work faster.  Raw devices are used when making new  filesys-
tems,  when  checking  unmounted filesystems, or for copying
quiescent filesystems.  The block devices are used to  mount
filesystems.




                        May 14, 1994





SMM:1-6                 Installing and Operating 4.4BSD UNIX


     You  should  be  aware  that  it is sometimes important
whether to use the character device (for efficiency) or  not
(because  it  would not work, e.g. to write a single byte in
the middle of a sector).  Do not change the instructions  by
using the wrong type of device indiscriminately.

22..  BBoooottssttrraapp pprroocceedduurree
     This  section explains the bootstrap procedure that can
be used to get the kernel supplied  with  this  distribution
running  on  your machine.  If you are not currently running
4.3BSD you will have to do  a  full  bootstrap.   Section  3
describes  how to upgrade a 4.3BSD system.  An understanding
of the operations used in a full  bootstrap  is  helpful  in
doing  an  upgrade  as  well.   In either case, it is highly
desirable to read and understand the remainder of this docu-
ment before proceeding.
     The  distribution  supports  a  somewhat  wider  set of
machines than those for which we have built  binaries.   The
architectures   that  are  supported  only  in  source  form
include:
+o    Intel 386/486-based machines (ISA/AT or EISA bus only)
+o    Sony News MIPS-based workstations
+o    Omron Luna 68000-based workstations
If you wish to run one of these architectures, you will have
to  build  a  cross  compilation environment.  Note that the
distribution does nnoott include the machine  support  for  the
Tahoe  and VAX architectures found in previous BSD distribu-
tions.   Our  primary   development   environment   is   the
HP9000/300  series  machines.   The  other architectures are
developed and supported by people  outside  the  university.
Consequently,  we  are not able to directly test or maintain
these  other  architectures,  so  cannot  comment  on  their
robustness, reliability, or completeness.

22..11..  BBoooottssttrraappppiinngg ffrroomm tthhee ttaappee
The set of files on the distribution tape are as follows:
1)   A   _d_d(1)  (HP300),  _t_a_r(1)  (DECstation),  or  _d_u_m_p(8)
     (SPARC) image of the root filesystem
2)   A _t_a_r image of the /var filesystem
3)   A _t_a_r image of the /usr filesystem
4)   A _t_a_r image of /usr/src/sys
5)   A _t_a_r image of /usr/src except sys and contrib
6)   A _t_a_r image of /usr/src/contrib
7)   (8mm Exabyte tape distributions only) A  _t_a_r  image  of
     /usr/src/X11R5
The tape bootstrap procedure used to create a working system
involves the following major steps:
1)   Transfer a bootable root filesystem from the tape to  a
     disk and get it booted and running.
2)   Build  and  restore  the /var and /usr filesystems from
     tape with _t_a_r(1).
3)   Extract the system and utility source files as desired.
     The  following  sections  describe  the  above steps in
detail.   The  details  of  the  first  step  vary   between



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                 SMM:1-7


architectures.  The specific steps for the HP300, SPARC, and
DECstation are given in  the  next  three  sections  respec-
tively.  You should follow the instructions for your partic-
ular  architecture.   In  all  sections,  commands  you  are
expected  to  type are shown in italics, while that informa-
tion printed by the system is shown emboldened.

22..22..  BBoooottiinngg tthhee HHPP330000

22..22..11..  SSuuppppoorrtteedd hhaarrddwwaarree
The hardware supported by 4.4BSD for  the  HP300/400  is  as
follows:

  +------------------------------------------------------+
  |CPU's        68020  based  (318,  319,  320,  330 and |
  |             350), 68030 based (340, 345,  360,  370, |
  |             375,  400)  and  68040  based (380, 425, |
  |             433).                                    |
  +------------------------------------------------------+
  |DISK's       HP-IB/CS80  (7912,  7914,  7933,   7936, |
  |             7945,  7957, 7958, 7959, 2200, 2203) and |
  |             SCSI-I (including magneto-optical).      |
  +------------------------------------------------------+
  |TAPE's       Low-density CS80 cartridge (7914,  7946, |
  |             9144),   high-density   CS80   cartridge |
  |             (9145), HP SCSI DAT and SCSI Exabyte.    |
  +------------------------------------------------------+
  |RS232        98644 built-in single-port, 98642 4-port |
  |             and 98638 8-port interfaces.             |
  +------------------------------------------------------+
  |NETWORK      98643 internal and external LAN cards.   |
  +------------------------------------------------------+
  |GRAPHICS     Terminal  emulation and raw frame buffer |
  |             support for 98544 / 98545 / 98547  (Top- |
  |             cat color & monochrome), 98548 / 98549 / |
  |             98550  (Catseye  color  &   monochrome), |
  |             98700  / 98710 (Gatorbox), 98720 / 98721 |
  |             (Renaissance), 98730 /  98731  (DaVinci) |
  |             and A1096A (Hyperion monochrome).        |
  +------------------------------------------------------+
  |INPUT        General  interface  supporting  all  HIL |
  |             devices.  (e.g. keyboard, 2 and 3 button |
  |             mice, ID module, ...)                    |
  +------------------------------------------------------+
  |MISC         Battery-backed  real time clock, builtin |
  |             and 98625A/B HP-IB  interfaces,  builtin |
  |             and   98658A   SCSI  interfaces,  serial |
  |             printers and plotters on HP-IB, and SCSI |
  |             autochanger device.                      |
  +------------------------------------------------------+
Major  items  that are not supported include the 310 and 332
CPU's, 400 series machines configured  for  Domain/OS,  EISA
and  VME bus adaptors, audio, the centronics port, 1/2" tape
drives  (7980),  CD-ROM,  and  the  PVRX/TVRX  3D   graphics



                        May 14, 1994





SMM:1-8                 Installing and Operating 4.4BSD UNIX


displays.

22..22..22..  SSttaannddaalloonnee ddeevviiccee ffiillee nnaammiinngg
The  standalone system device name syntax on the HP300 is of
the form:

     xx(a,c,u,p)

where _x_x is the device type, _a specifies the adaptor to use,
_c the controller, _u the unit, and _p a partition.  The _d_e_v_i_c_e
_t_y_p_e differentiates the various disks and tapes and  is  one
of:  ``rd'' for HP-IB CS80 disks, ``ct'' for HP-IB CS80 car-
tridge tapes, or ``sd'' for SCSI-I disks (SCSI-I  tapes  are
currently  not  supported).   The _a_d_a_p_t_o_r field is a logical
HP-IB or SCSI bus adaptor card number.  This will  typically
be  0  for  SCSI  disks, 0 for devices on the ``slow'' HP-IB
interface (usually tapes) and 1 for devices on the  ``fast''
HP-IB  interface (usually disks).  To get a complete mapping
of physical (select-code) to logical card numbers just  type
a  ^C at the standalone prompt.  The _c_o_n_t_r_o_l_l_e_r field is the
disk or tape's target number on the HP-IB or SCSI bus.   For
SCSI  the range is 0 to 6 (7 is the adaptor address) and for
HP-IB the range is 0 to 7.  The _u_n_i_t  field  is  unused  and
should be 0.  The _p_a_r_t_i_t_i_o_n field is interpreted differently
for tapes and disks: for disks it is a  disk  partition  (in
the  range 0-7), and for tapes it is a file number offset on
the tape.  Thus, partition 2 of a SCSI disk drive at  target
3  on SCSI bus 1 would be ``sd(1,3,0,2)''.  If you have only
one of any type bus adaptor, you may omit  the  adaptor  and
controller  numbers;  e.g. ``sd(0,2)'' could be used instead
of ``sd(0,0,0,2)''.  The following examples always  use  the
full syntax for clarity.

22..22..33..  TThhee pprroocceedduurree
The  basic  steps  involved  in bringing up the HP300 are as
follows:
1)   Obtain a second disk and format it, if necessary.
2)   Copy a root filesystem from the tape onto the beginning
     of the disk.
3)   Boot the UNIX system on the new disk.
4)   (Optional)  Build  a root filesystem optimized for your
     disk.
5)   Label the disks with the _d_i_s_k_l_a_b_e_l(8) program.

22..22..33..11..  SStteepp 11:: sseelleeccttiinngg aanndd ffoorrmmaattttiinngg aa ddiisskk
     For your first system you will have to obtain a format-
ted  disk of a type given in the ``supported hardware'' list
above.  If you want to load an entire binary  system  (i.e.,
everything  except  /usr/src),  on  the single disk you will
need a minimum of 290MB, ruling out anything smaller than  a
7959B/S  disk.  The disklabel included in the bootstrap root
image is laid out to accommodate this scenario.   Note  that
an  HP  SCSI  magneto-optical  disk  will work fine for this
case.  4.4BSD will boot and run (albeit slowly)  using  one.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                 SMM:1-9


If you want to load source on a single disk system, you will
need at least 640MB (at least a 2213A SCSI  or  2203A  HP-IB
disk).   A disk as small as the 7945A (54MB) can be used for
the bootstrap procedure but will hold only the root and pri-
mary  swap  partitions.   If you plan to use multiple disks,
refer to section 2.5 for suggestions on partitioning.
     After selecting a disk, you  may  need  to  format  it.
Since most HP disk drives come pre-formatted (except optical
media) you probably will not, but if necessary, you can for-
mat  a  disk  under  HP-UX  using the _m_e_d_i_a_i_n_i_t(1m) program.
Once you have 4.4BSD up and running on one machine  you  can
use  the  _s_c_s_i_f_o_r_m_a_t(8)  program  to  format additional SCSI
disks.  Any additional HP-IB disks will have to be formatted
using HP-UX.

22..22..33..22..   SStteepp  22:: ccooppyyiinngg tthhee rroooott ffiilleessyysstteemm ffrroomm ttaappee ttoo
ddiisskk
     Once  you  have a formatted second disk you can use the
_d_d(1) command under HP-UX to copy the root filesystem  image
from  the  tape  to  the  beginning of the second disk.  For
HP's, the root filesystem image is the  first  file  on  the
tape.   It includes a disklabel and bootblock along with the
root filesystem.  An example command to copy the image  from
tape to the beginning of a disk is:

     dd if=/dev/rmt/0m of=/dev/rdsk/1s0 bs=20b

The  actual  special  file syntax may vary depending on unit
numbers and the version of HP-UX that is  running.   Consult
the HP-UX _m_t(7) and _d_i_s_k(7) man pages for details.
     Note  that if you have a SCSI disk, you don't necessar-
ily have to use HP-UX (or an HP) to create  the  boot  disk.
Any machine and operating system that will allow you to copy
the raw disk image out to block 0 of the disk will do.
     If you have only a single machine with a  single  disk,
you may still be able to install and boot 4.4BSD if you have
an HP-IB cartridge tape drive.  If so, you can  use  a  more
difficult approach of booting a standalone copy program from
the tape, and using that to copy the root  filesystem  image
from  the tape to the disk.  To do this, you need to extract
the first file of the distribution tape  (the  root  image),
copy  it  over  to a machine with a cartridge drive and then
copy the image onto tape.  For example:

     dd if=/dev/rst0 of=bootimage bs=20b
     rcp bootimage foo:/tmp/bootimage
     <login to foo>
     dd if=/tmp/bootimage of=/dev/rct/0m bs=20b

Once this tape is created you can boot and  run  the  stand-
alone tape copy program from it.  The copy program is loaded
just as any other program would be loaded by the bootrom  in
``attended''  mode:  reset  the CPU, hold down the space bar
until  the  word  ``Keyboard''  appears  in  the   installed



                        May 14, 1994





SMM:1-10                Installing and Operating 4.4BSD UNIX


interface  list, and enter the menu selection for SYS_TCOPY.
Once loaded and running:


     FFrroomm:: _^_C                              (control-C to see logical adaptor assignments)
     hhppiibb00 aatt sscc77
     ssccssii00 aatt sscc1144
     FFrroomm:: _c_t_(_0_,_7_,_0_,_0_)                     (HP-IB tape, target 7, first tape file)
     TToo:: _s_d_(_0_,_0_,_0_,_2_)                       (SCSI disk, target 0, third partition)
     CCooppyy ccoommpplleetteedd:: 11772288 rreeccoorrddss ccooppiieedd


This copy will likely take 30 minutes or more.

22..22..33..33..  SStteepp 33:: bboooottiinngg tthhee rroooott ffiilleessyysstteemm
     You now have a bootable root filesystem  on  the  disk.
If  you  were previously running with two disks, it would be
best if you shut down the machine and turn off power on  the
HP-UX  drive.   It will be less confusing and it will elimi-
nate any chance of accidentally destroying the  HP-UX  disk.
If  you  used  a  cartridge tape for booting you should also
unload the tape at this point.  Whether you booted from tape
or copied from disk you should now reboot the machine and do
another attended boot (see previous section), this time with
SYS_TBOOT.   Once  loaded  and running the boot program will
display the CPU type and prompt for a kernel file to boot:

     HHPP443333 CCPPUU
     BBoooott
     :: _/_v_m_u_n_i_x

After providing the  kernel  name,  the  machine  will  boot
4.4BSD with output that looks about like this:

     559977448800++3344112200++113399228888 ssttaarrtt 00xxffee88001199eecc
     CCooppyyrriigghhtt ((cc)) 11998822,, 11998866,, 11998899,, 11999911,, 11999933
          TThhee RReeggeennttss ooff tthhee UUnniivveerrssiittyy ooff CCaalliiffoorrnniiaa..
     CCooppyyrriigghhtt ((cc)) 11999922 HHeewwlleetttt--PPaacckkaarrdd CCoommppaannyy
     CCooppyyrriigghhtt ((cc)) 11999922 MMoottoorroollaa IInncc..
     AAllll rriigghhttss rreesseerrvveedd..

     44..44BBSSDD UUNNIIXX ##11:: TTuuee JJuull 2200 1111::4400::3366 PPDDTT 11999933
         mmcckkuussiicckk@@vvaannggoogghh..CCSS..BBeerrkkeelleeyy..EEDDUU:://uussrr//oobbjj//ssyyss//ccoommppiillee//GGEENNEERRIICC..hhpp330000
     HHPP99000000//443333 ((3333MMHHzz MMCC6688004400 CCPPUU++MMMMUU++FFPPUU,, 44kk oonn--cchhiipp pphhyyssiiccaall II//DD ccaacchheess))
     rreeaall mmeemm == xxxxxx
     aavvaaiill mmeemm == ######
     uussiinngg ###### bbuuffffeerrss ccoonnttaaiinniinngg ###### bbyytteess ooff mmeemmoorryy
     ((...... iinnffoorrmmaattiioonn aabboouutt aavvaaiillaabbllee ddeevviicceess ......))
     rroooott ddeevviiccee??

     The  first  three  numbers are printed out by the boot-
strap program and are the sizes of different  parts  of  the
system (text, initialized and uninitialized data).  The sys-
tem also allocates several system data structures  after  it



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-11


starts  running.  The sizes of these structures are based on
the amount of available memory  and  the  maximum  count  of
active users expected, as declared in a system configuration
description.  This will be discussed later.
     UNIX itself then runs for the first time and begins  by
printing out a banner identifying the release and version of
the system that is in use and the date that it was compiled.
     Next  the  _m_e_m messages give the amount of real (physi-
cal) memory and the memory available  to  user  programs  in
bytes.   For example, if your machine has 16Mb bytes of mem-
ory, then xxxxxx will be 16777216.
     The messages that come out next show what devices  were
found   on   the  current  processor.   These  messages  are
described in _a_u_t_o_c_o_n_f(4).  The distributed  system  may  not
have  found  all  the communications devices you have or all
the mass storage peripherals you  have,  especially  if  you
have  more than two of anything.  You will correct this when
you create a description of your machine from which to  con-
figure  a  site-dependent  version  of  UNIX.   The messages
printed at boot here contain much of  the  information  that
will  be used in creating the configuration.  In a correctly
configured system most of the  information  present  in  the
configuration description is printed out at boot time as the
system verifies that each device is present.
     The ``root device?'' prompt was printed by  the  system
to ask you for the name of the root filesystem to use.  This
happens because the distribution system is a _g_e_n_e_r_i_c system,
i.e.,  it  can be bootstrapped on a CPU with its root device
and paging area on any available disk drive.  You will  most
likely  respond  to the root device question with ``sd0'' if
you are booting from a SCSI disk, or with ``rd0'' if you are
booting  from  an  HP-IB disk.  This response shows that the
disk it is running on is drive 0 of type  ``sd''  or  ``rd''
respectively.   If you have other disks attached to the sys-
tem, it is possible that the drive you are using will not be
configured  as logical drive 0.  Check the autoconfiguration
messages printed out by the kernel to make sure.  These mes-
sages  will  show  the type of every logical drive and their
associated controller and slave addresses.  You  will  later
build  a system tailored to your configuration that will not
prompt you for a root device when it is bootstrapped.

     rroooott ddeevviiccee?? _s_d_0
     WWAARRNNIINNGG:: pprreeppoosstteerroouuss ttiimmee iinn ffiilleessyysstteemm ---- CCHHEECCKK AANNDD RREESSEETT TTHHEE DDAATTEE!!
     eerraassee ^^??,, kkiillll ^^UU,, iinnttrr ^^CC
     ##

     The ``erase ...'' message is part of the /.profile that
was  executed  by the root shell when it started.  This mes-
sage tells you about the settings of  the  character  erase,
line erase, and interrupt characters.
     UNIX  is  now running, and the _U_N_I_X _P_r_o_g_r_a_m_m_e_r_'_s _M_a_n_u_a_l
applies.  The ``#'' is the prompt from the Bourne shell, and
lets  you know that you are the super-user, whose login name



                        May 14, 1994





SMM:1-12                Installing and Operating 4.4BSD UNIX


is ``root''.
     At this point, the root  filesystem  is  mounted  read-
only.   Before  continuing  the installation, the filesystem
needs to be ``updated'' to allow writing and device  special
files  for  the following steps need to be created.  This is
done as follows:


     ## _m_o_u_n_t___m_f_s _-_s _1_0_0_0 _-_T _t_y_p_e _/_d_e_v_/_n_u_l_l _/_t_m_p                (create a writable filesystem)
     (_t_y_p_e is the disk type as determined from /etc/disktab)
     ## _c_d _/_t_m_p                                                 (connect to that directory)
     ## _._._/_d_e_v_/_M_A_K_E_D_E_V _s_d_#                                      (create special files for root disk)
     (_s_d is the disk type, _# is the unit number)
     (ignore warning from ``sh'')
     ## _m_o_u_n_t _-_u_w _/_t_m_p_/_s_d_#_a _/                                   (read-write mount root filesystem)
     ## _c_d _/_d_e_v                                                 (go to device directory)
     ## _._/_M_A_K_E_D_E_V _s_d_#                                           (create permanent special files for root disk)
     (again, ignore warning from ``sh'')



22..22..33..44..  SStteepp 44:: ((ooppttiioonnaall)) rreessttoorriinngg tthhee rroooott ffiilleessyysstteemm
     The  root  filesystem that you are currently running on
is complete, however it probably is not optimally  laid  out
for  the  disk  on  which  you  are running.  If you will be
cloning copies of the system onto multiple disks  for  other
machines,  you  are advised to connect one of these disks to
this machine, and build and restore a properly laid out root
filesystem  onto  it.   If this is the only machine on which
you will be running 4.4BSD or peak  performance  is  not  an
issue,  you  can skip this step and proceed directly to step
5.
     Connect a second disk to your machine.   If  you  boot-
strapped  using  the two disk method, you can overwrite your
initial HP-UX disk, as it will no longer be needed (assuming
you have no plans to run HP-UX again).
     To  really  create  the  root filesystem on drive 1 you
should first label the disk as described in  step  5  below.
Then run the following commands:

     ## _c_d _/_d_e_v
     ## _._/_M_A_K_E_D_E_V _s_d_1_a
     ##_n_e_w_f_s _/_d_e_v_/_r_s_d_1_a
     ##_m_o_u_n_t _/_d_e_v_/_s_d_1_a _/_m_n_t
     ##_c_d _/_m_n_t
     ##_d_u_m_p _0_f _- _/_d_e_v_/_r_s_d_0_a _| _r_e_s_t_o_r_e _x_f _-
     (Note: restore will ask if you want to ``set owner/mode for '.'''
     to which you should reply ``yes''.)

     When this completes, you should then shut down the sys-
tem, and boot on the disk that you  just  created  following
the procedure in step (3) above.





                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-13


22..22..33..55..  SStteepp 55:: ppllaacciinngg llaabbeellss oonn tthhee ddiisskkss
     For  each  disk on the HP300, 4.4BSD places information
about the geometry of the drive and the partition layout  at
byte  offset 1024.  This information is written with _d_i_s_k_l_a_-
_b_e_l(8).
     The root image just loaded includes a ``generic'' label
intended to allow easy installation of the root and /usr and
may not be suitable for the actual  disk  on  which  it  was
installed.   In  particular,  it  may  make your disk appear
larger or smaller than its real size.  In the  former  case,
you  lose  some capacity.  In the latter, some of the parti-
tions may map non-existent  sectors  leading  to  errors  if
those  partitions  are  used.   It is also possible that the
defined geometry will interact poorly  with  the  filesystem
code  resulting in reduced performance.  However, as long as
you are willing to give up a little space, not  use  certain
partitions  or  suffer  minor  performance  degradation, you
might want to avoid this step; especially if you do not know
how to use _e_d(1).
     If  you choose to edit this label, you can fill in cor-
rect geometry information from /etc/disktab.  You  may  also
want to rework the ``e'' and ``f'' partitions used for load-
ing /usr and /var.  You should not attempt to, and _d_i_s_k_l_a_b_e_l
will  not  let you, modify the ``a'', ``b'' and ``d'' parti-
tions.  To edit a label:

     ## _E_D_I_T_O_R_=_e_d
     ## _e_x_p_o_r_t _E_D_I_T_O_R
     ## _d_i_s_k_l_a_b_e_l  _-_r  _-_e  _/_d_e_v_/_rXXXX##_d

where XXXX is the type and ## is the logical drive number; e.g.
/dev/rsd0d  or  /dev/rrd0d.   Note  the  explicit use of the
``d'' partition.  This partition includes the  bootblock  as
does  ``c''  and  using  it allows you to change the size of
``c''.
     If you wish to label any additional disks, run the fol-
lowing command for each:

     ##_d_i_s_k_l_a_b_e_l  _-_r_w  XXXX##  ttyyppee  _"_o_p_t_i_o_n_a_l___p_a_c_k___n_a_m_e_"

where XXXX## is the same as in the previous command and ttyyppee is
the HP300 disk device name as listed in  /etc/disktab.   The
optional  information  may  contain any descriptive name for
the contents of a disk, and may be up to 16 characters long.
This  procedure  will  place the label on the disk using the
information found in /etc/disktab for the disk  type  named.
If  you  have changed the disk partition sizes, you may wish
to add entries for the modified configuration in  /etc/disk-
tab before labeling the affected disks.
     You  have  now completed the HP300 specific part of the
installation.  Now  proceed  to  the  generic  part  of  the
installation  described starting in section 2.5 below.  Note
that where the disk name ``sd'' is used  throughout  section
2.5,  you  should  substitute  the  name  ``rd''  if you are



                        May 14, 1994





SMM:1-14                Installing and Operating 4.4BSD UNIX


running on an HP-IB disk.  Also, if you  are  loading  on  a
single  disk  with  the  default  disklabel,  /var should be
restored to the ``f'' partition and /usr to the ``e'' parti-
tion.

22..33..  BBoooottiinngg tthhee SSPPAARRCC

22..33..11..  SSuuppppoorrtteedd hhaarrddwwaarree
The  hardware  supported  by 4.4BSD for the SPARC is as fol-
lows:

  +------------------------------------------------------+
  |CPU's        SPARCstation 1 series (1, 1+, SLC,  IPC) |
  |             and SPARCstation 2 series (2, IPX).      |
  +------------------------------------------------------+
  |DISK's       SCSI.                                    |
  +------------------------------------------------------+
  |TAPE's       none.                                    |
  +------------------------------------------------------+
  |NETWORK      SPARCstation Lance (le).                 |
  +------------------------------------------------------+
  |GRAPHICS     bwtwo, cgthree, and the GX (cgsix).      |
  +------------------------------------------------------+
  |INPUT        Keyboard and mouse.                      |
  +------------------------------------------------------+
  |MISC         Battery-backed real time clock, built-in |
  |             serial devices,  Sbus  SCSI  controller, |
  |             and audio device.                        |
  +------------------------------------------------------+
Major  items  that  are  not supported include anything VME-
based, the floppy disk, and SCSI tapes.

22..33..22..  LLiimmiittaattiioonnss
There are several important limitations on the  4.4BSD  dis-
tribution for the SPARC:
1)   You  mmuusstt  have  SunOS  4.1.x  or  Solaris  to bring up
     4.4BSD.  There is no  SPARCstation  bootstrap  code  in
     this  distribution.   The Sun-supplied boot loader will
     be used to boot 4.4BSD; you must copy  this  from  your
     SunOS  distribution.  This imposes several restrictions
     on the system, as detailed below.
2)   The 4.4BSD SPARC kernel does not  remap  SCSI  IDs.   A
     SCSI  disk  at  target  0 will become ``sd0'', where in
     SunOS the same disk will normally  be  called  ``sd3''.
     If  your  existing  SunOS system is diskful, it will be
     least painful to have SunOS running on the disk on tar-
     get  3 lun 0 and put 4.4BSD on the disk on target 0 lun
     0.  Both systems will then think they  are  running  on
     ``sd0'',  and you can boot either system as needed sim-
     ply by changing the EEPROM's boot device.
3)   There is no SCSI tape driver.  You  must  have  another
     system for tape reading and backups.
4)   Although  the  4.4BSD SPARC kernel will handle existing
     SunOS shared libraries, it does not use or create  them



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-15


     itself,  and  therefore  requires  much more disk space
     than SunOS does.
5)   It is currently difficult (though not completely impos-
     sible)  to  run  4.4BSD  diskless.   These instructions
     assume you will have  a  local  boot,  swap,  and  root
     filesystem.
6)   When using a serial port rather than a graphics display
     as the console, only port ttya can be  used.   Attempts
     to  use  port  ttyb  will fail when the kernel tries to
     print the boot up messages to the console.

22..33..33..  TThhee pprroocceedduurree
     You must have a spare disk on which  to  place  4.4BSD.
The  steps  involved  in bootstrapping this tape are as fol-
lows:
1)   Bring up SunOS (preferably SunOS 4.1.x or Solaris  1.x,
     although Solaris 2 may work -- this is untested).
2)   Attach  auxiliary SCSI disk(s).  Format and label using
     the SunOS formatting and labeling programs  as  needed.
     Note  that  the  root  filesystem currently requires at
     least 10 MB; 16 MB or more is recommended.  The b  par-
     tition  will  be used for swap; this should be at least
     32 MB.
3)   Use the SunOS _n_e_w_f_s to build the root filesystem.   You
     may  also  want  to build other filesystems at the same
     time.  (By default, the 4.4BSD _n_e_w_f_s builds a  filesys-
     tem  that  SunOS will not handle; if you plan to switch
     OSes back and forth you may want to sacrifice the  per-
     formance  gain  from the new filesystem format for com-
     patibility.)  You can build an old-format filesystem on
     4.4BSD  by  giving  the -O option to _n_e_w_f_s(8).  _F_s_c_k(8)
     can  convert  old  format  filesystems  to  new  format
     filesystems,  but  not  vice  versa, so you may want to
     initially build old format filesystems so that they can
     be  mounted under SunOS, and then later convert them to
     new format filesystems  when  you  are  satisfied  that
     4.4BSD  is  running  properly.   In  any case, yyoouu mmuusstt
     bbuuiilldd aann oolldd--ssttyyllee rroooott ffiilleessyysstteemm so  that  the  SunOS
     boot program will work.
4)   Mount  the  new  root,  then  copy the SunOS /boot into
     place and use  the  SunOS  ``installboot''  program  to
     enable  disk-based  booting.   Note that the filesystem
     must be mounted when you do the ``installboot'':

          # mount /dev/sd3a /mnt
          # cp /boot /mnt/boot
          # cd /usr/kvm/mdec
          # installboot /mnt/boot bootsd /dev/rsd3a

     The SunOS /boot will load 4.4BSD kernels; there  is  no
     SPARCstation  bootstrap code on the distribution.  Note
     that the SunOS /boot does not  handle  the  new  4.4BSD
     filesystem format.




                        May 14, 1994





SMM:1-16                Installing and Operating 4.4BSD UNIX


5)   Restore the contents of the 4.4BSD root filesystem.

          # cd /mnt
          # rrestore xf tapehost:/dev/nrst0

6)   Boot the supplied kernel:

          # halt
          ok boot sd(0,3)vmunix -s      [for old proms] OR
          ok boot disk3 -s              [for new proms]
          ... [4.4BSD boot messages]

To  install  the  remaining  filesystems,  use the procedure
described starting in section 2.5.  In  these  instructions,
/usr  should  be loaded into the ``e'' partition and /var in
the ``f'' partition.
After completing the filesystem installation you may want to
set up 4.4BSD to reboot automatically:

     # halt
     ok setenv boot-from sd(0,3)vmunix  [for old proms] OR
     ok setenv boot-device disk3        [for new proms]

If  you  build backwards-compatible filesystems, either with
the SunOS newfs or with the 4.4BSD ``-O''  option,  you  can
mount  these  under  SunOS.   The  SunOS fsck will, however,
always think that these filesystems are corrupted, as  there
are  several  new (previously unused) superblock fields that
are updated in 4.4BSD.  Running ``fsck -b32'' and letting it
``fix'' the superblock will take care of this.
If  you  wish  to  run  SunOS binaries that use SunOS shared
libraries, you simply need to copy all  the  dynamic  linker
files from an existing SunOS system:

     # rcp sunos-host:/etc/ld.so.cache /etc/
     # rcp sunos-host:'/usr/lib/*.so*' /usr/lib/

The  SunOS  compiler  and  linker  should be able to produce
SunOS binaries under 4.4BSD, but this has not  been  tested.
If  you  plan  to  try  it you will need the appropriate .sa
files as well.

22..44..  BBoooottiinngg tthhee DDEECCssttaattiioonn

22..44..11..  SSuuppppoorrtteedd hhaarrddwwaarree
The hardware supported by 4.4BSD for the  DECstation  is  as
follows:










                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-17


  +------------------------------------------------------+
  |CPU's        R2000   based  (3100)  and  R3000  based |
  |             (5000/200, 5000/20, 5000/25,  5000/1xx). |
  +------------------------------------------------------+
  |DISK's       SCSI-I  (tested RZ23, RZ55, RZ57, Maxtor |
  |             8760S).                                  |
  +------------------------------------------------------+
  |TAPE's       SCSI-I (tested DEC  TK50,  Archive  DAT, |
  |             Emulex MT02).                            |
  +------------------------------------------------------+
  |RS232        Internal  DEC  dc7085 and AMD 8530 based |
  |             interfaces.                              |
  +------------------------------------------------------+
  |NETWORK      TURBOchannel PMAD-AA and internal  LANCE |
  |             based interfaces.                        |
  +------------------------------------------------------+
  |GRAPHICS     Terminal  emulation and raw frame buffer |
  |             support for 3100 (color  &  monochrome), |
  |             TURBOchannel  PMAG-AA, PMAG-BA, PMAG-DV. |
  +------------------------------------------------------+
  |INPUT        Standard DEC keyboard (LK201) and mouse. |
  +------------------------------------------------------+
  |MISC         Battery-backed real time clock, internal |
  |             and  TURBOchannel  PMAZ-AA  SCSI  inter- |
  |             faces.                                   |
  +------------------------------------------------------+
Major  items  that  are  not  supported include the 5000/240
(there is code but not compiled in or tested),  R4000  based
machines,  FDDI and audio interfaces.  Diskless machines are
not supported but booting kernels and bootstrapping over the
network is supported on the 5000 series.

22..44..22..  TThhee pprroocceedduurree
     The  first  file on the distribution tape is a tar file
that contains four files.  The first step requires a running
UNIX  (or ULTRIX) system that can be used to extract the tar
archive from the first file on the tape.  The command:

     tar xf /dev/rmt0

will extract the following four files:

     A) root.image: _d_d image of the root filesystem
     B) vmunix.tape: _d_d image for creating boot tapes
     C) vmunix.net: file for booting over the network
     D) root.dump: _d_u_m_p image of the root filesystem

There are three basic ways a system can be bootstrapped cor-
responding  to  the first three files.  You may want to read
the section on bootstrapping the HP300  since  many  of  the
steps  are  similar.   A  spare, formatted SCSI disk is also
useful.





                        May 14, 1994





SMM:1-18                Installing and Operating 4.4BSD UNIX


22..44..22..11..  PPrroocceedduurree AA:: ccooppyy rroooott ffiilleessyysstteemm ttoo ddiisskk
     This procedure is similar to the HP300.  If you have an
extra disk, the easiest  approach  is  to  use  _d_d(1)  under
ULTRIX to copy the root filesystem image to the beginning of
the spare  disk.   The  root  filesystem  image  includes  a
disklabel  and bootblock along with the root filesystem.  An
example command to copy the image to the beginning of a disk
is:

     dd if=root.image of=/dev/rz1c bs=20b

The  actual  special file syntax will vary depending on unit
numbers and the version of ULTRIX  that  is  running.   This
system  is  now  ready to boot. You can boot the kernel with
one of the following PROM commands. If you are booting on  a
3100, the disk must be SCSI id zero because of a bug.

     DEC 3100:    boot -f rz(0,0,0)vmunix
     DEC 5000:    boot 5/rz0/vmunix

You  can  then  proceed  to section 2.5 to create reasonable
disk partitions for your machine and then install  the  rest
of the system.

22..44..22..22..  PPrroocceedduurree BB:: bboooottssttrraapp ffrroomm ttaappee
     If  you  have only a single machine with a single disk,
you need to use the more difficult  approach  of  booting  a
kernel  and mini-root from tape or the network, and using it
to restore the root filesystem.
     First, you will need to create a boot tape. This can be
done using _d_d as in the following example.

     dd if=vmunix.tape of=/dev/nrmt0 bs=1b
     dd if=root.dump of=/dev/nrmt0 bs=20b

The  actual special file syntax for the tape drive will vary
depending on unit numbers, tape device and  the  version  of
ULTRIX that is running.
     The first file on the boot tape contains a boot header,
kernel, and mini-root filesystem that the PROM can copy into
memory.  Installing from tape has only been tested on a 3100
and a 5000/200 using a TK50 tape drive. Here are two example
PROM commands to boot from tape.

     DEC 3100:    boot -f tz(0,5,0) m    # 5 is the SCSI id of the TK50
     DEC 5000:    boot 5/tz6 m           # 6 is the SCSI id of the TK50

The  `m'  argument  tells  the  kernel  to  look  for a root
filesystem in memory.  Next you should  proceed  to  section
2.4.3 to build a disk-based root filesystem.

22..44..22..33..  PPrroocceedduurree CC:: bboooottssttrraapp oovveerr tthhee nneettwwoorrkk
     You  will need a host machine that is running the _b_o_o_t_p
server with the vmunix.net file  installed  in  the  default



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-19


directory defined by the configuration file for _b_o_o_t_p.  Here
are two example PROM commands to boot across the net:

     DEC 3100: boot -f tftp()vmunix.net m
     DEC 5000: boot 6/tftp/vmunix.net m

This command should load the kernel and mini-root into  mem-
ory and run the same as the tape install (procedure B).  The
rest of the steps are the same except you will need to start
the  network  (if  you  are unsure how to fill in the <name>
fields below, see sections 4.4 and 5).  Execute the  follow-
ing to start the networking:

     # mount -uw /
     # echo 127.0.0.1 localhost >> /etc/hosts
     # echo <your.host.inet.number> myname.my.domain myname >> /etc/hosts
     # echo <friend.host.inet.number> myfriend.my.domain myfriend >> /etc/hosts
     # ifconfig le0 inet myname

Next  you  should  proceed to section 2.4.3 to build a disk-
based root filesystem.

22..44..33..  LLaabbeell ddiisskk aanndd ccrreeaattee tthhee rroooott ffiilleessyysstteemm
There are five steps to create a disk-based root filesystem.
1)   Label the disk.

          # disklabel -W /dev/rrz?c          # This enables writing the label
          # disklabel -w -r -B /dev/rrz?c $DISKTYPE
          # newfs /dev/rrz?a
          ...
          # fsck /dev/rrz?a
          ...

     Supported disk types are listed in /etc/disktab.
2)   Restore the root filesystem.

          # mount -uw /
          # mount /dev/rz?a /a
          # cd /a

         If you are restoring locally (procedure B), run:

          # mt -f /dev/nrmt0 rew
          # restore -xsf 2 /dev/rmt0

         If  you are restoring across the net (procedure c),
     run:

          # rrestore xf myfriend:/path/to/root.dump

         When the restore finishes, clean up with:






                        May 14, 1994





SMM:1-20                Installing and Operating 4.4BSD UNIX


          # cd /
          # sync
          # umount /a
          # fsck /dev/rz?a

3)   Reset the system and initialize  the  PROM  monitor  to
     boot automatically.

          DEC 3100: setenv bootpath boot -f rz(0,?,0)vmunix
          DEC 5000: setenv bootpath 5/rz?/vmunix -a

4)   After  booting UNIX, you will need to create /dev/mouse
     to run X windows as in the following example.

          rm /dev/mouse
          ln /dev/xx /dev/mouse

     The 'xx' should be one of the following:

          pm0  raw interface to PMAX graphics devices
          cfb0 raw interface to TURBOchannel PMAG-BA color frame buffer
          xcfb0     raw interface to maxine graphics devices
          mfb0 raw interface to mono graphics devices

     You can then proceed to section 2.5 to install the rest
     of the system.  Note that where the disk name ``sd'' is
     used throughout section 2.5, you should substitute  the
     name ``rz''.

22..55..  DDiisskk ccoonnffiigguurraattiioonn
     All  architectures  now  have  a root filesystem up and
running and proceed from this point to layout filesystems to
make use of the available space and to balance disk load for
better system performance.

22..55..11..  DDiisskk nnaammiinngg aanndd ddiivviissiioonnss
     Each physical disk drive can be divided into  up  to  8
partitions; UNIX typically uses only 3 or 4 partitions.  For
instance, the first partition, sd0a,  is  used  for  a  root
filesystem,  a  backup  thereof, or a small filesystem like,
/var/tmp; the second partition, sd0b, is used for paging and
swapping;  and  a  third  partition, typically sd0e, holds a
user filesystem.
     The space available on a disk varies per device.   Each
disk  typically has a paging area of 30 to 100 megabytes and
a root filesystem of about 17  megabytes.   The  distributed
system  binaries occupy about 150 (180 with X11R5) megabytes
while the major sources occupy another 250 (340 with  X11R5)
megabytes.   The /var filesystem as delivered on the tape is
only 2Mb, however it should have at least 50Mb allocated  to
it just for normal system activity.  Usually it is allocated
the last partition on the disk so that  it  can  provide  as
much  space  as  possible to the /var/users filesystem.  See
section 2.5.4 for further details on disk layouts.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-21


     Be aware that the disks have their  sizes  measured  in
disk  sectors (usually 512 bytes), while the UNIX filesystem
blocks are variable sized.  If BLOCKSIZE=1k is  set  in  the
user's  environment,  all user programs report disk space in
kilobytes, otherwise, disk  sizes  are  always  reported  in
units  of  512-byte sectors2.  The /etc/disktab file used in
labelling disks and making filesystems specifies disk parti-
tion sizes in sectors.

22..55..22..  LLaayyoouutt ccoonnssiiddeerraattiioonnss
     There  are  several  considerations  in deciding how to
adjust the arrangement of things on your  disks.   The  most
important  is  making  sure that there is adequate space for
what is required; secondarily, throughput  should  be  maxi-
mized.  Paging space is an important parameter.  The system,
as distributed, sizes the configured paging areas each  time
the  system  is  booted.   Further, multiple paging areas of
different sizes may be interleaved.
     Many common system programs (C, the editor, the  assem-
bler etc.)  create intermediate files in the /tmp directory,
so the filesystem where this is stored also should  be  made
large  enough  to  accommodate most high-water marks.  Typi-
cally, /tmp is constructed from  a  memory-based  filesystem
(see  _m_o_u_n_t___m_f_s(8)).   Programs  that  want  their temporary
files to persist across system  reboots  (such  as  editors)
should  use  /var/tmp.  If you plan to use a disk-based /tmp
filesystem to avoid loss across  system  reboots,  it  makes
sense  to  mount  this  in a ``root'' (i.e. first partition)
filesystem on another disk.  All the  programs  that  create
files  in  /tmp take care to delete them, but are not immune
to rare events and can leave dregs.  The directory should be
examined every so often and the old files deleted.
     The  efficiency  with which UNIX is able to use the CPU
is often strongly affected by the configuration of disk con-
trollers;  it  is  critical  for good performance to balance
disk load.  There are at least five components of  the  disk
load that you can divide between the available disks:
1)   The root filesystem.
2)   The /var and /var/tmp filesystems.
3)   The /usr filesystem.
4)   The user filesystems.
5)   The paging activity.
The  following  possibilities are ones we have used at times
when we had 2, 3 and 4 disks:






-----------
  2 You can thank System V intransigence and POSIX
duplicity for requiring that  512-byte  blocks  be
the units that programs report.



                        May 14, 1994





SMM:1-22                Installing and Operating 4.4BSD UNIX


               +----------------------------+
               +--------+-------------------+
               |        |     | disk|s       |
               |what    | 2   | 3   | 4     |
               +--------+-----+-----+-------+
               |root    | 0   | 0   | 0     |
               |var     | 1   | 2   | 3     |
               |usr     | 1   | 1   | 1     |
               |paging  | 0+1 | 0+2 | 0+2+3 |
               |users   | 0   | 0+2 | 0+2   |
               |archive | x   | x   | 3     |
               +--------+-----+-----+-------+
     The most i+m-p-o-r-t-a-n-t--t-h-i-n-g-s--t-o--c-o-n-s-i-d-e-r--a+re to  even  out
the  disk load as much as possible, and to do this by decou-
pling filesystems (on separate  arms)  between  which  heavy
copying occurs.  Note that a long term average balanced load
is not important; it is  much  more  important  to  have  an
instantaneously balanced load when the system is busy.
     Intelligent   experimentation  with  a  few  filesystem
arrangements can pay off in much improved  performance.   It
is particularly easy to move the root, the /var and /var/tmp
filesystems and the paging areas.  Place the user files  and
the  /usr  directory  as  space needs dictate and experiment
with the other, more easily moved filesystems.

22..55..33..  FFiilleessyysstteemm ppaarraammeetteerrss
     Each filesystem is parameterized according to its block
size,  fragment  size, and the disk geometry characteristics
of the medium on which it resides.  Inaccurate specification
of  the  disk  characteristics  or  haphazard  choice of the
filesystem parameters can result in  substantial  throughput
degradation or significant waste of disk space.  As distrib-
uted, filesystems are configured according to the  following
table.


             Filesystem   Block size   Fragment size
             ----------------------------------------
             root         8 kbytes     1 kbytes
             usr          8 kbytes     1 kbytes
             users        4 kbytes     512 bytes


     The  root  filesystem block size is made large to opti-
mize bandwidth to the associated disk.  The large block size
is  important  as many of the most heavily used programs are
demand paged out of the /bin directory.  The  fragment  size
of  1 kbyte is a ``nominal'' value to use with a filesystem.
With a 1 kbyte fragment size disk space utilization is about
the same as with the earlier versions of the filesystem.
     The  filesystems  for  users  have a 4 kbyte block size
with 512 byte fragment size.   These  parameters  have  been
selected  based  on  observations  of the performance of our
user filesystems.  The 4 kbyte block size provides  adequate



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-23


bandwidth  while the 512 byte fragment size provides accept-
able space compaction and disk fragmentation.
     Other parameters may be chosen in constructing filesys-
tems,  but the factors involved in choosing a block size and
fragment size are many and interact in complex ways.  Larger
block  sizes  result  in better throughput to large files in
the filesystem as larger I/O requests will then be  done  by
the  system.   However,  consideration  must be given to the
average file sizes found in the filesystem and  the  perfor-
mance of the internal system buffer cache.   The system cur-
rently provides space in  the  inode  for  12  direct  block
pointers, 1 single indirect block pointer, 1 double indirect
block pointer, and 1 triple indirect block  pointer.   If  a
file  uses  only  direct  blocks,  access time to it will be
optimized by maximizing the block size.  If  a  file  spills
over  into  an  indirect block, increasing the block size of
the filesystem may decrease the  amount  of  space  used  by
eliminating  the  need  to allocate an indirect block.  How-
ever, if the block size is increased and an  indirect  block
is  still required, then more disk space will be used by the
file because indirect blocks are allocated according to  the
block size of the filesystem.
     In selecting a fragment size for a filesystem, at least
two considerations should be given.  The  major  performance
tradeoffs  observed  are between an 8 kbyte block filesystem
and a 4 kbyte block filesystem.  Because  of  implementation
constraints,  the  block size versus fragment size ratio can
not be greater than 8.  This means that an 8 kbyte  filesys-
tem  will  always have a fragment size of at least 1 kbytes.
If a filesystem is created with a 4 kbyte block size and a 1
kbyte  fragment size, then upgraded to an 8 kbyte block size
and 1 kbyte fragment size, identical space  compaction  will
be  observed.   However, if a filesystem has a 4 kbyte block
size and 512 byte fragment size, converting it to  an  8K/1K
filesystem  will result in 4-8% more space being used.  This
implies  that  4  kbyte  block  filesystems  that  might  be
upgraded to 8 kbyte blocks for higher performance should use
fragment sizes of at least 1 kbytes to minimize  the  amount
of work required in conversion.
     A  second, more important, consideration when selecting
the fragment size for a filesystem is the level of  fragmen-
tation  on  the  disk.  With an 8:1 fragment to block ratio,
storage fragmentation occurs much sooner, particularly  with
a  busy  filesystem running near full capacity.  By compari-
son, the level of fragmentation in a 4:1 fragment  to  block
ratio filesystem is one tenth as severe.  This means that on
filesystems where many files are created  and  deleted,  the
512  byte fragment size is more likely to result in apparent
space exhaustion because of fragmentation.   That  is,  when
the  filesystem is nearly full, file expansion that requires
locating a contiguous area of disk space is more  likely  to
fail  on a 512 byte filesystem than on a 1 kbyte filesystem.
To minimize fragmentation problems of this sort, a parameter
in the super block specifies a minimum acceptable free space



                        May 14, 1994





SMM:1-24                Installing and Operating 4.4BSD UNIX


threshold.  When normal users (i.e. anyone  but  the  super-
user)  attempt  to  allocate  disk  space and the free space
threshold is exceeded, the user is returned an error  as  if
the  filesystem  were  really full.  This parameter is nomi-
nally set to 5%; it may be changed by supplying a  parameter
to  _n_e_w_f_s(8),  or by updating the super block of an existing
filesystem using _t_u_n_e_f_s(8).
     Finally, a third,  less  common  consideration  is  the
attributes of the disk itself.  The fragment size should not
be smaller than the physical sector size of the disk.  As an
example,  the HP magneto-optical disks have 1024 byte physi-
cal sectors.  Using a 512 byte fragment size on  such  disks
will work but is extremely inefficient.
     Note that the above discussion considers block sizes of
up to only 8k.  As of the 4.4  release,  the  maximum  block
size has been increased to 64k.  This allows an entirely new
set of block/fragment combinations for which there is little
experience  to date.  In general though, unless a filesystem
is to be used for a special purpose application  (for  exam-
ple,  storing image processing data), we recommend using the
values supplied above.  Remember that the current  implemen-
tation  limits  the  block size to at most 64 kbytes and the
ratio of block size versus fragment size must be 1, 2, 4, or
8.
     The  disk  geometry  information used by the filesystem
affects  the  block  layout  policies  employed.   The  file
/etc/disktab,  as  supplied,  contains the data for most all
drives supported  by  the  system.   Before  constructing  a
filesystem  with  _n_e_w_f_s(8)  you should label the disk (if it
has not yet been labeled, and the driver  supports  labels).
If  labels cannot be used, you must instead specify the type
of disk on which the filesystem resides;  _n_e_w_f_s  then  reads
/etc/disktab instead of the pack label.  This file also con-
tains the default filesystem partition  sizes,  and  default
block  and  fragment  sizes.  To override any of the default
values you can modify the file, edit the disk label, or  use
an option to _n_e_w_f_s.

22..55..44..  IImmpplleemmeennttiinngg aa llaayyoouutt
     To put a chosen disk layout into effect, you should use
the _n_e_w_f_s(8) command to create each  new  filesystem.   Each
filesystem must also be added to the file /etc/fstab so that
it will be checked and mounted  when  the  system  is  boot-
strapped.
     First  we  will  consider  a system with a single disk.
There is little real choice on how to  do  the  layout;  the
root  filesystem  goes  in the ``a'' partition, /usr goes in
the ``e'' partition, and /var fills out the remainder of the
disk  in the ``f'' partition.  This is the organization used
if you loaded the  disk-image  root  filesystem.   With  the
addition  of a memory-based /tmp filesystem, its fstab entry
would be as follows:





                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-25


/dev/sd0a   /      ufs    rw                                     1   1
/dev/sd0b   none   swap   sw                                     0   0
/dev/sd0b   /tmp   mfs    rw,-s=14000,-b=8192,-f=1024,-T=sd660   0   0
/dev/sd0e   /usr   ufs    ro                                     1   2
/dev/sd0f   /var   ufs    rw                                     1   2

     If we had a  second  disk,  we  would  split  the  load
between  the  drives.  On the second disk, we place the /usr
and /var filesystems in their usual sd1e and sd1f partitions
respectively.   The sd1b partition would be used as a second
paging area, and the sd1a partition left  as  a  spare  root
filesystem  (alternatively sd1a could be used for /var/tmp).
The first disk still holds the the root filesystem in  sd0a,
and  the  primary  swap area in sd0b.  The sd0e partition is
used to hold home directories in /var/users.  The sd0f  par-
tition can be used for /usr/src or alternately the sd0e par-
tition can be extended to cover the rest of  the  disk  with
_d_i_s_k_l_a_b_e_l(8).   As  before,  the /tmp directory is a memory-
based  filesystem.   Note  that  to  interleave  the  paging
between  the two disks you must build a system configuration
that specifies:

     config    vmunix    root on sd0 swap on sd0 and sd1

The /etc/fstab file would then contain

/dev/sd0a   /            ufs    rw                                     1   1
/dev/sd0b   none         swap   sw                                     0   0
/dev/sd1b   none         swap   sw                                     0   0
/dev/sd0b   /tmp         mfs    rw,-s=14000,-b=8192,-f=1024,-T=sd660   0   0
/dev/sd1e   /usr         ufs    ro                                     1   2
/dev/sd0f   /usr/src     ufs    rw                                     1   2
/dev/sd1f   /var         ufs    rw                                     1   2
/dev/sd0e   /var/users   ufs    rw                                     1   2

     To make the /var filesystem we would do:

     ## _c_d _/_d_e_v
     ## _M_A_K_E_D_E_V _s_d_1
     ## _d_i_s_k_l_a_b_e_l _-_w_r _s_d_1 _"_d_i_s_k _t_y_p_e_" _"_d_i_s_k _n_a_m_e_"
     ## _n_e_w_f_s _s_d_1_f
     (information about filesystem prints out)
     ## _m_k_d_i_r _/_v_a_r
     ## _m_o_u_n_t _/_d_e_v_/_s_d_1_f _/_v_a_r


22..66..  IInnssttaalllliinngg tthhee rreesstt ooff tthhee ssyysstteemm
     At this point you should have your  disks  partitioned.
The  next  step  is to extract the rest of the data from the
tape.  At a minimum you need to set up  the  /var  and  /usr
filesystems.   You  may also want to extract some or all the
program sources.  Since not all architectures  support  tape
drives  or  don't  support the correct ones, you may need to
extract the files indirectly using _r_s_h(1).  For example, for



                        May 14, 1994





SMM:1-26                Installing and Operating 4.4BSD UNIX


a directly connected tape drive you might do:

     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f
     ## _t_a_r _x_b_p_f _2_0 _/_d_e_v_/_n_r_m_t_0

The  equivalent  indirect procedure (where the tape drive is
on machine ``foo'') is:

     ## _r_s_h _f_o_o _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f
     ## _r_s_h _f_o_o _d_d _i_f_=_/_d_e_v_/_n_r_m_t_0 _b_s_=_2_0_b _| _t_a_r _x_b_p_f _2_0 _-

Obviously, the target machine must be connected to the local
network for this to work.  To do this:

     ## _e_c_h_o  _1_2_7_._0_._0_._1  _l_o_c_a_l_h_o_s_t _>_> _/_e_t_c_/_h_o_s_t_s
     ## _e_c_h_o  your.host.inet.number  myname.my.domain  myname _>_> _/_e_t_c_/_h_o_s_t_s
     ## _e_c_h_o  friend.host.inet.number  myfriend.my.domain  myfriend _>_> _/_e_t_c_/_h_o_s_t_s
     ## _i_f_c_o_n_f_i_g  _l_e_0  _i_n_e_t  myname

where  the  ``host.inet.number'' fields are the IP addresses
for your host and the host  with  the  tape  drive  and  the
``my.domain''  fields  are the names of your machine and the
tape-hosting machine.  See  sections  4.4  and  5  for  more
information on setting up the network.
     Assuming  a  directly connected tape drive, here is how
to extract and install /var and /usr:

## _m_o_u_n_t _-_u_w _/_d_e_v_/_s_d_#_a _/                                 (read-write mount root filesystem)
## _d_a_t_e _y_y_m_m_d_d_h_h_m_m                                       (set date, see _d_a_t_e(1))
....
## _p_a_s_s_w_d _-_l _r_o_o_t                                        (set password for super-user)
NNeeww ppaasssswwoorrdd::                                           (password will not echo)
RReettyyppee nneeww ppaasssswwoorrdd::
## _p_a_s_s_w_d _-_l _t_o_o_r                                        (set password for super-user)
NNeeww ppaasssswwoorrdd::                                           (password will not echo)
RReettyyppee nneeww ppaasssswwoorrdd::
## _h_o_s_t_n_a_m_e _m_y_s_i_t_e_n_a_m_e                                   (set your hostname)
## _n_e_w_f_s _r_s_d_#_p                                           (create empty user filesystem)
(_s_d is the disk type, _# is the unit number,
_p is the partition; this takes a few minutes)
## _m_o_u_n_t _/_d_e_v_/_s_d_#_p _/_v_a_r                                  (mount the var filesystem)
## _c_d _/_v_a_r                                               (make /var the current directory)
## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f                                  (space to end of previous tape file)
## _t_a_r _x_b_p_f _2_0 _/_d_e_v_/_n_r_m_t_0                                (extract all of var)
(this takes a few minutes)
## _n_e_w_f_s _r_s_d_#_p                                           (create empty user filesystem)
(as before _s_d is the disk type, _# is the unit number,
_p is the partition)
## _m_o_u_n_t _/_d_e_v_/_s_d_#_p _/_m_n_t                                  (mount the new /usr in temporary location)
## _c_d _/_m_n_t                                               (make /mnt the current directory)
## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f                                  (space to end of previous tape file)
## _t_a_r _x_b_p_f _2_0 _/_d_e_v_/_n_r_m_t_0                                (extract all of usr except usr/src)
(this takes about 15-20 minutes)




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-27


## _c_d _/                                                  (make / the current directory)
## _u_m_o_u_n_t _/_m_n_t                                           (unmount from temporary mount point)
## _r_m _-_r _/_u_s_r_/_*                                          (remove excess bootstrap binaries)
## _m_o_u_n_t _/_d_e_v_/_s_d_#_p _/_u_s_r                                  (remount /usr)

If no disk label has been installed on the disk,  the  _n_e_w_f_s
command  will  require  a third argument to specify the disk
type, using one of the names in /etc/disktab.  If  the  tape
had  been  rewound or positioned incorrectly before the _t_a_r,
to extract /var it may be repositioned by the following com-
mands.

     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _r_e_w
     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f _1

The  data  on  the  second and third tape files has now been
extracted.  If you are using 6250bpi tapes, the  first  reel
of  the  distribution  is  no  longer needed; you should now
mount the second reel instead.  The  installation  procedure
continues from this point on the 8mm tape.  The next step is
to extract  the  sources.   As  previously  noted,  /usr/src
requires  about  250-340Mb of space.  Ideally sources should
be in a separate filesystem; if you plan to  put  them  into
your  /usr filesystem, it will need at least 500Mb of space.
Assuming that you will be using  a  separate  filesystem  on
sd0f  for  /usr/src, you will start by creating and mounting
it:

     ## _n_e_w_f_s _s_d_0_f
     (information about filesystem prints out)
     ## _m_k_d_i_r _/_u_s_r_/_s_r_c
     ## _m_o_u_n_t _/_d_e_v_/_s_d_0_f _/_u_s_r_/_s_r_c

First you will extract the kernel source:


     ## _c_d _/_u_s_r_/_s_r_c
     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f                                (space to end of previous tape file)
     (this should only be done on Exabyte distributions)
     ## _t_a_r _x_p_b_f _2_0 _/_d_e_v_/_n_r_m_t_0                              (extract the kernel sources)
     (this takes about 15-30 minutes)


The next tar file contains the sources  for  the  utilities.
It is extracted as follows:


     ## _c_d _/_u_s_r_/_s_r_c
     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f             (space to end of previous tape file)
     ## _t_a_r _x_p_b_f _2_0 _/_d_e_v_/_r_m_t_1_2           (extract the utility source)
     (this takes about 30-60 minutes)






                        May 14, 1994





SMM:1-28                Installing and Operating 4.4BSD UNIX


     If  you are using 6250bpi tapes, the second reel of the
distribution is no longer needed; you should now  mount  the
third  reel  instead.   The installation procedure continues
from this point on the 8mm tape.
     The next tar file contains the sources for the contrib-
uted software.  It is extracted as follows:


     ## _c_d _/_u_s_r_/_s_r_c
     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f                                (space to end of previous tape file)
     (this should only be done on Exabyte distributions)
     ## _t_a_r _x_p_b_f _2_0 _/_d_e_v_/_r_m_t_1_2                              (extract the contributed software source)
     (this takes about 30-60 minutes)


     If  you  received  a  distribution on 8mm Exabyte tape,
there is one additional tape file on the  distribution  tape
that  has  not been installed to this point; it contains the
sources for X11R5 in _t_a_r(1) format.  As  distributed,  X11R5
should be placed in /usr/src/X11R5.


     ## _c_d _/_u_s_r_/_s_r_c
     ## _m_t _-_f _/_d_e_v_/_n_r_m_t_0 _f_s_f             (space to end of previous tape file)
     ## _t_a_r _x_p_b_f _2_0 _/_d_e_v_/_n_r_m_t_0           (extract the X11R5 source)
     (this takes about 30-60 minutes)


Many of the X11 utilities search using the path /usr/X11, so
be sure that you have a symbolic link  that  points  at  the
location of your X11 binaries (here, X11R5).
     Having now completed the extraction of the sources, you
may want to verify that your /usr/src filesystem is  consis-
tent.   To  do  so,  you  must  unmount it, and run _f_s_c_k(8);
assuming that you used sd0f you would proceed as follows:


     ## _c_d _/                 (change directory, back to the root)
     ## _u_m_o_u_n_t _/_u_s_r_/_s_r_c      (unmount /usr/src)
     ## _f_s_c_k _/_d_e_v_/_r_s_d_0_f


The output from _f_s_c_k should look something like:

     **** //ddeevv//rrssdd00ff
     **** LLaasstt MMoouunntteedd oonn //uussrr//ssrrcc
     **** PPhhaassee 11 -- CChheecckk BBlloocckkss aanndd SSiizzeess
     **** PPhhaassee 22 -- CChheecckk PPaatthhnnaammeess
     **** PPhhaassee 33 -- CChheecckk CCoonnnneeccttiivviittyy
     **** PPhhaassee 44 -- CChheecckk RReeffeerreennccee CCoouunnttss
     **** PPhhaassee 55 -- CChheecckk CCyyll ggrroouuppss
     2233000000 ffiilleess,, 226611000000 uusseedd,, 3399000000 ffrreeee ((22220000 ffrraaggss,, 44660000 bblloocckkss))





                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-29


     If there are inconsistencies in the filesystem, you may
be  prompted  to apply corrective action; see the _f_s_c_k(8) or
_F_s_c_k _- _T_h_e _U_N_I_X _F_i_l_e _S_y_s_t_e_m _C_h_e_c_k _P_r_o_g_r_a_m (SMM:3)  for  more
details.
     To  use the /usr/src filesystem, you should now remount
it with:

     ## _m_o_u_n_t _/_d_e_v_/_s_d_0_f _/_u_s_r_/_s_r_c

or if you have made an entry for it in  /etc/fstab  you  can
remount it with:

     ## _m_o_u_n_t _/_u_s_r_/_s_r_c


22..77..  AAddddiittiioonnaall ccoonnvveerrssiioonn iinnffoorrmmaattiioonn
     After  setting  up  the new 4.4BSD filesystems, you may
restore the user files that were saved on tape before begin-
ning  the  conversion.  Note that the 4.4BSD _r_e_s_t_o_r_e program
does its work on a mounted filesystem  using  normal  system
operations.    This  means  that  filesystem  dumps  may  be
restored even  if  the  characteristics  of  the  filesystem
changed.  To restore a dump tape for, say, the /a filesystem
something like the following would be used:

     ## _m_k_d_i_r _/_a
     ## _n_e_w_f_s _s_d_#_p
     ## _m_o_u_n_t _/_d_e_v_/_s_d_#_p _/_a
     ## _c_d _/_a
     ## _r_e_s_t_o_r_e _x

     If _t_a_r images were written instead of doing a dump, you
should be sure to use its `-p' option when reading the files
back.  No matter how you restore a filesystem,  be  sure  to
unmount it and and check its integrity with _f_s_c_k(8) when the
job is complete.

33..  UUppggrraaddiinngg aa 44..33BBSSDD ssyysstteemm
     This section describes the procedure  for  upgrading  a
4.3BSD  system to 4.4BSD.  This procedure may vary according
to the version of the system running before conversion.   If
you are converting from a System V system, some of this sec-
tion will still apply (in particular, the filesystem conver-
sion).   However, many of the system configuration files are
different, and the executable file  formats  are  completely
incompatible.
     In  particular  be  wary when using this information to
upgrade a 4.3BSD HP300 system.  There are at least four dif-
ferent versions of ``4.3BSD'' out there:
1)   HPBSD 1.x from Utah.
     This was the original version of 4.3BSD for HP300s from
     which the other variants (and 4.4BSD) are derived.   It
     is  largely a 4.3BSD system with Sun's NFS 3.0 filesys-
     tem  code  and   some   4.3BSD-Tahoe   features   (e.g.



                        May 14, 1994





SMM:1-30                Installing and Operating 4.4BSD UNIX


     networking code).  Since the filesystem code is 4.2/4.3
     vintage and the filesystem hierarchy is largely 4.3BSD,
     most of this section should apply.
2)   MORE/bsd from Mt. Xinu.
     This  is  a  4.3BSD-Tahoe vintage system with Sun's NFS
     4.0 filesystem code upgraded with Tahoe  UFS  features.
     The instructions for 4.3BSD-Tahoe should largely apply.
3)   4.3BSD-Reno from CSRG.
     At least one site bootstrapped HP300 support  from  the
     Reno  distribution.  The Reno filesystem code was some-
     where between 4.3BSD and 4.4BSD:  the  VFS  switch  had
     been   added   but  many  of  the  UFS  features  (e.g.
     ``inline''  symlinks)  were  missing.   The  filesystem
     hierarchy   reorganization   first   appeared  in  this
     release.  Be extremely careful following these instruc-
     tions  if you are upgrading from the Reno distribution.
4)   HPBSD 2.0 from Utah.
     As if things were not bad enough already, this  release
     has  the  4.4BSD filesystem and networking code as well
     as some utilities, but still has  a  4.3BSD  hierarchy.
     No   filesystem  conversions  are  necessary  for  this
     upgrade, but files will still need to be moved  around.

33..11..  IInnssttaallllaattiioonn oovveerrvviieeww
     If  you  are  running  4.3BSD,  upgrading  your  system
involves replacing your kernel  and  system  utilities.   In
general,  there are three possible ways to install a new BSD
distribution: (1) boot directly from the distribution  tape,
use it to load new binaries onto empty disks, and then merge
or restore any existing configuration files and filesystems;
(2)  use  an  existing 4.3BSD or later system to extract the
root and /usr filesystems from the distribution  tape,  boot
from the new system, then merge or restore existing configu-
ration files and filesystems; or  (3)  extract  the  sources
from  the distribution tape onto an existing system, and use
that system to cross-compile and install 4.4BSD.   For  this
release,  the  second  alternative is strongly advised, with
the third alternative reserved as a last  resort.   In  gen-
eral,  older binaries will continue to run under 4.4BSD, but
there are many exceptions that are on the critical path  for
getting  the  system running.  Ideally, the new system bina-
ries (root and /usr  filesystems)  should  be  installed  on
spare  disk  partitions,  then site-specific files should be
merged into them.  Once the  new  system  is  up  and  fully
merged,  the  previous  root  and  /usr  filesystems  can be
reused.  Other existing  filesystems  can  be  retained  and
used,  except  that  (as  usual)  the new _f_s_c_k should be run
before they are mounted.
     It is SSTTRROONNGGLLYY advised that you make full dumps of each
filesystem  before beginning, especially any that you intend
to modify in place during the merge.  It is  also  desirable
to  run filesystem checks of all filesystems to be converted
to 4.4BSD before shutting down.  This is an  excellent  time
to review your disk configuration for possible tuning of the



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-31


layout.  Most systems will need to provide a new  filesystem
for  system  use  mounted on /var (see below).  However, the
/tmp  filesystem  can  be  an  MFS   virtual-memory-resident
filesystem,  potentially freeing an existing disk partition.
(Additional swap space may be desirable as  a  consequence.)
See _m_o_u_n_t___m_f_s(8).
     The  recommended  installation  procedure  includes the
following steps.  The order of  these  steps  will  probably
vary according to local needs.
+o    Extract root and /usr filesystems from the distribution
     tapes.
+o    Extract kernel and/or user-level sources from the  dis-
     tribution tape if space permits.  This can serve as the
     backup documentation as needed.
+o    Configure and boot a kernel for the local system.  This
     can be delayed if the generic kernel from the distribu-
     tion supports enough hardware to proceed.
+o    Build a skeletal /var filesystem (see _m_t_r_e_e(8)).
+o    Merge site-dependent configuration files from /etc  and
     /usr/lib  into  the new /etc directory.  Note that many
     file formats and contents have changed; see section 3.4
     of this document.
+o    Copy   or   merge   files  from  /usr/adm,  /usr/spool,
     /usr/preserve, /usr/lib, and other locations into /var.
+o    Merge local macros, dictionaries, etc. into /usr/share.
+o    Merge and update local software to reflect  the  system
     changes.
+o    Take off the rest of the morning, you've earned it!
     Section  3.2 lists the files to be saved as part of the
conversion process.  Section  3.3  describes  the  bootstrap
process.   Section  3.4  discusses  the  merger of the saved
files back into the new system.  Section 3.5 gives an  over-
view  of  the major bug fixes and changes between 4.3BSD and
4.4BSD.  Section 3.6  provides  general  hints  on  possible
problems  to  be  aware  of  when  converting from 4.3BSD to
4.4BSD.

33..22..  FFiilleess ttoo ssaavvee
     The following list enumerates the standard set of files
you  will  want  to  save  and suggests directories in which
site-specific files  should  be  present.   This  list  will
likely  be  augmented with non-standard files you have added
to your system.  If you do not have enough space  to  create
parallel  filesystems,  you should create a _t_a_r image of the
following files before the new filesystems are created.  The
rest  of  this  subsection describes where theses files have
moved and how they have changed.

/.cshrc                      root csh startup script (moves to /root/.cshrc)
/.login                      root csh login script (moves to /root/.login)
/.profile                    root sh startup script (moves to /root/.profile)
/.rhosts                     for trusted machines and users (moves to /root/.rhosts)
/etc/disktab                 in case you changed disk partition sizes




                        May 14, 1994





SMM:1-32                Installing and Operating 4.4BSD UNIX


/etc/fstab               *   disk configuration data
/etc/ftpusers                for local additions
/etc/gettytab                getty database
/etc/group               *   group data base
/etc/hosts                   for local host information
/etc/hosts.equiv             for local host equivalence information
/etc/hosts.lpd               printer access file
/etc/inetd.conf          *   Internet services configuration data
/etc/named*                  named configuration files
/etc/netstart                network initialization
/etc/networks                for local network information
/etc/passwd              *   user data base
/etc/printcap            *   line printer database
/etc/protocols               in case you added any local protocols
/etc/rc                  *   for any local additions
/etc/rc.local            *   site specific system startup commands
/etc/remote                  auto-dialer configuration
/etc/services                for local additions
/etc/shells                  list of valid shells
/etc/syslog.conf         *   system logger configuration
/etc/securettys          *   merged into ttys
/etc/ttys                *   terminal line configuration data
/etc/ttytype             *   merged into ttys
/etc/termcap                 for any local entries that may have been added
/lib                         for any locally developed language processors
/usr/dict/*                  for local additions to words and papers
/usr/include/*               for local additions
/usr/lib/aliases         *   mail forwarding data base (moves to /etc/aliases)
/usr/lib/crontab         *   cron daemon data base (moves to /etc/crontab)
/usr/lib/crontab.local   *   local cron daemon data base (moves to /etc/crontab.local)
/usr/lib/lib*.a              for local libraries
/usr/lib/mail.rc             system-wide mail(1) initialization (moves to /etc/mail.rc)
/usr/lib/sendmail.cf     *   sendmail configuration (moves to /etc/sendmail.cf)
/usr/lib/tmac/*              for locally developed troff/nroff macros (moves to /usr/share/tmac/*)
/usr/lib/uucp/*              for local uucp configuration files
/usr/man/manl            *   for manual pages for locally developed programs (moves to /usr/local/man)
/usr/spool/*                 for current mail, news, uucp files, etc. (moves to /var/spool)
/usr/src/local               for source for locally developed programs
/sys/conf/HOST               configuration file for your machine (moves to /sys/<arch>/conf)
/sys/conf/files.HOST         list of special files in your kernel (moves to /sys/<arch>/conf)
/*/quotas                *   filesystem quota files (moves to /*/quotas.user)


     Files that can be used from 4.3BSD without change.
     Files that need local changes merged into 4.4BSD files.
     *Files that require special work to merge and are discussed in section 3.4.


33..33..  IInnssttaalllliinngg 44..44BBSSDD
     The next step is to  build  a  working  4.4BSD  system.
This can be done by following the steps in section 2 of this
document for extracting the root and /usr  filesystems  from
the  distribution tape onto unused disk partitions.  For the
SPARC, the root filesystem dump on the tape  could  also  be



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-33


extracted  directly.   For the HP300 and DECstation, the raw
disk image can be copied into an unused partition  and  this
partition  can then be dumped to create an image that can be
restored.  The exact procedure chosen  will  depend  on  the
disk  configuration  and  the number of suitable disk parti-
tions that may  be  used.   It  is  also  desirable  to  run
filesystem  checks  of  all  filesystems  to be converted to
4.4BSD before shutting down.  In any case, this is an excel-
lent  time  to  review  your disk configuration for possible
tuning  of  the  layout.   Section  2.5  and  _c_o_n_f_i_g(8)  are
required reading.
The  filesystem  in 4.4BSD has been reorganized in an effort
to meet several goals:
1)   The root filesystem should be small.
2)   There should be a per-architecture  centrally-shareable
     read-only /usr filesystem.
3)   Variable per-machine directories should be concentrated
     below a single mount point named /var.
4)   Site-wide  machine  independent  shareable  text  files
     should  be  separated from architecture specific binary
     files and should be concentrated below a  single  mount
     point named /usr/share.
These goals are realized with the following general layouts.
The reorganized root filesystem has the  following  directo-
ries:

/etc     (config files)
/bin     (user binaries needed when single-user)
/sbin    (root binaries needed when single-user)
/local   (locally added binaries used only by this machine)
/tmp     (mount point for memory based filesystem)
/dev     (local devices)
/home    (mount point for AMD)
/var     (mount point for per-machine variable directories)
/usr     (mount point for multiuser binaries and files)

The  reorganized  /usr filesystem has the following directo-
ries:

/usr/bin       (user binaries)
/usr/contrib   (software contributed to 4.4BSD)
/usr/games     (binaries for games, score files in /var)
/usr/include   (standard include files)
/usr/lib       (lib*.a from old /usr/lib)
/usr/libdata   (databases from old /usr/lib)
/usr/libexec   (executables from old /usr/lib)
/usr/local     (locally added binaries used site-wide)
/usr/old       (deprecated binaries)
/usr/sbin      (root binaries)
/usr/share     (mount point for site-wide shared text)
/usr/src       (mount point for sources)

The reorganized  /usr/share  filesystem  has  the  following
directories:



                        May 14, 1994





SMM:1-34                Installing and Operating 4.4BSD UNIX


/usr/share/calendar     (various useful calendar files)
/usr/share/dict         (dictionaries)
/usr/share/doc          (4.4BSD manual sources)
/usr/share/games        (games text files)
/usr/share/groff_font   (groff font information)
/usr/share/man          (typeset manual pages)
/usr/share/misc         (dumping ground for random text files)
/usr/share/mk           (templates for 4.4BSD makefiles)
/usr/share/skel         (template user home directory files)
/usr/share/tmac         (various groff macro packages)
/usr/share/zoneinfo     (information on time zones)

The  reorganized  /var filesystem has the following directo-
ries:

/var/account        (accounting files, formerly /usr/adm)
/var/at             (_a_t(1) spooling area)
/var/backups        (backups of system files)
/var/crash          (crash dumps)
/var/db             (system-wide databases, e.g. tags)
/var/games          (score files)
/var/log            (log files)
/var/mail           (users mail)
/var/obj            (hierarchy to build /usr/src)
/var/preserve       (preserve area for vi)
/var/quotas         (directory to store quota files)
/var/run            (directory to store *.pid files)
/var/rwho           (rwho databases)
/var/spool/ftp      (home directory for anonymous ftp)
/var/spool/mqueue   (sendmail spooling directory)
/var/spool/news     (news spooling area)
/var/spool/output   (printer spooling area)
/var/spool/uucp     (uucp spooling area)
/var/tmp            (disk-based temporary directory)
/var/users          (root of per-machine user home directories)

     The 4.4BSD bootstrap routines pass the identity of  the
boot  device  through  to  the kernel.  The kernel then uses
that device as its root filesystem.  Thus, for  example,  if
you  boot  from  /dev/sd1a,  the kernel will use sd1a as its
root filesystem. If /dev/sd1b is configured as a swap parti-
tion,  it  will  be used as the initial swap area, otherwise
the normal primary swap area (/dev/sd0b) will be used.   The
4.4BSD  bootstrap is backward compatible with 4.3BSD, so you
can replace your old bootstrap if you use it  to  boot  your
first  4.4BSD  kernel.  However, the 4.3BSD bootstrap cannot
access 4.4BSD filesystems, so if you plan  to  convert  your
filesystems  to  4.4BSD,  you  must  install a new bootstrap
_b_e_f_o_r_e doing the conversion.  Note that SPARC  users  cannot
build  a 4.4BSD compatible version of the bootstrap, so must
_n_o_t convert their root filesystem to the new 4.4BSD  format.
     Once  you  have  extracted the 4.4BSD system and booted
from it, you will have to build a kernel customized for your
configuration.   If  you have any local device drivers, they



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-35


will have to be incorporated into the new kernel.  See  sec-
tion  4.1.3 and ``Building 4.3BSD UNIX Systems with Config''
(SMM:2).
     If converting from 4.3BSD, your old filesystems  should
be  converted.   If you've modified the partition sizes from
the original 4.3BSD ones, and  are  not  already  using  the
4.4BSD disk labels, you will have to modify the default disk
partition tables in the kernel.  Make  the  necessary  table
changes  and boot your custom kernel BBEEFFOORREE trying to access
any of your old filesystems!  After doing  this,  if  neces-
sary, the remaining filesystems may be converted in place by
running the 4.4BSD version of _f_s_c_k(8) on each filesystem and
allowing it to make the necessary corrections.  The new ver-
sion of _f_s_c_k is more strict about the  size  of  directories
than  the version supplied with 4.3BSD.  Thus the first time
that it is run on a 4.3BSD filesystem, it will produce  mes-
sages of the form:

     DDIIRREECCTTOORRYY ......:: LLEENNGGTTHH xx NNOOTT MMUULLTTIIPPLLEE OOFF 551122 ((AADDJJUUSSTTEEDD))

Length  ``xx'' will be the size of the directory; it will be
expanded to the next multiple of 512 bytes.   The  new  _f_s_c_k
will also set default _i_n_t_e_r_l_e_a_v_e and _n_p_s_e_c_t (number of phys-
ical sectors per track)  values  on  older  filesystems,  in
which  these fields were unused spares; this correction will
produce messages of the form:

     IIMMPPOOSSSSIIBBLLEE IINNTTEERRLLEEAAVVEE==00 IINN SSUUPPEERRBBLLOOCCKK ((SSEETT TTOO DDEEFFAAUULLTT))3
     IIMMPPOOSSSSIIBBLLEE NNPPSSEECCTT==00 IINN SSUUPPEERRBBLLOOCCKK ((SSEETT TTOO DDEEFFAAUULLTT))

Filesystems that have had their interleave and npsect values
set will be diagnosed by  the  old  _f_s_c_k  as  having  a  bad
superblock; the old _f_s_c_k will run only if given an alternate
superblock (_f_s_c_k _-_b_3_2), in which case it will re-zero  these
fields.   The 4.4BSD kernel will internally set these fields
to their defaults if fsck has not done so; again,  the  _-_b_3_2
option may be necessary for running the old _f_s_c_k.
     In  addition, 4.4BSD removes several limits on filesys-
tem sizes that were present in 4.3BSD.  The limited filesys-
tems  continue to work in 4.4BSD, but should be converted as
soon as it is convenient by  running  _f_s_c_k  with  the  _-_c  _2
option.  The sequence _f_s_c_k _-_p _-_c _2 will update them all, fix
the interleave and npsect fields, fix any  incorrect  direc-
tory  lengths,  expand  maximum  uid's and gid's to 32-bits,
place symbolic links less than 60 bytes  into  their  inode,
and  fill  in  directory  type  fields all at once.  The new
filesystem formats are incompatible with older systems.   If
you  wish to continue using these filesystems with the older
systems you should make only the  compatible  changes  using
-----------
  3 The defaults are to set _i_n_t_e_r_l_e_a_v_e  to  1  and
_n_p_s_e_c_t  to _n_s_e_c_t.  This is correct on most drives;
it affects  only  performance  (usually  virtually
unmeasurably).



                        May 14, 1994





SMM:1-36                Installing and Operating 4.4BSD UNIX


_f_s_c_k _-_c _1.

33..44..  MMeerrggiinngg yyoouurr ffiilleess ffrroomm 44..33BBSSDD iinnttoo 44..44BBSSDD
     When  your  system is booting reliably and you have the
4.4BSD root and /usr filesystems fully installed you will be
ready  to  continue  with  the  next  step in the conversion
process, merging your old files into the new system.
     If you saved the files on a _t_a_r tape, extract them into
a scratch directory, say /usr/convert:

     ## _m_k_d_i_r _/_u_s_r_/_c_o_n_v_e_r_t
     ## _c_d _/_u_s_r_/_c_o_n_v_e_r_t
     ## _t_a_r _x_p

     The data files marked in the previous table with a dag-
ger () may be used without change from the previous  system.
Those  data files marked with a double dagger () have syntax
changes or substantial enhancements.  You should start  with
the 4.4BSD version and carefully integrate any local changes
into the new file.   Usually  these  local  changes  can  be
incorporated without conflict into the new file; some excep-
tions are noted below.  The files marked  with  an  asterisk
(*) require particular attention and are discussed below.
     As described in section 3.3, the most immediately obvi-
ous change in 4.4BSD is the  reorganization  of  the  system
filesystems.   Users  of certain recent vendor releases have
seen this general organization, although  4.4BSD  takes  the
reorganization a bit further.  The directories most affected
are /etc, that now contains only system configuration files;
/var,  a  new filesystem containing per-system spool and log
files; and /usr/share, that contains most of the text  files
shareable  across  architectures  such  as documentation and
macros.  System administration programs formerly in /etc are
now found in /sbin and /usr/sbin.  Various programs and data
files formerly in /usr/lib are now found in /usr/libexec and
/usr/libdata,  respectively.   Administrative files formerly
in /usr/adm are in /var/account and,  similarly,  log  files
are now in /var/log.  The directory /usr/ucb has been merged
into /usr/bin, and the sources for programs in /usr/bin  are
in  /usr/src/usr.bin.  Other source directories parallel the
destination  directories;  /usr/src/etc  has  been   greatly
expanded,  and  /usr/src/share  is  new.  The source for the
manual pages, in general, are with the source code  for  the
applications they document.  Manual pages not closely corre-
sponding  to   an   application   program   are   found   in
/usr/src/share/man.   The  locations  of  all  man  pages is
listed in /usr/src/share/man/man0/man[1-8].  The manual page
_h_i_e_r(7)  has  been  updated  and  made  more detailed; it is
included in the printed documentation.  You should review it
to familiarize yourself with the new layout.
     A new utility, _m_t_r_e_e(8), is provided to build and check
filesystem hierarchies with the proper contents, owners  and
permissions.    Scripts  are  provided  in  /etc/mtree  (and
/usr/src/etc/mtree) for the root, /usr and /var filesystems.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-37


Once  a filesystem has been made for /var, _m_t_r_e_e can be used
to create a directory hierarchy there or you can simply  use
tar  to  extract  the  prototype from the second file of the
distribution tape.

33..44..11..  CChhaannggeess iinn tthhee //eettcc ddiirreeccttoorryy
     The /etc directory now contains nearly  all  the  host-
specific  configuration  files.  Note that some file formats
have changed, and those configuration files containing path-
names  are  nearly  all affected by the reorganization.  See
the examples provided in /etc (installed from  /usr/src/etc)
as  a  guide.   The  following table lists some of the local
configuration files whose  locations  and/or  contents  have
changed.

4.3BSD and Earlier     4.4BSD               Comments
-----------------------------------------------------------------------------
/etc/fstab             /etc/fstab           new format; see below
/etc/inetd.conf        /etc/inetd.conf      pathnames of executables changed
/etc/printcap          /etc/printcap        pathnames changed
/etc/syslog.conf       /etc/syslog.conf     pathnames of log files changed
/etc/ttys              /etc/ttys            pathnames of executables changed
/etc/passwd            /etc/master.passwd   new format; see below
/usr/lib/sendmail.cf   /etc/sendmail.cf     changed pathnames
/usr/lib/aliases       /etc/aliases         may contain changed pathnames
/etc/*.pid             /var/run/*.pid


New in 4.3BSD-Tahoe       4.4BSD                Comments
------------------------------------------------------------------------------------
/usr/games/dm.config      /etc/dm.conf          configuration for games (see _d_m(8))
/etc/zoneinfo/localtime   /etc/localtime        timezone configuration
/etc/zoneinfo             /usr/share/zoneinfo   timezone configuration


    New in 4.4BSD     Comments
--------------------------------------------------------------------
    /etc/aliases.db   database version of the aliases file
    /etc/amd-home     location database of home directories
    /etc/amd-vol      location database of exported filesystems
    /etc/changelist   /etc/security files to back up
    /etc/csh.cshrc    system-wide csh(1) initialization file
    /etc/csh.login    system-wide csh(1) login file
    /etc/csh.logout   system-wide csh(1) logout file
    /etc/disklabels   directory for saving disklabels
    /etc/exports      NFS list of export permissions
    /etc/ftpwelcome   message displayed for ftp users; see ftpd(8)
    /etc/kerberosIV   Kerberos directory; see below
    /etc/man.conf     lists directories searched by _m_a_n(1)
    /etc/mtree        directory for local mtree files; see mtree(8)
    /etc/netgroup     NFS group list used in /etc/exports
    /etc/pwd.db       non-secure hashed user data base file
    /etc/spwd.db      secure hashed user data base file




                        May 14, 1994





SMM:1-38                Installing and Operating 4.4BSD UNIX


    /etc/security     daily system security checker

     System  security  changes  require  adding  several new
``well-known'' groups to /etc/group.  The  groups  that  are
needed by the system as distributed are:

name       number   purpose
------------------------------------------------------------------
wheel         0     users allowed superuser privilege
daemon        1     processes that need less than wheel privilege
kmem          2     read access to kernel memory
sys           3     access to kernel sources
tty           4     access to terminals
operator      5     read access to raw disks
bin           7     group for system binaries
news          8     group for news
wsrc          9     write access to sources
games        13     access to games
staff        20     system staff
guest        31     system guests
nobody       39     the least privileged group
utmp         45     access to utmp files
dialer      117     access to remote ports and dialers


Only  users  in  the  ``wheel'' group are permitted to _s_u to
``root''.   Most  programs  that   manage   directories   in
/var/spool  now run set-group-id to ``daemon'' so that users
cannot directly access the files in the  spool  directories.
The  special  files that access kernel memory, /dev/kmem and
/dev/mem, are made readable only by group  ``kmem''.   Stan-
dard  system programs that require this access are made set-
group-id to that group.  The group ``sys''  is  intended  to
control  access  to kernel sources, and other sources belong
to group ``wsrc.''  Rather than make user terminals writable
by  all users, they are now placed in group ``tty'' and made
only group writable.  Programs that should legitimately have
access  to  write  on user terminals such as _t_a_l_k_d and _w_r_i_t_e
now run set-group-id to  ``tty''.   The  ``operator''  group
controls access to disks.  By default, disks are readable by
group ``operator'',

so that programs such as  _d_u_m_p  can  access  the  filesystem
information  without  being  set-user-id  to  ``root''.  The
_s_h_u_t_d_o_w_n(8) program is executable only by group operator and
is setuid to root so that members of group operator may shut
down the system without root access.
     The  ownership  and  modes  of  some  directories  have
changed.   The  _a_t  programs  now  run  set-user-id ``root''
instead of ``daemon.''  Also, the uucp directory  no  longer
needs  to be publicly writable, as _t_i_p reverts to privileged
status to remove its lock files.  After copying your version
of /var/spool, you should do:




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-39


     ## _c_h_o_w_n _-_R _r_o_o_t _/_v_a_r_/_s_p_o_o_l_/_a_t
     ## _c_h_o_w_n _-_R _u_u_c_p_._d_a_e_m_o_n _/_v_a_r_/_s_p_o_o_l_/_u_u_c_p
     ## _c_h_m_o_d _-_R _o_-_w _/_v_a_r_/_s_p_o_o_l_/_u_u_c_p

     The  format  of  the cron table, /etc/crontab, has been
changed to specify the user-id that should be used to run  a
process.   The  userid  ``nobody''  is frequently useful for
non-privileged programs.  Local changes are  now  put  in  a
separate file, /etc/crontab.local.
     Some  of  the commands previously in /etc/rc.local have
been moved to /etc/rc; several new functions are now handled
by  /etc/rc,  /etc/netstart  and  /etc/rc.local.  You should
look closely at the prototype version  of  these  files  and
read  the  manual  pages  for  the  commands contained in it
before trying to merge your local copy.  Note in  particular
that  _i_f_c_o_n_f_i_g has had many changes, and that host names are
now  fully  specified  as  domain-style  names  (e.g.,  van-
gogh.CS.Berkeley.EDU) for the benefit of the name server.
     Some of the commands previously in /etc/daily have been
moved to /etc/security, and several new functions have  been
added  to /etc/security to do nightly security checks on the
system.   The  script  /etc/daily  runs  /etc/security  each
night,  and mails the output to the super-user.  Some of the
checks done by /etc/security are:

     +o Syntax errors in the password and group files.
     +o Duplicate user and group names and id's.
     +o Dangerous search paths and umask values for the superuser.
     +o Dangerous values in various initialization files.
     +o Dangerous .rhosts files.
     +o Dangerous directory and file ownership or permissions.
     +o Globally exported filesystems.
     +o Dangerous owners or permissions for special devices.

In addition, it reports any changes  to  setuid  and  setgid
files,  special  devices,  or  the  files in /etc/changelist
since the last run of /etc/security.  Backup copies  of  the
files  are saved in /var/backups.  Finally, the system bina-
ries are checksummed and their permissions validated against
the _m_t_r_e_e(8) specifications in /etc/mtree.
     The  C-library  and system binaries on the distribution
tape are compiled with new  versions  of  _g_e_t_h_o_s_t_b_y_n_a_m_e  and
_g_e_t_h_o_s_t_b_y_a_d_d_r  that  use  the name server, _n_a_m_e_d(8).  If you
have only a small network and are not connected to  a  large
network,  you can use the distributed library routines with-
out any problems; they use a linear scan of the  host  table
/etc/hosts if the name server is not running.  If you are on
the Internet or have a large local network, it is  recommend
that  you  set up and use the name server.  For instructions
on how to set up the necessary configuration files, refer to
``Name Server Operations Guide for BIND'' (SMM:10).  Several
programs rely on the host name returned  by  _g_e_t_h_o_s_t_n_a_m_e  to
determine the local domain name.




                        May 14, 1994





SMM:1-40                Installing and Operating 4.4BSD UNIX


     If you are using the name server, your _s_e_n_d_m_a_i_l config-
uration file will need some updates to accommodate it.   See
the  ``Sendmail  Installation  and Operation Guide'' (SMM:8)
and   the   sample   _s_e_n_d_m_a_i_l   configuration    files    in
/usr/src/usr.sbin/sendmail/cf.      The     aliases    file,
/etc/aliases has also been changed to add certain well-known
addresses.

33..44..22..  SShhaaddooww ppaasssswwoorrdd ffiilleess
     The  password  file  format  adds change and expiration
fields and its location has changed to protect the encrypted
passwords  stored  there.   The  actual password file is now
stored in /etc/master.passwd.  The hashed dbm password files
do  not  contain  encrypted  passwords, but contain the file
offset to the entry with the password in  /etc/master.passwd
(that  is  readable only by root).  Thus, the _g_e_t_p_w_n_a_m() and
_g_e_t_p_w_u_i_d() functions will  no  longer  return  an  encrypted
password  string  to  non-root callers.  An old-style passwd
file  is  created  in  /etc/passwd  by   the   _v_i_p_w(8)   and
_p_w_d___m_k_d_b(8) programs.  See also _p_a_s_s_w_d(5).
     Several  new users have also been added to the group of
``well-known'' users in /etc/passwd.  The current list is:


     name       number
     ------------------
     root         0
     daemon       1
     operator     2
     bin          3
     games        7
     uucp         66
     nobody     32767


The ``daemon'' user is used for daemon processes that do not
need  root  privileges.  The ``operator'' user-id is used as
an account for dumpers so that they can log in without  hav-
ing  the root password.  By placing them in the ``operator''
group, they can get read access to the disks.  The  ``uucp''
login has existed long before 4.4BSD, and is noted here just
to provide a common user-id.  The password entry  ``nobody''
has  been  added  to  specify the user with least privilege.
The ``games'' user is a pseudo-user that controls access  to
game programs.
     After  installing  your updated password file, you must
run _p_w_d___m_k_d_b(8) to create the password database.  Note  that
_p_w_d___m_k_d_b(8) is run whenever _v_i_p_w(8) is run.

33..44..33..  TThhee //vvaarr ffiilleessyysstteemm
     The  spooling directories saved on tape may be restored
in their eventual resting places without too  much  concern.
Be  sure  to use the `-p' option to _t_a_r(1) so that files are
recreated with the same file modes.  The following  commands



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-41


provide  a  guide  for  copying  spool and log files from an
existing system into a new /var filesystem.   At  least  the
following  directories should already exist on /var: output,
log, backups and db.

     SRC=/oldroot/usr

     cd $SRC; tar cf - msgs preserve | (cd /var && tar xpf -)


     # copy $SRC/spool to /var
     cd $SRC/spool
     tar cf - at mail rwho | (cd /var && tar xpf -)
     tar cf - ftp mqueue news uucp uucppublic | \
          (cd /var/spool && tar xpf -)


     # everything else in spool is probably a printer area
     mkdir .save
     mv at ftp mail mqueue rwho uucp uucppublic .save
     tar cf - * | (cd /var/spool/output && tar xpf -)
     mv .save/* .
     rmdir .save


     cd /var/spool/mqueue
     mv syslog.7 /var/log/maillog.7
     mv syslog.6 /var/log/maillog.6
     mv syslog.5 /var/log/maillog.5
     mv syslog.4 /var/log/maillog.4
     mv syslog.3 /var/log/maillog.3
     mv syslog.2 /var/log/maillog.2
     mv syslog.1 /var/log/maillog.1
     mv syslog.0 /var/log/maillog.0
     mv syslog /var/log/maillog


     # move $SRC/adm to /var
     cd $SRC/adm
     tar cf - . | (cd /var/account && tar  xpf -)
     cd /var/account
     rm -f msgbuf
     mv messages messages.[0-9] ../log
     mv wtmp wtmp.[0-9] ../log
     mv lastlog ../log


33..55..  BBuugg ffiixxeess aanndd cchhaannggeess bbeettwweeeenn 44..33BBSSDD aanndd 44..44BBSSDD
     The  major  new  facilities  available  in  the  4.4BSD
release are a new virtual memory  system,  the  addition  of
ISO/OSI  networking support, a new virtual filesystem inter-
face  supporting  filesystem  stacking,  a   freely   redis-
tributable  implementation of NFS, a log-structured filesys-
tem, enhancement of the local filesystems to  support  files



                        May 14, 1994





SMM:1-42                Installing and Operating 4.4BSD UNIX


and  filesystems that are up to 2^63 bytes in size, enhanced
security and system management support, and  the  conversion
to and addition of the IEEE Std1003.1 (``POSIX'') facilities
and many of the IEEE  Std1003.2  facilities.   In  addition,
many  new  utilities  and  additions  to  the  C library are
present as well.  The kernel sources have  been  reorganized
to collect all machine-dependent files for each architecture
under one directory, and  most  of  the  machine-independent
code  is  now free of code conditional on specific machines.
The user structure and process structure have  been  reorga-
nized  to eliminate the statically-mapped user structure and
to make most of the process resources shareable by  multiple
processes.  The system and include files have been converted
to be compatible with ANSI C, including function  prototypes
for  most  of  the  exported  functions.  There are numerous
other changes throughout the system.

33..55..11..  CChhaannggeess ttoo tthhee kkeerrnneell
     This release includes several important structural ker-
nel  changes.   The  kernel  uses a new internal system call
convention; the use  of  global  (``u-dot'')  variables  for
parameters and error returns has been eliminated, and inter-
rupted system calls no longer abort using  non-local  goto's
(longjmp's).   A  new  sleep interface separates signal han-
dling from  scheduling  priority,  returning  characteristic
errors  to  abort  or restart the current system call.  This
sleep call also  passes  a  string  describing  the  process
state,  that  is  used  by the ps(1) program.  The old sleep
interface can be used  only  for  non-interruptible  sleeps.
The  sleep  interface  (_t_s_l_e_e_p) can be used at any priority,
but is only interruptible if the PCATCH flag is  set.   When
interrupted, _t_s_l_e_e_p returns EINTR or ERESTART.
     Many  data  structures  that were previously statically
allocated are now allocated dynamically.   These  structures
include mount entries, file entries, user open file descrip-
tors, the process entries, the vnode table, the name  cache,
and the quota structures.
     To protect against indiscriminate reading or writing of
kernel memory, all writing and most reading of  kernel  data
structures  must  be  done using a new ``sysctl'' interface.
The information to  be  accessed  is  described  through  an
extensible ``Management Information Base'' (MIB) style name,
described as a dotted set of  components.   A  new  utility,
_s_y_s_c_t_l(8),  retrieves kernel state and allows processes with
appropriate privilege to set kernel state.

33..55..22..  SSeeccuurriittyy
     The kernel runs with four different levels of security.
Any superuser process can raise the security level, but only
_i_n_i_t()(8) can lower it.  Security levels are defined as fol-
lows:
-1   Permanently  insecure mode - always run system in level
     0 mode.




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-43


  0  Insecure mode - immutable and append-only flags may  be
     turned off.  All devices may be read or written subject
     to their permissions.
  1  Secure mode - immutable and append-only flags  may  not
     be  cleared;  disks  for mounted filesystems, /dev/mem,
     and /dev/kmem are read-only.
  2  Highly secure mode - same as secure  mode,  plus  disks
     are  always  read-only  whether  mounted  or not.  This
     level precludes tampering with filesystems by  unmount-
     ing  them, but also inhibits running _n_e_w_f_s(8) while the
     system is multi-user.  See _c_h_f_l_a_g_s(1) and the -oo option
     to  _l_s(1) for information on setting and displaying the
     immutable and append-only flags.
     Normally, the system runs in level 0 mode while  single
user  and  in  level 1 mode while multiuser.  If the level 2
mode is desired while running multiuser, it can  be  set  in
the  startup  script  /etc/rc  using  _s_y_s_c_t_l(1).   If  it is
desired to run the system in level 0 mode  while  multiuser,
the  administrator  must  build  a  kernel with the variable
securelevel     in     the      kernel      source      file
/sys/kern/kern_sysctl.c initialized to -1.

33..55..22..11..  VViirrttuuaall mmeemmoorryy cchhaannggeess
     The  new  virtual memory implementation is derived from
the Mach operating system developed at Carnegie-Mellon,  and
was  ported to the BSD kernel at the University of Utah.  It
is based on the 2.0 release of Mach  (with  some  bug  fixes
from  the  2.5  and  3.0  releases)  and retains many of its
essential features such as the  separation  of  the  machine
dependent  and  independent layers (the ``pmap'' interface),
efficient memory utilization using copy-on-write  and  other
lazy-evaluation  techniques,  and  support for large, sparse
address spaces.  It does not include the ``external  pager''
interface  instead  using  a primitive internal pager inter-
face.  The Mach virtual memory  system  call  interface  has
been replaced with the ``mmap''-based interface described in
the ``Berkeley Software Architecture Manual'' (see UNIX Pro-
grammer's  Manual,  Supplementary  Documents,  PSD:5).   The
interface is similar to the interfaces  shipped  by  several
commercial  vendors  such  as  Sun, USL, and Convex Computer
Corp.  The integration of the new virtual  memory  is  func-
tionally  complete,  but still has serious performance prob-
lems under heavy memory load.  The  internal  kernel  inter-
faces  have  not  yet been completed and the memory pool and
buffer cache have not been merged.  Some additional caveats:
+o    Since  the  code  is  based on the 2.0 release of Mach,
     bugs and misfeatures of the BSD version should  not  be
     considered  short-comings  of  the current Mach virtual
     memory system.
+o    Because of the disjoint virtual memory  (page)  and  IO
     (buffer)  caches, it is possible to see inconsistencies
     if using both the mmap and read/write interfaces on the
     same file simultaneously.




                        May 14, 1994





SMM:1-44                Installing and Operating 4.4BSD UNIX


+o    Swap  space is allocated on-demand rather than up front
     and no allocation checks are performed so it is  possi-
     ble to over-commit memory and eventually deadlock.
+o    The  semantics of the _v_f_o_r_k(2) system call are slightly
     different.   The  synchronization  between  parent  and
     child  is  preserved,  but the memory sharing aspect is
     not.  In practice this has  been  enough  for  backward
     compatibility,  but newer code should just use _f_o_r_k(2).

33..55..22..22..  NNeettwwoorrkkiinngg aaddddiittiioonnss aanndd cchhaannggeess
     The ISO/OSI Networking consists of a kernel implementa-
tion  of transport class 4 (TP-4), connectionless networking
protocol (CLNP), and 802.3-based link-level  support  (hard-
ware-compatible with Ethernet4).  We  also  include  support
for  ISO  Connection-Oriented  Network  Service, X.25, TP-0.
The session and presentation layers are provided outside the
kernel  using  the  ISO  Development Environment by Marshall
Rose, that is  available  via  anonymous  FTP  (but  is  not
included on the distribution tape).  Included in this devel-
opment environment are file transfer and management  (FTAM),
virtual  terminals (VT), a directory services implementation
(X.500), and miscellaneous other utilities.
     Kernel support for the ISO  OSI  protocols  is  enabled
with  the  ISO option in the kernel configuration file.  The
_i_s_o(4) manual page describes the protocols  and  addressing;
see  also _c_l_n_p(4), _t_p(4) and _c_l_t_p(4).  The OSI equivalent to
ARP is ESIS (End System to Intermediate System Routing  Pro-
tocol);  running this protocol is mandatory, however one can
manually add translations for machines that do not  partici-
pate by use of the _r_o_u_t_e(8) command.  Additional information
is provided in the manual page describing _e_s_i_s(4).
     The command _r_o_u_t_e(8) has a new syntax and  several  new
capabilities:  it can install routes with a specified desti-
nation and mask, and can change route  characteristics  such
as hop count, packet size and window size.
     Several  important  enhancements have been added to the
TCP/IP protocols including TCP header prediction and  serial
line  IP (SLIP) with header compression.  The routing imple-
mentation has been completely rewritten to use a  hierarchi-
cal  routing tree with a mask per route to support the arbi-
trary levels of routing found in  the  ISO  protocols.   The
routing  table  also stores and caches route characteristics
to speed the adaptation of  the  throughput  and  congestion
avoidance algorithms.
     The  format  of  the  _s_o_c_k_a_d_d_r structure (the structure
used to describe a generic network address with  an  address
family  and  family-specific data) has changed from previous
releases, as have the address  family-specific  versions  of
this  structure.   The _s_a___f_a_m_i_l_y family field has been split
into a length, sa_len,  and  a  family,  sa_family.   System
calls  that  pass a _s_o_c_k_a_d_d_r structure into the kernel (e.g.
-----------
  4 Ethernet  is a trademark of the Xerox Corpora-
tion.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-45


_s_e_n_d_t_o() and _c_o_n_n_e_c_t()) have a separate parameter that spec-
ifies  the  _s_o_c_k_a_d_d_r length, and thus it is not necessary to
fill in the _s_a___l_e_n field for  those  system  calls.   System
calls  that  pass  a _s_o_c_k_a_d_d_r structure back from the kernel
(e.g.  _r_e_c_v_f_r_o_m() and _a_c_c_e_p_t()) receive a completely filled-
in  _s_o_c_k_a_d_d_r  structure,  thus  the  length  field is valid.
Because this would  not  work  for  old  binaries,  the  new
library  uses  a  different  system call number.  Thus, most
networking programs compiled under 4.4BSD  are  incompatible
with older systems.
     Although  this  change is mostly source and binary com-
patible with old programs, there are three exceptions.  Pro-
grams  with statically initialized _s_o_c_k_a_d_d_r structures (usu-
ally the Internet form, a _s_o_c_k_a_d_d_r___i_n) are  not  compatible.
Generally,  such  programs  should be changed to fill in the
structure at run time, as C allows no way  to  initialize  a
structure  without  assuming the order and number of fields.
Also, programs with use structures  to  describe  a  network
packet format that contain embedded _s_o_c_k_a_d_d_r structures also
require change; a definition of an  _o_s_o_c_k_a_d_d_r  structure  is
provided  for  this purpose.  Finally, programs that use the
SIOCGIFCONF ioctl  to  get  a  complete  list  of  interface
addresses  need  to  check  the  _s_a___l_e_n field when iterating
through the array of addresses  returned,  as  not  all  the
structures  returned  have the same length (this variance in
length is nearly guaranteed by the  presence  of  link-layer
address structures).


33..55..22..33..  AAddddiittiioonnss aanndd cchhaannggeess ttoo ffiilleessyysstteemmss
     The 4.4BSD distribution contains most of the interfaces
specified in the IEEE Std1003.1 system  interface  standard.
Filesystem  additions  include  IEEE  Std1003.1 FIFOs, byte-
range file locking, and saved user and group identifiers.
     A new virtual filesystem interface has  been  added  to
the  kernel  to support multiple filesystems.  In comparison
with other  interfaces,  the  Berkeley  interface  has  been
structured  for  more  efficient support of filesystems that
maintain state (such as the local filesystem).   The  inter-
face  has  been extended with support for stackable filesys-
tems done at UCLA.  These extensions allow  for  filesystems
to be layered on top of each other and allow new vnode oper-
ations to be added without  requiring  changes  to  existing
filesystem  implementations.  For example, the umap filesys-
tem (see _m_o_u_n_t___u_m_a_p(8)) is used to mount a  sub-tree  of  an
existing  filesystem  that  uses a different set of uids and
gids than the local system.   Such  a  filesystem  could  be
mounted from a remote site via NFS or it could be a filesys-
tem on removable media brought from  some  foreign  location
that uses a different password file.
     Other  new  filesystems that may be stacked include the
loopback filesystem  _m_o_u_n_t___l_o_f_s(8),  the  kernel  filesystem
_m_o_u_n_t___k_e_r_n_f_s(8),  and the portal filesystem _m_o_u_n_t___p_o_r_t_a_l(8).




                        May 14, 1994





SMM:1-46                Installing and Operating 4.4BSD UNIX


     The buffer cache in the kernel is now  organized  as  a
file  block  cache  rather  than a device block cache.  As a
consequence, cached blocks from a file and from  the  corre-
sponding  block  device  would no longer be kept consistent.
The block device thus has  little  remaining  value.   Three
changes have been made for these reasons:
1)   block devices may not be opened while they are mounted,
     and may not be mounted while open, so that the two ver-
     sions of cached file blocks cannot be created,
2)   filesystem checks of the root now use the raw device to
     access the root filesystem, and
3)   the root filesystem is initially mounted  read-only  so
     that  nothing  can  be  written  back to disk during or
     after change to the raw filesystem by _f_s_c_k.
The root filesystem may be made writable  while  in  single-
user mode with the command:

     mount -uw /

The  mount  command  has  an option to update the flags on a
mounted filesystem,  including  the  ability  to  upgrade  a
filesystem from read-only to read-write or downgrade it from
read-write to read-only.
     In addition to the local ``fast filesystem'',  we  have
added an implementation of the network filesystem (NFS) that
fully interoperates with the NFS  shipped  by  Sun  and  its
licensees.   Because  our NFS implementation was implemented
by Rick Macklem of the University of Guelph using  only  the
publicly  available NFS specification, it does not require a
license from Sun to  use  in  source  or  binary  form.   By
default  it runs over UDP to be compatible with Sun's imple-
mentation.  However, it can be  configured  on  a  per-mount
basis  to  run  over  TCP.   Using  TCP allows it to be used
quickly and efficiently through gateways and over  long-haul
networks.  Using an extended protocol, it supports Leases to
allow a limited callback mechanism that greatly reduces  the
network  traffic  necessary  to  maintain  cache consistency
between the server and its clients.  Its use will be  famil-
iar  to users of other implementations of NFS.  See the man-
ual pages _m_o_u_n_t(8), _m_o_u_n_t_d(8),  _f_s_t_a_b(5),  _e_x_p_o_r_t_s(5),  _n_e_t_-
_g_r_o_u_p(5),  _n_f_s_d(8), _n_f_s_i_o_d(8), and _n_f_s_s_v_c(8).  and the docu-
ment ``The 4.4BSD NFS Implementation'' (SMM:6)  for  further
information.  The format of /etc/fstab has changed from pre-
vious BSD releases to  a  blank-separated  format  to  allow
colons in pathnames.
     A  new  local filesystem, the log-structured filesystem
(LFS), has been added to the system.  It provides near disk-
speed  output  and fast crash recovery.  This work is based,
in part, on the LFS filesystem created for the Sprite  oper-
ating  system  at Berkeley.  While the kernel implementation
is almost complete, only some of the  utilities  to  support
the  filesystem have been written, so we do not recommend it
for  production  use.   See  _n_e_w_l_f_s(8),   _m_o_u_n_t___l_f_s(8)   and
_l_f_s___c_l_e_a_n_e_r_d(8)   for  more  information.   For  a  in-depth



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-47


description of the implementation and performance character-
istics  of  log-structured  filesystems in general, and this
one in particular, see Dr. Margo Seltzer's doctoral  thesis,
available from the University of California Computer Science
Department.
     We have also added a memory-based filesystem that  runs
in  pageable  memory,  allowing  large temporary filesystems
without requiring dedicated physical memory.
     The local ``fast filesystem'' has been enhanced  to  do
clustering that allows large pieces of files to be allocated
contiguously  resulting  in  near  doubling  of   filesystem
throughput.   The  filesystem interface has been extended to
allow files and filesystems to grow to 2^63 bytes  in  size.
The quota system has been rewritten to support both user and
group quotas (simultaneously if desired).  Quota  expiration
is  based  on time rather than the previous metric of number
of logins over quota.  This change makes quotas more  useful
on fileservers onto which users seldom login.
     The  system  security  has been greatly enhanced by the
addition of additional file flags that permit a file  to  be
marked  as  immutable or append only.  Once set, these flags
can only be cleared by the super-user  when  the  system  is
running  in insecure mode (normally, single-user).  In addi-
tion to the immutable and append-only flags, the  filesystem
supports  a  new user-settable flag ``nodump''.  (File flags
are set using the _c_h_f_l_a_g_s(1) utility.)  When set on a  file,
_d_u_m_p(8)  will  omit  the  file  from incremental backups but
retain them on full backups.  See the ``-h'' flag to _d_u_m_p(8)
for  details  on how to change this default.  The ``nodump''
flag is usually set on core dumps, system crash  dumps,  and
object  files generated by the compiler.  Note that the flag
is not preserved when files are copied so that installing an
object file will cause it to be preserved.
     The  filesystem format used in 4.4BSD has several addi-
tions.  Directory entries have an additional field,  d_type,
that identifies the type of the entry (normally found in the
st_mode field of the stat structure).  This field is partic-
ularly  useful  for identifying directories without the need
to use _s_t_a_t(2).
     Short (less than sixty byte)  symbolic  links  are  now
stored  in  the  inode itself rather than in a separate data
block.  This saves disk space and makes access  of  symbolic
links  faster.  Short symbolic links are not given a special
type, so a user-level application is unaware of  their  spe-
cial  treatment.   Unlike pre-4.4BSD systems, symbolic links
do not have  an  owner,  group,  access  mode,  times,  etc.
Instead,  these attributes are taken from the directory that
contains the link.  The only  attributes  returned  from  an
_l_s_t_a_t(2) that refer to the symbolic link itself are the file
type (S_IFLNK), size, blocks, and link count (always 1).
     An implementation of an auto-mounter daemon,  _a_m_d,  was
contributed  by  Jan-Simon Pendry of the Imperial College of
Science, Technology & Medicine.  See the  document  ``AMD  -
The 4.4BSD Automounter'' (SMM:13) for further information.



                        May 14, 1994





SMM:1-48                Installing and Operating 4.4BSD UNIX


     The  directory /dev/fd contains special files 0 through
63 that,  when  opened,  duplicate  the  corresponding  file
descriptor.    The   names   /dev/stdin,   /dev/stdout   and
/dev/stderr refer to file descriptors 0, 1 and 2.  See _f_d(4)
and _m_o_u_n_t___f_d_e_s_c(8) for more information.

33..55..22..44..  PPOOSSIIXX tteerrmmiinnaall ddrriivveerr cchhaannggeess
     The  4.4BSD system uses the IEEE P1003.1 (POSIX.1) ter-
minal interface rather than the previous BSD terminal inter-
face.  The terminal driver is similar to the System V termi-
nal driver with the addition of the necessary extensions  to
get  the  functionality  previously  available in the 4.3BSD
terminal driver.  Both the old _i_o_c_t_l calls and  old  options
to  _s_t_t_y(1)  are emulated.  This emulation is expected to be
unavailable in many vendors releases, so conversion  to  the
new interface is encouraged.
     4.4BSD  also adds the IEEE Std1003.1 job control inter-
face, that is similar to the 4.3BSD job  control  interface,
but adds a security model that was missing in the 4.3BSD job
control implementation.  A new system call,  _s_e_t_s_i_d(),  cre-
ates  a  job-control  session consisting of a single process
group with one member, the caller, that  becomes  a  session
leader.   Only  a  session  leader may acquire a controlling
terminal.  This is done explicitly via a  TIOCSCTTY  _i_o_c_t_l()
call,  not  implicitly by an _o_p_e_n() call.  The call fails if
the terminal is in use.  Programs that allocate  controlling
terminals  (or  pseudo-terminals)  require change to work in
this environment.  The versions of  _x_t_e_r_m  provided  in  the
X11R5  release  includes the necessary changes.  New library
routines  are  available  for  allocating  and  initializing
pseudo-terminals  and  other terminals as controlling termi-
nal; see /usr/src/lib/libutil/pty.c  and  /usr/src/lib/libu-
til/login_tty.c.
     The  POSIX  job  control  model formalizes the previous
conventions used in setting up a  process  group.   Unfortu-
nately,  this  requires  that  changes  be made in a defined
order and with some synchronization that were not  necessary
in  the past.  Older job control shells (csh, ksh) will gen-
erally not operate correctly with the new system.
     Most of the other kernel interfaces have  been  changed
to correspond with the POSIX.1 interface, although that work
is not complete.  See the relevant manual pages and the IEEE
POSIX standard.


33..55..22..55..  NNaattiivvee ooppeerraattiinngg ssyysstteemm ccoommppaattiibbiilliittyy
     Both  the  HP300 and SPARC ports feature the ability to
run binaries built for the native operating system (HP-UX or
SunOS)  by  emulating their system calls.  Building an HP300
kernel with the HPUXCOMPAT and  COMPAT_OHPUX  options  or  a
SPARC  kernel  with the COMPAT_SUNOS option will enable this
feature (on by default in the generic kernel provided in the
root filesystem image).  Though this native operating system
compatibility was provided by the developers as  needed  for



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-49


their  purposes  and is by no means complete, it is complete
enough to run  several  non-trivial  applications  including
those  that  require  HP-UX  or SunOS shared libraries.  For
example, the vendor supplied X11 server and windowing  envi-
ronment can be used on both the HP300 and SPARC.
     It  is important to remember that merely copying over a
native binary and executing it  (or  executing  it  directly
across  NFS)  does  not imply that it will run.  All but the
most trivial of applications are likely to require access to
auxiliary  files  that  do  not  exist  under  4.4BSD  (e.g.
/etc/ld.so.cache) or have a slightly different format  (e.g.
/etc/passwd).   However,  by  using  system call tracing and
through creative use  of  symlinks,  many  problems  can  be
tracked down and corrected.
     The  DECstation port also has code for ULTRIX emulation
(kernel option ULTRIXCOMPAT, not compiled into  the  generic
kernel)  but  it was used primarily for initially bootstrap-
ping the port and has not been used since.  Hence, some work
may be required to make it generally useful.

33..55..33..  CChhaannggeess ttoo tthhee uuttiilliittiieess
     We  have  been  tracking  the  IEEE Std1003.2 shell and
utility work and have included prototypes  of  many  of  the
proposed  utilities  based  on draft 12 of the POSIX.2 Shell
and Utilities document.  Because  most  of  the  traditional
utilities have been replaced with implementations conformant
to the POSIX standards, you should realize that the  utility
software  may  not be as stable, reliable or well documented
as in traditional Berkeley releases.  In particular,  almost
the  entire  manual  suite has been rewritten to reflect the
POSIX defined interfaces, and in some instances it does  not
correctly  reflect the current state of the software.  It is
also worth noting that, in rewriting this software, we  have
generally   been   rewarded   with  significant  performance
improvements.  Most of the libraries and header  files  have
been  converted  to  be  compliant with ANSI C.  The shipped
compiler (gcc) is a superset of ANSI C, but supports  tradi-
tional C as a command-line option.  The system libraries and
utilities all compile with either ANSI or traditional C.

33..55..33..11..  MMaakkee aanndd MMaakkeeffiilleess
     This release uses a completely new version of the  _m_a_k_e
program  derived  from  the  _p_m_a_k_e  program developed by the
Sprite project at Berkeley.  It supports existing makefiles,
although  certain  incorrect  makefiles may fail.  The make-
files for the 4.4BSD sources make extensive use of  the  new
facilities,  especially conditionals and file inclusion, and
are thus completely incompatible with older versions of _m_a_k_e
(but  nearly all the makefiles are now trivial!).  The stan-
dard include files for _m_a_k_e are in /usr/share/mk.  There  is
a bsd.README file in /usr/src/share/mk.
     Another  global  change  supported  by  the new _m_a_k_e is
designed to allow multiple architectures to share a copy  of
the  sources.  If a subdirectory named obj is present in the



                        May 14, 1994





SMM:1-50                Installing and Operating 4.4BSD UNIX


current directory, _m_a_k_e descends  into  that  directory  and
creates  all  object  and other files there.  We use this by
building a directory hierarchy in  /var/obj  that  parallels
/usr/src.  We then create the obj subdirectories in /usr/src
as  symbolic  links  to  the  corresponding  directories  in
/var/obj.   (This  step  is  automated.   The command ``make
obj'' in /usr/src builds both  the  local  symlink  and  the
shadow  directory,  using  /usr/obj,  that may be a symbolic
link, as the root of the shadow tree.  The use  of  /usr/obj
is for historic reasons only, and the system make configura-
tion files in /usr/share/mk can trivially be modified to use
/var/obj  instead.)   We  have one /var/obj hierarchy on the
local system, and another on each  system  that  shares  the
source  filesystem.   All the sources in /usr/src except for
/usr/src/contrib and portions of /usr/src/old have been con-
verted  to  use  the  new  make and obj subdirectories; this
change allows compilation for  multiple  architectures  from
the same source tree (that may be mounted read-only).

33..55..33..22..  KKeerrbbeerrooss
     The Kerberos authentication server from MIT (version 4)
is included in this release.  See _k_e_r_b_e_r_o_s(1) for a general,
if   MIT-specific,   introduction.   If  it  is  configured,
_l_o_g_i_n(1), _p_a_s_s_w_d(1), _r_l_o_g_i_n(1) and _r_s_h(1) will all begin  to
use   it  automatically.   The  file  /etc/kerberosIV/README
describes the configuration.  Each  system  needs  the  file
/etc/kerberosIV/krb.conf to set its realm and local servers,
and a private  key  stored  in  /etc/kerberosIV/srvtab  (see
_e_x_t___s_r_v_t_a_b(8)).   The  Kerberos server should be set up on a
single, physically secure, server machine.  Users and  hosts
may   be   added   to  the  server  database  manually  with
_k_d_b___e_d_i_t(8), or users on authorized hosts can add themselves
and   a   Kerberos  password  after  verification  of  their
``local'' (passwd-file) password using the _r_e_g_i_s_t_e_r(1)  pro-
gram.
     Note  that  by  default  the  password-changing program
_p_a_s_s_w_d(1) changes the Kerberos password,  that  must  exist.
The -l option to _p_a_s_s_w_d(1) changes the ``local'' password if
one exists.
     Note that Version 5 of Kerberos will be released  soon;
Version 4 should probably be replaced at that time.

33..55..33..33..  TTiimmeezzoonnee ssuuppppoorrtt
     The timezone conversion code in the C library uses data
files  installed  in  /usr/share/zoneinfo  to  convert  from
``GMT'' to various timezones.  The data file for the default
timezone for the system should be copied to  /etc/localtime.
Other  timezones  can be selected by setting the TZ environ-
ment variable.
     The data files initially installed in  /usr/share/zone-
info  include  corrections for leap seconds since the begin-
ning of 1970.  Thus, they assume that the kernel will incre-
ment  the time at a constant rate during a leap second; that
is, time just keeps on  ticking.   The  conversion  routines



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-51


will  then  name  a leap second 23:59:60.  For purists, this
effectively means that the kernel  maintains  TAI  (Interna-
tional  Atomic  Time) rather than UTC (Coordinated Universal
Time, aka GMT).
     For systems that run current NTP (Network  Time  Proto-
col)  implementations  or that wish to conform to the letter
of the POSIX.1 law, it is possible to rebuild  the  timezone
data  files  so  that  leap  seconds  are not counted.  (NTP
causes the time to jump over a leap second, and POSIX effec-
tively  requires  the  clock to be reset by hand when a leap
second occurs.  In this mode, the  kernel  effectively  runs
UTC rather than TAI.)
     The data files without leap second information are con-
structed from the source directory, /usr/src/share/zoneinfo.
Change  the  variable  REDO  in  Makefile  from ``right'' to
``posix'', and then do

     make obj  (if necessary)
     make
     make install

     You will then need to copy  the  correct  default  zone
file to /etc/localtime, as the old one would still have used
leap seconds, and because the Makefile  installs  a  default
/etc/localtime each time ``make install'' is done.
     It  is  possible  to install both sets of timezone data
files.   This  results  in  subdirectories  /usr/share/zone-
info/right  and  /usr/share/zoneinfo/posix.   Each contain a
complete  set  of  zone  files.   See   /usr/src/share/zone-
info/Makefile for details.

33..55..33..44..  AAddddiittiioonnss aanndd cchhaannggeess ttoo tthhee lliibbrraarriieess
     Notable additions to the libraries include functions to
traverse a  filesystem  hierarchy,  database  interfaces  to
btree and hashing functions, a new, faster implementation of
stdio and a radix and merge sort functions.
     The _f_t_s(3) functions will do either physical or logical
traversal  of a file hierarchy as well as handle essentially
infinite depth filesystems and filesystems with cycles.  All
the utilities in 4.4BSD which traverse file hierarchies have
been converted to use _f_t_s(3).   The  conversion  has  always
resulted in a significant performance gain, often of four or
five to one in system time.
     The _d_b_o_p_e_n(3) functions are intended to be a family  of
database   access   methods.   Currently,  they  consist  of
_h_a_s_h(3), an extensible, dynamic hashing scheme, _b_t_r_e_e(3),  a
sorted,  balanced tree structure (B+tree's), and _r_e_c_n_o(3), a
flat-file interface for fixed  or  variable  length  records
referenced  by  logical  record  number.  Each of the access
methods stores associated key/data pairs and uses  the  same
record oriented interface for access.
     The _q_s_o_r_t(3) function has been rewritten for additional
performance.  In addition, three new types of sorting  func-
tions,  _h_e_a_p_s_o_r_t(3), _m_e_r_g_e_s_o_r_t(3) and _r_a_d_i_x_s_o_r_t(3) have been



                        May 14, 1994





SMM:1-52                Installing and Operating 4.4BSD UNIX


added to the system.  The _m_e_r_g_e_s_o_r_t  function  is  optimized
for  data  with pre-existing order, in which case it usually
significantly outperforms _q_s_o_r_t.  The _r_a_d_i_x_s_o_r_t(3) functions
are  variants  of most-significant-byte radix sorting.  They
take time linear to the number of bytes to be  sorted,  usu-
ally  significantly  outperforming _q_s_o_r_t on data that can be
sorted in this fashion.   An  implementation  of  the  POSIX
1003.2  standard _s_o_r_t(1), based on _r_a_d_i_x_s_o_r_t, is included in
/usr/src/contrib/sort.
     Some additional comments about the 4.4BSD C library:
+o    The floating point support in the C  library  has  been
     replaced and is now accurate.
+o    The  C functions specified by both ANSI C, POSIX 1003.1
     and 1003.2  are  now  part  of  the  C  library.   This
     includes support for file name matching, shell globbing
     and both basic and extended regular expressions.
+o    ANSI C multibyte and wide-character  support  has  been
     integrated.  The rune functionality from the Bell Labs'
     Plan 9 system is provided as well.
+o    The _t_e_r_m_c_a_p(3)  functions  have  been  generalized  and
     replaced  with  a  general purpose interface named _g_e_t_-
     _c_a_p(3).
+o    The _s_t_d_i_o(3) routines have been replaced, and are  usu-
     ally  much  faster.  In addition, the _f_u_n_o_p_e_n(3) inter-
     face permits applications  to  provide  their  own  I/O
     stream function support.
     The  _c_u_r_s_e_s(3)  library  has  been  largely  rewritten.
Important additional features include support for  scrolling
and _t_e_r_m_i_o_s(3).
     An   application   front-end   editing  library,  named
libedit, has been added to the system.
     A superset implementation of the  SunOS  kernel  memory
interface library, libkvm, has been integrated into the sys-
tem.

33..55..33..55..  AAddddiittiioonnss aanndd cchhaannggeess ttoo ootthheerr uuttiilliittiieess
     There are many new utilities, offering many  new  capa-
bilities,  in  4.4BSD.   Skimming  through the section 1 and
section 8 manual pages is sure to be useful.  The  additions
to  the  utility  suite include greatly enhanced versions of
programs that display system status information, implementa-
tions  of  various  traditional  tools described in the IEEE
Std1003.2 standard, new  tools  not  previous  available  on
Berkeley  UNIX  systems, and many others.  Also, with only a
very few exceptions, all  the  utilities  from  4.3BSD  that
included  proprietary  source  code  have been replaced, and
their 4.4BSD counterparts are freely redistributable.   Nor-
mally,  this replacement resulted in significant performance
improvements and the increase of the limits imposed on  data
by the utility as well.
     A summary of specific additions and changes are as fol-
lows:





                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-53


amd          An auto-mounter implementation.
ar           Replacement of the historic archive format with a new one.
awk          Replaced by gawk; see /usr/src/old/awk for the historic version.
bdes         Utility implementing DES modes of operation described in FIPS PUB 81.
calendar     Addition of an interface for system calendars.
cap_mkdb     Utility for building hashed versions of termcap style databases.
cc           Replacement of pcc with gcc suite.
chflags      A utility for setting the per-file user and system flags.
chfn         An editor based replacement for changing user information.
chpass       An editor based replacement for changing user information.
chsh         An editor based replacement for changing user information.
cksum        The POSIX 1003.2 checksum utility; compatible with sum.
column       A columnar text formatting utility.
cp           POSIX 1003.2 compatible, able to copy special files.
csh          Freely redistributable and 8-bit clean.
date         User specified formats added.
dd           New EBCDIC conversion tables, major performance improvements.
dev_mkdb     Hashed interface to devices.
dm           Dungeon master.
find         Several new options and primaries, major performance improvements.
fstat        Utility displaying information on files open on the system.
ftpd         Connection logging added.
hexdump      A binary dump utility, superseding od.
id           The POSIX 1003.2 user identification utility.
inetd        Tcpmux added.
jot          A text formatting utility.
kdump        A system-call tracing facility.
ktrace       A system-call tracing facility.
kvm_mkdb     Hashed interface to the kernel name list.
lam          A text formatting utility.
lex          A new, freely redistributable, significantly faster version.
locate       A database of the system files, by name, constructed weekly.
logname      The POSIX 1003.2 user identification utility.
mail.local   New local mail delivery agent, replacing mail.
make         Replaced with a new, more powerful make, supporting include files.
man          Added support for man page location configuration.
mkdep        A new utility for generating make dependency lists.
mkfifo       The POSIX 1003.2 FIFO creation utility.
mtree        A new utility for mapping file hierarchies to a file.
nfsstat      An NFS statistics utility.
nvi          A freely redistributable replacement for the ex/vi editors.
pax          The POSIX 1003.2 replacement for cpio and tar.
printf       The POSIX 1003.2 replacement for echo.
roff         Replaced by groff; see /usr/src/old/roff for the historic versions.
rs           New utility for text formatting.
shar         An archive building utility.
sysctl       MIB-style interface to system state.
tcopy        Fast tape-to-tape copying and verification.
touch        Time and file reference specifications.
tput         The POSIX 1003.2 terminal display utility.
tr           Addition of character classes.
uname        The POSIX 1003.2 system identification utility.
vis          A filter for converting and displaying non-printable characters.




                        May 14, 1994





SMM:1-54                Installing and Operating 4.4BSD UNIX


xargs        The POSIX 1003.2 argument list constructor utility.
yacc         A new, freely redistributable, significantly faster version.

     The new  versions  of  _l_e_x(1)  (``flex'')  and  _y_a_c_c(1)
(``zoo'')  should  be  installed  early  on if attempting to
cross-compile 4.4BSD on another system.  Note that  the  new
_l_e_x  program is not completely backward compatible with his-
toric versions of _l_e_x, although it is believed that all doc-
umented features are supported.
     The _f_i_n_d utility has two new options that are important
to be aware of if you intend to use NFS.  The ``fstype'' and
``prune''  options can be used together to prevent find from
crossing NFS mount points.  See /etc/daily for an example of
their use.

33..66..  HHiinnttss oonn ccoonnvveerrttiinngg ffrroomm 44..33BBSSDD ttoo 44..44BBSSDD
     This  section  summarizes  changes  between  4.3BSD and
4.4BSD that are likely to cause difficulty in doing the con-
version.   It  does  not include changes in the network; see
section 5 for information on setting up the network.
     Since the stat st_size field is now 64-bits instead  of
32, doing something like:

     foo(st.st_size);

and  then  (improperly)  defining  foo  with  an  ``int'' or
``long'' parameter:

     foo(size)
          int size;
     {
          ...
     }

will fail miserably (well, it might work on a little  endian
machine).   This  problem  showed  up in _e_m_a_c_s(1) as well as
several other programs.  A  related  problem  is  improperly
casting   (or  failing  to  cast)  the  second  argument  to
_l_s_e_e_k(2), _t_r_u_n_c_a_t_e(2), or _f_t_r_u_n_c_a_t_e(2) ala:

     lseek(fd, (long)off, 0);

or

     lseek(fd, 0, 0);

The best solution is to include <unistd.h> which has  proto-
types that catch these types of errors.
     Determining  the ``namelen'' parameter for a _c_o_n_n_e_c_t(2)
call on a unix domain  socket  should  use  the  ``SUN_LEN''
macro from <sys/un.h>.  One old way that was used:

     addrlen = strlen(unaddr.sun_path) + sizeof(unaddr.sun_family);




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-55


no longer works as there is an additional sun_len field.
     The kernel's limit on the number of open files has been
increased from 20 to 64.  It is now possible to change  this
limit almost arbitrarily.  The standard I/O library autocon-
figures to the kernel  limit.   Note  that  file  (``_iob'')
entries  may be allocated by _m_a_l_l_o_c from _f_o_p_e_n; this alloca-
tion has been known to cause problems with programs that use
their  own  memory  allocators.   Memory allocation does not
occur until after 20 files have been opened by the  standard
I/O library.
     _S_e_l_e_c_t  can  be  used  with more than 32 descriptors by
using arrays of iinntts for the bit fields rather  than  single
iinntts.  Programs that used _g_e_t_d_t_a_b_l_e_s_i_z_e as their first argu-
ment to _s_e_l_e_c_t will no longer work correctly.   Usually  the
program  can  be modified to correctly specify the number of
bits in an iinntt.  Alternatively the program can  be  modified
to  use  an array of iinntts.  There are a set of macros avail-
able in <sys/types.h> to simplify this.  See _s_e_l_e_c_t(2).
     Old core files will not be intelligible by the  current
debuggers  because of numerous changes to the user structure
and because the kernel stack has been enlarged.   The  _a_._o_u_t
header  that was in the user structure is no longer present.
Locally-written debuggers that try to check the magic number
will need to be changed.
     Files  may  not  be deleted from directories having the
``sticky'' (ISVTX) bit set in  their  modes  except  by  the
owner  of the file or of the directory, or by the superuser.
This is primarily  to  protect  users'  files  in  publicly-
writable  directories  such  as /tmp and /var/tmp.  All pub-
licly-writable directories should have their ``sticky'' bits
set with ``chmod +t.''
     The  following  two  sections  contain additional notes
about changes in 4.4BSD  that  affect  the  installation  of
local files; be sure to read them as well.

44..  SSyysstteemm sseettuupp
     This  section  describes  procedures  used  to set up a
4.4BSD UNIX system.  These procedures are used when a system
is first installed or when the system configuration changes.
Procedures for normal system operation are described in  the
next section.

44..11..  KKeerrnneell ccoonnffiigguurraattiioonn
     This section briefly describes the layout of the kernel
code and how files for devices are made.  For a full discus-
sion  of configuring and building system images, consult the
document  ``Building  4.3BSD  UNIX  Systems  with   Config''
(SMM:2).

44..11..11..  KKeerrnneell oorrggaanniizzaattiioonn
     As  distributed, the kernel source is in a separate tar
image.  The source may be physically located anywhere within
any filesystem so long as a symbolic link to the location is
created for the file /sys (many files  in  /usr/include  are



                        May 14, 1994





SMM:1-56                Installing and Operating 4.4BSD UNIX


normally  symbolic links relative to /sys).  In further dis-
cussions of the system source all path names will  be  given
relative to /sys.
The kernel is made up of several large generic parts:

sys               main kernel header files
kern              kernel functions broken down as follows
         init     system startup, syscall dispatching, entry points
         kern     scheduling, descriptor handling and generic I/O
         sys      process management, signals
         tty      terminal handling and job control
         vfs      filesystem management
         uipc     interprocess communication (sockets)
         subr     miscellaneous support routines
vm                virtual memory management
ufs               local filesystems broken down as follows
         ufs      common local filesystem routines
         ffs      fast filesystem
         lfs      log-based filesystem
         mfs      memory based filesystem
nfs               Sun-compatible network filesystem
miscfs            miscellaneous filesystems broken down as follows
         deadfs   where rejected vnodes go to die
         fdesc    access to per-process file descriptors
         fifofs   IEEE Std1003.1 FIFOs
         kernfs   filesystem access to kernel data structures
         lofs     loopback filesystem
         nullfs   another loopback filesystem
         portal   associate processes with filesystem locations
         specfs   device special files
         umapfs   provide alternate uid/gid mappings
dev               generic device drivers (SCSI, vnode, concatenated disk)

The networking code is organized by protocol

net       routing and generic interface drivers
netinet   Internet protocols (TCP, UDP, IP, etc)
netiso    ISO protocols (TP-4, CLNP, CLTP, etc)
netns     Xerox network systems protocols (IDP, SPP, etc)
netx25    CCITT X.25 protocols (X.25 Packet Level, HDLC/LAPB)

A  separate subdirectory is provided for each machine archi-
tecture

hp300      HP 9000/300 series of Motorola 68000-based machines
hp         code common to both HP 68k and (non-existent) PA-RISC ports
i386       Intel 386/486-based PC machines
luna68k    Omron 68000-based workstations
news3400   Sony News MIPS-based workstations
pmax       Digital 3100/5000 MIPS-based workstations
sparc      Sun Microsystems SPARCstation 1, 1+, and 2
tahoe      (deprecated) CCI Power 6-series machines
vax        (deprecated) Digital VAX machines




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-57


Each machine directory is subdivided by function; for  exam-
ple the hp300 directory contains

include   exported machine-dependent header files
hp300     machine-dependent support code and private header files
dev       device drivers
conf      configuration files
stand     machine-dependent standalone code

Other kernel related directories

compile   area to compile kernels
conf      machine-independent configuration files
stand     machine-independent standalone code


44..11..22..  DDeevviicceess aanndd ddeevviiccee ddrriivveerrss
     Devices supported by UNIX are implemented in the kernel
by drivers whose source is kept in  /sys/<architecture>/dev.
These  drivers are loaded into the system when included in a
CPU specific configuration file kept in the conf  directory.
Devices  are  accessed through special files in the filesys-
tem, made by the _m_k_n_o_d(8) program and normally kept  in  the
/dev  directory.   For all the devices supported by the dis-
tribution system, the files  in  /dev  are  created  by  the
/dev/MAKEDEV shell script.
     Determine the set of devices that you have and create a
new /dev directory by running  the  MAKEDEV  script.   First
create  a  new directory /newdev, copy MAKEDEV into it, edit
the file MAKEDEV.local to provide an entry for local  needs,
and run it to generate a /newdevdirectory.  For instance,

     ## _c_d _/
     ## _m_k_d_i_r _n_e_w_d_e_v
     ## _c_p _d_e_v_/_M_A_K_E_D_E_V _n_e_w_d_e_v_/_M_A_K_E_D_E_V
     ## _c_d _n_e_w_d_e_v
     ## _M_A_K_E_D_E_V _s_d_0 _p_t_0 _s_t_d _L_O_C_A_L

Note  the  ``std''  argument causes standard devices such as
/dev/console, the machine console, to be created.
     You can then do

     ## _c_d _/
     ## _m_v _d_e_v _o_l_d_d_e_v _; _m_v _n_e_w_d_e_v _d_e_v
     ## _s_y_n_c

to install the new device directory.

44..11..33..  BBuuiillddiinngg nneeww ssyysstteemm iimmaaggeess
     The  kernel  configuration  of  each  UNIX  system   is
described  by  a  single  configuration  file, stored in the
/sys/<architecture>/conf directory.  To learn about the for-
mat  of  this  file  and  the procedure used to build system
images, start by reading ``Building 4.3BSD UNIX Systems with



                        May 14, 1994





SMM:1-58                Installing and Operating 4.4BSD UNIX


Config''  (SMM:2),  look at the manual pages in section 4 of
the UNIX manual for the devices you have, and  look  at  the
sample  configuration  files in the /sys/<architecture>/conf
directory.
     The configured system image vmunix should be copied  to
the root, and then booted to try it out.  It is best to name
it /newvmunix so as not to destroy the working system  until
you are sure it does work:

     ## _c_p _v_m_u_n_i_x _/_n_e_w_v_m_u_n_i_x
     ## _s_y_n_c

It  is  also  a good idea to keep the previous system around
under some other name.  In particular, we recommend that you
save  the  generic distribution version of the system perma-
nently as /genvmunix for use in emergencies.   To  boot  the
new  version  of  the system you should follow the bootstrap
procedures outlined in section 6.1.  After having booted and
tested  the  new  system,  it should be installed as /vmunix
before going into multiuser operation.  A systematic  scheme
for  numbering  and saving old versions of the system may be
useful.

44..22..  CCoonnffiigguurriinngg tteerrmmiinnaallss
     If  UNIX  is  to  support  simultaneous   access   from
directly-connected  terminals  other  than  the console, the
file /etc/ttys (see _t_t_y_s(5)) must be edited.
     To add a new terminal device, be  sure  the  device  is
configured  into  the  system and that the special files for
the device have been made by /dev/MAKEDEV.  Then, enable the
appropriate  lines  of  /etc/ttys  by setting the ``status''
field to  oonn  (or  add  new  lines).   Note  that  lines  in
/etc/ttys  are  one-for-one with entries in the file of cur-
rent users (see /var/run/utmp), and therefore it is best  to
make  changes  while  running in single-user mode and to add
all the entries for a new device at once.
     Each line in the /etc/ttys file is broken into four tab
separated  fields (comments are shown by a `#' character and
extend to the end of the line).  For each terminal line  the
four  fields  are:  the device (without a leading /dev), the
program /sbin/init should startup to service  the  line  (or
nnoonnee  if  the  line  is to be left alone), the terminal type
(found  in  /usr/share/misc/termcap),  and  optional  status
information describing if the terminal is enabled or not and
if it is ``secure'' (i.e. the super user should  be  allowed
to  login on the line).  If the console is marked as ``inse-
cure'', then the root password  is  required  to  bring  the
machine  up  single-user.   All fields are character strings
with entries requiring embedded white space enclosed in dou-
ble quotes.  Thus a newly added terminal /dev/tty00 could be
added as

     tty00     "/usr/libexec/getty std.9600" vt100     on secure # mike's office




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-59


The std.9600 parameter  provided  to  /usr/libexec/getty  is
used  in  searching  the  file /etc/gettytab; it specifies a
terminal's characteristics (such as  baud  rate).   To  make
custom  terminal types, consult _g_e_t_t_y_t_a_b(5) before modifying
/etc/gettytab.
     Dialup terminals should be wired  so  that  carrier  is
asserted  only  when  the phone line is dialed up.  For non-
dialup terminals, from which modem control is not available,
you  must  wire back the signals so that the carrier appears
to always be present.  For further details, find your termi-
nal driver in section 4 of the manual.
     For  network terminals (i.e. pseudo terminals), no pro-
gram should be started up on the lines.   Thus,  the  normal
entry in /etc/ttys would look like

     ttyp0     none network

(Note, the fourth field is not needed here.)
     When  the  system  is running multi-user, all terminals
that are listed in /etc/ttys as oonn have their line  enabled.
If, during normal operations, you wish to disable a terminal
line, you can edit the file /etc/ttys to change  the  termi-
nal's  status  to  ooffff  and then send a hangup signal to the
_i_n_i_t process, by doing

     ## _k_i_l_l _-_s _H_U_P _1

Terminals can similarly be enabled by  changing  the  status
field from ooffff to oonn and sending a hangup signal to _i_n_i_t.
     Note  that  if a special file is inaccessible when _i_n_i_t
tries to create a process for it, _i_n_i_t will log a message to
the system error logging process (see _s_y_s_l_o_g_d(8)) and try to
reopen the terminal every  minute,  reprinting  the  warning
message  every  10  minutes.  Messages of this sort are nor-
mally printed on the console, though other actions may occur
depending   on   the   configuration  information  found  in
/etc/syslog.conf.
     Finally note that you should change the  names  of  any
dialup  terminals  to  ttyd?   where ? is in [0-9a-zA-Z], as
some programs use this property of the names to determine if
a terminal is a dialup.  Shell commands to do this should be
put in the /dev/MAKEDEV.local script.
     While it is possible to use truly arbitrary strings for
terminal names, the accounting and noticeably the _p_s(1) com-
mand make good use of the  convention  that  tty  names  (by
default,  and  also  after  dialups  are  named as suggested
above) are distinct in the last 2 characters.   Change  this
and  you  may  be  sorry  later, as the heuristic _p_s(1) uses
based on these conventions will then break down and _p_s  will
run MUCH slower.

44..33..  AAddddiinngg uusseerrss
     The  procedure  for  adding  a new user is described in
_a_d_d_u_s_e_r(8).  You should add accounts for  the  initial  user



                        May 14, 1994





SMM:1-60                Installing and Operating 4.4BSD UNIX


community,  giving  each  a  directory  and  a password, and
putting users who will wish to share software  in  the  same
groups.
     Several  guest  accounts have been provided on the dis-
tribution system; these accounts are for people at Berkeley,
Bell  Laboratories,  and  others who have done major work on
UNIX in the past.  You can delete these accounts,  or  leave
them  on  the  system  if you expect that these people would
have occasion to login as guests on your system.

44..44..  SSiittee ttaaiilloorriinngg
     All programs that require the site's name, or some sim-
ilar  characteristic,  obtain the information through system
calls or from files located in /etc.  Aside  from  parts  of
the  system  related to the network, to tailor the system to
your site you must simply select a site name, then edit  the
file

     /etc/netstart

The  first  lines in /etc/netstart use a variable to set the
hostname,

     hostname=_m_y_s_i_t_e_n_a_m_e
     /bin/hostname $hostname

to define the value returned by  the  _g_e_t_h_o_s_t_n_a_m_e(2)  system
call.   If  you  are running the name server, your site name
should be your fully qualified domain name.   Programs  such
as  _g_e_t_t_y(8),  _m_a_i_l(1), _w_a_l_l(1), and _u_u_c_p(1) use this system
call so that the binary images are site independent.
     You will also need to edit /etc/netstart to do the net-
work interface initialization using _i_f_c_o_n_f_i_g(8).  If you are
not sure how to do this, see sections 5.1, 5.2, and 5.3.  If
you  are not running a routing daemon and have more than one
Ethernet in your environment you  will  need  to  set  up  a
default route; see section 5.4 for details.  Before bringing
your system up multiuser, you should ensure  that  the  net-
working  is  properly configured.  The network is started by
running /etc/netstart.  Once started, you should  test  con-
nectivity using _p_i_n_g(8).  You should first test connectivity
to yourself, then another host on your Ethernet, and finally
a  host  on another Ethernet.  The _n_e_t_s_t_a_t(8) program can be
used to inspect and debug your routes; see section 5.4.

44..55..  SSeettttiinngg uupp tthhee lliinnee pprriinntteerr ssyysstteemm
     The line printer system consists of at least  the  fol-
lowing files and commands:









                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-61


     /usr/bin/lpq     spooling queue examination program
     /usr/bin/lprm    program to delete jobs from a queue
     /usr/bin/lpr     program to enter a job in a printer queue
     /etc/printcap    printer configuration and capability database
     /usr/sbin/lpd    line printer daemon, scans spooling queues
     /usr/sbin/lpc    line printer control program
     /etc/hosts.lpd   list of host allowed to use the printers


     The  file /etc/printcap is a master database describing
line printers directly attached  to  a  machine  and,  also,
printers  accessible  across  a  network.   The  manual page
_p_r_i_n_t_c_a_p(5) describes the format of this database  and  also
shows the default values for such things as the directory in
which spooling is performed.  The line printer  system  han-
dles  multiple printers, multiple spooling queues, local and
remote printers, and also printers attached via serial lines
that  require  line  initialization  such  as the baud rate.
Raster output devices such as  a  Varian  or  Versatec,  and
laser  printers such as an Imagen, are also supported by the
line printer system.
     Remote spooling via the network  is  handled  with  two
spooling  queues,  one  on  the local machine and one on the
remote machine.  When a remote printer job is  started  with
_l_p_r,  the job is queued locally and a daemon process created
to oversee the transfer of the job to  the  remote  machine.
If  the  destination  machine  is  unreachable, the job will
remain queued until it is possible to transfer the files  to
the  spooling  queue on the remote machine.  The _l_p_q program
shows the contents of spool queues on  both  the  local  and
remote machines.
     To  configure  your line printers, consult the printcap
manual page and the  accompanying  document,  ``4.3BSD  Line
Printer Spooler Manual'' (SMM:7).  A call to the _l_p_d program
should be present in /etc/rc.

44..66..  SSeettttiinngg uupp tthhee mmaaiill ssyysstteemm
     The mail system consists of the following commands:


     /usr/bin/mail         UCB mail program, described in _m_a_i_l(1)
     /usr/sbin/sendmail    mail routing program
     /var/spool/mail       mail spooling directory
     /etc/aliases          mail forwarding information
     /usr/bin/newaliases   command to rebuild binary forwarding database
     /usr/bin/biff         mail notification enabler
     /usr/libexec/comsat   mail notification daemon


Mail is normally sent and received using the _m_a_i_l(1) command
(found in /usr/bin/mail), which provides a front-end to edit
the messages sent and received, and passes the  messages  to
_s_e_n_d_m_a_i_l(8)  for routing.  The routing algorithm uses knowl-
edge of the network name  syntax,  aliasing  and  forwarding



                        May 14, 1994





SMM:1-62                Installing and Operating 4.4BSD UNIX


information, and network topology, as defined in the config-
uration file /usr/lib/sendmail.cf, to process each piece  of
mail.   Local  mail is delivered by giving it to the program
/usr/libexec/mail.local that adds it to the mailboxes in the
directory /var/spool/mail/<username>, using a locking proto-
col to avoid problems with simultaneous updates.  After  the
mail   is   delivered,   the   local  mail  delivery  daemon
/usr/libexec/comsat is  notified,  which  in  turn  notifies
users  who  have  issued  a ``_b_i_f_f y'' command that mail has
arrived.
     Mail queued in the directory  /var/spool/mail  is  nor-
mally readable only by the recipient.
     To  set  up  the  mail  facility  you  should  read the
instructions  in  the  file   READ_ME   in   the   directory
/usr/src/usr.sbin/sendmail  and  then  adjust  the necessary
configuration files.   You  should  also  set  up  the  file
/etc/aliases  for your installation, creating mail groups as
appropriate.  For more informations see ``Sendmail Installa-
tion  and  Operation  Guide''  (SMM:8)  and  ``Sendmail - An
Internetwork Mail Router'' (SMM:9).


44..66..11..  SSeettttiinngg uupp aa UUUUCCPP ccoonnnneeccttiioonn
The version of _u_u_c_p included in  4.4BSD  has  the  following
features:
+o  support  for many auto call units and dialers in addition
   to the DEC DN11,
+o  breakup of the spooling area  into  multiple  subdirecto-
   ries,
+o  addition of an L.cmds file to control the set of commands
   that may be executed by a remote site,
+o  enhanced ``expect-send'' sequence capabilities when  log-
   ging in to a remote site,
+o  new  commands  to  be used in polling sites and obtaining
   snap shots of _u_u_c_p activity,
+o  additional protocols for different communication media.
This section gives a brief overview of _u_u_c_p and  points  out
the most important steps in its installation.
     To  connect  two UNIX machines with a _u_u_c_p network link
using modems, one site must have an automatic call unit  and
the  other  must  have  a dialup port.  It is better if both
sites have both.
     You should first read the paper in the UNIX System Man-
ager's Manual: ``Uucp Implementation Description'' (SMM:14).
It describes in detail the file formats and conventions, and
will  give  you a little context.  In addition, the document
``setup.tblms'',     located      in      the      directory
/usr/src/usr.bin/uucp/UUAIDS, may be of use in tailoring the
software to your needs.
     The _u_u_c_p support is located in three major directories:
/usr/bin, /usr/lib/uucp, and /var/spool/uucp.  User commands
are kept in /usr/bin, operational commands in /usr/lib/uucp,
and  /var/spool/uucp  is  used as a spooling area.  The com-
mands in /usr/bin are:



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-63


     /usr/bin/uucp       file-copy command
     /usr/bin/uux        remote execution command
     /usr/bin/uusend     binary file transfer using mail
     /usr/bin/uuencode   binary file encoder (for _u_u_s_e_n_d)
     /usr/bin/uudecode   binary file decoder (for _u_u_s_e_n_d)
     /usr/bin/uulog      scans session log files
     /usr/bin/uusnap     gives a snap-shot of _u_u_c_p activity
     /usr/bin/uupoll     polls remote system until an answer is received
     /usr/bin/uuname     prints a list of known uucp hosts
     /usr/bin/uuq        gives information about the queue


The important files and commands in /usr/lib/uucp are:


     /usr/lib/uucp/L-devices     list of dialers and hard-wired lines
     /usr/lib/uucp/L-dialcodes   dialcode abbreviations
     /usr/lib/uucp/L.aliases     hostname aliases
     /usr/lib/uucp/L.cmds        commands remote sites may execute
     /usr/lib/uucp/L.sys         systems to communicate with, how to connect, and when
     /usr/lib/uucp/SEQF          sequence numbering control file
     /usr/lib/uucp/USERFILE      remote site pathname access specifications
     /usr/lib/uucp/uucico        _u_u_c_p protocol daemon
     /usr/lib/uucp/uuclean       cleans up garbage files in spool area
     /usr/lib/uucp/uuxqt         _u_u_c_p remote execution server


while the spooling area  contains  the  following  important
files and directories:


     /var/spool/uucp/C.           directory for command, ``C.'' files
     /var/spool/uucp/D.           directory for data, ``D.'', files
     /var/spool/uucp/X.           directory for command execution, ``X.'', files
     /var/spool/uucp/D._m_a_c_h_i_n_e    directory for local ``D.'' files
     /var/spool/uucp/D._m_a_c_h_i_n_eX   directory for local ``X.'' files
     /var/spool/uucp/TM.          directory for temporary, ``TM.'', files
     /var/spool/uucp/LOGFILE      log file of _u_u_c_p activity
     /var/spool/uucp/SYSLOG       log file of _u_u_c_p file transfers


     To  install  _u_u_c_p  on your system, start by selecting a
site name (shorter than 14 characters).  A _u_u_c_p account must
be  created  in  the  password  file  and a password set up.
Then, create the appropriate spooling directories with  mode
755 and owned by user _u_u_c_p, group _d_a_e_m_o_n.
     If  you have an auto-call unit, the L.sys, L-dialcodes,
and L-devices files  should  be  created.   The  L.sys  file
should   contain  the  phone  numbers  and  login  sequences
required to establish a connection with  a  _u_u_c_p  daemon  on
another  machine.   For  example, our L.sys file looks some-
thing like:





                        May 14, 1994





SMM:1-64                Installing and Operating 4.4BSD UNIX


     adiron Any ACU 1200 out0123456789- ogin-EOT-ogin uucp
     cbosg Never Slave 300
     cbosgd Never Slave 300
     chico Never Slave 1200 out2010123456

The first field is the name of a site, the second shows when
the machine may be called, the third field specifies how the
host is connected (through an ACU, a hard-wired line, etc.),
then  comes the phone number to use in connecting through an
auto-call unit, and finally a  login  sequence.   The  phone
number  may contain common abbreviations that are defined in
the L-dialcodes file.  The device specification should refer
to  devices  specified  in the L-devices file.  Listing only
ACU causes the _u_u_c_p daemon, _u_u_c_i_c_o, to search for any avail-
able  auto-call  unit in L-devices.  Our L-dialcodes file is
of the form:

     ucb 2
     out 9%

while our L-devices file is:

     ACU cul0 unused 1200 ventel

Refer to the README file in the _u_u_c_p  source  directory  for
more information about installation.
     As  _u_u_c_p  operates  it creates (and removes) many small
files in the directories underneath /var/spool/uucp.   Some-
times files are left undeleted; these are most easily purged
with the _u_u_c_l_e_a_n program.  The log files  can  grow  without
bound  unless  trimmed  back;  _u_u_l_o_g  maintains these files.
Many useful aids in maintaining your _u_u_c_p  installation  are
included     in     a     subdirectory     UUAIDS    beneath
/usr/src/usr.bin/uucp.  Peruse this directory and  read  the
``setup'' instructions also located there.

55..  NNeettwwoorrkk sseettuupp
     4.4BSD  provides support for the standard Internet pro-
tocols IP, ICMP, TCP, and UDP.  These protocols may be  used
on  top of a variety of hardware devices ranging from serial
lines to local area network controllers  for  the  Ethernet.
Network services are split between the kernel (communication
protocols) and user programs (user services such  as  TELNET
and FTP).  This section describes how to configure your sys-
tem to use the Internet  networking  support.   4.4BSD  also
supports  the Xerox Network Systems (NS) protocols.  IDP and
SPP are implemented in the kernel, and other protocols  such
as Courier run at the user level.  4.4BSD provides some sup-
port for the ISO OSI protocols CLNP  TP4,  and  ESIS.   User
level  process  complete  the  application protocols such as
X.400 and X.500.






                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-65


55..11..  SSyysstteemm ccoonnffiigguurraattiioonn
     To configure the kernel to include the Internet  commu-
nication  protocols,  define the INET option.  Xerox NS sup-
port is enabled with the NS  option.   ISO  OSI  support  is
enabled  with  the  ISO option.  In either case, include the
pseudo-devices ``pty'', and ``loop'' in your machine's  con-
figuration  file.   The  ``pty''  pseudo-device  forces  the
pseudo terminal device driver to be configured into the sys-
tem,  see  _p_t_y(4),  while  the ``loop'' pseudo-device forces
inclusion of the software loopback  interface  driver.   The
loop driver is used in network testing and also by the error
logging system.
     If you are planning to use the Internet network facili-
ties  on  a  10Mb/s  Ethernet,  the  pseudo-device ``ether''
should also be included in the  configuration;  this  forces
inclusion  of the Address Resolution Protocol module used in
mapping  between  48-bit  Ethernet   and   32-bit   Internet
addresses.
     Before configuring the appropriate networking hardware,
you should consult the manual pages in section 4 of the Pro-
grammer's  Manual  selecting  the appropriate interfaces for
your architecture.
     All network interface drivers  including  the  loopback
interface, require that their host address(es) be defined at
boot time.  This is done with _i_f_c_o_n_f_i_g(8) commands  included
in  the  /etc/netstart  file.   Interfaces  that are able to
dynamically deduce the host part of  an  address  may  check
that  the  host  part of the address is correct.  The manual
page for each network interface describes the method used to
establish a host's address.  _I_f_c_o_n_f_i_g(8) can also be used to
set options for the interface at boot time.  Options are set
independently  for  each interface, and apply to all packets
sent using that interface.  Alternatively, translations  for
such  hosts  may  be  set  in  advance or ``published'' by a
4.4BSD host by use of the _a_r_p(8) command.  Note that the use
of trailer link-level is now negotiated between 4.4BSD hosts
using ARP, and it is thus no longer necessary to disable the
use of trailers with _i_f_c_o_n_f_i_g.
     The OSI equivalent to ARP is ESIS (End System to Inter-
mediate System Routing Protocol); running this  protocol  is
mandatory,  however  one  can  manually add translations for
machines that do not participate by use of the _r_o_u_t_e(8) com-
mand.  Additional information is provided in the manual page
describing _E_S_I_S(4).
     To use the pseudo  terminals  just  configured,  device
entries must be created in the /dev directory.  To create 32
pseudo terminals (plenty, unless you have  a  heavy  network
load) execute the following commands.

     ## _c_d _/_d_e_v
     ## _M_A_K_E_D_E_V _p_t_y_0 _p_t_y_1

More  pseudo terminals may be made by specifying pty2, pty3,
etc.  The kernel normally includes  support  for  32  pseudo



                        May 14, 1994





SMM:1-66                Installing and Operating 4.4BSD UNIX


terminals  unless the configuration file specifies a differ-
ent number.  Each pseudo terminal  really  consists  of  two
files in /dev: a master and a slave.  The master pseudo ter-
minal file is named /dev/ptyp?,  while  the  slave  side  is
/dev/ttyp?.   Pseudo terminals are also used by several pro-
grams not related to the network.  In addition  to  creating
the  pseudo  terminals,  be  sure  to  install  them  in the
/etc/ttys file (with a `none' in the  second  column  so  no
_g_e_t_t_y is started).

55..22..  LLooccaall ssuubbnneettss
     In  4.4BSD  the Internet support includes the notion of
``subnets''.  This is a mechanism by  which  multiple  local
networks  may  appears  as a single Internet network to off-
site hosts.  Subnetworks are useful  because  they  allow  a
site  to  hide their local topology, requiring only a single
route in external gateways; it also means that local network
numbers  may be locally administered.  The standard describ-
ing this change in Internet addressing is RFC-950.
     To set up local subnets one must first decide  how  the
available  address  space (the Internet ``host part'' of the
32-bit address) is to be partitioned.  Sites with a class  A
network  number  have a 24-bit host address space with which
to work, sites with a class B network number have  a  16-bit
host  address space, while sites with a class C network num-
ber have an 8-bit host address space5.  To define local sub-
nets  you  must  steal some bits from the local host address
space for use in extending the network portion of the Inter-
net address.  This reinterpretation of Internet addresses is
done only for local networks; i.e.  it  is  not  visible  to
hosts  off-site.   For  example,  if your site has a class B
network number, hosts  on  this  network  have  an  Internet
address  that  contains the network number, 16 bits, and the
host number, another 16 bits.  To define 254 local  subnets,
each  possessing at most 255 hosts, 8 bits may be taken from
the local part.  (The use of subnets 0 and all-1's,  255  in
this example, is discouraged to avoid confusion about broad-
cast addresses.)  These new network numbers  are  then  con-
structed by concatenating the original 16-bit network number
with the extra 8 bits containing the local subnet number.
     The existence of local subnets is communicated  to  the
system  at  the  time a network interface is configured with
the _n_e_t_m_a_s_k option to the  _i_f_c_o_n_f_i_g  program.   A  ``network
mask''  is  specified  to define the portion of the Internet
address that is to be considered the network part  for  that
network.  This mask normally contains the bits corresponding
to the standard network part as well as the portion  of  the
local part that has been assigned to subnets.  If no mask is
-----------
  5 If  you  are  unfamiliar  with  the   Internet
addressing   structure,   consult  ``Address  Map-
pings'', Internet RFC-796,  J.  Postel;  available
from  the  Internet  Network Information Center at
SRI.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-67


specified when the address is set, it will be set  according
to  the  class  of  the  network.   For example, at Berkeley
(class B network 128.32) 8 bits of the local part have  been
reserved  for  defining  subnets; consequently the /etc/net-
start file contains lines of the form

     /sbin/ifconfig le0 netmask 0xffffff00 128.32.1.7

This specifies that for interface ``le0'', the upper 24 bits
of  the  Internet address should be used in calculating net-
work  numbers  (netmask  0xffffff00),  and  the  interface's
Internet  address  is  ``128.32.1.7''  (host  7  on  network
128.32.1).  Hosts _m on sub-network _n of this  network  would
then  have  addresses of the form ``128.32._n._m'';  for exam-
ple,  host  99  on  network  129  would  have   an   address
``128.32.129.99''.   For hosts with multiple interfaces, the
network mask should be set for each interface,  although  in
practice  only  the mask of the first interface on each net-
work is really used.

55..33..  IInntteerrnneett bbrrooaaddccaasstt aaddddrreesssseess
     The address defined as the broadcast address for Inter-
net networks according to RFC-919 is the address with a host
part of all 1's.  The address used by 4.2BSD was the address
with  a  host part of 0.  4.4BSD uses the standard broadcast
address (all 1's)  by  default,  but  allows  the  broadcast
address  to be set (with _i_f_c_o_n_f_i_g) for each interface.  This
allows networks consisting of both 4.2BSD, 4.3BSD and 4.4BSD
hosts to coexist while the upgrade process proceeds.  In the
presence of subnets, the broadcast address uses  the  subnet
field  as for normal host addresses, with the remaining host
part set to 1's (or 0's, on a network that has not yet  been
converted).   4.4BSD hosts recognize and accept packets sent
to the logical-network broadcast address as  well  as  those
sent  to  the  subnet  broadcast  address, and when using an
all-1's broadcast, also recognize and receive  packets  sent
to host 0 as a broadcast.

55..44..  RRoouuttiinngg
     If  your  environment  allows  access  to  networks not
directly attached to your host you will need to set up rout-
ing information to allow packets to be properly routed.  Two
schemes are supported  by  the  system.   The  first  scheme
employs  a  routing table management daemon.  Optimally, you
should use the routing daemon _g_a_t_e_d available  from  Cornell
university.   We  use  it  on our systems and it works well,
especially  for  multi-homed  hosts  using  Serial  Line  IP
(SLIP).   Unfortunately,  we were not able to obtain permis-
sion to include it on 4.4BSD.
     If you do not wish to or cannot obtain _g_a_t_e_d, the  dis-
tribution  does  include  _r_o_u_t_e_d(8)  to  maintain the system
routing tables.  The routing daemon uses a  variant  of  the
Xerox  Routing  Information  Protocol to maintain up to date
routing tables in a cluster  of  local  area  networks.   By



                        May 14, 1994





SMM:1-68                Installing and Operating 4.4BSD UNIX


using the /etc/gateways file, the routing daemon can also be
used to initialize static routes to  distant  networks  (see
the  next section for further discussion).  When the routing
daemon  is  started  up  (usually  from  /etc/rc)  it  reads
/etc/gateways if it exists and installs those routes defined
there, then broadcasts on each local network  to  which  the
host is attached to find other instances of the routing dae-
mon.  If any responses are  received,  the  routing  daemons
cooperate in maintaining a globally consistent view of rout-
ing in the local environment.  This view can be extended  to
include remote sites also running the routing daemon by set-
ting up suitable entries in /etc/gateways; consult _r_o_u_t_e_d(8)
for a more thorough discussion.
     The  second approach is to define a default or wildcard
route to a smart gateway and depend on the gateway  to  pro-
vide ICMP routing redirect information to dynamically create
a routing data base.  This is done by adding an entry of the
form

     /sbin/route add default _s_m_a_r_t_-_g_a_t_e_w_a_y 1

to  /etc/netstart;  see  _r_o_u_t_e(8) for more information.  The
default route will  be  used  by  the  system  as  a  ``last
resort''  in routing packets to their destination.  Assuming
the gateway to which packets are directed is able to  gener-
ate  the  proper  routing redirect messages, the system will
then add routing table entries based on the information sup-
plied.   This approach has certain advantages over the rout-
ing daemon, but is unsuitable in an environment where  there
are  only bridges (i.e.  pseudo gateways that, for instance,
do not generate routing redirect messages).  Further, if the
smart gateway goes down there is no alternative, save manual
alteration of the routing table entry, to  maintaining  ser-
vice.
     The system always listens, and processes, routing redi-
rect information, so it is possible to combine both  of  the
above facilities.  For example, the routing table management
process might be used to maintain  up  to  date  information
about routes to geographically local networks, while employ-
ing the wildcard routing  techniques  for  ``distant''  net-
works.   The _n_e_t_s_t_a_t(1) program may be used to display rout-
ing table contents as well as various routing oriented  sta-
tistics.  For example,

     ## _n_e_t_s_t_a_t _-_r

will display the contents of the routing tables, while

     ## _n_e_t_s_t_a_t _-_r _-_s

will  show  the  number of routing table entries dynamically
created as a result of routing redirect messages, etc.





                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-69


55..55..  UUssee ooff 44..44BBSSDD mmaacchhiinneess aass ggaatteewwaayyss
     Several changes have been made in 4.4BSD in the area of
gateway  support  (or packet forwarding, if one prefers).  A
new configuration option, GATEWAY, is used when  configuring
a  machine  to  be used as a gateway.  This option increases
the size of the routing hash tables in the  kernel.   Unless
configured  with  that option, hosts with only a single non-
loopback interface never attempt to forward  packets  or  to
respond  with  ICMP  error  messages to misdirected packets.
This change reduces the problems that may occur when differ-
ent  hosts  on  a  network disagree on the network number or
broadcast address.  Another change is that  4.4BSD  machines
that  forward  packets  back  through  the same interface on
which they arrived will send ICMP redirects  to  the  source
host if it is on the same network.  This improves the inter-
action of 4.4BSD gateways with hosts  that  configure  their
routes  via  default gateways and redirects.  The generation
of redirects may be disabled with the  configuration  option
IPSENDREDIRECTS=0  or  while  the system is running by using
the command:

     sysctl -w net.inet.ip.redirect=0

in environments where it may cause difficulties.

55..66..  NNeettwwoorrkk ddaattaabbaasseess
     Several data files are used by the network library rou-
tines  and  server  programs.   Most of these files are host
independent and updated only rarely.

File               Manual reference   Use
-----------------------------------------------------------------------------------
/etc/hosts         _h_o_s_t_s(5)           local host names
/etc/networks      _n_e_t_w_o_r_k_s(5)        network names
/etc/services      _s_e_r_v_i_c_e_s(5)        list of known services
/etc/protocols     _p_r_o_t_o_c_o_l_s(5)       protocol names
/etc/hosts.equiv   _r_s_h_d(8)            list of ``trusted'' hosts
/etc/netstart      _r_c(8)              command script for initializing network
/etc/rc            _r_c(8)              command script for starting standard servers
/etc/rc.local      _r_c(8)              command script for starting local servers
/etc/ftpusers      _f_t_p_d(8)            list of ``unwelcome'' ftp users
/etc/hosts.lpd     _l_p_d(8)             list of hosts allowed to access printers
/etc/inetd.conf    _i_n_e_t_d(8)           list of servers started by _i_n_e_t_d

The files distributed are set up for Internet hosts.   Local
networks  and  hosts  should  be added to describe the local
configuration; the Berkeley entries may  serve  as  examples
(see  also the section on /etc/hosts).  Network numbers will
have to be chosen for each Ethernet.  For sites connected to
the Internet, the normal channels should be used for alloca-
tion of network numbers  (contact  hostmaster@SRI-NIC.ARPA).
For  other  sites,  these could be chosen more or less arbi-
trarily, but it is generally better to request official num-
bers to avoid conversion if a connection to the Internet (or



                        May 14, 1994





SMM:1-70                Installing and Operating 4.4BSD UNIX


others on the Internet) is ever established.

55..66..11..  NNeettwwoorrkk sseerrvveerrss
     Most network servers are automatically  started  up  at
boot  time  by  the  command file /etc/rc or by the Internet
daemon (see below).  These include the following:

Program                Server                            Started by
--------------------------------------------------------------------
/usr/sbin/syslogd      error logging server              /etc/rc
/usr/sbin/named        Internet name server              /etc/rc
/sbin/routed           routing table management daemon   /etc/rc
/usr/sbin/rwhod        system status daemon              /etc/rc
/usr/sbin/timed        time synchronization daemon       /etc/rc
/usr/sbin/sendmail     SMTP server                       /etc/rc
/usr/libexec/rshd      shell server                      inetd
/usr/libexec/rexecd    exec server                       inetd
/usr/libexec/rlogind   login server                      inetd
/usr/libexec/telnetd   TELNET server                     inetd
/usr/libexec/ftpd      FTP server                        inetd
/usr/libexec/fingerd   Finger server                     inetd
/usr/libexec/tftpd     TFTP server                       inetd

Consult the  manual  pages  and  accompanying  documentation
(particularly  for  named  and  sendmail)  for details about
their operation.
     The use of _r_o_u_t_e_d and  _r_w_h_o_d  is  controlled  by  shell
variables set in /etc/netstart.  By default, _r_o_u_t_e_d is used,
but _r_w_h_o_d is not; they are enabled by setting the  variables
_r_o_u_t_e_d_f_l_a_g_s  and  _r_w_h_o_d  to  strings other than ``NO.''  The
value  of  _r_o_u_t_e_d_f_l_a_g_s  provides  host-specific  options  to
_r_o_u_t_e_d.  For example,

     routedflags=-q
     rwhod=NO

would run _r_o_u_t_e_d _-_q and would not run _r_w_h_o_d.
     To have other network servers started as well, commands
of the following sort should be placed in the site-dependent
file /etc/rc.local.

     if [ -f /usr/sbin/timed ]; then
          /usr/sbin/timed & echo -n ' timed'           >/dev/console
     fi


55..66..22..  IInntteerrnneett ddaaeemmoonn
     In 4.4BSD most of the servers for user-visible services
are started up by a ``super server'', the  Internet  daemon.
The  Internet  daemon,  /usr/sbin/inetd,  acts  as  a master
server for programs specified  in  its  configuration  file,
/etc/inetd.conf,  listening  for  service requests for these
servers, and starting up the appropriate program whenever  a
request  is received.  The configuration file contains lines



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-71


containing a service name (as found in  /etc/services),  the
type  of  socket  the server expects (e.g. stream or dgram),
the protocol to  be  used  with  the  socket  (as  found  in
/etc/protocols), whether to wait for each server to complete
before starting up another,  the  user  name  by  which  the
server  should  run,  the server program's name, and at most
five arguments to pass to the server program.  Some  trivial
services  are  implemented  internally  in  _i_n_e_t_d, and their
servers are listed as ``internal.''  For example,  an  entry
for the file transfer protocol server would appear as

     ftp  stream    tcp  nowait    root /usr/libexec/ftpd   ftpd

Consult  _i_n_e_t_d(8)  for more detail on the format of the con-
figuration file and the operation of the Internet daemon.

55..66..33..  TThhee //eettcc//hhoossttss..eeqquuiivv ffiillee
     The remote login and shell servers use  an  authentica-
tion  scheme  based  on trusted hosts.  The hosts.equiv file
contains a list of hosts that are  considered  trusted  and,
under a single administrative control.  When a user contacts
a remote login  or  shell  server  requesting  service,  the
client  process passes the user's name and the official name
of the host on which the client is located.  In  the  simple
case,  if  the host's name is located in hosts.equiv and the
user has an account on the server's machine, then service is
rendered (i.e. the user is allowed to log in, or the command
is executed).  Users  may  expand  this  ``equivalence''  of
machines  by installing a .rhosts file in their login direc-
tory.  The root login is handled  specially,  bypassing  the
hosts.equiv file, and using only the /.rhosts file.
     Thus,  to  create  a  class of equivalent machines, the
hosts.equiv file should contain the _o_f_f_i_c_i_a_l names for those
machines.   If you are running the name server, you may omit
the domain part of the host name for machines in your  local
domain.  For example, four machines on our local network are
considered trusted, so the hosts.equiv file is of the form:

     vangogh.CS.Berkeley.EDU
     picasso.CS.Berkeley.EDU
     okeeffe.CS.Berkeley.EDU


55..66..44..  TThhee //eettcc//ffttppuusseerrss ffiillee
     The FTP server included in the system provides  support
for an anonymous FTP account.  Because of the inherent secu-
rity problems with such a facility you should read this sec-
tion carefully if you consider providing such a service.
     An anonymous account is enabled by creating a user _f_t_p.
When a client uses the anonymous account a _c_h_r_o_o_t(2)  system
call  is performed by the server to restrict the client from
moving outside that part of the filesystem  where  the  user
ftp  home  directory  is  located.  Because a _c_h_r_o_o_t call is
used, certain programs and files used by the server  process



                        May 14, 1994





SMM:1-72                Installing and Operating 4.4BSD UNIX


must be placed in the ftp home directory.  Further, one must
be sure that  all  directories  and  executable  images  are
unwritable.   The  following directory setup is recommended.
The use of the _a_w_k commands  to  copy  the  /etc/passwd  and
/etc/group files are SSTTRROONNGGLLYY recommended.

     ## _c_d _~_f_t_p
     ## _c_h_m_o_d _5_5_5 _._; _c_h_o_w_n _f_t_p _._; _c_h_g_r_p _f_t_p _.
     ## _m_k_d_i_r _b_i_n _e_t_c _p_u_b
     ## _c_h_o_w_n _r_o_o_t _b_i_n _e_t_c
     ## _c_h_m_o_d _5_5_5 _b_i_n _e_t_c
     ## _c_h_o_w_n _f_t_p _p_u_b
     ## _c_h_m_o_d _7_7_7 _p_u_b
     ## _c_d _b_i_n
     ## _c_p _/_b_i_n_/_s_h _/_b_i_n_/_l_s _.
     ## _c_h_m_o_d _1_1_1 _s_h _l_s
     ## _c_d _._._/_e_t_c
     ## _a_w_k _-_F_: _'_{_$_2_=_"_*_"_;_p_r_i_n_t_$_1_"_:_"_$_2_"_:_"_$_3_"_:_"_$_4_"_:_"_$_5_"_:_"_$_6_"_:_"_}_' _< _/_e_t_c_/_p_a_s_s_w_d _> _p_a_s_s_w_d
     ## _a_w_k _-_F_: _'_{_$_2_=_"_*_"_;_p_r_i_n_t_$_1_"_:_"_$_2_"_:_"_}_' _< _/_e_t_c_/_g_r_o_u_p _> _g_r_o_u_p
     ## _c_h_m_o_d _4_4_4 _p_a_s_s_w_d _g_r_o_u_p

When  local users wish to place files in the anonymous area,
they must be placed in a subdirectory.  In the  setup  here,
the directory ~ftp/pub is used.
     Aside  from  the  problems of directory modes and such,
the ftp server may provide a  loophole  for  interlopers  if
certain  user  accounts are allowed.  The file /etc/ftpusers
is checked on each connection.  If the requested  user  name
is  located  in the file, the request for service is denied.
This file normally has the following names on our systems.

     uucp
     root

Accounts without passwords need not be listed in  this  file
as  the  ftp  server  will  refuse  service  to these users.
Accounts  with  nonstandard  shells  (any  not   listed   in
/etc/shells) will also be denied access via ftp.

66..  SSyysstteemm ooppeerraattiioonn
     This  section  describes  procedures  used to operate a
4.4BSD UNIX system.   Procedures  described  here  are  used
periodically,  to  reboot the system, analyze error messages
from devices, do disk backups, monitor  system  performance,
recompile system software and control local changes.

66..11..  BBoooottssttrraapp aanndd sshhuuttddoowwnn pprroocceedduurreess
     In  a  normal  reboot,  the system checks the disks and
comes up multi-user without  intervention  at  the  console.
Such a reboot can be stopped (after it prints the date) with
a ^C (interrupt).  This will leave the system in single-user
mode,  with  only the console terminal active.  (If the con-
sole has been marked  ``insecure''  in  /etc/ttys  you  must
enter  the root password to bring the machine to single-user



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-73


mode.)  It is also possible to allow the  filesystem  checks
to  complete  and then to return to single-user mode by sig-
naling _f_s_c_k(8) with a QUIT signal (^\).
     To bring the system up to  a  multi-user  configuration
from the single-user status, all you have to do is hit ^D on
the console.  The system will then execute /etc/rc, a multi-
user  restart script (and /etc/rc.local), and come up on the
terminals listed as  active  in  the  file  /etc/ttys.   See
_i_n_i_t(8)  and _t_t_y_s(5) Note, however, that this does not cause
a filesystem check to be done.  Unless the system was  taken
down  cleanly,  you should run ``fsck -p'' or force a reboot
with _r_e_b_o_o_t(8) to have the disks checked.
     To take the system down to a single user state you  can
use

     ## _k_i_l_l _1

or  use  the _s_h_u_t_d_o_w_n(8) command (which is much more polite,
if there are other users logged in)  when  you  are  running
multi-user.  Either command will kill all processes and give
you a shell on the console,  as  if  you  had  just  booted.
Filesystems remain mounted after the system is taken single-
user.  If you wish to come up multi-user again,  you  should
do this by:

     ## _c_d _/
     ## _/_s_b_i_n_/_u_m_o_u_n_t _-_a
     ## _^_D

     Each  system shutdown, crash, processor halt and reboot
is recorded in the system log with its cause.

66..22..  DDeevviiccee eerrrroorrss aanndd ddiiaaggnnoossttiiccss
     When serious errors occur on peripherals or in the sys-
tem,  the system prints a warning diagnostic on the console.
These messages are collected by  the  system  error  logging
process  _s_y_s_l_o_g_d(8) and written into a system error log file
/var/log/messages.  Less serious errors are sent directly to
_s_y_s_l_o_g_d,  which may log them on the console.  The error pri-
orities that are logged and the locations to which they  are
logged  are  controlled by /etc/syslog.conf.  See _s_y_s_l_o_g_d(8)
for further details.
     Error messages printed by the devices in the system are
described  with  the drivers for the devices in section 4 of
the programmer's manual.  If errors occur  suggesting  hard-
ware  problems,  you  should  contact  your hardware support
group or field service.  It is a good idea  to  examine  the
error  log  file  regularly  (e.g.  with the command _t_a_i_l _-_r
_/_v_a_r_/_l_o_g_/_m_e_s_s_a_g_e_s).

66..33..  FFiilleessyysstteemm cchheecckkss,, bbaacckkuuppss,, aanndd ddiissaasstteerr rreeccoovveerryy
     Periodically  (say  every  week or so in the absence of
any problems) and always  (usually  automatically)  after  a
crash, all the filesystems should be checked for consistency



                        May 14, 1994





SMM:1-74                Installing and Operating 4.4BSD UNIX


by _f_s_c_k(1).  The procedures of _r_e_b_o_o_t(8) should be  used  to
get  the  system  to a state where a filesystem check can be
done manually or automatically.
     Dumping of the filesystems should  be  done  regularly,
since  once the system is going it is easy to become compla-
cent.  Complete and incremental dumps are easily  done  with
_d_u_m_p(8).   You  should  arrange to do a towers-of-hanoi dump
sequence; we tune ours so that almost all files  are  dumped
on  two  tapes  and  kept  for at least a week in most every
case.  We take full dumps every month (and keep these indef-
initely).   Operators  can  execute ``dump w'' at login that
will tell them  what  needs  to  be  dumped  (based  on  the
/etc/fstab information).  Be sure to create a group ooppeerraattoorr
in the file /etc/group so that  dump  can  notify  logged-in
operators when it needs help.
     More  precisely,  we  have three sets of dump tapes: 10
daily tapes, 5 weekly sets of 2 tapes,  and  fresh  sets  of
three  tapes  monthly.   We do daily dumps circularly on the
daily tapes with sequence `3 2 5 4 7 6 9 8 9 9 9 ...'.  Each
weekly  is  a  level  1  and  the  daily dump sequence level
restarts after each weekly dump.  Full dumps are level 0 and
the daily sequence restarts after each full dump also.
     Thus a typical dump sequence would be:

 tape name   level number       date         opr      size
 ----------------------------------------------------------
   FULL           0         Nov 24, 1992   operator   137K
     D1           3         Nov 28, 1992   operator   29K
     D2           2         Nov 29, 1992   operator   34K
     D3           5         Nov 30, 1992   operator   19K
     D4           4          Dec 1, 1992   operator   22K
     W1           1          Dec 2, 1992   operator   40K
     D5           3          Dec 4, 1992   operator   15K
     D6           2          Dec 5, 1992   operator   25K
     D7           5          Dec 6, 1992   operator   15K
     D8           4          Dec 7, 1992   operator   19K
     W2           1          Dec 9, 1992   operator   118K
     D9           3         Dec 11, 1992   operator   15K
    D10           2         Dec 12, 1992   operator   26K
     D1           5         Dec 15, 1992   operator   14K
     W3           1         Dec 17, 1992   operator   71K
     D2           3         Dec 18, 1992   operator   13K
   FULL           0         Dec 22, 1992   operator   135K

We  do weekly dumps often enough that daily dumps always fit
on one tape.
     Dumping of files by name is best done by _t_a_r(1) but the
amount of data that can be moved in this way is limited to a
single tape.  Finally if  there  are  enough  drives  entire
disks  can  be copied with _d_d(1) using the raw special files
and an appropriate blocking factor; the  number  of  sectors
per track is usually a good value to use, consult /etc/disk-
tab.




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-75


     It is desirable that full dumps of the root  filesystem
be  made  regularly.   This is especially true when only one
disk is available.  Then, if the root filesystem is  damaged
by  a  hardware or software failure, you can rebuild a work-
able disk doing a restore in the same way that  the  initial
root filesystem was created.
     Exhaustion  of  user-file space is certain to occur now
and then; disk quotas may be imposed, or  if  you  prefer  a
less  fascist approach, try using the programs _d_u(1), _d_f(1),
and _q_u_o_t(8), combined with threatening messages of the  day,
and personal letters.

66..44..  MMoovviinngg ffiilleessyysstteemm ddaattaa
     If  you  have  the  resources,  the  best way to move a
filesystem is to dump it to a spare disk partition, or  mag-
tape, using _d_u_m_p(8), use _n_e_w_f_s(8) to create the new filesys-
tem, and restore the filesystem using _r_e_s_t_o_r_e(8).   Filesys-
tems  may  also  be  moved  by  piping the output of _d_u_m_p to
_r_e_s_t_o_r_e.  The _r_e_s_t_o_r_e program uses an ``in-place'' algorithm
that  allows filesystem dumps to be restored without concern
for the original size of the filesystem.  Further,  portions
of  a  filesystem may be selectively restored using a method
similar to the tape archive program.
     If you have to merge a filesystem into another,  exist-
ing  one, the best bet is to use _t_a_r(1).  If you must shrink
a filesystem, the best bet  is  to  dump  the  original  and
restore it onto the new filesystem.  If you are playing with
the root filesystem and only have one drive,  the  procedure
is  more  complicated.   If  the  only drive is a Winchester
disk, this procedure may not be used without overwriting the
existing root or another partition.  What you do is the fol-
lowing:
1.   GET A SECOND PACK, OR USE ANOTHER DISK DRIVE!!!!
2.   Dump the root filesystem to tape using _d_u_m_p(8).
3.   Bring the system down.
4.   Mount the new pack in the correct disk drive, if  using
     removable media.
5.   Load  the  distribution  tape  and install the new root
     filesystem as you did when first installing the system.
     Boot  normally using the newly created disk filesystem.
     Note that if you change the disk  partition  tables  or
add new disk drivers they should also be added to the stand-
alone system in /sys/<architecture>/stand, and  the  default
disk partition tables in /etc/disktab should be modified.

66..55..  MMoonniittoorriinngg ssyysstteemm ppeerrffoorrmmaannccee
     The _s_y_s_t_a_t program provided with the system is designed
to be an aid to monitoring systemwide activity.  The default
``pigs''  mode  shows  a  dynamic ``ps''.  By running in the
``vmstat'' mode when the system is active you can judge  the
system  activity  in  several  dimensions: job distribution,
virtual memory load, paging and  swapping  activity,  device
interrupts,  and  disk  and CPU utilization.  Ideally, there
should be few blocked  (b)  jobs,  there  should  be  little



                        May 14, 1994





SMM:1-76                Installing and Operating 4.4BSD UNIX


paging or swapping activity, there should be available band-
width on the disk devices (most  single  arms  peak  out  at
20-30  tps  in  practice), and the user CPU utilization (us)
should be high (above 50%).
     If the system is busy, then the count  of  active  jobs
may be large, and several of these jobs may often be blocked
(b).  If the virtual memory is active, then the paging demon
will  be  running  (sr will be non-zero).  It is healthy for
the paging demon to free pages when the virtual memory  gets
active;  it  is triggered by the amount of free memory drop-
ping below a threshold and increases its pace as free memory
goes to zero.
     If  you  run  in the ``vmstat'' mode when the system is
busy, you can find imbalances by noting abnormal job distri-
butions.   If  many processes are blocked (b), then the disk
subsystem is overloaded or imbalanced.  If you have  several
non-DMA devices or open teletype lines that are ``ringing'',
or user programs  that  are  doing  high-speed  non-buffered
input/output,  then  the  system time may go high (60-70% or
higher).  It is often possible to pin down the cause of high
system  time by looking to see if there is excessive context
switching  (cs),  interrupt  activity  (in)  and  per-device
interrupt  counts,  or  system  call activity (sy).  Cumula-
tively on one of our large machines we average about  60-200
context  switches and interrupts per second and about 50-500
system calls per second.
     If the system is heavily loaded, or if you have  little
memory  for  your load (2M is little in most any case), then
the system may be forced to swap.   This  is  likely  to  be
accompanied  by a noticeable reduction in system performance
and pregnant pauses when interactive jobs  such  as  editors
swap  out.  If you expect to be in a memory-poor environment
for an extended period you might  consider  administratively
limiting system load.

66..66..  RReeccoommppiilliinngg aanndd rreeiinnssttaalllliinngg ssyysstteemm ssooffttwwaarree
     It is easy to regenerate either the entire system or  a
single  utility,  and  it  is  a good idea to try rebuilding
pieces of the system to build confidence in the  procedures.
In  general,  there  are six well-known targets supported by
all the makefiles on the system:
all      This entry is the default target, the same as if no
         target  is  specified.  This target builds the ker-
         nel, binary or library, as well as  its  associated
         manual  pages.   This  target  ddooeess  nnoott  build the
         dependency files.  Some of  the  utilities  require
         that  a  _m_a_k_e  _d_e_p_e_n_d be done before a _m_a_k_e _a_l_l can
         succeed.
depend   Build   the   include   file    dependency    file,
         ``.depend'',  which  is read by _m_a_k_e.  See _m_k_d_e_p(1)
         for further details.
install  Install the kernel, binary or library, as  well  as
         its  associated  manual  pages.  See _i_n_s_t_a_l_l(1) for
         further details.



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-77


clean    Remove the kernel, binary or library,  as  well  as
         any object files created when building it.
cleandir The same as clean, except that the dependency files
         and formatted manual pages are removed as well.
obj      Build a shadow directory structure in the area ref-
         erenced  by  /usr/obj and create a symbolic link in
         the current  source  directory  to  referenced  it,
         named ``obj''.  Once this shadow structure has been
         created, all the files created by _m_a_k_e will live in
         the  shadow  structure, and /usr/src may be mounted
         read-only by multiple machines.  Doing a  _m_a_k_e  _o_b_j
         in  /usr/src will build the shadow directory struc-
         ture for everything on the system  except  for  the
         contributed, old, and kernel software.
     The  system  consists  of three major parts: the kernel
itself, found in /usr/src/sys,  the  libraries  ,  found  in
/usr/src/lib,  and the user programs (the rest of /usr/src).
     Deprecated software, found in /usr/src/old,  often  has
old  style  makefiles;  some  of  it  does not compile under
4.4BSD at all.
     Contributed software, found in  /usr/src/contrib,  usu-
ally  does  not  support  the  ``cleandir'',  ``depend'', or
``obj'' targets.
     The kernel does not support the ``obj''  shadow  struc-
ture.    All  kernels  are  compiled  in  subdirectories  of
/usr/src/sys/compile  which  is   usually   abbreviated   as
/sys/compile.   If  you want to mount your source tree read-
only, /usr/src/sys/compile will have to  be  on  a  separate
filesystem  from  /usr/src.  Separation from /usr/src can be
done by making /usr/src/sys/compile  a  symbolic  link  that
references  /usr/obj/sys/compile.  If it is a symbolic link,
the _S variable in the kernel Makefile must be  changed  from
../..   to the absolute pathname needed to locate the kernel
sources, usually /usr/src/sys.  The symbolic link created by
_c_o_n_f_i_g(8)  for  machine  must also be manually changed to an
absolute pathname.   Finally,  the  /usr/src/sys/libkern/obj
directory must be located in /usr/obj/sys/libkern.
     Each  of  the  standard  utilities and libraries may be
built and installed by changing directories into the correct
location and doing:

     ## _m_a_k_e
     ## _m_a_k_e _i_n_s_t_a_l_l

Note, if system include files have changed between compiles,
_m_a_k_e will not do the correct dependency checks if the depen-
dency files have not been built using the ``depend'' target.
     The entire library and utility suite for the system may
be recompiled from scratch by changing directory to /usr/src
and doing:

     ## _m_a_k_e _b_u_i_l_d

This target installs the system include  files,  cleans  the



                        May 14, 1994





SMM:1-78                Installing and Operating 4.4BSD UNIX


source  tree,  builds and installs the libraries, and builds
and installs the system utilities.
     To recompile a specific program, first determine  where
the  binary resides with the _w_h_e_r_e_i_s(1) command, then change
to the corresponding source directory and build it with  the
Makefile  in  the  directory.   For  instance,  to recompile
``passwd'', all one has to do is:

     ## _w_h_e_r_e_i_s _p_a_s_s_w_d
     //uussrr//bbiinn//ppaasssswwdd
     ## _c_d _/_u_s_r_/_s_r_c_/_u_s_r_._b_i_n_/_p_a_s_s_w_d
     ## _m_a_k_e
     ## _m_a_k_e _i_n_s_t_a_l_l

this will compile and install the _p_a_s_s_w_d utility.
     If you wish to recompile and install all programs  into
a  particular  target area you can override the default path
prefix by doing:

     ## _m_a_k_e
     ## _m_a_k_e _D_E_S_T_D_I_R_=pathname _i_n_s_t_a_l_l

Similarly, the mode, owner, group, and other characteristics
of  the  installed  object can be modified by changing other
default      make       variables.        See       _m_a_k_e(1),
/usr/src/share/mk/bsd.README, and the ``.mk'' scripts in the
/usr/share/mk directory for more information.
     If you modify the C library or system include files, to
change  a  system  call for example, and want to rebuild and
install everything, you have to be a  little  careful.   You
must ensure that the include files are installed before any-
thing is compiled, and  that  the  libraries  are  installed
before  the  remainder  of  the source, otherwise the loaded
images will not contain the new routine  from  the  library.
If  include files have been modified, the following commands
should be done first:

     ## _c_d _/_u_s_r_/_s_r_c_/_i_n_c_l_u_d_e
     ## _m_a_k_e _i_n_s_t_a_l_l

Then, if, for example, C library files have  been  modified,
the following commands should be executed:

     ## _c_d _/_u_s_r_/_s_r_c_/_l_i_b_/_l_i_b_c
     ## _m_a_k_e _d_e_p_e_n_d
     ## _m_a_k_e
     ## _m_a_k_e _i_n_s_t_a_l_l
       ## _c_d _/_u_s_r_/_s_r_c
       ## _m_a_k_e _d_e_p_e_n_d
       ## _m_a_k_e
       ## _m_a_k_e _i_n_s_t_a_l_l

Alternatively,  the  _m_a_k_e _b_u_i_l_d command described above will
accomplish the same tasks.  This takes several  hours  on  a



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-79


reasonably configured machine.

66..77..  MMaakkiinngg llooccaall mmooddiiffiiccaattiioonnss
     The  source  for  locally  written commands is normally
stored in /usr/src/local, and their  binaries  are  kept  in
/usr/local/bin.   This  isolation  of  local binaries allows
/usr/bin, and /bin to correspond to  the  distribution  tape
(and  to  the  manuals  that  people can buy).  People using
local commands should be made aware that they are not in the
base  manual.   Manual  pages  for  local commands should be
installed in /usr/local/man/cat[1-8].   The  _m_a_n(1)  command
automatically     finds     manual     pages    placed    in
/usr/local/man/cat[1-8]  to  encourage  this  practice  (see
_m_a_n_._c_o_n_f(5)).

66..88..  AAccccoouunnttiinngg
     UNIX  optionally records two kinds of accounting infor-
mation:  connect  time  accounting  and   process   resource
accounting.   The  connect  time  accounting  information is
stored in the file /var/log/wtmp, which is summarized by the
program  _a_c(8).   The process time accounting information is
stored in the file /var/account/acct after it is enabled  by
_a_c_c_t_o_n(8),  and  is  analyzed  and summarized by the program
_s_a(8).
     If you need to recharge for  computing  time,  you  can
develop  procedures  based  on  the  information provided by
these commands.  A convenient way to do this is to give com-
mands  to  the  clock  daemon  /usr/sbin/cron to be executed
every day at a specified time.  This is done by adding lines
to /etc/crontab.local; see _c_r_o_n(8) for details.

66..99..  RReessoouurrccee ccoonnttrrooll
     Resource control in the current version of UNIX is more
elaborate than in most UNIX systems.  The disk quota facili-
ties  developed  at  the  University  of Melbourne have been
incorporated in the system and allow control over the number
of files and amount of disk space each user and/or group may
use on each filesystem.  In addition, the resources consumed
by  any  single  process can be limited by the mechanisms of
_s_e_t_r_l_i_m_i_t(2).  As distributed, the latter mechanism is  vol-
untary,  though  sites may choose to modify the login mecha-
nism to impose limits not covered with disk quotas.
     To use the disk quota facilities, the  system  must  be
configured  with ``options QUOTA''.  Filesystems may then be
placed under the quota mechanism by  creating  a  null  file
quota.user and/or quota.group at the root of the filesystem,
running _q_u_o_t_a_c_h_e_c_k(8), and modifying /etc/fstab to show that
the filesystem is to run with disk quotas (options userquota
and/or groupquota).  The _q_u_o_t_a_o_n(8) program may then be  run
to enable quotas.
     Individual quotas are applied by using the quota editor
_e_d_q_u_o_t_a(8).  Users may view their quotas (but not  those  of
other users) with the _q_u_o_t_a(1) program. The _r_e_p_q_u_o_t_a(8) pro-
gram may be used to summarize the quotas and  current  space



                        May 14, 1994





SMM:1-80                Installing and Operating 4.4BSD UNIX


usage on a particular filesystem or filesystems.
     Quotas  are enforced with _s_o_f_t and _h_a_r_d limits.  When a
user and/or group first reaches a soft limit on a  resource,
a  message  is  generated  on  their  terminal.  If the user
and/or group fails to lower the  resource  usage  below  the
soft  limit  for  longer than the time limit established for
that filesystem (default seven days) the system then  treats
the soft limit as a _h_a_r_d limit and disallows any allocations
until enough space is reclaimed to  bring  the  user  and/or
group  back  below the soft limit.  Hard limits are enforced
strictly resulting in errors when a user and/or group  tries
to  create  or  write  a  file.   Each  time a hard limit is
exceeded the system will generate a message  on  the  user's
terminal.
     Consult the auxiliary document, ``Disc Quotas in a UNIX
Environment'' (SMM:4) and the appropriate manual entries for
more information.

66..1100..  NNeettwwoorrkk ttrroouubblleesshhoooottiinngg
     If  you  have anything more than a trivial network con-
figuration, from time to time you  are  bound  to  run  into
problems.   Before  blaming  the  software, first check your
network connections.  On networks such  as  the  Ethernet  a
loose  cable  tap or misplaced power cable can result in se-
verely deteriorated service.  The _n_e_t_s_t_a_t(1) program may  be
of  aid in tracking down hardware malfunctions.  In particu-
lar, look at the --ii and --ss options in the manual page.
     Should you believe  a  communication  protocol  problem
exists,  consult  the protocol specifications and attempt to
isolate the problem in a packet trace.  The SO_DEBUG  option
may  be  supplied  before  establishing  a  connection  on a
socket, in which case the system will trace all traffic  and
internal  actions  (such  as  timers expiring) in a circular
trace buffer.  This buffer may then be printed out with  the
_t_r_p_t(8)  program.   Most of the servers distributed with the
system accept a --dd option forcing all sockets to be  created
with  debugging  turned  on.  Consult the appropriate manual
pages for more information.

66..1111..  FFiilleess tthhaatt nneeeedd ppeerriiooddiicc aatttteennttiioonn
     We conclude the  discussion  of  system  operations  by
listing  the  files  that  require periodic attention or are
system specific:

/etc/fstab           how disk partitions are used
/etc/disktab         default disk partition sizes/labels
/etc/printcap        printer database
/etc/gettytab        terminal type definitions
/etc/remote          names and phone numbers of remote machines for _t_i_p(1)
/etc/group           group memberships
/etc/motd            message of the day
/etc/master.passwd   password file; each account has a line
/etc/rc.local        local system restart script; runs reboot; starts daemons




                        May 14, 1994





Installing and Operating 4.4BSD UNIX                SMM:1-81


/etc/inetd.conf      local internet servers
/etc/hosts           local host name database
/etc/networks        network name database
/etc/services        network services database
/etc/hosts.equiv     hosts under same administrative control
/etc/syslog.conf     error log configuration for _s_y_s_l_o_g_d(8)
/etc/ttys            enables/disables ports
/etc/crontab         commands that are run periodically
/etc/crontab.local   local commands that are run periodically
/etc/aliases         mail forwarding and distribution groups
/var/account/acct    raw process account data
/var/log/messages    system error log
/var/log/wtmp        login session accounting












































                        May 14, 1994





SMM:1-2                 Installing and Operating 4.4BSD UNIX



                     TTaabbllee ooff CCoonntteennttss


1.    Introduction . . . . . . . . . . . . . . . . . . .   4
1.1.  Distribution format  . . . . . . . . . . . . . . .   4
1.2.  UNIX device naming . . . . . . . . . . . . . . . .   4
1.3.  UNIX devices: block and raw  . . . . . . . . . . .   5
2.    Bootstrap procedure  . . . . . . . . . . . . . . .   6
2.1.  Bootstrapping from the tape  . . . . . . . . . . .   6
2.2.  Booting the HP300  . . . . . . . . . . . . . . . .   7
2.2.1.Supported hardware . . . . . . . . . . . . . . . .   7
2.2.2.Standalone device file naming  . . . . . . . . . .   8
2.2.3.The procedure  . . . . . . . . . . . . . . . . . .   8
2.2.3.1.Step 1: selecting and formatting a disk  . . . .   8
2.2.3.2.Step 2: copying the root filesystem from
tape to disk . . . . . . . . . . . . . . . . . . . . . .   9
2.2.3.3.Step 3: booting the root filesystem  . . . . . .  10
2.2.3.4.Step 4: (optional) restoring the root
filesystem . . . . . . . . . . . . . . . . . . . . . . .  12
2.2.3.5.Step 5: placing labels on the disks  . . . . . .  13
2.3.  Booting the SPARC  . . . . . . . . . . . . . . . .  14
2.3.1.Supported hardware . . . . . . . . . . . . . . . .  14
2.3.2.Limitations  . . . . . . . . . . . . . . . . . . .  14
2.3.3.The procedure  . . . . . . . . . . . . . . . . . .  15
2.4.  Booting the DECstation . . . . . . . . . . . . . .  16
2.4.1.Supported hardware . . . . . . . . . . . . . . . .  16
2.4.2.The procedure  . . . . . . . . . . . . . . . . . .  17
2.4.2.1.Procedure A: copy root filesystem to disk  . . .  18
2.4.2.2.Procedure B: bootstrap from tape . . . . . . . .  18
2.4.2.3.Procedure C: bootstrap over the network  . . . .  18
2.4.3.Label disk and create the root filesystem  . . . .  19
2.5.  Disk configuration . . . . . . . . . . . . . . . .  20
2.5.1.Disk naming and divisions  . . . . . . . . . . . .  20
2.5.2.Layout considerations  . . . . . . . . . . . . . .  21
2.5.3.Filesystem parameters  . . . . . . . . . . . . . .  22
2.5.4.Implementing a layout  . . . . . . . . . . . . . .  24
2.6.  Installing the rest of the system  . . . . . . . .  25
2.7.  Additional conversion information  . . . . . . . .  29
3.    Upgrading a 4.3BSD system  . . . . . . . . . . . .  29
3.1.  Installation overview  . . . . . . . . . . . . . .  30
3.2.  Files to save  . . . . . . . . . . . . . . . . . .  31
3.3.  Installing 4.4BSD  . . . . . . . . . . . . . . . .  32
3.4.  Merging your files from 4.3BSD into 4.4BSD . . . .  36
3.4.1.Changes in the /etc directory  . . . . . . . . . .  37
3.4.2.Shadow password files  . . . . . . . . . . . . . .  40
3.4.3.The /var filesystem  . . . . . . . . . . . . . . .  40
3.5.  Bug fixes and changes between 4.3BSD and
4.4BSD . . . . . . . . . . . . . . . . . . . . . . . . .  41
3.5.1.Changes to the kernel  . . . . . . . . . . . . . .  42
3.5.2.Security . . . . . . . . . . . . . . . . . . . . .  42
3.5.2.1.Virtual memory changes . . . . . . . . . . . . .  43
3.5.2.2.Networking additions and changes . . . . . . . .  44
3.5.2.3.Additions and changes to filesystems . . . . . .  45



                        May 14, 1994





Installing and Operating 4.4BSD UNIX                 SMM:1-3


3.5.2.4.POSIX terminal driver changes  . . . . . . . . .  48
3.5.2.5.Native operating system compatibility  . . . . .  48
3.5.3.Changes to the utilities . . . . . . . . . . . . .  49
3.5.3.1.Make and Makefiles . . . . . . . . . . . . . . .  49
3.5.3.2.Kerberos . . . . . . . . . . . . . . . . . . . .  50
3.5.3.3.Timezone support . . . . . . . . . . . . . . . .  50
3.5.3.4.Additions and changes to the libraries . . . . .  51
3.5.3.5.Additions and changes to other utilities . . . .  52
3.6.  Hints on converting from 4.3BSD to 4.4BSD  . . . .  54
4.    System setup . . . . . . . . . . . . . . . . . . .  55
4.1.  Kernel configuration . . . . . . . . . . . . . . .  55
4.1.1.Kernel organization  . . . . . . . . . . . . . . .  55
4.1.2.Devices and device drivers . . . . . . . . . . . .  57
4.1.3.Building new system images . . . . . . . . . . . .  57
4.2.  Configuring terminals  . . . . . . . . . . . . . .  58
4.3.  Adding users . . . . . . . . . . . . . . . . . . .  59
4.4.  Site tailoring . . . . . . . . . . . . . . . . . .  60
4.5.  Setting up the line printer system . . . . . . . .  60
4.6.  Setting up the mail system . . . . . . . . . . . .  61
4.6.1.Setting up a UUCP connection . . . . . . . . . . .  62
5.    Network setup  . . . . . . . . . . . . . . . . . .  64
5.1.  System configuration . . . . . . . . . . . . . . .  65
5.2.  Local subnets  . . . . . . . . . . . . . . . . . .  66
5.3.  Internet broadcast addresses . . . . . . . . . . .  67
5.4.  Routing  . . . . . . . . . . . . . . . . . . . . .  67
5.5.  Use of 4.4BSD machines as gateways . . . . . . . .  69
5.6.  Network databases  . . . . . . . . . . . . . . . .  69
5.6.1.Network servers  . . . . . . . . . . . . . . . . .  70
5.6.2.Internet daemon  . . . . . . . . . . . . . . . . .  70
5.6.3.The /etc/hosts.equiv file  . . . . . . . . . . . .  71
5.6.4.The /etc/ftpusers file . . . . . . . . . . . . . .  71
6.    System operation . . . . . . . . . . . . . . . . .  72
6.1.  Bootstrap and shutdown procedures  . . . . . . . .  72
6.2.  Device errors and diagnostics  . . . . . . . . . .  73
6.3.  Filesystem checks, backups, and disaster
recovery . . . . . . . . . . . . . . . . . . . . . . . .  73
6.4.  Moving filesystem data . . . . . . . . . . . . . .  75
6.5.  Monitoring system performance  . . . . . . . . . .  75
6.6.  Recompiling and reinstalling system software
 . . . . . . . . . . . . . . . . . . . . . . . . . . . .  76
6.7.  Making local modifications . . . . . . . . . . . .  79
6.8.  Accounting . . . . . . . . . . . . . . . . . . . .  79
6.9.  Resource control . . . . . . . . . . . . . . . . .  79
6.10. Network troubleshooting  . . . . . . . . . . . . .  80
6.11. Files that need periodic attention . . . . . . . .  80












                        May 14, 1994


