2.1 Hello World(P1)
环境:Linux内核 2.6
1.简单的内核模块实例(hello.c)
# include<linux/kernel.h>
# include<linux/module.h>
# include<linux/init.h>
static int __init hello_init(void)
{
printk(KERN_INFO "Hello world\n");
return 0;
}
static void __exit hello_exit(void)
{
printk(KERN_INFO "Goodbye world\n");
}
module_init(hello_init);
module_exit(hello_exit);
MODULE_LICENSE("GPL");
注意:static int __init 其中int后面有一个空格,init前有两道下划线。详情参见。
2.编写Makefile文件
[root@localhost star]# vi Makefile
obj-m := hello.o
all:
make -C /lib/modules/$(shell uname -r)/build M=$(shell pwd) modules
clean:
make -C /lib/modules/$(shell uname -r)/build M=$(shell pwd) clean
注意:
- 在all和clean下面的命令行前面是按Tab形成的空当,切不可按成“空格键”。我就是输入错误导致make命令不成功。
错误提示:make:Nothing to be done for 'all'.
- 其中-C后指定的是Linux内核源代码的目录,而M=后指定的是hello.c和Makefile所在的目录
3.输入命令(hello.c与Makefile文件放在同一目录下)
(1)
[root@localhost star]# make
make -C /lib/modules/2.6.18-371.el5/build M=/home/star modules
make[1]: Entering directory `/usr/src/kernels/2.6.18-371.el5-i686'
CC [M] /home/star/hello.o
Building modules, stage 2.
MODPOST
CC /home/star/hello.mod.o
LD [M] /home/star/hello.ko
make[1]: Leaving directory `/usr/src/kernels/2.6.18-371.el5-i686'
显示上面的情况表明编译成功。
(2)查看编译生成的模块信息
[root@localhost star]# modinfo hello.ko
filename: hello.ko
srcversion: 2BC3DDDE2F3989DA1A22677
depends:
vermagic: 2.6.18-371.el5 SMP mod_unload 686 REGPARM 4KSTACKS gcc-4.1
filename: hello.ko
srcversion: 2BC3DDDE2F3989DA1A22677
depends:
vermagic: 2.6.18-371.el5 SMP mod_unload 686 REGPARM 4KSTACKS gcc-4.1
4.装载和卸载模块(必须root用户)
(1)insmod(install module);rmmod(remove module)
装载 insmod hello.ko
卸载 rmmod hello.ko
(2)查看已经装载的模块(命令lsmod显示所有装载模块)
[root@localhost star]# lsmod | grep hello
hello 5504 0
该命令可以直接找到自己添加的模块
(3)运行模块dmesg(
diagnostic message)
输入命令 dmesg
(或者用 cat /var/log/messages查看系统日志文件)
一般在最后两行可以看见下面,表示执行了装载和卸载过程。
Hello world
Goodbye world
Goodbye world
相关链接: