1998-08-06 18:56:17 +04:00
|
|
|
.\" $NetBSD: config.8,v 1.14 1998/08/06 14:56:17 tv Exp $
|
1996-03-03 20:21:25 +03:00
|
|
|
.\"
|
1995-04-28 10:54:58 +04:00
|
|
|
.\" Copyright (c) 1980, 1991, 1993
|
|
|
|
.\" The Regents of the University of California. All rights reserved.
|
1993-03-21 12:45:37 +03:00
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
.\" must display the following acknowledgement:
|
|
|
|
.\" This product includes software developed by the University of
|
|
|
|
.\" California, Berkeley and its contributors.
|
|
|
|
.\" 4. Neither the name of the University nor the names of its contributors
|
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
1995-04-28 10:54:58 +04:00
|
|
|
.\" from: @(#)config.8 8.2 (Berkeley) 4/19/94
|
1993-03-21 12:45:37 +03:00
|
|
|
.\"
|
1995-04-28 10:54:58 +04:00
|
|
|
.Dd April 19, 1994
|
1993-03-21 12:45:37 +03:00
|
|
|
.Dt CONFIG 8
|
|
|
|
.Os BSD 4
|
|
|
|
.Sh NAME
|
|
|
|
.Nm config
|
1995-04-28 10:54:58 +04:00
|
|
|
.Nd build kernel compilation directories
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh SYNOPSIS
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
.Op Fl b Ar builddir
|
|
|
|
.Op Fl s Ar srcdir
|
1998-06-28 08:41:36 +04:00
|
|
|
.Op Fl pv
|
1996-09-01 00:58:16 +04:00
|
|
|
.Op Ar config-file
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh DESCRIPTION
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
creates a kernel build directory from the file
|
|
|
|
.Ar config-file ,
|
|
|
|
which describes the system to configure.
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
1996-09-01 00:58:16 +04:00
|
|
|
There are several different ways to run the
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
program. The traditional way is to run
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
from the
|
1995-04-28 10:54:58 +04:00
|
|
|
.Pa conf
|
1996-09-01 00:58:16 +04:00
|
|
|
subdirectory of the machine-specific directory of the system source
|
|
|
|
(usually
|
1995-04-28 10:54:58 +04:00
|
|
|
.Pa /sys/arch/MACHINE/conf ,
|
|
|
|
where
|
|
|
|
.Pa MACHINE
|
|
|
|
is one of
|
|
|
|
.Pa vax ,
|
|
|
|
.Pa hp300 ,
|
1996-09-01 00:58:16 +04:00
|
|
|
and so forth), and to specify as the
|
|
|
|
.Ar config-file
|
|
|
|
the name of a file located in that directory.
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
will by default create files in the directory
|
|
|
|
.Pa ../compile/SYSTEMNAME ,
|
|
|
|
where
|
|
|
|
.Pa SYSTEMNAME
|
|
|
|
is the last path component of
|
|
|
|
.Ar config-file .
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
will assume that the top-level kernel source directory is located four
|
|
|
|
directories above the build directory.
|
|
|
|
.Pp
|
|
|
|
Another way is to create the build directory yourself, place the
|
|
|
|
configuration file in the build directory with the name
|
|
|
|
.Pa CONFIG ,
|
|
|
|
and run
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
from within the build directory without specifying a
|
|
|
|
.Ar config-file .
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
will then by default create files in the current directory. If you
|
|
|
|
run
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
this way, you must specify the location of the top-level kernel source
|
|
|
|
directory using the
|
|
|
|
.Fl s
|
|
|
|
option or by using the
|
|
|
|
.Dq Li source
|
|
|
|
directive at the beginning of the system configuration file.
|
|
|
|
.Pp
|
|
|
|
Finally, you can specify the build directory for
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1996-09-01 00:58:16 +04:00
|
|
|
and run it from anywhere. You can specify a build directory with the
|
|
|
|
.Fl b
|
|
|
|
option or by using the
|
|
|
|
.Dq Li build
|
|
|
|
directive at the beginning of the system configuration file. You must
|
|
|
|
specify the location of the top-level kernel source directory if you
|
|
|
|
specify a build directory.
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
|
|
|
If the
|
|
|
|
.Fl p
|
1995-04-28 10:54:58 +04:00
|
|
|
option is supplied,
|
|
|
|
.Pa .PROF
|
1996-09-01 00:58:16 +04:00
|
|
|
is appended to the default compilation directory name, and
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1995-04-28 10:54:58 +04:00
|
|
|
acts as if the lines
|
|
|
|
.Dq Li makeoptions PROF="-pg"
|
|
|
|
and
|
|
|
|
.Dq Li options GPROF
|
|
|
|
appeared in the configuration file.
|
|
|
|
This will build a system that includes profiling code; see
|
1993-03-21 12:45:37 +03:00
|
|
|
.Xr kgmon 8
|
|
|
|
and
|
|
|
|
.Xr gprof 1 .
|
1995-04-28 10:54:58 +04:00
|
|
|
The
|
|
|
|
.Fl p
|
|
|
|
flag is expected to be used for
|
|
|
|
.Dq one-shot
|
|
|
|
profiles of existing systems;
|
|
|
|
for regular profiling,
|
|
|
|
it is probably wiser to make a separate configuration
|
|
|
|
containing the
|
|
|
|
.Li makeoptions
|
|
|
|
line.
|
|
|
|
.Pp
|
1998-06-28 08:41:36 +04:00
|
|
|
The
|
|
|
|
.Fl v
|
|
|
|
option causes
|
|
|
|
.Nm
|
|
|
|
to be somewhat more verbose by enabling certain warning messages.
|
|
|
|
.Pp
|
1995-04-28 10:54:58 +04:00
|
|
|
The old undocumented
|
|
|
|
.Fl g
|
|
|
|
flag is no longer supported.
|
|
|
|
Instead, use
|
|
|
|
.Dq Li makeoptions DEBUG="-g"
|
|
|
|
and (typically)
|
|
|
|
.Dq Li options KGDB .
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
|
|
|
The output of
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1995-04-28 10:54:58 +04:00
|
|
|
consists of a number of files, principally
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pa ioconf.c ,
|
1995-04-28 10:54:58 +04:00
|
|
|
a description of I/O devices that may be attached to the system; and a
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pa Makefile ,
|
|
|
|
used by
|
|
|
|
.Xr make 1
|
1995-04-28 10:54:58 +04:00
|
|
|
in building the kernel.
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
|
|
|
After running
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm "" ,
|
1995-04-28 10:54:58 +04:00
|
|
|
it is wise to run
|
1993-03-21 12:45:37 +03:00
|
|
|
.Dq Li make depend
|
|
|
|
in the directory where the new makefile
|
|
|
|
was created.
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1993-03-21 12:45:37 +03:00
|
|
|
prints a reminder of this when it completes.
|
|
|
|
.Pp
|
1995-04-28 10:54:58 +04:00
|
|
|
If
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1995-04-28 10:54:58 +04:00
|
|
|
stops due to errors, the problems reported should be corrected and
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1993-03-21 12:45:37 +03:00
|
|
|
should be run again.
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1995-04-28 10:54:58 +04:00
|
|
|
attempts to avoid changing the compilation directory
|
|
|
|
if there are configuration errors,
|
|
|
|
but this code is not well-tested,
|
|
|
|
and some problems (such as running out of disk space)
|
|
|
|
are unrecoverable.
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh SEE ALSO
|
|
|
|
The SYNOPSIS portion of each device in section 4.
|
|
|
|
.Rs
|
1995-04-28 10:54:58 +04:00
|
|
|
.%T "Building 4.4 BSD Systems with Config"
|
|
|
|
.\" .%T "Device Support in 4.4BSD"
|
1993-03-21 12:45:37 +03:00
|
|
|
.Re
|
1995-04-28 10:54:58 +04:00
|
|
|
.sp
|
1997-02-05 22:17:28 +03:00
|
|
|
.Xr options 4
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
1997-10-18 11:58:56 +04:00
|
|
|
.Nm
|
1993-03-21 12:45:37 +03:00
|
|
|
command appeared in
|
|
|
|
.Bx 4.1 .
|
1995-04-28 10:54:58 +04:00
|
|
|
It was completely revised in
|
|
|
|
.Bx 4.4 .
|