2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
Slackware initrd mini HOWTO
|
|
|
|
by Patrick Volkerding, volkerdi@slackware.com
|
2012-09-26 03:10:42 +02:00
|
|
|
@DATE@
|
2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
This document describes how to create and install an initrd, which may be
|
2012-09-26 03:10:42 +02:00
|
|
|
required to use some features of the kernel. Also see "man mkinitrd".
|
2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
1. What is an initrd?
|
2022-12-02 07:58:38 +01:00
|
|
|
2. Why do I need an initrd?
|
2009-08-26 17:00:38 +02:00
|
|
|
3. How do I build the initrd?
|
|
|
|
4. Now that I've built an initrd, how do I use it?
|
|
|
|
|
|
|
|
|
|
|
|
1. What is an initrd?
|
|
|
|
|
|
|
|
Initrd stands for "initial ramdisk". An initial ramdisk is a very small
|
|
|
|
Linux filesystem that is loaded into RAM and mounted as the kernel boots,
|
|
|
|
and before the main root filesystem is mounted.
|
|
|
|
|
|
|
|
2. Why do I need an initrd?
|
|
|
|
|
|
|
|
The usual reason to use an initrd is because you need to load kernel
|
|
|
|
modules before mounting the root partition. Usually these modules are
|
2011-04-25 15:37:00 +02:00
|
|
|
required to support the filesystem used by the root partition (ext3,
|
2009-08-26 17:00:38 +02:00
|
|
|
reiserfs, xfs), or perhaps the controller that the hard drive is attached
|
|
|
|
to (SCSI, RAID, etc). Essentially, there are so many different options
|
|
|
|
available in modern Linux kernels that it isn't practical to try to ship
|
|
|
|
many different kernels to try to cover everyone's needs. It's a lot more
|
|
|
|
flexible to ship a generic kernel and a set of kernel modules for it.
|
|
|
|
|
|
|
|
3. How do I build the initrd?
|
|
|
|
|
|
|
|
The easiest way to make the initrd is to use the mkinitrd script included
|
|
|
|
in Slackware's mkinitrd package. We'll walk through the process of
|
2012-09-26 03:10:42 +02:00
|
|
|
upgrading to the generic @KERNEL_VERSION@ Linux kernel using the packages
|
2009-08-26 17:00:38 +02:00
|
|
|
found in Slackware's slackware/a/ directory.
|
|
|
|
|
|
|
|
First, make sure the kernel, kernel modules, and mkinitrd package are
|
|
|
|
installed (the current version numbers might be a little different, so
|
|
|
|
this is just an example):
|
|
|
|
|
2012-09-26 03:10:42 +02:00
|
|
|
installpkg kernel-generic-@KERNEL_VERSION@-@ARCH@-@BUILD@.tgz
|
|
|
|
installpkg kernel-modules-@KERNEL_VERSION@-@ARCH@-@BUILD@.tgz
|
|
|
|
installpkg mkinitrd-@MKINITRD_VERSION@-@ARCH@-@BUILD@.tgz
|
2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
Change into the /boot directory:
|
|
|
|
|
|
|
|
cd /boot
|
|
|
|
|
2012-09-26 03:10:42 +02:00
|
|
|
Now you'll want to run "mkinitrd". I'm using ext4 for my root
|
|
|
|
filesystem, and since mkinitrd should figure out any other modules
|
|
|
|
it requires, I shouldn't need to specify any others:
|
2009-08-26 17:00:38 +02:00
|
|
|
|
2012-09-26 03:10:42 +02:00
|
|
|
mkinitrd -c -k @KERNEL_VERSION@ -m ext4
|
2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
This should do two things. First, it will create a directory
|
|
|
|
/boot/initrd-tree containing the initrd's filesystem. Then it will
|
|
|
|
create an initrd (/boot/initrd.gz) from this tree. If you wanted to,
|
|
|
|
you could make some additional changes in /boot/initrd-tree/ and
|
|
|
|
then run mkinitrd again without options to rebuild the image. That's
|
|
|
|
optional, though, and only advanced users will need to think about that.
|
|
|
|
|
2012-09-26 03:10:42 +02:00
|
|
|
Here's another example: Build an initrd image using Linux @KERNEL_VERSION@
|
2011-04-25 15:37:00 +02:00
|
|
|
kernel modules for a system with an ext3 root partition on /dev/sdb3:
|
2009-08-26 17:00:38 +02:00
|
|
|
|
2012-09-26 03:10:42 +02:00
|
|
|
mkinitrd -c -k @KERNEL_VERSION@ -m ext3 -f ext3 -r /dev/sdb3
|
2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
|
|
|
|
4. Now that I've built an initrd, how do I use it?
|
|
|
|
|
|
|
|
Now that you've got an initrd (/boot/initrd.gz), you'll want to load
|
|
|
|
it along with the kernel at boot time. If you use LILO for your boot
|
|
|
|
loader you'll need to edit /etc/lilo.conf and add a line to load the
|
|
|
|
initrd. Here's an example section of lilo.conf showing how this is
|
|
|
|
done:
|
|
|
|
|
|
|
|
# Linux bootable partition config begins
|
2024-07-25 22:22:54 +02:00
|
|
|
image = /boot/vmlinuz-@KERNEL_VERSION@-generic
|
2009-08-26 17:00:38 +02:00
|
|
|
initrd = /boot/initrd.gz
|
2011-04-25 15:37:00 +02:00
|
|
|
root = /dev/sda6
|
2012-09-26 03:10:42 +02:00
|
|
|
label = @LILO_KERNEL_NAME@
|
2009-08-26 17:00:38 +02:00
|
|
|
read-only
|
|
|
|
# Linux bootable partition config ends
|
|
|
|
|
|
|
|
The initrd is loaded by the "initrd = /boot/initrd.gz" line.
|
|
|
|
Just add the line right below the line for the kernel image you use.
|
|
|
|
Save the file, and then run LILO again ('lilo' at the command line).
|
|
|
|
You'll need to run lilo every time you edit lilo.conf or rebuild the
|
|
|
|
initrd.
|
|
|
|
|
|
|
|
Other bootloaders such as syslinux also support the use of an initrd.
|
|
|
|
See the documentation for those programs for details on using an
|
|
|
|
initrd with them.
|
|
|
|
|
2024-07-25 22:22:54 +02:00
|
|
|
Some, such as GRUB, require the initrd to be named similarly to the
|
|
|
|
kernel. So, for this kernel:
|
|
|
|
|
|
|
|
/boot/vmlinuz-@KERNEL_VERSION@-generic
|
|
|
|
|
|
|
|
You would want to rename your initrd to this:
|
|
|
|
|
|
|
|
/boot/initrd-@KERNEL_VERSION@-generic.img
|
|
|
|
|
|
|
|
In fact, if you use the geninitrd script to make your initrd (which it
|
|
|
|
will pretty much do automatically for the generic kernel) it will name
|
|
|
|
it this way, and will make a compatibilty symlink initrd.gz.
|
|
|
|
|
2009-08-26 17:00:38 +02:00
|
|
|
|
|
|
|
---------
|
|
|
|
|
|
|
|
Have fun!
|