source: chapter08/kernel.xml@ e63529b

10.0 10.0-rc1 10.1 10.1-rc1 11.0 11.0-rc1 11.0-rc2 11.0-rc3 11.1 11.1-rc1 11.2 11.2-rc1 11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 6.0 6.1 6.1.1 6.3 6.4 6.5 6.6 6.7 6.8 7.0 7.1 7.2 7.3 7.4 7.5 7.5-systemd 7.6 7.6-systemd 7.7 7.7-systemd 7.8 7.8-systemd 7.9 7.9-systemd 8.0 8.1 8.2 8.3 8.4 9.0 9.1 arm bdubbs/gcc13 ml-11.0 multilib renodr/libudev-from-systemd s6-init trunk xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/lfs-next xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/mips64el xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since e63529b was a56c4bb, checked in by Alexander E. Patrakov <alexander@…>, 20 years ago

Several kernel-related textual changes

git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@3722 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 8.9 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
3 <!ENTITY % general-entities SYSTEM "../general.ent">
4 %general-entities;
5]>
6<sect1 id="ch-bootable-kernel" xreflabel="Linux" role="wrap">
7<title>Linux-&linux-version;</title>
8<?dbhtml filename="kernel.html"?>
9
10<indexterm zone="ch-bootable-kernel"><primary sortas="a-Linux">Linux</primary></indexterm>
11
12<sect2 role="package"><title/>
13<para>The Linux package contains the kernel and the header files.</para>
14
15<segmentedlist>
16<segtitle>&buildtime;</segtitle>
17<segtitle>&diskspace;</segtitle>
18<seglistitem><seg>All default options: 4.20 SBU</seg>
19<seg>All default options: 181 MB</seg></seglistitem>
20</segmentedlist>
21
22<segmentedlist>
23<segtitle>Linux installation depends on</segtitle>
24<seglistitem><seg>Bash, Binutils, Coreutils, Findutils,
25GCC, Glibc, Grep, Gzip, Make, Modutils, Perl, Sed</seg></seglistitem>
26</segmentedlist>
27</sect2>
28
29<sect2 role="installation">
30<title>Installation of the kernel</title>
31
32<para>Building the kernel involves a few steps: configuration, compilation, and
33installation. If you don't like the way this book configures the kernel, view
34the <filename>README</filename> file in the kernel source tree for alternative
35methods.</para>
36
37<para>Prepare for compilation by running the following command:</para>
38
39<screen><userinput>make mrproper</userinput></screen>
40
41<para>This ensures that the kernel tree is absolutely clean. The kernel team
42recommends that this command be issued prior to <emphasis>each</emphasis>
43kernel compilation. You shouldn't rely on the source tree being clean after
44un-tarring.</para>
45
46<para>Configure the kernel via a menu-driven interface:</para>
47
48<screen><userinput>make menuconfig</userinput></screen>
49
50<para><userinput>make oldconfig</userinput> may be more appropriate in some
51situations. See the <filename>README</filename> file for more
52information.</para>
53
54<para>If you wish, you may skip kernel configuration by simply copying the
55kernel config file, <filename>.config</filename>, from your host system
56(assuming it is available) to the unpacked <filename class="directory">linux-&linux-version;</filename>
57directory. However, we
58don't recommend this option. You're much better off exploring all the
59configuration menus and creating your own kernel configuration from
60scratch.</para>
61
62<para>For POSIX shared memory support, ensure that the kernel config option
63<quote>Virtual memory file system support</quote> is enabled. It resides within
64the <quote>File systems</quote> menu and is normally enabled by default.</para>
65
66<para>LFS bootscripts make the assumption that you either compile
67both "Support for Host-side USB" and
68"USB device filesystem" directly into the kernel, or don't compile them at
69all. Bootscripts will not work properly if it is a module (usbcore.ko).</para>
70
71<note><para>NPTL requires the kernel to be compiled with GCC 3.x, in this case
72&gcc-version;. Compiling with 2.95.x is known to cause failures in the glibc
73testsuite, so do <emphasis>not</emphasis> compile the kernel with gcc 2.95.x
74unless you know what you're getting yourself into.</para></note>
75
76<para>Compile the kernel image and modules:</para>
77
78<screen><userinput>make</userinput></screen>
79
80<para>If you intend to use kernel modules, you may need an
81<filename>/etc/modprobe.conf</filename> file. Information pertaining
82to modules and to kernel configuration in general may be found in the
83kernel documentation, which is found in the
84<filename>linux-&linux-version;/Documentation</filename> directory.
85The
86modprobe.conf man page
87<!-- removed for review from tldp.org
88and the kernel HOWTO at
89<ulink url="http://www.tldp.org/HOWTO/Kernel-HOWTO.html"/> -->
90may also be of
91interest to you.</para>
92
93<para>Be very suspicious while reading other documentation, because it
94usually applies to 2.4.x kernels only. As far as the editors know, kernel
95configuration issues specific to Hotplug and Udev
96are documented nowhere. The problem is that Udev will create a device node
97only if Hotplug or a user-written script inserts the corresponding module
98into the kernel, and not all modules are detectable by Hotplug. Note
99that statements like
100<screen>alias char-major-XXX some-module</screen>
101in <filename>/etc/modprobe.conf</filename> file don't work with
102Udev, and other aliases are often unnecessary with Hotplug.</para>
103
104<para>Because of all those compilcations with Hotplug, Udev and modules, we
105strongly recommend you to start with a completely non-modular kernel
106configuration, especially if this is the first time you use Udev.</para>
107
108<para>Install the modules, if your kernel configuration uses them:</para>
109
110<screen><userinput>make modules_install</userinput></screen>
111
112<para>If you have a lot of modules and very little space, you may want to
113consider stripping and compressing the modules. For most people such compression
114isn't worth the trouble, but if you're really pressed for space, then have a look at
115<ulink url="http://www.linux-mips.org/archives/linux-mips/2002-04/msg00031.html"/>.</para>
116
117<para>Kernel compilation has finished but more steps are required to complete
118the installation. Some files need to be copied to the <filename>/boot</filename>
119directory.</para>
120
121<para>The path to the kernel image may vary depending on the platform you're
122using. Issue the following command to install the kernel:</para>
123
124<screen><userinput>cp arch/i386/boot/bzImage /boot/lfskernel-&linux-version;</userinput></screen>
125
126<para><filename>System.map</filename> is a symbol file for the kernel. It maps
127the function entry points of every function in the kernel API (Application Programming Interface), as well as the
128addresses of the kernel data structures for the running kernel. Issue the
129following command to install the map file:</para>
130
131<screen><userinput>cp System.map /boot/System.map-&linux-version;</userinput></screen>
132
133<para><filename>.config</filename> is the kernel configuration file that was
134produced by the <command>make menuconfig</command> step above. It contains all
135the config selections for the kernel that was just compiled. It's a good idea
136to keep this file for future reference:</para>
137
138<screen><userinput>cp .config /boot/config-&linux-version;</userinput></screen>
139
140<para>It is important to note that the files in the kernel source directory are
141not owned by <emphasis>root</emphasis>. Whenever you unpack a package as user
142<emphasis>root</emphasis> (like we did here inside chroot), the files end up
143having the user and group IDs of whatever they were on the packager's computer.
144This is usually not a problem for any other package you install because you
145remove the source tree after the installation. But the Linux source tree is
146often kept around for a long time, so there's a chance that whatever user ID
147the packager used will be assigned to somebody on your machine and then that
148person would have write access to the kernel source.</para>
149
150<para>If you are going to keep the kernel source tree around, you may want to
151run <userinput>chown -R 0:0</userinput> on the
152<filename>linux-&linux-version;</filename> directory to ensure all files are
153owned by user <emphasis>root</emphasis>.</para>
154
155</sect2>
156
157
158<sect2 id="contents-kernel" role="content"><title>Contents of Linux</title>
159
160<segmentedlist>
161<segtitle>Installed files</segtitle>
162<seglistitem><seg>the kernel, the kernel headers,
163and the System.map</seg></seglistitem>
164</segmentedlist>
165
166<variablelist><title>Short descriptions</title>
167
168<varlistentry id="kernel">
169<term>The <emphasis>kernel</emphasis></term>
170<listitem>
171<indexterm zone="ch-bootable-kernel kernel"><primary sortas="b-kernel">kernel</primary></indexterm>
172<para>is the engine of your GNU/Linux system.
173When switching on your box, the kernel is the first part of your operating
174system that gets loaded. It detects and initializes all the components of your
175computer's hardware, then makes these components available as a tree of files
176to the software, and turns a single CPU into a multi-tasking machine capable
177of running scores of programs seemingly at the same time.</para>
178</listitem>
179</varlistentry>
180
181<varlistentry id="kernel-headers">
182<term>The <emphasis>kernel headers</emphasis></term>
183<listitem>
184<indexterm zone="ch-bootable-kernel kernel-headers"><primary sortas="e-kernel-headers">kernel headers</primary></indexterm>
185<para>define the interface to the
186services that the kernel provides. The headers in your system's
187<filename>include</filename> directory should <emphasis>always</emphasis> be
188the ones against which Glibc was compiled and should therefore
189<emphasis>not</emphasis> be replaced when upgrading the kernel.</para>
190</listitem>
191</varlistentry>
192
193<varlistentry id="System.map">
194<term><filename>System.map</filename></term>
195<listitem>
196<indexterm zone="ch-bootable-kernel System.map"><primary sortas="e-/boot/System.map">/boot/System.map</primary></indexterm>
197<para>is a list of addresses and symbols. It maps the entry points and addresses
198of all the functions and data structures in the kernel.</para>
199</listitem>
200</varlistentry>
201</variablelist>
202
203</sect2>
204
205</sect1>
Note: See TracBrowser for help on using the repository browser.