Tiny6410 简单的设备驱动helloworld_driver
Tiny6410 简单的设备驱动helloworld_driver
在自己的工作目录下建立helloworld_driver.c
- #include <linux/init.h>
- #include <linux/module.h>
- //代码遵守的license:BSD GPL
- MODULE_LICENSE("Dual BSD/GPL");
- //代码作者声明
- MODULE_AUTHOR("yf210yf");
- //模块初始化
- static int __init hello_init(void)
- {
- printk(KERN_ALERT "Hello world!\n");
- return 0;
- }
- //模块退出
- static void __exit hello_exit(void)
- {
- printk(KERN_ALERT "Goodbye world!\n");
- }
- module_init(hello_init);
- module_exit(hello_exit);
补充下:
1. printk输出跟输出的日志级别有关系,当输出日志级别比控制台的级别高时,就会显示在控制台上,当比控制台低时,则会记录在/var/log/message中。
2. printk()并不是设计用来同用户交互的,虽然我们在 hello-1就是出于这样的目的使用它!它实际上是为内核提供日志功能, 记录内核信息或用来给出警告。因此,每
个printk() 声明都会带一个优先级,就像你看到的<1>和KERN_ALERT 那样。内核总共定义了八个优先级的宏, 所以你不必使用晦涩的数字代码,并且你可以从文
件linux/kernel.h查看这些宏和它们的意义。如果你 不指明优先级,默认的优先级DEFAULT_MESSAGE_LOGLEVEL将被采用。
#define KERN_EMERG "<0>"
#define KERN_ALERT "<1>"
#define KERN_CRIT "<2>"
#define KERN_ERR "<3>"
#define KERN_WARNING "<4>"
#define KERN_NOTICE "<5>"
#define KERN_INFO "<6>"
#define KERN_DEBUG "<7>"
在同目录下建立Makefile
- KERNELDIR :=/home/workdir/kernel/linux-2.6.38
- PWD :=$(shell pwd)
- modules:
- $(MAKE) -C $(KERNELDIR) M=$(PWD) modules
- modules_install:
- $(MAKE) -C $(KERNELDIR) M=$(PWD) modules_install
- obj-m:=helloworld_driver.o
- clean:
- rm -rf *.o *~core .depend .*.cmd *.ko *.mod.c .tmp_versions *.order *.symvers
执行make modules生成helloworld_driver.ko文件。
将helloworld_driver.ko下载到开发板文件系统中,执行insmod helloworld_driver.ko加载驱动模块,串口将打印如下信息:
成功!
卸载helloworld_driver.ko
这是最简单的设备驱动示例!
|
评论暂时关闭