1.helloworld.c
#include <linux/module.h>//与module相关的信息
#include <linux/kernel.h>
#include <linux/init.h> //与init相关的函数
static int __init hellokernel_init(void)
{
printk(KERN_INFO "Hello kernel!\n");
return 0;
}
static void __exit hellokernel_exit(void)
{
printk(KERN_INFO "Exit kernel!\n");
}
module_init(hellokernel_init);
module_exit(hellokernel_exit);
MODULE_LICENSE("GPL");
MODULE_AUTHOR("xxxx");
2.Makefile
<pre name="code" class="cpp">obj-m := helloworld.o
PWD := $(shell pwd)
all:
make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules
clean:
rm -rf *.o *~ core .*.cmd *.mod.c ./tmp_version
执行make:
编译成功之后会生成相应有ko文件,也就是我们想要的驱动了
驱动程序的相关操作:
查看ko模块的信息 modinfo
插入模块 insmod helloworld.ko
卸载模块 rmmod helloworld
还有一个modprobe功能,以后介绍
查看驱动的打印信息:
使用dmesg可以查看在驱动的相关打印信息!
现在有例子是会有如下的打印内容:
---------------------log start----------------------------
[27520.195551] Exit kernel!
[27948.531569] Hello kernel!
---------------------log end----------------------------