Fedora Core 5 内核源代码安装手记

来源:互联网 发布:淘宝保证金欠款不还 编辑:程序博客网 时间:2024/05/29 19:49

FC5release已经快一个月了,才发现安装后没有内核源码,安装光盘里也找不到,这是和以前版本不一样的地方。只好自己动手编译源码。一般也不需要用的Linux 内核源码,但是在安装一些软件的时候提示Invalid module format这就是没有用Makefile编译内核的原因。

安装kernel的src.rpm 
到:http://download.fedora.redhat.com/pub/fedora/linux/core/5/source/SRPMS/kernel-2.6.15-1.2054_FC5.src.rpm下载kernel-2.6.15-1.2054_FC5.src的安装包。(我的内核版本是这个所以就下载的这个版本,你可以用uname -r这个命令来查看你内核版本号)

下面是安装kernel-2.6.15-1.2054_FC5.src的过程
编译内核源码:
# rpm –Uvh kernel-2.6.15-1.2054_FC5.src.rpm
# cd /usr/src/redhat/SPECS
# rpmbuild -bp --target $(uname -m) kernel-2.6.spec
# ls /usr/src/redhat/BUILD/kernel-2.6.15/
Config.mk linux-2.6.15.i686 vanilla xen xen-vanilla (有可能是i586我的是i686)
# cd /usr/src
# mkdir kernels (默认的安装是没有kernels这个文件夹)
# cd kernels/
# ln -s ../redhat/BUILD/kernel-2.6.15/linux-2.6.15.i686/ 2.6.15-1.2054_FC5-i686
# cd 2.6.15-1.2054_FC5-i686/
# cp configs/kernel-2.6.15-i686.config .config
cp:是否覆盖“.config”? y

修正Makefile
#uname –r (得到2.6.15-1.2054_FC5)
2.6.15-1.2054_FC5
那么就要将Makefile中的
EXTRAVERSION = -prep
换成
EXTRAVERSION = -1.2054_FC5

继续编译:
#make mrproper
#make oldconfig
#make (比较耗时,我用了一个多小时)
#make modules_install
到此我们要用的内核编译完成。

 

好了,现在可以开始编写内核模块了。

让我们从Hello World 开始吧。

/*hello.c*/
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("Dual BSD/GPL");

static int hello_init(void)
{
        printk(KERN_ALERT "Hello World/n" );
        return 0;
}

static void hello_exit(void)
{
        printk(KERN_ALERT "Goodbye World/n" );
}

module_init(hello_init);
module_exit(hello_exit);

        这个模块什么也不做,只是在加载时显示"Hello,World",卸载时显示"Goodbye World"。
        这个模块定义了两个函数,其中一个在模块被装载到内核时调用hello_init(),而另一个则在模块被移出时调用hello_exit()。
       module_init 和 module_exit 行使用了内核的特殊宏来表示上述两个函数所扮演的角色。另外一个宏MODULE_LICENSE 用来告诉内核,该模块采用自由许可证,如果没有这样的声明,内核在装载该模块时会产生抱怨。函数printk()在linux/kernel.h中定义,功能和标准C库函数printf()类似。需要说明一点,写内核或内核模块不能用写应用程序时的系统调用或函数库,因为我们写的就是为应用程序提供系统调用的代码。内核有专用的函数库,如<linux/kernel.h>, <linux/fs.h>,<linux/sche.h>等。   

        KERN_ALERT定义了这条消息的优先级,我们需要在模块代码中显示地指定高优先级的原因在于:具有默认优先级的消息可能不会输出在控制台上。需要特别指出的是,printk 只能输出到文本控制台上,图形界面下的终端仿真器是不会看到printk的输出的。这些信息也可能保存到/var/log/messages中,你可以用dmesg查看。

接下来是编写makefile:

TARGET = hello
KDIR = /usr/src/linux
PWD = $(shell pwd)
obj-m      := $(TARGET).o
default:
        make -C $(KDIR) M=$(PWD) modules

输入:
# make
         好了模块已经编译好了,输入ls -a 可以看到hello.ko,现在就让我们来加载这个模块看看效果,按 ctrl+alt+F2 切换到文本界面,输入root 和密码,cd 到hello.ko 所在目录。
# insmod ./hello.ko
Hello World
# rmmod hello
Goodbye World

       我们已经看到,编写一个模块并没有现象的那么困难——至少当模块不需要完成什么有价值的工作时。真正的困难在于理解设备并最大化其性能。

 

原文连接: http://hi.baidu.com/wjq_qust/blog/item/a4d769d9c2cf102c11df9b47.html

原创粉丝点击