如何重新编译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”是否已在内核中:

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

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

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

Linux编译安装相关命令,下面以Linux安装MySQL工具为例进行说明,代码如下:

1、测试环境在Linux MySQL下进行,版本系统为CentOS5,以下为相关软件:

mysql-5.1.30

memcached-1.2.6

libevent-1.4.7-stable

memcached_functions_mysql-0.8

libmemcached-0.26

2、编译安装Linux MySQL

[root@localhost ~]#tar xzf mysql-5.1.30.tar_001.gz  

[root@localhost ~]#cd mysql-5.1.30  

[root@localhost ~]#./configure --prefix=/usr/local/mysql51  

[root@localhost ~]#make  

[root@localhost ~]#make install  

[root@localhost ~]#./scripts/mysql_install_db --user=mysql --skip-name-resolve  

[root@localhost ~]#/usr/local/mysql51/bin/mysqld_safe 

#连接符&这是放入后台,&&是前一个正确执行,才会执行后一个

#Linux编译安装流程./configure && make && make install(默认目录安装)

#./configure --prefix=/usr/local/pcre && make && make install(指定安装目录)

你编译时是不是加了什么参数,默认的编译就是只编译更改过的文件,这是gmake本身的作用:管理工程,按照时间戳进行文件编译。

-B 和 --always-make这两个参数就是全部重新编译。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存