步骤一、编写hello.c。
代码如下:
#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("Dual BSD/GPL");
static int hello_init(void)
{
printk(KERN_INFO " Hello World enter\n");
return 0;
}
static void hello_exit(void)
{
printk(KERN_INFO " Hello World exit\n ");
}
module_init(hello_init);
module_exit(hello_exit);
步骤二、编写makefile。
内容如下:
ifneq ($(KERNELRELEASE),)
obj-m := hello.o
# Otherwise we were called directly from the command
# line; invoke the kernel build system.
else
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)
default:
$(MAKE) -C $(KERNELDIR) M=$(PWD) modules
endif
步骤三、测试驱动的安装、卸载。
执行过程:
[root@ hello]# make
输出:
make -C /lib/modules/2.6.27.5-117.fc10.i686/build M=/mnt/hgfs/pub/code/kernel/hello modules
make[1]: Entering directory `/usr/src/kernels/2.6.27.5-117.fc10.i686'
CC [M] /mnt/hgfs/pub/code/kernel/hello/hello.o
Building modules, stage 2.
MODPOST 1 modules
CC /mnt/hgfs/pub/code/kernel/hello/hello.mod.o
LD [M] /mnt/hgfs/pub/code/kernel/hello/hello.ko
make[1]: Leaving directory `/usr/src/kernels/2.6.27.5-117.fc10.i686'
执行: insmod ./hello.ko 和 rmmod,没有输出任何内容!
[root@ hello]# insmod ./hello.ko
[root@ hello]# rmmod hello
为什么呢。
原来,如果不在字符模式下需要到 /var/log/messages中去看输出结果的。
执行 tail /var/log/messages,看见输出结果了!