错误:
自己编写了memdev字符设备驱动程序,加载驱动模块后,执行应用程序./app_mem程序来测试驱动,出现了如下问题。

向设备文件中写入数据正常,但是当要从设备文件中读出“写入的数据时”,提示buf is null没有数据
分析:
1、printk函数打印的提示信息“written 4096 bytes(s) from 0”,说明驱动函数read已经被调用
2、但是没有见到驱动函数read被调用,没有打印出read中的printk,刚开始以为是驱动函数中read函数的实现由问题
3、经过检查,read函数没有问题,但是发现驱动函数llseek的实现有问题

当时把
这段函数写在switch语句里面了,所以在进行设备的写入后,llseek得重新定位,此时定位失效,那么当调用read函数,当然读不到设备文件中的数据了,因为指针已经不知道跑向那个地方去了!!!

结果:
经过修改后,得到了正确的结果
oys!!# lsmod memdev.ko# insmod memdev.ko# ./app-memBUF: Mem is char dev!written 4096 bytes(s) from 0 // 驱动函数write中printk打印信息BUF: Buf is NULL!read 4096 bytes(s) from 0 // 驱动函数read中printk打印信息BUF: Mem is char dev!#









作者:quannii 发表于2013-5-31 0:30:06 原文链接
阅读:157 评论:0 查看评论