免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1849 | 回复: 5
打印 上一主题 下一主题

驱动打印 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-09-27 16:47 |只看该作者 |倒序浏览
写了一个字符设备驱动,用register_chrdev()注册成功,实现了fops的write()等成员函数,测试阶段所以写的很简单:

static ssize_t dsp_write(struct file * file,const char * buf,size_t count,loff_t *l)
{
         printk("\n%s: ###write() called!", __FUNCTION__);

         return count;
}

然后加载驱动,在应用程序中open()成功了,然后write(fd, "abc", 3),然后dmesg|tail查看驱动打印却只看到了驱动加载时的打印,应用程序也没报错,不知为何看不到dsp_write()中的打印输出?

论坛徽章:
0
2 [报告]
发表于 2010-09-27 19:43 |只看该作者
dmesg 命令产生的是关于启动时产生的一些信息... printk产生的信息用dmesg不会看到吧..
具体printk产生的信息会存放到哪里与syslong.conf文件有关... 我的是在/var/log/message中。

论坛徽章:
0
3 [报告]
发表于 2010-09-28 09:56 |只看该作者
回复 2# PCliangtao


    不好意思,是我写的应用程序里面的设备节点弄错了,该过来就有了。

论坛徽章:
0
4 [报告]
发表于 2010-09-28 10:04 |只看该作者
printk产生的信息用dmesg是可以看到,我夹在驱动时,驱动init函数中的打印信息用dmesg可以看到,针对楼主的问题,是不是没进入write函数中去啊
char test[]={"abc"};
char testbuf=test;
write(fd, testbuf, 3);
试试

论坛徽章:
0
5 [报告]
发表于 2010-09-28 10:54 |只看该作者
回复 4# linux_of_ly


    是open()时有问题,写成了open(fd, "/dev/" MODULE_NAME, 0),应该是O_RDWR才对。

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
6 [报告]
发表于 2010-09-28 13:06 |只看该作者
回复 5# garyv


    看来不是驱动的问题,总觉得写驱动的人,应该对应用程序有足够的了解,否则总会不明白驱动到底能为应用做些什么
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP