如何编译kernel
我们知道Linux内核才是Linux操作系统最为核心的内容。内核实现了对硬件的管理,为应用软件提供了使用硬件的接口。
对于Linux开发人员而言,内核的学习和开发才是终极目标。因此我们今天先介绍一下内核的编译。
需要知道的是,Linux内核的编译和安装并非想象的那么难,那么复杂,其实只需要几条命令就可以搞定。
本文,我们将一步一步地介绍如何从源代码编译和安装一个Linux内核。需要注意的是本指导基于Ubuntu 18.04版本编译安装,其它发行版可能会有差异。
编译一个Linux内核
整个内核编译的过程非常简单,但是内核编译需要花费比较长的时间。这主要是因为内核的代码非常多。当然,如果你的计算机性能强劲,时间会短很多。另外需要注意的是,建议在虚拟机环境下编译,这样避免错误导致系统问题。如果在虚拟机测试,建议系统分区和内核源代码分区的大小大于20GB。
Step 1: 下载源代码
- 进入Linux 内核的官网,下载最新版本,或者其它版本的内核代码。这里是源代码的压缩包。
2. 假设我们现在在一个Linux操作系统中,在命令行输入如下命令就可以下载内核了
Step 2: 解压并编译
压缩包下载完成后,可以通过tar命令解压。
1
tar -xvf linux-5.9.6.tar.xz
安装编译工具
1 | sudo apt-get install git fakeroot build-essential ncurses-dev xz-utils libssl-dev bc flex libelf-dev bison |
Step 4: 配置内核代码
从当前机器的启动目录拷贝配置信息到源代码目录。这步操作的意思是我们编译内核的配置采用用当前环境一致的配置。
1 | cp -v /boot/config-$(uname -r) .config |
可以通过如下命令启动配置界面
1 | make menuconfig |
保存完成后执行下面的命令编译
1 | make -j8 //-j 根据你的cpu核心数而定 |
编译完成后会在arch/x86/boot下输出bzImgae文件,这个文件就是linux内核
结论
通过上面几步,我们可以很简单的编译一个内核。如果后面开发内核模块,也是要基于内核代码树的,因此这个是内核开发的基础。