2011-06-11 21:44:07 +00:00
|
|
|
.\"-
|
2013-01-22 02:47:08 +00:00
|
|
|
.\" Copyright (c) 2011-2013 Nathan Whitehorn <nwhitehorn@FreeBSD.org>
|
2011-06-11 21:44:07 +00:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
.\" WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
.\" DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
|
|
.\" INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
.\" (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
.\" SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
.\" STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
.\" ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
2017-05-23 08:01:11 +00:00
|
|
|
.Dd May 23, 2017
|
2012-03-25 19:34:05 +00:00
|
|
|
.Dt BSDINSTALL 8
|
2011-06-11 21:44:07 +00:00
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm bsdinstall
|
|
|
|
.Nd system installer
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm
|
2013-11-08 09:57:03 +00:00
|
|
|
.Op Ar options
|
2011-06-11 21:44:07 +00:00
|
|
|
.Op Ar target
|
|
|
|
.Op Ar ...
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
.Nm
|
|
|
|
is used for installation of new systems, both for system setup from
|
2017-05-23 08:01:11 +00:00
|
|
|
installation media, e.g., CD-ROMs, and for use on live systems to prepare
|
2011-06-11 21:44:07 +00:00
|
|
|
VM images and jails.
|
|
|
|
.Pp
|
|
|
|
Much like
|
|
|
|
.Xr make 1 , Nm
|
2017-05-23 08:01:11 +00:00
|
|
|
takes a target and possible parameters of the target as arguments.
|
|
|
|
If invoked with no arguments, it will invoke the
|
2011-06-11 21:44:07 +00:00
|
|
|
.Cm auto
|
|
|
|
target, which provides a standard interactive installation, invoking the
|
2017-05-23 08:01:11 +00:00
|
|
|
others in sequence.
|
|
|
|
To perform a scripted installation,
|
|
|
|
these subtargets can be invoked separately by an installation script.
|
2013-11-08 09:57:03 +00:00
|
|
|
.Sh OPTIONS
|
|
|
|
.Nm
|
|
|
|
supports the following options, global to all targets:
|
|
|
|
.Bl -tag -width indent+
|
|
|
|
.It Fl D Ar file
|
|
|
|
Provide a path for the installation log file
|
|
|
|
.Pq overrides Ev BSDINSTALL_LOG .
|
|
|
|
See
|
|
|
|
.Sx ENVIRONMENT VARIABLES
|
|
|
|
for more information on
|
|
|
|
.Ev BSDINSTALL_LOG .
|
2013-11-08 23:11:04 +00:00
|
|
|
.El
|
2011-06-11 21:44:07 +00:00
|
|
|
.Sh TARGETS
|
|
|
|
Most of the following targets are only useful for scripting the installer.
|
|
|
|
For interactive use, most users will be interested only in the
|
2013-01-22 02:40:06 +00:00
|
|
|
.Cm auto ,
|
|
|
|
.Cm jail ,
|
2011-06-11 21:44:07 +00:00
|
|
|
and
|
2013-01-22 02:40:06 +00:00
|
|
|
.Cm script
|
2011-06-11 21:44:07 +00:00
|
|
|
targets.
|
|
|
|
.Bl -tag -width ".Cm jail Ar destination"
|
|
|
|
.It Cm auto
|
|
|
|
Run the standard interactive installation, including disk partitioning.
|
|
|
|
.It Cm jail Ar destination
|
|
|
|
Sets up a new chroot system at
|
|
|
|
.Pa destination ,
|
|
|
|
suitable for use with
|
|
|
|
.Xr jail 8 .
|
|
|
|
Behavior is generally similar to
|
|
|
|
.Cm auto ,
|
|
|
|
except that disk partitioning and network setup are skipped and a kernel is
|
|
|
|
not installed into the new system.
|
2013-01-22 02:40:06 +00:00
|
|
|
.It Cm script Ar script
|
|
|
|
Runs the installation script at
|
|
|
|
.Pa script .
|
|
|
|
See
|
|
|
|
.Sx SCRIPTING
|
|
|
|
for more information on this target.
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Cm keymap
|
|
|
|
If the current controlling TTY is a
|
|
|
|
.Xr syscons 4
|
2014-08-26 10:55:08 +00:00
|
|
|
or
|
|
|
|
.Xr vt 4
|
2011-06-11 21:44:07 +00:00
|
|
|
console, asks the user to set the current keymap, and saves the result to the
|
|
|
|
new system's
|
|
|
|
.Pa rc.conf .
|
|
|
|
.It Cm hostname
|
|
|
|
Prompts the user for a host name for the new system and saves the result to the
|
|
|
|
new system's
|
|
|
|
.Pa rc.conf .
|
|
|
|
If
|
|
|
|
.Ev BSDINSTALL_CONFIGCURRENT
|
|
|
|
is set, also sets the host name of the current system.
|
|
|
|
.It Cm netconfig
|
|
|
|
Interactively configures network interfaces (first invoking
|
|
|
|
.Cm wlanconfig
|
|
|
|
on wireless interfaces), saving the result to the new system's
|
2012-03-29 05:02:12 +00:00
|
|
|
.Pa rc.conf
|
2011-06-11 21:44:07 +00:00
|
|
|
and
|
|
|
|
.Pa resolv.conf .
|
|
|
|
If
|
|
|
|
.Ev BSDINSTALL_CONFIGCURRENT
|
|
|
|
is set, also configures the network interfaces of the current system to match.
|
|
|
|
.It Cm autopart
|
|
|
|
Provides the installer's interactive guided disk partitioner for single-disk
|
2017-05-23 08:01:11 +00:00
|
|
|
installations.
|
|
|
|
Defaults to UFS.
|
2013-10-15 17:33:30 +00:00
|
|
|
.It Cm zfsboot
|
2014-10-31 23:52:02 +00:00
|
|
|
Provides an alternative ZFS-only automatic interactive disk partitioner.
|
2013-10-15 17:33:30 +00:00
|
|
|
Creates a single
|
|
|
|
.Ic zpool
|
2014-10-31 23:52:02 +00:00
|
|
|
with separate datasets for
|
|
|
|
.Pa /tmp ,
|
|
|
|
.Pa /usr ,
|
|
|
|
.Pa /usr/home ,
|
|
|
|
.Pa /usr/ports ,
|
|
|
|
.Pa /usr/src ,
|
2013-10-15 17:33:30 +00:00
|
|
|
and
|
2014-10-31 23:52:02 +00:00
|
|
|
.Pa /var .
|
|
|
|
Optionally can set up
|
2014-12-29 13:50:59 +00:00
|
|
|
.Xr geli 8
|
2014-10-31 23:52:02 +00:00
|
|
|
to encrypt the disk.
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Cm partedit
|
2014-10-31 23:52:02 +00:00
|
|
|
Provides the installer's interactive manual disk partitioner with an interface
|
|
|
|
identical to
|
|
|
|
.Xr sade 8 .
|
2017-05-23 08:01:11 +00:00
|
|
|
Supports multiple disks as well as UFS, ZFS, and FAT file systems.
|
|
|
|
ZFS is set up with one pool and dataset per partition.
|
2013-01-22 02:40:06 +00:00
|
|
|
.It Cm scriptedpart Ar parameters
|
|
|
|
Sets up disks like
|
|
|
|
.Cm autopart
|
|
|
|
and
|
|
|
|
.Cm partedit ,
|
|
|
|
but non-interactively according to the disk setup specified in
|
|
|
|
.Ar parameters .
|
|
|
|
Each disk setup is specified by a three-part argument:
|
|
|
|
.Pp
|
2013-01-22 15:26:19 +00:00
|
|
|
.Ar disk
|
|
|
|
.Op Ar scheme
|
|
|
|
.Op Ar {partitions}
|
2013-01-22 02:40:06 +00:00
|
|
|
.Pp
|
2017-05-23 08:01:11 +00:00
|
|
|
Multiple disk setups are separated by semicolons.
|
|
|
|
The
|
2013-01-22 02:40:06 +00:00
|
|
|
.Ar disk
|
|
|
|
argument specifies the disk on which to operate (which will be erased),
|
|
|
|
while the
|
|
|
|
.Ar scheme
|
|
|
|
argument specifies the
|
|
|
|
.Xr gpart 8
|
2017-05-23 08:01:11 +00:00
|
|
|
partition scheme to apply to the disk.
|
|
|
|
If
|
2013-01-22 02:40:06 +00:00
|
|
|
.Ar scheme
|
|
|
|
is unspecified,
|
|
|
|
.Cm scriptedpart
|
|
|
|
will apply the default bootable scheme on your platform.
|
|
|
|
The
|
|
|
|
.Ar partitions
|
|
|
|
argument is also optional and specifies how to partition
|
|
|
|
.Ar disk .
|
|
|
|
It consists of a comma-separated list of partitions to create enclosed in
|
2017-05-23 08:01:11 +00:00
|
|
|
curly braces.
|
|
|
|
Each partition declaration takes the form
|
2013-01-22 02:40:06 +00:00
|
|
|
.Pp
|
2013-01-22 15:26:19 +00:00
|
|
|
.Ar size
|
|
|
|
.Ar type
|
|
|
|
.Op Ar mount point
|
2013-01-22 02:40:06 +00:00
|
|
|
.Pp
|
|
|
|
.Ar size
|
|
|
|
specifies the partition size to create in bytes (K, M, and G suffixes
|
|
|
|
can be appended to specify kilobytes, megabytes, and gigabytes respectively),
|
|
|
|
while the
|
|
|
|
.Em auto
|
2017-05-23 08:01:11 +00:00
|
|
|
keyword causes the partition to take all the remaining space on the disk.
|
|
|
|
The
|
2013-01-22 02:40:06 +00:00
|
|
|
.Ar type
|
|
|
|
option chooses the
|
|
|
|
.Xr gpart 8
|
2017-05-23 08:01:11 +00:00
|
|
|
filesystem type, e.g., freebsd-ufs, freebsd-zfs, or freebsd-swap.
|
2013-01-22 02:40:06 +00:00
|
|
|
The optional
|
|
|
|
.Ar mount point
|
|
|
|
argument sets where the created partition is to be mounted in the installed
|
2017-05-23 08:01:11 +00:00
|
|
|
system.
|
|
|
|
As an example, a typical invocation looks like:
|
2013-01-22 02:40:06 +00:00
|
|
|
.Pp
|
|
|
|
bsdinstall scriptedpart ada0 { 20G freebsd-ufs /, 4G freebsd-swap, 20G freebsd-ufs /var, auto freebsd-ufs /usr }
|
2014-10-31 23:52:02 +00:00
|
|
|
.Pp
|
|
|
|
A shorter invocation to use the default partitioning (as
|
|
|
|
.Cm autopart
|
|
|
|
would have used) on the same disk:
|
|
|
|
.Pp
|
|
|
|
bsdinstall scriptedpart ada0
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Cm mount
|
|
|
|
Mounts the file systems previously configured by
|
2013-01-22 02:40:06 +00:00
|
|
|
.Cm autopart ,
|
|
|
|
.Cm partedit ,
|
2011-06-11 21:44:07 +00:00
|
|
|
or
|
2013-01-22 02:40:06 +00:00
|
|
|
.Cm scriptedpart
|
2011-06-11 21:44:07 +00:00
|
|
|
under
|
|
|
|
.Ev BSDINSTALL_CHROOT .
|
|
|
|
.It Cm distfetch
|
|
|
|
Fetches the distributions in
|
|
|
|
.Ev DISTRIBUTIONS
|
|
|
|
to
|
|
|
|
.Ev BSDINSTALL_DISTDIR
|
|
|
|
from
|
|
|
|
.Ev BSDINSTALL_DISTSITE .
|
|
|
|
.It Cm checksum
|
|
|
|
Verifies the checksums of the distributions listed in
|
|
|
|
.Ev DISTRIBUTIONS
|
|
|
|
against the distribution manifest.
|
|
|
|
.It Cm distextract
|
|
|
|
Extracts the distributions listed in
|
|
|
|
.Ev DISTRIBUTIONS
|
|
|
|
into
|
|
|
|
.Ev BSDINSTALL_CHROOT .
|
|
|
|
.It Cm rootpass
|
|
|
|
Interactively invokes
|
|
|
|
.Xr passwd 1
|
|
|
|
in the new system to set the root user's password.
|
|
|
|
.It Cm adduser
|
|
|
|
Interactively invokes
|
|
|
|
.Xr adduser 8
|
|
|
|
in the new system.
|
|
|
|
.It Cm time
|
|
|
|
Interactively sets the time, date, and time zone of the new system.
|
|
|
|
.It Cm services
|
|
|
|
Queries the user for the system daemons to begin at system startup,
|
|
|
|
writing the result into the new system's
|
|
|
|
.Pa rc.conf .
|
2014-10-31 23:52:02 +00:00
|
|
|
.It Cm entropy
|
|
|
|
Reads a small amount of data from
|
|
|
|
.Pa /dev/random
|
|
|
|
and stores it in a file in the new system's root directory.
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Cm config
|
2017-05-23 08:01:11 +00:00
|
|
|
Installs the configuration files destined for the new system, e.g.,
|
|
|
|
.Xr rc.conf 5
|
2011-06-11 21:44:07 +00:00
|
|
|
fragments generated by
|
|
|
|
.Cm netconfig ,
|
|
|
|
etc.) onto the new system.
|
|
|
|
.El
|
|
|
|
.Sh ENVIRONMENT VARIABLES
|
|
|
|
The following environment variables control various aspects of the installation
|
2017-05-23 08:01:11 +00:00
|
|
|
process.
|
|
|
|
Many are used internally during installation and have reasonable default values
|
|
|
|
for most installation scenarios.
|
|
|
|
Others are set by various interactive user prompts, and can be usefully
|
|
|
|
overridden when making scripted or customized installers.
|
2013-01-22 15:26:19 +00:00
|
|
|
.Bl -tag -width ".Ev BSDINSTALL_DISTSITE"
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Ev DISTRIBUTIONS
|
2017-05-23 08:01:11 +00:00
|
|
|
The set of distributions to install, e.g., "base kernel ports".
|
|
|
|
Default: none
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Ev BSDINSTALL_DISTDIR
|
|
|
|
The directory in which the distribution files can be found (or to which they
|
2017-05-23 08:01:11 +00:00
|
|
|
should be downloaded).
|
|
|
|
Default:
|
2011-06-11 21:44:07 +00:00
|
|
|
.Pa /usr/freebsd-dist
|
2013-01-22 15:26:19 +00:00
|
|
|
.It Ev BSDINSTALL_DISTSITE
|
|
|
|
URL from which the distribution files should be downloaded if they are not
|
|
|
|
already present in the directory defined by
|
|
|
|
.Ev BSDINSTALL_DISTDIR .
|
|
|
|
This should be a full path to the files, including architecture and release
|
2017-05-23 08:01:11 +00:00
|
|
|
names.
|
|
|
|
Most targets, e.g.,
|
2013-01-22 15:26:19 +00:00
|
|
|
.Cm auto
|
|
|
|
and
|
2017-05-23 08:01:11 +00:00
|
|
|
.Cm jail ,
|
2013-01-22 15:26:19 +00:00
|
|
|
that prompt for a
|
|
|
|
.Fx
|
|
|
|
mirror will skip that step if this variable is already defined in the
|
2017-05-23 08:01:11 +00:00
|
|
|
environment.
|
|
|
|
Example:
|
2013-01-22 15:26:19 +00:00
|
|
|
.Pa ftp://ftp.freebsd.org/pub/FreeBSD/releases/powerpc/powerpc64/9.1-RELEASE
|
2011-06-11 21:44:07 +00:00
|
|
|
.It Ev BSDINSTALL_CHROOT
|
|
|
|
The directory into which the distribution files should be unpacked and the
|
|
|
|
directory at which the root file system of the new system should be mounted.
|
|
|
|
Default:
|
|
|
|
.Pa /mnt
|
|
|
|
.It Ev BSDINSTALL_LOG
|
2017-05-23 08:01:11 +00:00
|
|
|
Path to a log file for the installation.
|
|
|
|
Default:
|
2011-06-11 21:44:07 +00:00
|
|
|
.Pa /tmp/bsdinstall_log
|
|
|
|
.It Ev BSDINSTALL_TMPETC
|
|
|
|
Directory where files destined for the new system's
|
|
|
|
.Pa /etc
|
|
|
|
will be stored until the
|
|
|
|
.Cm config
|
2017-05-23 08:01:11 +00:00
|
|
|
target is executed.
|
|
|
|
If this directory does not already exist, it will be created.
|
|
|
|
Default:
|
2011-06-11 21:44:07 +00:00
|
|
|
.Pa /tmp/bsdinstall_etc
|
2013-10-15 14:46:37 +00:00
|
|
|
.It Ev BSDINSTALL_TMPBOOT
|
|
|
|
Directory where files destined for the new system's
|
|
|
|
.Pa /boot
|
|
|
|
will be stored until the
|
|
|
|
.Cm config
|
2017-05-23 08:01:11 +00:00
|
|
|
target is executed.
|
|
|
|
If this directory does not already exist, it will be created.
|
|
|
|
Default:
|
2013-10-15 14:46:37 +00:00
|
|
|
.Pa /tmp/bsdinstall_boot
|
2011-06-11 21:44:07 +00:00
|
|
|
.El
|
2013-01-22 02:40:06 +00:00
|
|
|
.Sh SCRIPTING
|
|
|
|
.Nm
|
|
|
|
scripts consist of two parts: a
|
|
|
|
.Em preamble
|
|
|
|
and a
|
|
|
|
.Em setup script .
|
|
|
|
The preamble sets up the options for the installation (how to partition the
|
2013-01-22 02:57:53 +00:00
|
|
|
disk[s], which distributions to install, etc.) and the optional second part is
|
|
|
|
a shell script run under
|
|
|
|
.Xr chroot 8
|
|
|
|
in the newly installed system before
|
2013-01-22 02:40:06 +00:00
|
|
|
.Nm
|
2017-05-23 08:01:11 +00:00
|
|
|
exits.
|
|
|
|
The two parts are separated by the usual script header (#!), which also sets
|
|
|
|
the interpreter for the setup script.
|
2013-01-22 02:40:06 +00:00
|
|
|
.Pp
|
|
|
|
A typical bsdinstall script looks like this:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
PARTITIONS=ada0
|
|
|
|
DISTRIBUTIONS="kernel.txz base.txz"
|
|
|
|
|
|
|
|
#!/bin/sh
|
|
|
|
echo "ifconfig_em0=DHCP" >> /etc/rc.conf
|
|
|
|
echo "sshd_enable=YES" >> /etc/rc.conf
|
|
|
|
pkg install puppet
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
On
|
|
|
|
.Fx
|
|
|
|
release media, such a script placed at
|
|
|
|
.Pa /etc/installerconfig
|
|
|
|
will be run at boot time and the system will be rebooted automatically after
|
2017-05-23 08:01:11 +00:00
|
|
|
the installation has completed.
|
|
|
|
This can be used for unattended network installation of new systems; see
|
2013-01-22 02:40:06 +00:00
|
|
|
.Xr diskless 8
|
|
|
|
for details.
|
|
|
|
.Ss PREAMBLE
|
2017-05-23 08:01:11 +00:00
|
|
|
The preamble consists of installer settings.
|
|
|
|
These control global installation parameters (see
|
2013-01-22 02:40:06 +00:00
|
|
|
.Sx ENVIRONMENT VARIABLES )
|
2017-05-23 08:01:11 +00:00
|
|
|
as well as disk partitioning.
|
|
|
|
The preamble is interpreted as a
|
2013-01-22 02:40:06 +00:00
|
|
|
.Xr sh 1
|
2017-05-23 08:01:11 +00:00
|
|
|
script run at the very beginning of the install.
|
|
|
|
If more complicated behavior than setting these variables is desired,
|
|
|
|
arbitrary commands can be run here to extend the installer.
|
|
|
|
In addition to the variables in
|
2013-01-22 02:40:06 +00:00
|
|
|
.Sx ENVIRONMENT VARIABLES ,
|
|
|
|
in particular
|
|
|
|
.Ev DISTRIBUTIONS ,
|
|
|
|
the preamble can contain a variable
|
|
|
|
.Ev PARTITIONS
|
|
|
|
which is passed to the
|
|
|
|
.Cm scriptedpart
|
|
|
|
target to control disk setup.
|
2013-10-15 17:33:30 +00:00
|
|
|
Alternatively,
|
2014-10-31 23:52:02 +00:00
|
|
|
to use
|
|
|
|
.Cm zfsboot
|
2013-10-15 17:33:30 +00:00
|
|
|
instead of
|
2014-10-31 23:52:02 +00:00
|
|
|
.Cm partedit ,
|
2013-10-15 17:33:30 +00:00
|
|
|
the preamble can contain the variable
|
|
|
|
.Ev ZFSBOOT_DATASETS
|
2014-12-29 13:50:59 +00:00
|
|
|
instead of
|
2014-10-31 23:52:02 +00:00
|
|
|
.Ev PARTITIONS .
|
2013-01-22 02:40:06 +00:00
|
|
|
.Ss SETUP SCRIPT
|
2013-01-22 15:26:19 +00:00
|
|
|
Following the preamble is an optional shell script, beginning with a #!
|
2017-05-23 08:01:11 +00:00
|
|
|
declaration.
|
|
|
|
This script will be run at the end of the installation process inside a
|
2013-01-22 02:40:06 +00:00
|
|
|
.Xr chroot 8
|
|
|
|
environment in the newly installed system and can be used to set up
|
2017-05-23 08:01:11 +00:00
|
|
|
configuration files, install packages, etc.
|
|
|
|
Note that newly configured system services, e.g., networking have not
|
|
|
|
been started in the installed system at this time and only installation
|
|
|
|
host services are available.
|
2011-06-11 21:44:07 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
This version of
|
|
|
|
.Nm
|
|
|
|
first appeared in
|
|
|
|
.Fx 9.0 .
|
|
|
|
.Sh AUTHORS
|
2014-06-20 09:57:27 +00:00
|
|
|
.An Nathan Whitehorn Aq Mt nwhitehorn@FreeBSD.org
|