Kernel/Upgrade

This article describes the steps to upgrade to a new kernel.

Installing and using a new kernel
A kernel upgrade may be a good idea when new kernel sources are installed. New kernel sources are sometimes installed when you update your system by running emerge -a --update --deep --with-bdeps=y --newuse @world --- or you might have them installed yourself.

Installing new kernel sources doesn't provide you with a new kernel. You need to make and install a new kernel from the new sources and then reboot your system to actually run the new kernel.

Making a new kernel from the new sources is basically the same process as making a kernel when installing the system. The difference is that you can use the configuration of the old kernel to create a configuration for the new kernel. Using the old configuration saves you from going through all the kernel options --- as make menuconfig presents you with --- again.

The configuration of the kernel is saved in a file named in the directory that holds the kernel sources. A new kernel may have options or features the old kernel does not have, or it might not have a feature or option anymore which the old kernel still has. The kernel configuration specifies whether the features and options of a kernel are to be enabled or not, perhaps built into the kernel, or perhaps built as modules which can be loaded into the running kernel on demand. Hence the configuration file of the new kernel may have new entries the configuration file of the old kernel doesn't have, and it might not have entries anymore which are present in the configuration file of the old kernel.

To deal with such changes of the configuration file, the configuration file of the old kernel needs to be converted to a configuration that can be used with the new kernel. This article shows you how to make a new kernel from new kernel sources with converting the configuration file of the old kernel.

Make a backup of the current kernel configuration
You probably do not want to lose your kernel configuration --- after all, you probably have spent quite some time to figure out the best configuration for your system. It's easy to make a backup of it:



Provided that the symlink to the kernel sources has been set correctly, this copies the configuration of the currently used kernel to the home directory of root. (In case a backup already exists, it will be overwritten.)

Set symlink to new kernel sources
The symlink should always point to the directory that holds the sources of the kernel which currently runs. This can be done in one of three ways:


 * 1. Installing the kernel sources with active symlink USE flag
 * This will make the point to your newly installed kernel sources. If necessary, it can still be modified later with the following two methods:


 * 2. Setting the symlink with eselect:




 * This outputs the available kernel sources. The asterisk indicates the chosen sources. To change the kernel sources, e.g. to the second entry, do:




 * 3. Setting the symlink manually:



Copy previous kernel configuration
The configuration of the old kernel needs to be copied to the new one. It can be found in several places:


 * In the procfs filesystem, if the kernel option Enable access to .config through /proc/config.gz was activated in your present kernel:




 * In the directory, if you installed the config file there:




 * In the kernel directory of the currently-running kernel:



Configure the new kernel
To use the configuration of the old kernel with the new kernel, it needs to be converted. The conversion can be done by running either make oldconfig or make silentoldconfig.

make oldconfig gives you choices, make silentoldconfig does not. Use either, not both.

make oldconfig
The following configuration is like the text based configuration with make config. For new configuration options, it gives you a choice. For example:

The string (NEW) at the end of the line marks this option as new. Left to the string in square brackets are the possible answers: Yes, no, module or ? to show the help. The recommend answer is capitalized (here Y). The help explains the option or driver.

Unfortunately make oldconfig doesn't show - next to the help - a lot more information for each option, like the context, so that it is sometimes difficult to give the right answer. In this case the best way to go is to remember the option name and revise it afterwards through one of the graphical kernel configuration tools.

make silentoldconfig
When you can't be bothered with choices, you can use make silentoldconfig</tt>:

Build

 * In case you have external kernel modules installed (like nvidia or zfs), you may need to run make modules_prepare</tt> as described below before bulding the kernel. --- Some modules cannot be installed or prepared before the kernel has been built.

For this step, follow the steps in the manual configuration article.

Reinstall external kernel modules

 * Someone who knows better, please clarify: When exactly should make modules_prepare</tt> be run? Lee (talk) 13:28, 14 February 2015 (UTC)

Any external kernel modules, such as binary kernel modules, need to be rebuilt for each new kernel. If the kernel hasn't been built yet, it has to first be prepared for the building of the external kernel modules:

You can rebuild the packages using the @module-rebuild set:

Solving build problems
If you are experiencing build problems while rebuilding the current kernel, it might help to sanitize the kernel sources. Make sure you backup the file first, as the operation will remove it. Make sure not to use a or  suffix as backup as make distclean</tt> will clean those up as well.

Removing old kernels
See the kernel removal article.

External resources

 * kernel changelog with some explanations of new features