内核模块编译、加载&卸载及查看运行结果 -- linux内核
2014-09-22 15:45
701 查看
花了一晚上的时间才搞出这么点名堂,有点丢人。不过丢人就丢人吧,总归得把这仅有的成果记录下来。
[环境]Vmware5.5 + Fedora8(Kernel:2.6.23.1-42.fc8-i586)
===================================================
[源代码hellomod.c]
这里我仅使用了最简单的代码HelloWorld
#include<linux/module.h>
#include<linux/kernel.h>
#include<linux/init.h>
MODULE_LICENSE("GPL")
static int __init my_init(void)
{
printk("<1>hello world!\n");
return 0;
}
static void __exit my_cleanup(void)
{
printk("<1>GoodBye!\n");
}
module_init(my_init);
module_exit(my_cleanup);
==============================================
[Makefile文件内容]
obj-m += hellomod.o
all:
make -C /lib/modules/`uname -r`/build M=`pwd` modules
clean:
make -C /lib/modules/`uname -r`/build M=`pwd` clean
****说明:
-C选项指定内核头文件的路径,所以如果这里不正确的话,就得仔细检查你的目录是不是正确。build只是一个符号链接,一般它指定的正是你的源码所在的目录,如果有的话。如果它不能正确链接,那么可能是你的源码并未安装或者安装的版本与当前正在工作的内核不对应。这时你就需要安装正确的与当前内核匹配的源码(这步很重要,我就在这儿吃了亏,浪费很多时间)。
==============================================
[编译]
好了,这时已经有两个文件了,hellomod.c和Makefile,随便找个目录放下,shell到这目录,输入make:
MODPOST 1 modules
看到这个的话说明编译通过了,生成正确的内核模块文件hellomod.ko
===============================================
[加载]
执行insmod hellomod.ko
[卸载]
rmmod hellomod
[查看内核输出]
tail /var/log/messages
这时就可以看到内核模块在加载和卸载时输出的信息了。
================================================
P.S 本来是个挺简单的事情,结果由于我的FC8内核与源码不一致,导致编译通过的模块一直加载不了,报格式错误,折腾了好久才发现。
为什么很久呢,因为我uname -r出来,都说我是i686;另外我到/lib/modules/下,发现也是i686,但是我到里面随便找了个.ko文件,执行modinfo发现都依赖i586,这才让我找到真正原因。于是找出光盘,重装i586源码,再编译,一切正常。^_^
[环境]Vmware5.5 + Fedora8(Kernel:2.6.23.1-42.fc8-i586)
===================================================
[源代码hellomod.c]
这里我仅使用了最简单的代码HelloWorld
#include<linux/module.h>
#include<linux/kernel.h>
#include<linux/init.h>
MODULE_LICENSE("GPL")
static int __init my_init(void)
{
printk("<1>hello world!\n");
return 0;
}
static void __exit my_cleanup(void)
{
printk("<1>GoodBye!\n");
}
module_init(my_init);
module_exit(my_cleanup);
==============================================
[Makefile文件内容]
obj-m += hellomod.o
all:
make -C /lib/modules/`uname -r`/build M=`pwd` modules
clean:
make -C /lib/modules/`uname -r`/build M=`pwd` clean
****说明:
-C选项指定内核头文件的路径,所以如果这里不正确的话,就得仔细检查你的目录是不是正确。build只是一个符号链接,一般它指定的正是你的源码所在的目录,如果有的话。如果它不能正确链接,那么可能是你的源码并未安装或者安装的版本与当前正在工作的内核不对应。这时你就需要安装正确的与当前内核匹配的源码(这步很重要,我就在这儿吃了亏,浪费很多时间)。
==============================================
[编译]
好了,这时已经有两个文件了,hellomod.c和Makefile,随便找个目录放下,shell到这目录,输入make:
MODPOST 1 modules
看到这个的话说明编译通过了,生成正确的内核模块文件hellomod.ko
===============================================
[加载]
执行insmod hellomod.ko
[卸载]
rmmod hellomod
[查看内核输出]
tail /var/log/messages
这时就可以看到内核模块在加载和卸载时输出的信息了。
================================================
P.S 本来是个挺简单的事情,结果由于我的FC8内核与源码不一致,导致编译通过的模块一直加载不了,报格式错误,折腾了好久才发现。
为什么很久呢,因为我uname -r出来,都说我是i686;另外我到/lib/modules/下,发现也是i686,但是我到里面随便找了个.ko文件,执行modinfo发现都依赖i586,这才让我找到真正原因。于是找出光盘,重装i586源码,再编译,一切正常。^_^
相关文章推荐
- Linux内核模块编译、加载&卸载及查看运行结果
- Linux内核模块编译、加载&卸载及查看运行结果
- Linux内核模块编译、加载&卸载及查看运行结果
- ubuntu下helloworld内核模块编译、加载/卸载
- 编译,加载并卸载一个内核模块
- Linux内核编译,内核模块编译加载
- 内核模块编写,编译,加载和卸载过程
- Linux内核如何加载编译进内核的模块
- 【TINY4412】LINUX学习笔记:(2)内核模块编译、安装、加载、卸载
- 内核模块编写 编译 加载/查看/删除模块
- 内核模块的编写、编译、加载、卸载;Makefile的编写
- 转:linux启动时对编译进内核驱动模块的加载
- 内核编译 & 模块编译
- Linux 2.6内核的编译步骤及模块的动态加载
- Code maturity level options 代码成熟度选项 [*]Prompt for development and/or incomplete code/drivers 显示尚在开发中或尚未完成的代码与驱动.除非你是测试人员或者开发者,否则请勿选择 我是开发者,所以选[*] Loadable module support 可加载模块支持 [*]Enable loadable module support 内核编译配置选项简介 (2.4.20-8
- Linux 2.6内核的编译步骤及模块的动态加载
- 内核自动加载模块编译选项
- Linux 2.6 内核驱动模块的编译和加载
- Linuxx 2.6内核可加载模块的编译
- 向内核加载/卸载模块