Linux字符设备驱动程序的编写框架
指针,接着把控制权交给该函数.这是linux的设备驱动程序工作的基本原理.既然是这样,则编写设备驱动程序的主要工作就是编写子函数,并填充file_operations的各个域.
下面就开始写子程序. 这个函数是为read调用准备的.当调用read时,read_test()被调用,它把用户的缓冲区全部写1.buf 是read调用的一个参数.它是用户进程空间的一个地址.但是在read_test被调用时,系统进入核心态.不能使用buf这个地址,用__put_user(),这是kernel提供的一个函数,用于向用户传送数据.另外还有很多类似功能的函数.请参考,在向用户空间拷贝数据之前,验证buf是否可用.这就用到函数verify_area.为了验证BUF是否可以用. static int write_test(struct inode *inode,struct file *file,const char *buf,int count) 这几个函数都是空操作.实际调用发生时什么也不做,他们仅仅为下面的结构提供函数指针.
read_test, write_test, open_test, release_test, }; 设备驱动程序的主体可以说是写好了.现在要把驱动程序嵌入内核.驱动程序可以按照两种方式编译.一种是编译进kernel,另一种是编译成模块(modules),如果编译进内核的话,会增加内核的大小,还要改动内核的源文件,不能动态的卸载,不利于调试,推荐使用模块方式. int init_module(void) 在用insmod命令将编译好的模块调入内存时,init_module 函数被调用.在这里,init_module只做了一件事,就是向系统的字符设备表登记了一个字符设备.register_chrdev需要三个参数,参数一是希望获得的设备号,如果是零的话,系统将选择一个没有被占用的设备号返回.参数二是设备文件名,参数三用来登记驱动程序实际执行操作的函数的指针. 如果登记成功,返回设备的主设备号,不成功,返回一个负值. 在用rmmod卸载模块时,cleanup_module函数被调用,它释放字符设备test在系统字符设备表中占有的表项. 一个极其简单的字符设备可以说写好了,文件名就叫test.c吧. 下面编译 : $ gcc -O2 -DMODULE -D__KERNEL__ -c test.c –c表示输出制定名,自动生成.o文件
得到文件test.o就是一个设备驱动程序. 如果设备驱动程序有多个文件,把每个文件按上面的命令行编 |
|||
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |