You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
330 lines
10 KiB
330 lines
10 KiB
.TH GENKERNEL "8" "June 2006" "genkernel 3.3" "Gentoo Linux"
|
|
.SH NAME
|
|
genkernel \- the Gentoo Linux automatic kernel compiler.
|
|
.SH SYNOPSIS
|
|
\fBgenkernel\fR \fI[options...] action\fR
|
|
.SH INTRODUCTION
|
|
Genkernel is designed to allow users who are not previously used to
|
|
compiling a kernel to use a similar setup to that one that is used on
|
|
the Gentoo LiveCDs which auto-detects your hardware.
|
|
.PP
|
|
Some users may also be interested in using genkernel for hardware
|
|
which requires initialization and a working kernel before it can be
|
|
booted because genkernel also automatically compiles your kernel
|
|
modules, allowing hardware which needs to be loaded with module
|
|
parameters to be used.
|
|
.SH USAGE
|
|
All that is needed to run genkernel is just ``genkernel'' with an action
|
|
and any flags you might need:
|
|
.PP
|
|
# genkernel --menuconfig --no-clean --no-install all
|
|
.PP
|
|
This would produce a kernel, asking you what how to configure it
|
|
to your desire, leaving alone any existing compiled object files, but not
|
|
installing anything.
|
|
.SH ACTIONS
|
|
An action tells genkernel what you want it to do - the following
|
|
actions are supported:
|
|
.PP
|
|
.I \fBall\fR
|
|
.RS
|
|
Build all steps - the kernel, modules, and the ramdisk.
|
|
.RE
|
|
.I \fBbzImage\fR
|
|
.RS
|
|
Build only the kernel.
|
|
.RE
|
|
.I \fBkernel\fR
|
|
.RS
|
|
Build only the kernel and the modules.
|
|
.RE
|
|
.I \fBinitramfs\fR
|
|
.RS
|
|
Build only the ramdisk.
|
|
.RE
|
|
.SH OPTIONS
|
|
Genkernel supports the following options which alter its
|
|
behaviour. Certain options have ``\fB--no-\fR'' variants which
|
|
do the opposite thing. You can specify your options in any order.
|
|
.PP
|
|
.BR Debugging \ Options
|
|
.TP
|
|
\fB\-\-loglevel=\fR<0-5>
|
|
This controls the out verbosity level of genkernel output - if this is set
|
|
to 0, minimal debugging is done; if this is set to 5 as much output as
|
|
possible is given.
|
|
.TP
|
|
\fB\-\-logfile=\fR<outfile>
|
|
This outputs debugging data to the file <outfile>. By default this is
|
|
.I /var/log/genkernel.log\fR.
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBcolor\fR
|
|
Turns on, or off, output in color using escape sequences.
|
|
.PP
|
|
.BR Kernel \ Configuration
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBmenuconfig\fR
|
|
Runs, or does not run "make menuconfig" after running "make oldconfig".
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBsave\-config\fR
|
|
Saves, or does not save the kernel configuration to
|
|
.I /etc/kernels
|
|
if the kernel is successfully compiled.
|
|
.TP
|
|
\fB\-\-gconfig\fR
|
|
Run "make gconfig" after "make oldconfig".
|
|
.TP
|
|
\fB\-\-xconfig\fR
|
|
Run "make xconfig" after "make oldconfig".
|
|
.PP
|
|
.BR Kernel \ Compilation
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBclean\fR
|
|
Runs, or does not run, "make clean" before compilation - this erases any
|
|
compiled object files in the kernel source tree but does not have an impact
|
|
on the kernel configuration. Specifying \fB\-\-no\-clean\fR implies
|
|
\fB\-\-no\-mrproper\fR.
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBmrproper\fR
|
|
Runs, or does not run, "make mrproper" before compilation - this erases both
|
|
any compiled object files in the kernel source tree as well as the kernel
|
|
configuration.
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBinstall\fR
|
|
Installs, or does not install the kernel to
|
|
.I /boot
|
|
after building. The default is --install. If MOUNTBOOT is set in
|
|
.I /etc/genkernel.conf
|
|
then
|
|
.I /boot
|
|
will be automatically mounted if it is
|
|
not already mounted before the ramdisk and kernel images are copied over.
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBsymlink\fR
|
|
Manages, or does not manage, symlinks in
|
|
.I /boot
|
|
like the manual kernel "make install" process does. A
|
|
.I kernel
|
|
(or, depending on options,
|
|
.I kernelz\fR)
|
|
symlink will link to the most recently built kernel image and a
|
|
.I kernel.old
|
|
(or
|
|
.I kernelz.old\fR)
|
|
symlink will link to the second most recently built image, if one exists.
|
|
Similar symlinks (both * and *.old) are managed for
|
|
.I initramfs\fR
|
|
and
|
|
.I System.map\f.
|
|
The corresponding work products (i.e., the actual kernel and initamfs images,
|
|
and System.map) are also managed accordingly. NOTE: Specifying --symlink
|
|
does nothing unless --install is also specified.
|
|
.TP
|
|
\fB\-\-no\-ramdisk\-modules\fR
|
|
Don't copy any modules to the ramdisk.
|
|
.TP
|
|
\fB\-\-oldconfig\fR
|
|
Implies \fB\-\-no\-clean\fR, and thus \fB\-\-no\-mrproper\fR, running a
|
|
"make oldconfig".
|
|
.TP
|
|
\fB\-\-callback=\fR<...>
|
|
Run the specified arguments in the current environment after the kernel and
|
|
modules have been compiled.
|
|
.PP
|
|
.BR Kernel \ Locations
|
|
.TP
|
|
\fB\-\-kerneldir=\fR<dir>
|
|
This specifies the location of the kernel sources; the default is
|
|
/usr/src/linux.
|
|
.TP
|
|
\fB\-\-kernel\-config=\fR<file>
|
|
This specifies a kernel configuration file to use for compilation; by
|
|
default genkernel uses the config from the previous build of the same kernel
|
|
version or a default kernel config if there isn't a previous config.
|
|
.PP
|
|
.BR Low-Level \ Compilation \ Options
|
|
.TP
|
|
\fB\-\-kernel\-cc=\fR<compiler>
|
|
Compiler to use for the kernel compilation (e.g. distcc).
|
|
.TP
|
|
\fB\-\-kernel\-as=\fR<assembler>
|
|
Assembler to use for the kernel compilation.
|
|
.TP
|
|
\fB\-\-kernel\-ld=\fR<linker>
|
|
Linker to use for the kernel compilation.
|
|
.TP
|
|
\fB\-\-kernel\-make=\fR<makeprg>
|
|
GNU Make to use for the kernel compilation.
|
|
.TP
|
|
\fB\-\-utils\-cc=\fR<compiler>
|
|
Compiler to use for utilities.
|
|
.TP
|
|
\fB\-\-utils\-as=\fR<assembler>
|
|
Assembler to use for utilities.
|
|
.TP
|
|
\fB\-\-utils\-ld=\fR<linker>
|
|
Linker to use for utilities.
|
|
.TP
|
|
\fB\-\-utils\-make=\fR<makeprog>
|
|
GNU Make to use for utilities.
|
|
.TP
|
|
\fB\-\-makeopts=\fR<makeopts>
|
|
GNU Make options such as \fB\-j2\fR, etc.
|
|
.PP
|
|
.BR Initialization
|
|
.TP
|
|
\fB\-\-\fR[no\-]\fBsplash=\fR<theme>
|
|
If the extra argument is specified, splash is forced using <theme>
|
|
rather than the default theme specified in your splash
|
|
configuration. If \fB\-\-no-splash\fR is specified, then
|
|
splash is disabled.
|
|
.TP
|
|
\fB\-\-splash-res=\fR<resolutions>
|
|
Optionally select splash resolutions to include.
|
|
.TP
|
|
\fB\-\-do\-keymap\-auto\fR
|
|
Force keymap selection at boot.
|
|
.TP
|
|
\fB\-\-dmraid\fR
|
|
Add DMRAID support.
|
|
.TP
|
|
\fB\-\-evms\fR
|
|
Add in EVMS support from static binaries if they exist on the system:
|
|
you should run "emerge evms" first.
|
|
.TP
|
|
\fB\-\-lvm\fR
|
|
.RS
|
|
Add in LVM support from static binaries if they exist on the system,
|
|
or compile static LVM binaries if static ones do not exist.
|
|
.RE
|
|
.TP
|
|
\fB\-\-luks\fR
|
|
.RS
|
|
Add in Luks support from static binaries if they exist on the
|
|
system.
|
|
.RE
|
|
.TP
|
|
\fB\-\-static\fR
|
|
This builds a monolithic kernel without any modules on any initial ramdisks.
|
|
.TP
|
|
\fB\-\-linuxrc=\fR<file>
|
|
Use <file> for the linuxrc instead of the genkernel linuxrc.
|
|
.PP
|
|
.BR Internals
|
|
.TP
|
|
\fB\-\-arch\-override=\fR<arch>
|
|
Force the architecture settings described by the <arch> profile
|
|
instead of autodetecting the running architecture.
|
|
.TP
|
|
\fB\-\-tempdir=\fR<dir>
|
|
Sets genkernel's temporary working directory to <dir>.
|
|
.PP
|
|
.BR Output \ Settings
|
|
.TP
|
|
\fB\-\-kernname=\fR<...>
|
|
Tag the kernel and initrd with a name, if not defined this option defaults to genkernel
|
|
.TP
|
|
\fB\-\-minkernpackage=\fR<tbz2>
|
|
File to output a .tar.bz2'd kernel and initrd: no modules outside of the
|
|
initrd will be included...
|
|
.TP
|
|
\fB\-\-modulespackage=\fR<tbz2>
|
|
File to output a .tar.bz2'd modules after the callbacks have run
|
|
.TP
|
|
\fB\-\-kerncache=\fR<tbz2>
|
|
File to output a .tar.bz2'd kernel, contents of /lib/modules/ and the kernel config.
|
|
\fBNOTE\fR: This is created before the callbacks are run.
|
|
.TP
|
|
\fB\-\-no\-kernel\-sources=\fR<tbz2>
|
|
This option is only valid if kerncache is defined
|
|
If there is a valid kerncache no checks will be made
|
|
against a kernel source tree.
|
|
.TP
|
|
\fB\-\-initramfs\-overlay=\fR<dir>
|
|
Directory structure to include in the initramfs,
|
|
only available on 2.6 kernels
|
|
.SH RAMDISK OPTIONS
|
|
The following options can be passed as kernel parameters from the
|
|
bootloader, which the ramdisk scripts would recognize.
|
|
.TP
|
|
\fBreal_root=\fR<...>
|
|
Specifies the device node of the root filesystem to mount.
|
|
.TP
|
|
\fBcrypt_root=\fR<...>
|
|
This specifies the device encrypted by Luks, which contains the root
|
|
filesystem to mount.
|
|
.TP
|
|
\fBcrypt_swap=\fR<...>
|
|
This specifies the swap device encrypted by Luks.
|
|
.TP
|
|
\fBroot_key=\fR<...>
|
|
In case your root is encrypted with a key, you can use a device like a usb pen to store the key.
|
|
This value should be the key path relative to the mount point.
|
|
.TP
|
|
\fBroot_keydev=\fR<...>
|
|
If necessary provide the name of the device that carries the root_key.
|
|
If unset while using root_key, it will automatically look for the device in every boot.
|
|
.TP
|
|
\fBswap_key=\fR<...>
|
|
Same as root_key for swap.
|
|
.TP
|
|
\fBswap_keydev=\fR<...>
|
|
Same as root_keydev for swap.
|
|
.TP
|
|
\fBcrypt_silent\fR
|
|
Set this to silent all the output related to the cryptographic software, and in case your encrypted device isn't open with the key, it opens a shell in the initrd quietly.
|
|
.TP
|
|
\fBdodmraid=\fR<...>
|
|
Passes arguments to dmraid on bootup.
|
|
.TP
|
|
\fBreal_init=\fR<...>
|
|
Passes arguments to init on bootup.
|
|
.TP
|
|
\fBscandelay=\fR<...>
|
|
Pauses for 10 seconds before running devfsd if no argument is specified;
|
|
otherwise pauses for the number of specified seconds.
|
|
.TP
|
|
\fBip=\fR<...>
|
|
Normally used to tell the kernel that it should start a network interface. If present, the initrd will try to mount a livecd over NFS.
|
|
.TP
|
|
\fBnfsroot=\fR<...>
|
|
If present, the initrd will try to mount a livecd from that location. Otherwise the location will be deduced from the DCHP request (option root\-path)
|
|
.TP
|
|
\fBdoevms\fR
|
|
Activate EVMS volumes on bootup
|
|
.TP
|
|
\fBdolvm\fR
|
|
Activate LVM volumes on bootup
|
|
.TP
|
|
\fBdoscsi\fR
|
|
Activate SCSI devices on bootup, necessary when SCSI support is compiled as modules and you're using SCSI or SATA devices.
|
|
|
|
.SH NETBOOTING
|
|
The initrd scripts have limited support for network booting.
|
|
This is activated if the ip=<...> kernel parameter was given. Please refer to the genkernel guide at http://www.gentoo.org/doc/en/genkernel.xml for more information.
|
|
|
|
The initrd scripts will extract any *.tar.gz files found in the \fB/add\fR directory of the livecd into the root filesystem during boot. This way it is easy to extend a netbooted LiveCD i.e. add custom tools, or other kernel modules.
|
|
.SH REPORTING BUGS
|
|
If you believe you have found a bug in the genkernel scripts, then please
|
|
file a bug on the Gentoo Linux Bugzilla:
|
|
.I http://bugs.gentoo.org\fR,
|
|
assigning your bug to genkernel@gentoo.org. We cannot assist you
|
|
with kernel compilation failures unless they are caused by a genkernel
|
|
bug.
|
|
.PP
|
|
Kernel issues for Gentoo-supported kernels, including compilation
|
|
failures should go to
|
|
.I http://bugs.gentoo.org
|
|
and should be assigned to kernel@gentoo.org. Please check if an
|
|
existing bug documents the same issue before opening a new bug. Issues
|
|
for kernel sources not supported by Gentoo should go to their relevant
|
|
authors.
|
|
.SH AUTHORS
|
|
.nf
|
|
Tim Yamin <plasmaroo@gentoo.org>
|
|
Eric Edgar <rocket@gentoo.org>
|
|
NFS Support by Thomas Seiler <thseiler@gmail.com>
|
|
.fi
|
|
.SH SEE ALSO
|
|
\fB/etc/genkernel.conf\fR \- genkernel configuration file
|