| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 | <?xml version="1.0" encoding="ISO-8859-1"?><!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN" "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [  <!ENTITY % general-entities SYSTEM "../general.ent">  %general-entities;]><sect1 id="ch-bootable-kernel" role="wrap"><title>Linux-&linux-version;</title><?dbhtml filename="kernel.html"?><indexterm zone="ch-bootable-kernel"><primary sortas="a-Linux">Linux</primary></indexterm><sect2 role="package"><title/><para>The Linux package contains the Linux kernel.</para><segmentedlist><segtitle>&buildtime;</segtitle><segtitle>&diskspace;</segtitle><seglistitem><seg>4.20 SBU</seg><seg>181 MB</seg></seglistitem></segmentedlist><segmentedlist><segtitle>&dependencies;</segtitle><seglistitem><seg>Bash, Binutils, Coreutils, Findutils,GCC, Glibc, Grep, Gzip, Make, Modutils, Perl, and Sed</seg></seglistitem></segmentedlist></sect2><sect2 role="installation"><title>Installation of the kernel</title><para>Building the kernel involves a few steps—configuration, compilation,and installation. Read the <filename>README</filename> file in the kernel sourcetree for alternative methods to the way this book configures the kernel.</para><para>Prepare for compilation by running the following command:</para><screen><userinput>make mrproper</userinput></screen><para>This ensures that the kernel tree is absolutely clean. Thekernel team recommends that this command be issued prior to eachkernel compilation. Do not rely on the source tree being clean afterun-tarring.</para><para>If, in <xref linkend="ch-scripts-console" role=","/> it was decided tocompile the keymap into the kernel, issue the command below:</para><screen><userinput>loadkeys -m /usr/share/kbd/keymaps/<replaceable>[path to  keymap]</replaceable> > \    drivers/char/defkeymap.c</userinput></screen><para>For example, if using a Dutch keyboard, use<filename>/usr/share/kbd/keymaps/i386/qwerty/nl.map.gz</filename>.</para><para>Configure the kernel via a menu-driven interface. BLFS has someinformation regarding particular kernel configuration requirements ofpackages outside of LFS at <ulinkurl="&blfs-root;view/svn/longindex.html#kernel-config-index"><phrasecondition="pdf">&blfs-root;view/svn/longindex.html#kernel-config-index</phrase></ulink>:</para><screen><userinput>make menuconfig</userinput></screen><para>Alternatively, <command>make oldconfig</command> may be more appropriate in somesituations. See the <filename>README</filename> file for moreinformation.</para><note><para>When configuring the kernel, be sure to enable the <quote>Supportfor hot-pluggable devices</quote> option under the <quote>General Setup</quote>menu. This enables hotplug events that are used by <command>udev</command> topopulate the <filename class="directory">/dev</filename> directory with devicenodes. Likewise, enable the <quote>Virtual memory file system support</quote>option under the <quote>File systems</quote>/<quote>Pseudo filesystems</quote>menu. This enables the virtual filesystem that the <filenameclass="directory">/dev</filename> directory will be mounted on.</para></note><para>If desired, skip kernel configuration by copying the kernelconfig file, <filename>.config</filename>, from the host system(assuming it is available) to the unpacked <filenameclass="directory">linux-&linux-version;</filename> directory. However,we do not recommend this option. It is often better to explore all theconfiguration menus and create the kernel configuration fromscratch.</para><note><para>NPTL requires the kernel to be compiled with GCC 3.x, inthis case &gcc-version;. Compiling with 2.95.x is known to cause failures inthe glibc test suite, so it is not recommended to compile the kernelwith gcc 2.95.x.</para></note><para>Compile the kernel image and modules:</para><screen><userinput>make</userinput></screen><para>If using kernel modules, an <filename>/etc/modprobe.conf</filename> filemay be needed. Information pertaining to modules and kernel configuration islocated in the kernel documentation in the <filenameclass="directory">linux-&linux-version;/Documentation</filename> directory. The<emphasis>modprobe.conf</emphasis> <command>man</command> page may also be ofinterest.</para><para>Be very careful when reading other documentation relating to kernelmodules because it usually applies to 2.4.x kernels only. As far as we know,kernel configuration issues specific to Hotplug and Udev are not documented.The problem is that Udev will create a device node only if Hotplug or auser-written script inserts the corresponding module into the kernel, and notall modules are detectable by Hotplug. Note that statements like the one belowin the <filename>/etc/modprobe.conf</filename> file do not work withUdev:</para><para><screen>alias char-major-XXX some-module</screen></para><para>Because of the complications with Hotplug, Udev, and modules, westrongly recommend starting with a completely non-modular kernelconfiguration, especially if this is the first time using Udev.</para><para>Install the modules, if the kernel configuration uses them:</para><screen><userinput>make modules_install</userinput></screen><para>After kernel compilation is complete, additional steps arerequired to complete the installation. Some files need to be copied tothe <filename class="directory">/boot</filename> directory.</para><para>The path to the kernel image may vary depending on the platformbeing used. The following command assumes an x86 architecture:</para><screen><userinput>cp arch/i386/boot/bzImage /boot/lfskernel-&linux-version;</userinput></screen><para><filename>System.map</filename> is a symbol file for the kernel.It maps the function entry points of every function in the kernel API,as well as the addresses of the kernel data structures for the runningkernel. Issue the following command to install the map file:</para><screen><userinput>cp System.map /boot/System.map-&linux-version;</userinput></screen><beginpage/><para>The kernel configuration file <filename>.config</filename>produced by the <command>make menuconfig</command> stepabove contains all the configuration selections for the kernelthat was just compiled. It is a good idea to keep this file for futurereference:</para><screen><userinput>cp .config /boot/config-&linux-version;</userinput></screen><para>It is important to note that the files in the kernel sourcedirectory are not owned by <emphasis>root</emphasis>. Whenever apackage is unpacked as user <emphasis>root</emphasis> (like we didinside chroot), the files have the user and group IDs of whateverthey were on the packager's computer. This is usually not a problemfor any other package to be installed because the source tree isremoved after the installation. However, the Linux source tree isoften retained for a long time.  Because of this, there is a chancethat whatever user ID the packager used will be assigned to somebodyon the machine. That person would then have write access to the kernelsource.</para><para>If the kernel source tree is going to be retained, run<command>chown -R 0:0</command> on the <filenameclass="directory">linux-&linux-version;</filename> directory to ensureall files are owned by user <emphasis>root</emphasis>.</para><warning><para>Some kernel documentation recommends creating a symlink from<filename class="symlink">/usr/src/linux</filename> pointing to the kernelsource directory.  This is specific to kernels prior to the 2.6 series and<emphasis>must not</emphasis> be created on an LFS system as it can causeproblems for packages you may wish to build once your base LFS system iscomplete.</para><para>Also, the headers in the system's<filename class="directory">include</filename> directory should<emphasis>always</emphasis> be the ones against which Glibc was compiled,that is, the ones from the Linux-Libc-Headers package, and therefore, should<emphasis>never</emphasis> be replaced by the kernel headers.</para></warning></sect2><sect2 id="contents-kernel" role="content"><title>Contents of Linux</title><segmentedlist><segtitle>Installed files</segtitle><seglistitem><seg>config-&linux-version;, lfskernel-&linux-version;,and System.map-&linux-version;</seg></seglistitem></segmentedlist><variablelist><bridgehead renderas="sect3">Short Descriptions</bridgehead><?dbfo list-presentation="list"?><?dbhtml list-presentation="table"?><varlistentry id="config"><term><filename>config-&linux-version;</filename></term><listitem><para>Contains all the configuration selections for the kernel</para><indexterm zone="ch-bootable-kernel config"><primary sortas="e-/boot/config">/boot/config-&linux-version;</primary></indexterm></listitem></varlistentry><varlistentry id="lfskernel"><term><filename>lfskernel-&linux-version;</filename></term><listitem><para>The engine of the Linux system. When turning on the computer,the kernel is the first part of the operating system that gets loaded.It detects and initializes all components of the computer's hardware,then makes these components available as a tree of files to thesoftware and turns a single CPU into a multitasking machine capableof running scores of programs seemingly at the same time</para><indexterm zone="ch-bootable-kernel lfskernel"><primary sortas="b-lfskernel">lfskernel-&linux-version;</primary></indexterm></listitem></varlistentry><varlistentry id="System.map"><term><filename>System.map-&linux-version;</filename></term><listitem><para>A list of addresses and symbols; it maps the entry points andaddresses of all the functions and data structures in thekernel</para><indexterm zone="ch-bootable-kernel System.map"><primary sortas="e-/boot/System.map">/boot/System.map-&linux-version;</primary></indexterm></listitem></varlistentry></variablelist></sect2></sect1>
 |