如何重新编译linux内核

如何重新编译linux内核,第1张

因为一般电脑安装的系统都是Windows,而整个编译过程都需要在Linux环境下实现,所以最好是在虚拟机里安装Linux系统来完成这一过程。我使用的虚拟机是VMware-workstation-full-v7.1.4。

然后,我们需要下载一个较高版本的Linux系统的镜像文件,安装在虚拟机上,作为编译环境。我使用的是ubuntu-11.04-desktop-i386。之所以选择较高版本,是因为它的界面比较方便用户 *** 作。

然后下载一个Linux内核源代码文件,将它保存到虚拟机上新安装的系统中去。并解压到/usr/src目录。我使用的是linux-2.6.36,下载低版本的原因是,小巧轻便,易于编译。

解压命令如下:

bzip2 -d linux-2.6.36.tar.bz2

tar -xvf linux-2.6.36.ta

修改/usr/src/linux-2.6.36/kernel/sys.c文件,在文件末尾增加一个系统调用函数。自行编写一个简单的程序即可,只为测试用。

修改/usr/src/linux-2.6.36/arch/x86/kernel/syscall_table_32.S,为新添加的程序配置系统调用号。

在/usr/src/linux-2.6.36/arch/x86/include/asm/unistd_32.h中配置系统调用表。

下面就是最重要的内核编译与安装:

首先配置编译信息,使其生成适合当前机器的Makefile,输入make oldconf ig。

接着还要输入make menuconfig,在字符界面下进行必要的细微的修改。

然后要经过四步编译过程(直接输入命令即可):

(1)make bzImage

将内核编译为压缩映像,存储在源码根目录下的“System.map”文件中。

(2)make modules

编译各个模块。

(3)sudo make modules_install

安装模块

(4)sudo make install

安装内核

第(2)(3)步等待时间较长,可能需要数个小时,请耐心等待。

无报错的话重启进入GRUB界面,就可以看到新编译的内核了。

按回车键进入我们编译的目标内核中,用关键词搜索查看新增加的系统调用“my call”是否已在内核中:

编写测试程序,调用新添加的系统调用:

测试成功,说明系统调用添加成功,进而说明内核编译成功!

以上的办法你可以试一下,希望对你有所帮助。

不放以前的系统里放什么地方?另一台计算机里?之后你这个机器启动时自己跑到那台计算机上要数据启动完后,在自己跑回来?

initrd 是内核启动的一个虚拟的磁盘。作用是在 Linux 内核启动时,不直接进入硬盘上的 root 分区,而是进入内存里面的虚拟的 root 分区。

这个用意是当内核不能直接读取硬盘时(比如用了内核没有自带的驱动的硬盘、分区。或者 root 分区在网络上)。那么就可以用 initrd 里面的驱动来过渡进入正确的 root ,或者干脆就停在 initrd 模拟的内存盘里面。

PS:我编译内核都是 make xconfig make make modules_install make install

前3个不解释,最好一个其实就是吧编译好的内核复制到 /boot 里面。并且根据这个目录里面的某些特点。进行一些 *** 作。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7263424.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存