summaryrefslogtreecommitdiff
path: root/doc/kernel.notes
blob: 675e80be3af4ba52da07ab42db5c17575acd341e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
Notes on Red Hat 5.2 kernel installation (See Addendum for RH6.1)
=================================================================

Warning: We (the FreeS/WAN Project http://www.xs4all.nl/~freeswan/)
had nothing to do with designing the kernel installation process.  This
document explains some tricky points that we wish we had been told.
We don't know if these notes apply to systems other than Red Hat 5.2.
This is meant as a supplement to other kernel install guides (such as
the Red Hat 5.2 Installation Guide section 11.6).

Goal: install a new kernel on RH5.2 in such a way that it doesn't
interfere with any other kernels.  This should be repeatable: each new
kernel should have this property.  Each should remain bootable.

Problem: there are several components to a kernel, and each must be
segregated.  How are the parts kept apart?  How are they found?

All the parts live in the file system, so it all comes down to
pathnames.  Well, except for the fiddly bits in /etc/lilo.conf.  What
are the parts?

	/lib/modules/VER/	directory for kernel modules
	/boot/vmlinux-VER	the kernel
	/boot/System.map-VER	the kernel symbol table
	/boot/initrd-VER.img 	the initial ramdisk (for modules needed
				at boot time -- usually not necessary)
	/boot/boot.b		the second-stage loader
	/boot/map		the map file, an index into system index for
				all files used by boot loader (all kernels,
				all initrds, perhaps /boot/boot.b, and itself)

This list does not include /boot/module-info-VER.  That is supplied
by RedHat, and it isn't clear to me how to build it or why.

In each entry, I've used "VER" to signify a version number.  For
RH-supplied kernels, these look like 2.0.36-0.7 (the original 5.2) or
2.0.36-3 (the kernel updates).

There are also symbolic links:
	/lib/modules/preferred	created by /etc/rc.d/rc.sysinit
	/boot/System.map	created by /etc/rc.d/rc.sysinit
	/boot/module-info	created by /etc/rc.d/rc.sysinit
	/vmlinuz		created by ???
I don't know when the /vmlinuz symlink is set up and I don't know
for what it is used.

If you follow the RH procedures, documented in 11.6 of their Installation
Guide, all your VERs will be 2.0.36.  This is very bad: all your builds
will step on each other.  Worse, your new module directory will be half
picked up when you boot a stock RH kernel binary! 

It is important to know how the various parts of the built kernel are
found at booting.

- the kernel path is specified in the image= option in lilo.conf.
  (Lilo.conf may specify several and one is selected at boot time
  by default or user selection.)  The kernel is loaded by the
  boot loader.

- The initial ramdisk is a per-image option (initrd=) specified in
  lilo.conf.  (It isn't described in the RH5.2 lilo.conf(5) manpage!).
  The initial ramdisk is loaded into RAM by the boot loader.

- Since the boot loader doesn't know about the file system, it needs a
  map to figure out which absolute disk blocks to load, and where.
  This is /boot/map.  It is built by the lilo command (also known as
  the map installer).  It will have indices for the all the kernels
  that can be booted, all their initial ram disks, perhaps
  /boot/boot.b, and itself.  This is why moving the blocks of these
  files throws off the boot loader -- lilo must be rerun after even a
  cp command to one of them.

- the modules directory is found two different ways.  Unfortunately,
  they don't mesh properly:

  + at boot time, /etc/rc.d/rc.sysinit tries to figure out the correct
    subdirectory of /lib/modules, using the .rhkmvtag trick (see
    later).  It then builds a symlink /lib/modules/preferred to
    record this.  It also invokes depmod to build the module
    dependency info.  At the same time, it creates the symlinks
    /boot/System.map and /boot/module-info, using the inferred
    value for VER!

  + modprobe and friends stupidly look first in /lib/modules/2.0.36
    (more precisely, /lib/modules/`uname -r`) and then in
    /lib/modules/preferred.  So if there is a /lib/modules/2.0.36 and
    it is the wrong one, you are in trouble.

  If there is no /lib/modules/2.0.36, then both searches above will
  agree (a very Good Thing).  So I recommend strongly that you not
  have a /lib/boot/2.0.36 at boot time.  Unfortunately, you will get
  one during the kernel install process.  Be sure to rename it.  I
  suggest using 2.0.36-x (for some unique x) as VER.

- Red Hat supplied /lib/modules/VER directories contain a hidden file
  .rhkmvtag.  This file contains exactly one line.  This line is
  exactly the same as the contents of /proc/version while the
  corresponding kernel is running.  For the stock kernel, the line is:
Linux version 2.0.36 (root@porky.redhat.com) (gcc version 2.7.2.3) #1 Tue Dec 29 13:11:13 EST 1998

- At boot time, /etc/rc.d/rc.sysinit uses the .rhkmvtag files to
  figure out which of the /lib/modules/* directories matches the
  kernel.  If it could figure out the directory, it uses this
  information to set the symlinks mentioned above.  It then runs
  depmod to build the module dependency information (in
  /lib/modules/preferred/modules.dep, if it created the
  /lib/modules/preferred symlink).  I recommend looking at the code.

- The documented kernel install procedures DO NOT fill in the
  .rhkmvtag file for the new modules directory!  So you should do so
  by hand.  You have to figure out what the contents should be.  Here
  is is a command that will do the job, assuming that
  /usr/src/linux/vmlinux is the kernel associated with
  /lib/modules/2.0.36/:

	strings /usr/src/linux/vmlinux \
	| grep 'x version' >/lib/modules/2.0.36/.rhkmvtag

I've recommended (above) that you use 2.0.36-x for VER when you install
a kernel.  What should x be?  I have found that there is a hidden file
/usr/src/linux/.version which contains a counter that gets incremented
whenever you do a "make install" in the kernel (see target
newversion).  There are some other times that it gets incremented, but
I think that it all works out.  It also gets incorporated into the
resulting kernel's /proc/version, prefixed with ``#''.  This makes it
a natural.

Here is a script to do the recommended renaming:

   # VER will eventually need to be updated
   VER=2.0.36
   VERX=${VER}-`cat /usr/src/linux/.version`

   strings /usr/src/linux/vmlinux | grep 'x version' >/lib/modules/$VER/.rhkmvtag
   mv /lib/modules/$VER /lib/modules/$VERX
   mv /boot/System.map-$VER /boot/System.map-$VERX
   mv /boot/vmlinuz-$VER /boot/vmlinuz-$VERX

And, if an initrd has been built (usually it is best to arrange not to
use one -- see the Red Hat Installation Guide):

   /sbin/mkinitrd /boot/initrd-$VERX.img $VERX

Remember: a new lilo.conf entry is needed for the new kernel, and then
the lilo command will need to be rerun.

Now that kernel installs don't overwrite the results of previous ones,
you will need to manually delete the components and their lilo entry
to get rid of them.

Please send comments, additions, and corrections to:

Hugh Redelmeier
hugh@mimosa.com  voice: +1 416 482-8253


Addendum: Red Hat 6.1
=====================

The kernel supplied with RH6.1 kernel is out of date, so you might
wish to use a newer one.

Much of the description for 5.2 still applies, but the procedure is
quite different because the .version file is no longer used.  Instead,
the top-level Makefile contains a definition EXTRAVERSION which adds a
qualifier to the version for most purposes.  No manual renaming is
required.

Before building the kernel, change EXTRAVERSION by editing
/usr/src/linux/Makefile, and make an appropriate entry in /etc/lilo.conf.

EXTRAVERSION is a feature of the standard kernel sources, not just the
ones supplied by Red Hat.