分类: LINUX
2008-07-14 17:59:20
内核模块的结构特点及运行环境和普通程序有很大不同。
模块编写的语法和C语法相差无几,但如果能真正理解模块运行的特点,还需要知道硬件和操作系统的一些知识。
我第一次编译内核模块的经历:
ls
hellomod.c Makefile modutils-2.4.27 常用资料
cat hellomod.c
#include
#include
#include
static int __init lkp_init(void)
{
printk("<1>Hello,World!from the kernel space...\n");
return 0;
}
static void __exit lkp_cleanup(void)
{
printk("<1>Goodbye,World!leaving kernel space..\n");
}
module_init(lkp_init);
module_exit(lkp_cleanup);
MODULE_LICENSE("GPL");
cat Makefile
obj-m +=hellomod.o
all:
make -C /usr/src/linux M=$(PWD) modules
clean:
make -C /usr/src/linux M=$(PWD) clean
ls /usr/src/
gcc-4.2 linux-headers-2.6.22-14 linux-headers-2.6.22-14-generic
sudo make -C /usr/src/linux-headers-2.6.22-14-generic SUBDIRS=$PWD modules
make: Entering directory `/usr/src/linux-headers-2.6.22-14-generic'
CC [M] /home/lzel/Module/hellomod.o
Building modules, stage 2.
MODPOST 1 modules
CC /home/lzel/Module/hellomod.mod.o
LD [M] /home/lzel/Module/hellomod.ko
make: Leaving directory `/usr/src/linux-headers-2.6.22-14-generic'
ls
hellomod.ko hellomod.mod.o Makefile modutils-2.4.27
hellomod.c hellomod.mod.c hellomod.o Module.symvers 常用资料
sudo insmod hellomod.ko
lsmod
Module Size Used by
hellomod 2560 0
nls_iso8859_1 5120 1
.....................................
dmesg
.....................................
[ 1121.812000] Hello,World!from the kernel space...
sudo rmmod hellomod
lsmod |less
Module Size Used by
nls_iso8859_1 5120 1
....................................
dmesg
[ 1331.104000] Goodbye,World!leaving kernel space..
cat /var/log/syslog|less
......................................
Mar 21 14:04:48 lzel-laptop kernel: [ 1317.028000] Hello,World!from the kernel space...
Mar 21 14:05:02 lzel-laptop kernel: [ 1331.104000] Goodbye,World!leaving kernel space..
刚刚并不是这么顺利:
1.modutils 工具没安装,insmod,rmmod,lsmod等都用不了
modutiles-2.4.27下载地址:
2.要特别注意你的linux操作系统的内核版本
用ls /usr/src/
我在Ubuntu下是:
linux-headers-2.6.22-14 linux-headers-2.6.22-14-generic
Redhat 6.0下为:
kernels Redhat
必须进入kernels
ls /usr/src/kernels/
有2.6.22.6-1-i686
然后用make -C /内核路径 SUBDIRS=$PWD modules编译(注意:超级用户权限)
3.将模块插入内核和清除内核
分别用insmod [module.ko(2.6以上版本)]和 rmmod [module]
4.查看运行情况:
1)dmesg命令
2)cat或tail或head /var/log/syslog(message)
具体可参看上述操作,第一次编译内核,还有很多不知道的地方,望各位不吝赐教啊。