字符设备驱动程序设计.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
. . 实验七 字符设备驱动程序设计 实验目的 掌握字符设备驱动程序编写的框架; 掌握设备驱动相关的知识; 实验原理 参考本周大课课件《字符设备驱动程序.PPT》。 实验步骤 建立一个工作目录,我们的驱动程序模块程序保存在这个目录下; #mkdir first_drv #cd first_drv 1 自己编写一个字符设备驱动程序,程序格式参考下面; #include linux/module.h #include linux/kernel.h #include linux/init.h #include linux/fs.h #include linux/types.h #include linux/uaccess.h #include linux/cdev.h //(1)编写硬件底层操作函数实现open,release,write,read ...... //(2)创建一个file_operations结构 ...... static int __init xxx_init(void) { //(3)申请设备号 ........ //(4)初始化cdev结构 ........ //(5)注册cdev结构 ........ return 0; } static void __exit XXX_exit(void) { //注销cdev结构 ........ //注销设备号 } module_init(.......); module_exit(.......); MODULE_LICENSE(......); 注意:要求底层函数要实现open,release,write,read方法。 2 编写Makefile文件 内容格式,参考如下: obj-m +=模块程序文件名.o all: make -C 内核源码路径 M=`pwd` modules #这一行要以TAB键开头 clean: make -C 内核源码路径 M=`pwd` modules clean #这一行要以TAB键开头 3 编译模块,拷贝到根文件系统中 编译内核模块,直接使用make命令就可以了; #make 编译没有错误时,将模块拷贝到跟文件系统中; #cp xxx.ko /opt/rootfs/lib/modules/3.5.0-yyy/ 4 启动开发板,进入linux系统后,在开发板上加载和卸载模块 加载: # insmod /lib/modules/3.5.0-yyy/xxxx.ko 查看系统分配的设备号 #cat /proc/devices 手动添加设备文件(设备节点) # mknod /dev/first_drv c 主设备号 次设备号 5 交叉编译应程序,打开设备文件进行读写操作 实验成功后,叫老师查看实验结果,作为平时考察成绩; first_drv: #include linux/module.h #include linux/init.h #include linux/fs.h #include linux/types.h #include linux/uaccess.h #include linux/kernel.h #include linux/cdev.h #include linux/device.h #include asm/io.h static int first_drv_open(struct inode *in, struct file *fp) { printk(first driver open called!\n); return 0; } static int first_drv_release(struct inode *in, struct file *fp) { printk(first driver release called!\n); return 0; } static int data=0; static ssize_t first_drv_write(struct file *fp, const char __user *buf, size_t len, loff_t *offset) { copy_from_user((void *)data,buf,sizeof(int)); printk(first driver write called!data is %d\n,data); return sizeof(int); } static ssize_t first_drv_read(struct file *fp, char __user *buf, size_t len, loff_t

文档评论(0)

hkfgmny + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档