【驱动】——驱动入门用例
2015-05-24 17:14
120 查看
#include <linux/init.h> #include <linux/module.h> static int __init hello_init(void){ printk("hello kernel!\n"); return 0; } static void __exit hello_exit(void){ printk("bye kernel!\n"); } module_init(hello_init); module_exit(hello_exit); MODULE_AUTHOR("ngnetboy"); MODULE_DESCRIPTION("say hello to kernel!"); MODULE_LICENSE("GPL"); MODULE_VERSION("0.0.0.1");
实例代码
注:
__init 对内核来说是一种暗示,表明该函数仅在初始化期间使用。在模块被装载之后,模块装载器就会将初始化函数扔掉,这样可将该函数占用的内存释放出来,以作他用。
__exit 修饰词标记该代码仅用于模块卸载(编译器将把该函数放在特殊的 ELF 段中)。如果一个模块未定义清除函数,则内核不允许卸载该模块。
ifeq ($(KERNELRELEASE), ) KERNELDIR ?= /lib/modules/$(shell uname -r)/build PWD := $(shell pwd) all: clean $(MAKE) -C $(KERNELDIR) M=$(PWD) modules -rm -rf *.o *~ core .depend .*.cmd *.mod.c .tmp_versions Module.* Makefile.xen modules.order clean: -rm -rf *.o *~ core .depend .*.cmd *.ko *.mod.c .tmp_versions Module.* Makefile.xen modules.order else obj-m := hello.o endif
Makefile 文件。
注:
-C 改变目录到指定的位置(内核源代码目录),其中保存有内核的顶层 makefile 文件。
M= 选项让该 makefile 在构造 modules 目标之前返回到模块源代码目录。
按照顺序分析以下make的执行步骤:
在模块的源代码目录下执行make,此时,宏“KERNELRELEASE”没有定义,因此进入else。由于make 后面没有目标,所以make会在Makefile中的第一个不是以.开头的目标作为默认的目标执行。于是 all 成为 make 的目标。 make 会执行 $(MAKE) -C $(KERNELDIR) M=$(PWD) modules 。 这个目标会第二次运行 make 命令。
最简单的驱动示例程序;
相关文章推荐
- 测试用例设计白皮书--判定表驱动分析方法
- fl2440——驱动入门,hello world!
- VS 2010 测试功能学习(九) - 数据驱动的手工测试用例(@Parameter)
- v4l2视频驱动中关于vivi.c的个人分析(菜鸟入门,请轻拍!)
- Linux驱动开发入门——基本知识简介
- 【UML 建模】UML建模语言入门 -- 用例视图详解 用例视图建模实战
- Arduino入门教程--课前准备--Arduino驱动安装及1.0 IDE菜单介绍
- Windows内核驱动开发入门学习资料 + 内核数据类型和函数
- linux驱动入门之hello wrold
- 树莓派GPIO入门05-驱动数码管显示数字(嵌入式很好的链接平台,见解深刻)
- node.js入门(二) 模块 事件驱动
- linux 驱动入门程序,写一个块设备驱动 (2)
- 设备驱动入门系列文章
- 墙裂推荐一本案例驱动的PhoneGap入门书,早看早收货
- 20145201 20145227 《信息安全系统设计基础》实验四 内核驱动设计入门-模块方式驱动实验
- android驱动学习入门-android应用怎么调用驱动
- 试析RUP以用例驱动的需求管理
- 驱动入门
- TQ2440驱动-hello world(入门,注意事项)
- windows过滤驱动程序设计入门(驱动程序基本结构,设备栈,IRP栈和工作原理)