错误:
自己编写了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函数,当然读不到设备文件中的数据了,因为指针已经不知道跑向那个地方去了!!!
结果:
经过修改后,得到了正确的结果
# lsmod memdev.ko
# insmod memdev.ko
# ./app-mem
BUF: 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!
#
oys!!