| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097 |
- .. SPDX-License-Identifier: (GPL-2.0+ OR CC-BY-4.0)
- .. [see the bottom of this file for redistribution information]
- ===========================================
- How to quickly build a trimmed Linux kernel
- ===========================================
- This guide explains how to swiftly build Linux kernels that are ideal for
- testing purposes, but perfectly fine for day-to-day use, too.
- The essence of the process (aka 'TL;DR')
- ========================================
- *[If you are new to compiling Linux, ignore this TLDR and head over to the next
- section below: it contains a step-by-step guide, which is more detailed, but
- still brief and easy to follow; that guide and its accompanying reference
- section also mention alternatives, pitfalls, and additional aspects, all of
- which might be relevant for you.]*
- If your system uses techniques like Secure Boot, prepare it to permit starting
- self-compiled Linux kernels; install compilers and everything else needed for
- building Linux; make sure to have 12 Gigabyte free space in your home directory.
- Now run the following commands to download fresh Linux mainline sources, which
- you then use to configure, build and install your own kernel::
- git clone --depth 1 -b master \
- https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git ~/linux/
- cd ~/linux/
- # Hint: if you want to apply patches, do it at this point. See below for details.
- # Hint: it's recommended to tag your build at this point. See below for details.
- yes "" | make localmodconfig
- # Hint: at this point you might want to adjust the build configuration; you'll
- # have to, if you are running Debian. See below for details.
- make -j $(nproc --all)
- # Note: on many commodity distributions the next command suffices, but on Arch
- # Linux, its derivatives, and some others it does not. See below for details.
- command -v installkernel && sudo make modules_install install
- reboot
- If you later want to build a newer mainline snapshot, use these commands::
- cd ~/linux/
- git fetch --depth 1 origin
- # Note: the next command will discard any changes you did to the code:
- git checkout --force --detach origin/master
- # Reminder: if you want to (re)apply patches, do it at this point.
- # Reminder: you might want to add or modify a build tag at this point.
- make olddefconfig
- make -j $(nproc --all)
- # Reminder: the next command on some distributions does not suffice.
- command -v installkernel && sudo make modules_install install
- reboot
- Step-by-step guide
- ==================
- Compiling your own Linux kernel is easy in principle. There are various ways to
- do it. Which of them actually work and is the best depends on the circumstances.
- This guide describes a way perfectly suited for those who want to quickly
- install Linux from sources without being bothered by complicated details; the
- goal is to cover everything typically needed on mainstream Linux distributions
- running on commodity PC or server hardware.
- The described approach is great for testing purposes, for example to try a
- proposed fix or to check if a problem was already fixed in the latest codebase.
- Nonetheless, kernels built this way are also totally fine for day-to-day use
- while at the same time being easy to keep up to date.
- The following steps describe the important aspects of the process; a
- comprehensive reference section later explains each of them in more detail. It
- sometimes also describes alternative approaches, pitfalls, as well as errors
- that might occur at a particular point -- and how to then get things rolling
- again.
- ..
- Note: if you see this note, you are reading the text's source file. You
- might want to switch to a rendered version, as it makes it a lot easier to
- quickly look something up in the reference section and afterwards jump back
- to where you left off. Find a the latest rendered version here:
- https://docs.kernel.org/admin-guide/quickly-build-trimmed-linux.html
- .. _backup_sbs:
- * Create a fresh backup and put system repair and restore tools at hand, just
- to be prepared for the unlikely case of something going sideways.
- [:ref:`details<backup>`]
- .. _secureboot_sbs:
- * On platforms with 'Secure Boot' or similar techniques, prepare everything to
- ensure the system will permit your self-compiled kernel to boot later. The
- quickest and easiest way to achieve this on commodity x86 systems is to
- disable such techniques in the BIOS setup utility; alternatively, remove
- their restrictions through a process initiated by
- ``mokutil --disable-validation``.
- [:ref:`details<secureboot>`]
- .. _buildrequires_sbs:
- * Install all software required to build a Linux kernel. Often you will need:
- 'bc', 'binutils' ('ld' et al.), 'bison', 'flex', 'gcc', 'git', 'openssl',
- 'pahole', 'perl', and the development headers for 'libelf' and 'openssl'. The
- reference section shows how to quickly install those on various popular Linux
- distributions.
- [:ref:`details<buildrequires>`]
- .. _diskspace_sbs:
- * Ensure to have enough free space for building and installing Linux. For the
- latter 150 Megabyte in /lib/ and 100 in /boot/ are a safe bet. For storing
- sources and build artifacts 12 Gigabyte in your home directory should
- typically suffice. If you have less available, be sure to check the reference
- section for the step that explains adjusting your kernels build
- configuration: it mentions a trick that reduce the amount of required space
- in /home/ to around 4 Gigabyte.
- [:ref:`details<diskspace>`]
- .. _sources_sbs:
- * Retrieve the sources of the Linux version you intend to build; then change
- into the directory holding them, as all further commands in this guide are
- meant to be executed from there.
- *[Note: the following paragraphs describe how to retrieve the sources by
- partially cloning the Linux stable git repository. This is called a shallow
- clone. The reference section explains two alternatives:* :ref:`packaged
- archives<sources_archive>` *and* :ref:`a full git clone<sources_full>` *;
- prefer the latter, if downloading a lot of data does not bother you, as that
- will avoid some* :ref:`peculiar characteristics of shallow clones the
- reference section explains<sources_shallow>` *.]*
- First, execute the following command to retrieve a fresh mainline codebase::
- git clone --no-checkout --depth 1 -b master \
- https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git ~/linux/
- cd ~/linux/
- If you want to access recent mainline releases and pre-releases, deepen you
- clone's history to the oldest mainline version you are interested in::
- git fetch --shallow-exclude=v6.0 origin
- In case you want to access a stable/longterm release (say v6.1.5), simply add
- the branch holding that series; afterwards fetch the history at least up to
- the mainline version that started the series (v6.1)::
- git remote set-branches --add origin linux-6.1.y
- git fetch --shallow-exclude=v6.0 origin
- Now checkout the code you are interested in. If you just performed the
- initial clone, you will be able to check out a fresh mainline codebase, which
- is ideal for checking whether developers already fixed an issue::
- git checkout --detach origin/master
- If you deepened your clone, you instead of ``origin/master`` can specify the
- version you deepened to (``v6.0`` above); later releases like ``v6.1`` and
- pre-release like ``v6.2-rc1`` will work, too. Stable or longterm versions
- like ``v6.1.5`` work just the same, if you added the appropriate
- stable/longterm branch as described.
- [:ref:`details<sources>`]
- .. _patching_sbs:
- * In case you want to apply a kernel patch, do so now. Often a command like
- this will do the trick::
- patch -p1 < ../proposed-fix.patch
- If the ``-p1`` is actually needed, depends on how the patch was created; in
- case it does not apply thus try without it.
- If you cloned the sources with git and anything goes sideways, run ``git
- reset --hard`` to undo any changes to the sources.
- [:ref:`details<patching>`]
- .. _tagging_sbs:
- * If you patched your kernel or have one of the same version installed already,
- better add a unique tag to the one you are about to build::
- echo "-proposed_fix" > localversion
- Running ``uname -r`` under your kernel later will then print something like
- '6.1-rc4-proposed_fix'.
- [:ref:`details<tagging>`]
- .. _configuration_sbs:
- * Create the build configuration for your kernel based on an existing
- configuration.
- If you already prepared such a '.config' file yourself, copy it to
- ~/linux/ and run ``make olddefconfig``.
- Use the same command, if your distribution or somebody else already tailored
- your running kernel to your or your hardware's needs: the make target
- 'olddefconfig' will then try to use that kernel's .config as base.
- Using this make target is fine for everybody else, too -- but you often can
- save a lot of time by using this command instead::
- yes "" | make localmodconfig
- This will try to pick your distribution's kernel as base, but then disable
- modules for any features apparently superfluous for your setup. This will
- reduce the compile time enormously, especially if you are running an
- universal kernel from a commodity Linux distribution.
- There is a catch: 'localmodconfig' is likely to disable kernel features you
- did not use since you booted your Linux -- like drivers for currently
- disconnected peripherals or a virtualization software not haven't used yet.
- You can reduce or nearly eliminate that risk with tricks the reference
- section outlines; but when building a kernel just for quick testing purposes
- it is often negligible if such features are missing. But you should keep that
- aspect in mind when using a kernel built with this make target, as it might
- be the reason why something you only use occasionally stopped working.
- [:ref:`details<configuration>`]
- .. _configmods_sbs:
- * Check if you might want to or have to adjust some kernel configuration
- options:
- * Evaluate how you want to handle debug symbols. Enable them, if you later
- might need to decode a stack trace found for example in a 'panic', 'Oops',
- 'warning', or 'BUG'; on the other hand disable them, if you are short on
- storage space or prefer a smaller kernel binary. See the reference section
- for details on how to do either. If neither applies, it will likely be fine
- to simply not bother with this. [:ref:`details<configmods_debugsymbols>`]
- * Are you running Debian? Then to avoid known problems by performing
- additional adjustments explained in the reference section.
- [:ref:`details<configmods_distros>`].
- * If you want to influence the other aspects of the configuration, do so now
- by using make targets like 'menuconfig' or 'xconfig'.
- [:ref:`details<configmods_individual>`].
- .. _build_sbs:
- * Build the image and the modules of your kernel::
- make -j $(nproc --all)
- If you want your kernel packaged up as deb, rpm, or tar file, see the
- reference section for alternatives.
- [:ref:`details<build>`]
- .. _install_sbs:
- * Now install your kernel::
- command -v installkernel && sudo make modules_install install
- Often all left for you to do afterwards is a ``reboot``, as many commodity
- Linux distributions will then create an initramfs (also known as initrd) and
- an entry for your kernel in your bootloader's configuration; but on some
- distributions you have to take care of these two steps manually for reasons
- the reference section explains.
- On a few distributions like Arch Linux and its derivatives the above command
- does nothing at all; in that case you have to manually install your kernel,
- as outlined in the reference section.
- If you are running a immutable Linux distribution, check its documentation
- and the web to find out how to install your own kernel there.
- [:ref:`details<install>`]
- .. _another_sbs:
- * To later build another kernel you need similar steps, but sometimes slightly
- different commands.
- First, switch back into the sources tree::
- cd ~/linux/
- In case you want to build a version from a stable/longterm series you have
- not used yet (say 6.2.y), tell git to track it::
- git remote set-branches --add origin linux-6.2.y
- Now fetch the latest upstream changes; you again need to specify the earliest
- version you care about, as git otherwise might retrieve the entire commit
- history::
- git fetch --shallow-exclude=v6.0 origin
- Now switch to the version you are interested in -- but be aware the command
- used here will discard any modifications you performed, as they would
- conflict with the sources you want to checkout::
- git checkout --force --detach origin/master
- At this point you might want to patch the sources again or set/modify a build
- tag, as explained earlier. Afterwards adjust the build configuration to the
- new codebase using olddefconfig, which will now adjust the configuration file
- you prepared earlier using localmodconfig (~/linux/.config) for your next
- kernel::
- # reminder: if you want to apply patches, do it at this point
- # reminder: you might want to update your build tag at this point
- make olddefconfig
- Now build your kernel::
- make -j $(nproc --all)
- Afterwards install the kernel as outlined above::
- command -v installkernel && sudo make modules_install install
- [:ref:`details<another>`]
- .. _uninstall_sbs:
- * Your kernel is easy to remove later, as its parts are only stored in two
- places and clearly identifiable by the kernel's release name. Just ensure to
- not delete the kernel you are running, as that might render your system
- unbootable.
- Start by deleting the directory holding your kernel's modules, which is named
- after its release name -- '6.0.1-foobar' in the following example::
- sudo rm -rf /lib/modules/6.0.1-foobar
- Now try the following command, which on some distributions will delete all
- other kernel files installed while also removing the kernel's entry from the
- bootloader configuration::
- command -v kernel-install && sudo kernel-install -v remove 6.0.1-foobar
- If that command does not output anything or fails, see the reference section;
- do the same if any files named '*6.0.1-foobar*' remain in /boot/.
- [:ref:`details<uninstall>`]
- .. _submit_improvements:
- Did you run into trouble following any of the above steps that is not cleared up
- by the reference section below? Or do you have ideas how to improve the text?
- Then please take a moment of your time and let the maintainer of this document
- know by email (Thorsten Leemhuis <linux@leemhuis.info>), ideally while CCing the
- Linux docs mailing list (linux-doc@vger.kernel.org). Such feedback is vital to
- improve this document further, which is in everybody's interest, as it will
- enable more people to master the task described here.
- Reference section for the step-by-step guide
- ============================================
- This section holds additional information for each of the steps in the above
- guide.
- .. _backup:
- Prepare for emergencies
- -----------------------
- *Create a fresh backup and put system repair and restore tools at hand*
- [:ref:`... <backup_sbs>`]
- Remember, you are dealing with computers, which sometimes do unexpected things
- -- especially if you fiddle with crucial parts like the kernel of an operating
- system. That's what you are about to do in this process. Hence, better prepare
- for something going sideways, even if that should not happen.
- [:ref:`back to step-by-step guide <backup_sbs>`]
- .. _secureboot:
- Dealing with techniques like Secure Boot
- ----------------------------------------
- *On platforms with 'Secure Boot' or similar techniques, prepare everything to
- ensure the system will permit your self-compiled kernel to boot later.*
- [:ref:`... <secureboot_sbs>`]
- Many modern systems allow only certain operating systems to start; they thus by
- default will reject booting self-compiled kernels.
- You ideally deal with this by making your platform trust your self-built kernels
- with the help of a certificate and signing. How to do that is not described
- here, as it requires various steps that would take the text too far away from
- its purpose; 'Documentation/admin-guide/module-signing.rst' and various web
- sides already explain this in more detail.
- Temporarily disabling solutions like Secure Boot is another way to make your own
- Linux boot. On commodity x86 systems it is possible to do this in the BIOS Setup
- utility; the steps to do so are not described here, as they greatly vary between
- machines.
- On mainstream x86 Linux distributions there is a third and universal option:
- disable all Secure Boot restrictions for your Linux environment. You can
- initiate this process by running ``mokutil --disable-validation``; this will
- tell you to create a one-time password, which is safe to write down. Now
- restart; right after your BIOS performed all self-tests the bootloader Shim will
- show a blue box with a message 'Press any key to perform MOK management'. Hit
- some key before the countdown exposes. This will open a menu and choose 'Change
- Secure Boot state' there. Shim's 'MokManager' will now ask you to enter three
- randomly chosen characters from the one-time password specified earlier. Once
- you provided them, confirm that you really want to disable the validation.
- Afterwards, permit MokManager to reboot the machine.
- [:ref:`back to step-by-step guide <secureboot_sbs>`]
- .. _buildrequires:
- Install build requirements
- --------------------------
- *Install all software required to build a Linux kernel.*
- [:ref:`...<buildrequires_sbs>`]
- The kernel is pretty stand-alone, but besides tools like the compiler you will
- sometimes need a few libraries to build one. How to install everything needed
- depends on your Linux distribution and the configuration of the kernel you are
- about to build.
- Here are a few examples what you typically need on some mainstream
- distributions:
- * Debian, Ubuntu, and derivatives::
- sudo apt install bc binutils bison dwarves flex gcc git make openssl \
- pahole perl-base libssl-dev libelf-dev
- * Fedora and derivatives::
- sudo dnf install binutils /usr/include/{libelf.h,openssl/pkcs7.h} \
- /usr/bin/{bc,bison,flex,gcc,git,openssl,make,perl,pahole}
- * openSUSE and derivatives::
- sudo zypper install bc binutils bison dwarves flex gcc git make perl-base \
- openssl openssl-devel libelf-dev
- In case you wonder why these lists include openssl and its development headers:
- they are needed for the Secure Boot support, which many distributions enable in
- their kernel configuration for x86 machines.
- Sometimes you will need tools for compression formats like bzip2, gzip, lz4,
- lzma, lzo, xz, or zstd as well.
- You might need additional libraries and their development headers in case you
- perform tasks not covered in this guide. For example, zlib will be needed when
- building kernel tools from the tools/ directory; adjusting the build
- configuration with make targets like 'menuconfig' or 'xconfig' will require
- development headers for ncurses or Qt5.
- [:ref:`back to step-by-step guide <buildrequires_sbs>`]
- .. _diskspace:
- Space requirements
- ------------------
- *Ensure to have enough free space for building and installing Linux.*
- [:ref:`... <diskspace_sbs>`]
- The numbers mentioned are rough estimates with a big extra charge to be on the
- safe side, so often you will need less.
- If you have space constraints, remember to read the reference section when you
- reach the :ref:`section about configuration adjustments' <configmods>`, as
- ensuring debug symbols are disabled will reduce the consumed disk space by quite
- a few gigabytes.
- [:ref:`back to step-by-step guide <diskspace_sbs>`]
- .. _sources:
- Download the sources
- --------------------
- *Retrieve the sources of the Linux version you intend to build.*
- [:ref:`...<sources_sbs>`]
- The step-by-step guide outlines how to retrieve Linux' sources using a shallow
- git clone. There is :ref:`more to tell about this method<sources_shallow>` and
- two alternate ways worth describing: :ref:`packaged archives<sources_archive>`
- and :ref:`a full git clone<sources_full>`. And the aspects ':ref:`wouldn't it
- be wiser to use a proper pre-release than the latest mainline code
- <sources_snapshot>`' and ':ref:`how to get an even fresher mainline codebase
- <sources_fresher>`' need elaboration, too.
- Note, to keep things simple the commands used in this guide store the build
- artifacts in the source tree. If you prefer to separate them, simply add
- something like ``O=~/linux-builddir/`` to all make calls; also adjust the path
- in all commands that add files or modify any generated (like your '.config').
- [:ref:`back to step-by-step guide <sources_sbs>`]
- .. _sources_shallow:
- Noteworthy characteristics of shallow clones
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- The step-by-step guide uses a shallow clone, as it is the best solution for most
- of this document's target audience. There are a few aspects of this approach
- worth mentioning:
- * This document in most places uses ``git fetch`` with ``--shallow-exclude=``
- to specify the earliest version you care about (or to be precise: its git
- tag). You alternatively can use the parameter ``--shallow-since=`` to specify
- an absolute (say ``'2023-07-15'``) or relative (``'12 months'``) date to
- define the depth of the history you want to download. As a second
- alternative, you can also specify a certain depth explicitly with a parameter
- like ``--depth=1``, unless you add branches for stable/longterm kernels.
- * When running ``git fetch``, remember to always specify the oldest version,
- the time you care about, or an explicit depth as shown in the step-by-step
- guide. Otherwise you will risk downloading nearly the entire git history,
- which will consume quite a bit of time and bandwidth while also stressing the
- servers.
- Note, you do not have to use the same version or date all the time. But when
- you change it over time, git will deepen or flatten the history to the
- specified point. That allows you to retrieve versions you initially thought
- you did not need -- or it will discard the sources of older versions, for
- example in case you want to free up some disk space. The latter will happen
- automatically when using ``--shallow-since=`` or
- ``--depth=``.
- * Be warned, when deepening your clone you might encounter an error like
- 'fatal: error in object: unshallow cafecaca0c0dacafecaca0c0dacafecaca0c0da'.
- In that case run ``git repack -d`` and try again``
- * In case you want to revert changes from a certain version (say Linux 6.3) or
- perform a bisection (v6.2..v6.3), better tell ``git fetch`` to retrieve
- objects up to three versions earlier (e.g. 6.0): ``git describe`` will then
- be able to describe most commits just like it would in a full git clone.
- [:ref:`back to step-by-step guide <sources_sbs>`] [:ref:`back to section intro <sources>`]
- .. _sources_archive:
- Downloading the sources using a packages archive
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- People new to compiling Linux often assume downloading an archive via the
- front-page of https://kernel.org is the best approach to retrieve Linux'
- sources. It actually can be, if you are certain to build just one particular
- kernel version without changing any code. Thing is: you might be sure this will
- be the case, but in practice it often will turn out to be a wrong assumption.
- That's because when reporting or debugging an issue developers will often ask to
- give another version a try. They also might suggest temporarily undoing a commit
- with ``git revert`` or might provide various patches to try. Sometimes reporters
- will also be asked to use ``git bisect`` to find the change causing a problem.
- These things rely on git or are a lot easier and quicker to handle with it.
- A shallow clone also does not add any significant overhead. For example, when
- you use ``git clone --depth=1`` to create a shallow clone of the latest mainline
- codebase git will only retrieve a little more data than downloading the latest
- mainline pre-release (aka 'rc') via the front-page of kernel.org would.
- A shallow clone therefore is often the better choice. If you nevertheless want
- to use a packaged source archive, download one via kernel.org; afterwards
- extract its content to some directory and change to the subdirectory created
- during extraction. The rest of the step-by-step guide will work just fine, apart
- from things that rely on git -- but this mainly concerns the section on
- successive builds of other versions.
- [:ref:`back to step-by-step guide <sources_sbs>`] [:ref:`back to section intro <sources>`]
- .. _sources_full:
- Downloading the sources using a full git clone
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- If downloading and storing a lot of data (~4,4 Gigabyte as of early 2023) is
- nothing that bothers you, instead of a shallow clone perform a full git clone
- instead. You then will avoid the specialties mentioned above and will have all
- versions and individual commits at hand at any time::
- curl -L \
- https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/clone.bundle \
- -o linux-stable.git.bundle
- git clone linux-stable.git.bundle ~/linux/
- rm linux-stable.git.bundle
- cd ~/linux/
- git remote set-url origin \
- https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
- git fetch origin
- git checkout --detach origin/master
- [:ref:`back to step-by-step guide <sources_sbs>`] [:ref:`back to section intro <sources>`]
- .. _sources_snapshot:
- Proper pre-releases (RCs) vs. latest mainline
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- When cloning the sources using git and checking out origin/master, you often
- will retrieve a codebase that is somewhere between the latest and the next
- release or pre-release. This almost always is the code you want when giving
- mainline a shot: pre-releases like v6.1-rc5 are in no way special, as they do
- not get any significant extra testing before being published.
- There is one exception: you might want to stick to the latest mainline release
- (say v6.1) before its successor's first pre-release (v6.2-rc1) is out. That is
- because compiler errors and other problems are more likely to occur during this
- time, as mainline then is in its 'merge window': a usually two week long phase,
- in which the bulk of the changes for the next release is merged.
- [:ref:`back to step-by-step guide <sources_sbs>`] [:ref:`back to section intro <sources>`]
- .. _sources_fresher:
- Avoiding the mainline lag
- ~~~~~~~~~~~~~~~~~~~~~~~~~
- The explanations for both the shallow clone and the full clone both retrieve the
- code from the Linux stable git repository. That makes things simpler for this
- document's audience, as it allows easy access to both mainline and
- stable/longterm releases. This approach has just one downside:
- Changes merged into the mainline repository are only synced to the master branch
- of the Linux stable repository every few hours. This lag most of the time is
- not something to worry about; but in case you really need the latest code, just
- add the mainline repo as additional remote and checkout the code from there::
- git remote add mainline \
- https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
- git fetch mainline
- git checkout --detach mainline/master
- When doing this with a shallow clone, remember to call ``git fetch`` with one
- of the parameters described earlier to limit the depth.
- [:ref:`back to step-by-step guide <sources_sbs>`] [:ref:`back to section intro <sources>`]
- .. _patching:
- Patch the sources (optional)
- ----------------------------
- *In case you want to apply a kernel patch, do so now.*
- [:ref:`...<patching_sbs>`]
- This is the point where you might want to patch your kernel -- for example when
- a developer proposed a fix and asked you to check if it helps. The step-by-step
- guide already explains everything crucial here.
- [:ref:`back to step-by-step guide <patching_sbs>`]
- .. _tagging:
- Tagging this kernel build (optional, often wise)
- ------------------------------------------------
- *If you patched your kernel or already have that kernel version installed,
- better tag your kernel by extending its release name:*
- [:ref:`...<tagging_sbs>`]
- Tagging your kernel will help avoid confusion later, especially when you patched
- your kernel. Adding an individual tag will also ensure the kernel's image and
- its modules are installed in parallel to any existing kernels.
- There are various ways to add such a tag. The step-by-step guide realizes one by
- creating a 'localversion' file in your build directory from which the kernel
- build scripts will automatically pick up the tag. You can later change that file
- to use a different tag in subsequent builds or simply remove that file to dump
- the tag.
- [:ref:`back to step-by-step guide <tagging_sbs>`]
- .. _configuration:
- Define the build configuration for your kernel
- ----------------------------------------------
- *Create the build configuration for your kernel based on an existing
- configuration.* [:ref:`... <configuration_sbs>`]
- There are various aspects for this steps that require a more careful
- explanation:
- Pitfalls when using another configuration file as base
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Make targets like localmodconfig and olddefconfig share a few common snares you
- want to be aware of:
- * These targets will reuse a kernel build configuration in your build directory
- (e.g. '~/linux/.config'), if one exists. In case you want to start from
- scratch you thus need to delete it.
- * The make targets try to find the configuration for your running kernel
- automatically, but might choose poorly. A line like '# using defaults found
- in /boot/config-6.0.7-250.fc36.x86_64' or 'using config:
- '/boot/config-6.0.7-250.fc36.x86_64' tells you which file they picked. If
- that is not the intended one, simply store it as '~/linux/.config'
- before using these make targets.
- * Unexpected things might happen if you try to use a config file prepared for
- one kernel (say v6.0) on an older generation (say v5.15). In that case you
- might want to use a configuration as base which your distribution utilized
- when they used that or an slightly older kernel version.
- Influencing the configuration
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- The make target olddefconfig and the ``yes "" |`` used when utilizing
- localmodconfig will set any undefined build options to their default value. This
- among others will disable many kernel features that were introduced after your
- base kernel was released.
- If you want to set these configurations options manually, use ``oldconfig``
- instead of ``olddefconfig`` or omit the ``yes "" |`` when utilizing
- localmodconfig. Then for each undefined configuration option you will be asked
- how to proceed. In case you are unsure what to answer, simply hit 'enter' to
- apply the default value.
- Big pitfall when using localmodconfig
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- As explained briefly in the step-by-step guide already: with localmodconfig it
- can easily happen that your self-built kernel will lack modules for tasks you
- did not perform before utilizing this make target. That's because those tasks
- require kernel modules that are normally autoloaded when you perform that task
- for the first time; if you didn't perform that task at least once before using
- localmodonfig, the latter will thus assume these modules are superfluous and
- disable them.
- You can try to avoid this by performing typical tasks that often will autoload
- additional kernel modules: start a VM, establish VPN connections, loop-mount a
- CD/DVD ISO, mount network shares (CIFS, NFS, ...), and connect all external
- devices (2FA keys, headsets, webcams, ...) as well as storage devices with file
- systems you otherwise do not utilize (btrfs, ext4, FAT, NTFS, XFS, ...). But it
- is hard to think of everything that might be needed -- even kernel developers
- often forget one thing or another at this point.
- Do not let that risk bother you, especially when compiling a kernel only for
- testing purposes: everything typically crucial will be there. And if you forget
- something important you can turn on a missing feature later and quickly run the
- commands to compile and install a better kernel.
- But if you plan to build and use self-built kernels regularly, you might want to
- reduce the risk by recording which modules your system loads over the course of
- a few weeks. You can automate this with `modprobed-db
- <https://github.com/graysky2/modprobed-db>`_. Afterwards use ``LSMOD=<path>`` to
- point localmodconfig to the list of modules modprobed-db noticed being used::
- yes "" | make LSMOD="${HOME}"/.config/modprobed.db localmodconfig
- Remote building with localmodconfig
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- If you want to use localmodconfig to build a kernel for another machine, run
- ``lsmod > lsmod_foo-machine`` on it and transfer that file to your build host.
- Now point the build scripts to the file like this: ``yes "" | make
- LSMOD=~/lsmod_foo-machine localmodconfig``. Note, in this case
- you likely want to copy a base kernel configuration from the other machine over
- as well and place it as .config in your build directory.
- [:ref:`back to step-by-step guide <configuration_sbs>`]
- .. _configmods:
- Adjust build configuration
- --------------------------
- *Check if you might want to or have to adjust some kernel configuration
- options:*
- Depending on your needs you at this point might want or have to adjust some
- kernel configuration options.
- .. _configmods_debugsymbols:
- Debug symbols
- ~~~~~~~~~~~~~
- *Evaluate how you want to handle debug symbols.*
- [:ref:`...<configmods_sbs>`]
- Most users do not need to care about this, it's often fine to leave everything
- as it is; but you should take a closer look at this, if you might need to decode
- a stack trace or want to reduce space consumption.
- Having debug symbols available can be important when your kernel throws a
- 'panic', 'Oops', 'warning', or 'BUG' later when running, as then you will be
- able to find the exact place where the problem occurred in the code. But
- collecting and embedding the needed debug information takes time and consumes
- quite a bit of space: in late 2022 the build artifacts for a typical x86 kernel
- configured with localmodconfig consumed around 5 Gigabyte of space with debug
- symbols, but less than 1 when they were disabled. The resulting kernel image and
- the modules are bigger as well, which increases load times.
- Hence, if you want a small kernel and are unlikely to decode a stack trace
- later, you might want to disable debug symbols to avoid above downsides::
- ./scripts/config --file .config -d DEBUG_INFO \
- -d DEBUG_INFO_DWARF_TOOLCHAIN_DEFAULT -d DEBUG_INFO_DWARF4 \
- -d DEBUG_INFO_DWARF5 -e CONFIG_DEBUG_INFO_NONE
- make olddefconfig
- You on the other hand definitely want to enable them, if there is a decent
- chance that you need to decode a stack trace later (as explained by 'Decode
- failure messages' in Documentation/admin-guide/tainted-kernels.rst in more
- detail)::
- ./scripts/config --file .config -d DEBUG_INFO_NONE -e DEBUG_KERNEL
- -e DEBUG_INFO -e DEBUG_INFO_DWARF_TOOLCHAIN_DEFAULT -e KALLSYMS -e KALLSYMS_ALL
- make olddefconfig
- Note, many mainstream distributions enable debug symbols in their kernel
- configurations -- make targets like localmodconfig and olddefconfig thus will
- often pick that setting up.
- [:ref:`back to step-by-step guide <configmods_sbs>`]
- .. _configmods_distros:
- Distro specific adjustments
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~
- *Are you running* [:ref:`... <configmods_sbs>`]
- The following sections help you to avoid build problems that are known to occur
- when following this guide on a few commodity distributions.
- **Debian:**
- * Remove a stale reference to a certificate file that would cause your build to
- fail::
- ./scripts/config --file .config --set-str SYSTEM_TRUSTED_KEYS ''
- Alternatively, download the needed certificate and make that configuration
- option point to it, as `the Debian handbook explains in more detail
- <https://debian-handbook.info/browse/stable/sect.kernel-compilation.html>`_
- -- or generate your own, as explained in
- Documentation/admin-guide/module-signing.rst.
- [:ref:`back to step-by-step guide <configmods_sbs>`]
- .. _configmods_individual:
- Individual adjustments
- ~~~~~~~~~~~~~~~~~~~~~~
- *If you want to influence the other aspects of the configuration, do so
- now* [:ref:`... <configmods_sbs>`]
- You at this point can use a command like ``make menuconfig`` to enable or
- disable certain features using a text-based user interface; to use a graphical
- configuration utilize, use the make target ``xconfig`` or ``gconfig`` instead.
- All of them require development libraries from toolkits they are based on
- (ncurses, Qt5, Gtk2); an error message will tell you if something required is
- missing.
- [:ref:`back to step-by-step guide <configmods_sbs>`]
- .. _build:
- Build your kernel
- -----------------
- *Build the image and the modules of your kernel* [:ref:`... <build_sbs>`]
- A lot can go wrong at this stage, but the instructions below will help you help
- yourself. Another subsection explains how to directly package your kernel up as
- deb, rpm or tar file.
- Dealing with build errors
- ~~~~~~~~~~~~~~~~~~~~~~~~~
- When a build error occurs, it might be caused by some aspect of your machine's
- setup that often can be fixed quickly; other times though the problem lies in
- the code and can only be fixed by a developer. A close examination of the
- failure messages coupled with some research on the internet will often tell you
- which of the two it is. To perform such a investigation, restart the build
- process like this::
- make V=1
- The ``V=1`` activates verbose output, which might be needed to see the actual
- error. To make it easier to spot, this command also omits the ``-j $(nproc
- --all)`` used earlier to utilize every CPU core in the system for the job -- but
- this parallelism also results in some clutter when failures occur.
- After a few seconds the build process should run into the error again. Now try
- to find the most crucial line describing the problem. Then search the internet
- for the most important and non-generic section of that line (say 4 to 8 words);
- avoid or remove anything that looks remotely system-specific, like your username
- or local path names like ``/home/username/linux/``. First try your regular
- internet search engine with that string, afterwards search Linux kernel mailing
- lists via `lore.kernel.org/all/ <https://lore.kernel.org/all/>`_.
- This most of the time will find something that will explain what is wrong; quite
- often one of the hits will provide a solution for your problem, too. If you
- do not find anything that matches your problem, try again from a different angle
- by modifying your search terms or using another line from the error messages.
- In the end, most trouble you are to run into has likely been encountered and
- reported by others already. That includes issues where the cause is not your
- system, but lies the code. If you run into one of those, you might thus find a
- solution (e.g. a patch) or workaround for your problem, too.
- Package your kernel up
- ~~~~~~~~~~~~~~~~~~~~~~
- The step-by-step guide uses the default make targets (e.g. 'bzImage' and
- 'modules' on x86) to build the image and the modules of your kernel, which later
- steps of the guide then install. You instead can also directly build everything
- and directly package it up by using one of the following targets:
- * ``make -j $(nproc --all) bindeb-pkg`` to generate a deb package
- * ``make -j $(nproc --all) binrpm-pkg`` to generate a rpm package
- * ``make -j $(nproc --all) tarbz2-pkg`` to generate a bz2 compressed tarball
- This is just a selection of available make targets for this purpose, see
- ``make help`` for others. You can also use these targets after running
- ``make -j $(nproc --all)``, as they will pick up everything already built.
- If you employ the targets to generate deb or rpm packages, ignore the
- step-by-step guide's instructions on installing and removing your kernel;
- instead install and remove the packages using the package utility for the format
- (e.g. dpkg and rpm) or a package management utility build on top of them (apt,
- aptitude, dnf/yum, zypper, ...). Be aware that the packages generated using
- these two make targets are designed to work on various distributions utilizing
- those formats, they thus will sometimes behave differently than your
- distribution's kernel packages.
- [:ref:`back to step-by-step guide <build_sbs>`]
- .. _install:
- Install your kernel
- -------------------
- *Now install your kernel* [:ref:`... <install_sbs>`]
- What you need to do after executing the command in the step-by-step guide
- depends on the existence and the implementation of an ``installkernel``
- executable. Many commodity Linux distributions ship such a kernel installer in
- ``/sbin/`` that does everything needed, hence there is nothing left for you
- except rebooting. But some distributions contain an installkernel that does
- only part of the job -- and a few lack it completely and leave all the work to
- you.
- If ``installkernel`` is found, the kernel's build system will delegate the
- actual installation of your kernel's image and related files to this executable.
- On almost all Linux distributions it will store the image as '/boot/vmlinuz-
- <your kernel's release name>' and put a 'System.map-<your kernel's release
- name>' alongside it. Your kernel will thus be installed in parallel to any
- existing ones, unless you already have one with exactly the same release name.
- Installkernel on many distributions will afterwards generate an 'initramfs'
- (often also called 'initrd'), which commodity distributions rely on for booting;
- hence be sure to keep the order of the two make targets used in the step-by-step
- guide, as things will go sideways if you install your kernel's image before its
- modules. Often installkernel will then add your kernel to the bootloader
- configuration, too. You have to take care of one or both of these tasks
- yourself, if your distributions installkernel doesn't handle them.
- A few distributions like Arch Linux and its derivatives totally lack an
- installkernel executable. On those just install the modules using the kernel's
- build system and then install the image and the System.map file manually::
- sudo make modules_install
- sudo install -m 0600 $(make -s image_name) /boot/vmlinuz-$(make -s kernelrelease)
- sudo install -m 0600 System.map /boot/System.map-$(make -s kernelrelease)
- If your distribution boots with the help of an initramfs, now generate one for
- your kernel using the tools your distribution provides for this process.
- Afterwards add your kernel to your bootloader configuration and reboot.
- [:ref:`back to step-by-step guide <install_sbs>`]
- .. _another:
- Another round later
- -------------------
- *To later build another kernel you need similar, but sometimes slightly
- different commands* [:ref:`... <another_sbs>`]
- The process to build later kernels is similar, but at some points slightly
- different. You for example do not want to use 'localmodconfig' for succeeding
- kernel builds, as you already created a trimmed down configuration you want to
- use from now on. Hence instead just use ``oldconfig`` or ``olddefconfig`` to
- adjust your build configurations to the needs of the kernel version you are
- about to build.
- If you created a shallow-clone with git, remember what the :ref:`section that
- explained the setup described in more detail <sources>`: you need to use a
- slightly different ``git fetch`` command and when switching to another series
- need to add an additional remote branch.
- [:ref:`back to step-by-step guide <another_sbs>`]
- .. _uninstall:
- Uninstall the kernel later
- --------------------------
- *All parts of your installed kernel are identifiable by its release name and
- thus easy to remove later.* [:ref:`... <uninstall_sbs>`]
- Do not worry installing your kernel manually and thus bypassing your
- distribution's packaging system will totally mess up your machine: all parts of
- your kernel are easy to remove later, as files are stored in two places only and
- normally identifiable by the kernel's release name.
- One of the two places is a directory in /lib/modules/, which holds the modules
- for each installed kernel. This directory is named after the kernel's release
- name; hence, to remove all modules for one of your kernels, simply remove its
- modules directory in /lib/modules/.
- The other place is /boot/, where typically one to five files will be placed
- during installation of a kernel. All of them usually contain the release name in
- their file name, but how many files and their name depends somewhat on your
- distribution's installkernel executable (:ref:`see above <install>`) and its
- initramfs generator. On some distributions the ``kernel-install`` command
- mentioned in the step-by-step guide will remove all of these files for you --
- and the entry for your kernel in the bootloader configuration at the same time,
- too. On others you have to take care of these steps yourself. The following
- command should interactively remove the two main files of a kernel with the
- release name '6.0.1-foobar'::
- rm -i /boot/{System.map,vmlinuz}-6.0.1-foobar
- Now remove the belonging initramfs, which often will be called something like
- ``/boot/initramfs-6.0.1-foobar.img`` or ``/boot/initrd.img-6.0.1-foobar``.
- Afterwards check for other files in /boot/ that have '6.0.1-foobar' in their
- name and delete them as well. Now remove the kernel from your bootloader's
- configuration.
- Note, be very careful with wildcards like '*' when deleting files or directories
- for kernels manually: you might accidentally remove files of a 6.0.11 kernel
- when all you want is to remove 6.0 or 6.0.1.
- [:ref:`back to step-by-step guide <uninstall_sbs>`]
- .. _faq:
- FAQ
- ===
- Why does this 'how-to' not work on my system?
- ---------------------------------------------
- As initially stated, this guide is 'designed to cover everything typically
- needed [to build a kernel] on mainstream Linux distributions running on
- commodity PC or server hardware'. The outlined approach despite this should work
- on many other setups as well. But trying to cover every possible use-case in one
- guide would defeat its purpose, as without such a focus you would need dozens or
- hundreds of constructs along the lines of 'in case you are having <insert
- machine or distro>, you at this point have to do <this and that>
- <instead|additionally>'. Each of which would make the text longer, more
- complicated, and harder to follow.
- That being said: this of course is a balancing act. Hence, if you think an
- additional use-case is worth describing, suggest it to the maintainers of this
- document, as :ref:`described above <submit_improvements>`.
- ..
- end-of-content
- ..
- This document is maintained by Thorsten Leemhuis <linux@leemhuis.info>. If
- you spot a typo or small mistake, feel free to let him know directly and
- he'll fix it. You are free to do the same in a mostly informal way if you
- want to contribute changes to the text -- but for copyright reasons please CC
- linux-doc@vger.kernel.org and 'sign-off' your contribution as
- Documentation/process/submitting-patches.rst explains in the section 'Sign
- your work - the Developer's Certificate of Origin'.
- ..
- This text is available under GPL-2.0+ or CC-BY-4.0, as stated at the top
- of the file. If you want to distribute this text under CC-BY-4.0 only,
- please use 'The Linux kernel development community' for author attribution
- and link this as source:
- https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/plain/Documentation/admin-guide/quickly-build-trimmed-linux.rst
- ..
- Note: Only the content of this RST file as found in the Linux kernel sources
- is available under CC-BY-4.0, as versions of this text that were processed
- (for example by the kernel's build system) might contain content taken from
- files which use a more restrictive license.
|