diff options
author | grog <grog@FreeBSD.org> | 1999-04-07 09:42:29 +0000 |
---|---|---|
committer | grog <grog@FreeBSD.org> | 1999-04-07 09:42:29 +0000 |
commit | 4ef566065e6b94e7776f716eb3b6de7a4fa7e720 (patch) | |
tree | 5463f6697fb56982364fa5d0974e6f0f0c93d894 /usr.sbin/config | |
parent | 23a589f45ba719ddb3d051d5c71098c19b10c4df (diff) | |
download | FreeBSD-src-4ef566065e6b94e7776f716eb3b6de7a4fa7e720.zip FreeBSD-src-4ef566065e6b94e7776f716eb3b6de7a4fa7e720.tar.gz |
1. Modify config to issue different code for debugging.
2. Config complains if you use -g:
Debugging is enabled by default, there is no ned to specify the -g option
3. Config warns you if you don't use -s:
Building kernel with full debugging symbols. Do
"config -s BSD" for historic partial symbolic support.
To install the debugging kernel, do make install.debug
(BSD was the name of the config file I used; I print out the same
name).
4. Modify Makefile.i386, Makefile.alpha, Makefile.pc98 and config to
work if a kernel name other than 'kernel' is specified. This is
not absolutely necessary, but useful, and it was relatively easy.
I now have a kernel called /crapshit :-)
5. Modify Makefile.i386, Makefile.alpha, Makefile.pc98 "clean" target
to remove both the debug and normal kernel.
6. Modify all to install the stripped kernel by default and the debug
kernel if you enter "make install.debug".
7. Update version number of Makefiles and config.
Diffstat (limited to 'usr.sbin/config')
-rw-r--r-- | usr.sbin/config/config.8 | 44 | ||||
-rw-r--r-- | usr.sbin/config/configvers.h | 4 |
2 files changed, 44 insertions, 4 deletions
diff --git a/usr.sbin/config/config.8 b/usr.sbin/config/config.8 index d2be2bb..67af781 100644 --- a/usr.sbin/config/config.8 +++ b/usr.sbin/config/config.8 @@ -73,7 +73,8 @@ Available options and operands: .Pp .Bl -tag -width SYSTEM_NAME .It Fl g -Configure a system for debugging. +Configure a system for debugging. This is the default, so this flag has no +meaning, and causes a warning message to be printed. .It Fl p Configure a system for profiling; for example, .Xr kgmon 8 @@ -83,9 +84,13 @@ If two or more .Fl p options are supplied, .Nm -will configure a system for high resolution profiling. +configures a system for high resolution profiling. .It Fl r Remove the old compile directory (see below). +.It Fl s +Configure a system without debugging symbols. This saves both time and space, +but if problems occur with the kernel, it will be almost impossible to find out +their causes. .It Ar SYSTEM_NAME Specifies the name of the system configuration file containing device specifications, configuration options @@ -150,6 +155,41 @@ entire input file is embedded in the new kernel. This means that can be used to extract it from a kernel. .Pp Strings | grep ___ will print just the configure information. +.Sh DEBUG KERNELS +Traditional BSD kernels were compiled without symbols due to the heavy load on +the system when compiling a +.if n "debug" +.if t ``debug'' +kernel. A debug kernel contains complete symbols for all the source files, and +enables an experienced kernel programmer to analyse the cause of a problem. The +debuggers available prior to 4.4BSD-Lite were able to find some information +from a normal kernel; this is no longer the case with +.Xr gdb 8 , +and a debug kernel is needed for any meaningful analysis. +.Pp +Building a debug kernel is the default with FreeBSD, and the +.Fl s +option is required to revert to historical behaviour. A debug kernel takes up +to 30% longer to build and requires about 30 MB of disk storage in the build +directory, compared to about 6 MB for a non-debug kernel. A debug kernel is +about 11 MB in size, compared to about 2 MB for a non-debug kernel. This space +is used both in the root file system and at run time in memory. Since kernel +storage is non-pageable, the additional space required by a debug kernel is lost +to the system when not debugging. +.Pp +There is currently little sense in installing and booting from a debug kernel, +since the only tools available which use the symbols do not run on-line. There +are therefore two options for installing a debug kernel: +.Bl -bullet +.It +.Nm make +.Ar install +makes a stripped copy of the kernel and installs it in the root file system. +.It +.Nm make +.Ar install.debug +installs the complete debug kernel in the root file system. +.El .Sh FILES .Bl -tag -width /sys/i386/conf/Makefile.i386 -compact .It Pa /sys/conf/files diff --git a/usr.sbin/config/configvers.h b/usr.sbin/config/configvers.h index c43c000..35c31ad 100644 --- a/usr.sbin/config/configvers.h +++ b/usr.sbin/config/configvers.h @@ -6,6 +6,6 @@ * The numbering scheme is inspired by the sys/conf/newvers.sh RELDATE * and <osreldate.h> system. * - * $Id: configvers.h,v 1.7 1998/10/23 17:05:06 bde Exp $ + * $Id: configvers.h,v 1.8 1998/11/15 18:07:35 dfr Exp $ */ -#define CONFIGVERS 300009 +#define CONFIGVERS 300010 |