当前位置:  技术问答>linux和unix

Linux字符设备驱动疑难问题--printf打印信息发到字符设备write函数中

    来源: 互联网  发布时间:2016-09-26

    本文导语:  我在开发中遇到一个奇怪的问题: 1、创建了一个字符设备驱动,为其注册了open、read、write、poll等函数; 2、创建了一个用户空间程序,用来打开1中的字符设备驱动,为的是传递命令到用户空间程序进行处理; 3、当...

我在开发中遇到一个奇怪的问题:
1、创建了一个字符设备驱动,为其注册了open、read、write、poll等函数;
2、创建了一个用户空间程序,用来打开1中的字符设备驱动,为的是传递命令到用户空间程序进行处理;
3、当PC端发送一个请求,我们受到后会将其放到请求列表ctrl_list中;
4、字符设备的read函数会循环检测ctrl_list中有没有控制请求,当有控制请求的时候,会通过copy_to_user发送到用户空间程序中;
5、用户空间程序解析4中的请求并执行处理,处理完成后发送结果,在用户空间调用write,我们的请求处理结果最大50字节;
6、在字符设备驱动的write函数中,会出现被写入4096或1024字节数据的情况(依平台不同有所变化),这个是一页的数据;
7、上述一页的数据是我们用户空间程序中所有printf语句的打印信息,并被发送到PC侧,可以从打印log看出;
8、我们通过在内核加panic和在用户空间加指针误操作进行追踪,发现上述4096字节的数据不是我们的用户空间程序调用的,从panic看是文件系统自己调用,并把printf的打印发过去,出现这种情况时,用户空间的打印不会在串口打印出来;


麻烦大家看下有没有遇到过这种问题,为什么会被莫名其妙调到;

不方便贴代码;

谢谢

|
你把标准输出 定向的这个字符设备了吧。

比如启动时用   program  > /dev/char


|
static ssize_t ***_write_***(struct file * file, const char __user * buf, 
 size_t count, loff_t *ppos)

在这个write 里把count 打印出来看看.
copied = copy_from_user(dest, buf, sz); 
再把这个 copied 值打印出来看看呢?
如果处理数据最多50字节, 即便是缓存在内存里, 也需要好几十次才会分页 .


|
如果确定是驱动里面write被调用导致的话,可以在write函数中打印出调用的堆栈信息,并可以打印出调用write函数的进程名称.

|
#include 

把调用这个write 的进程打印出来 current->pid 

对比一下是哪个进程调用的, 是不是设备号分配冲突?

|
copied值每次都是0 , 那这里就有问题呢

|
是不是程序中,将stdin、stdout、stderr的fd关闭过了呢?导致0、1、2描述符被重用。
使用ps查看一下用户进程的进程号,比如3063。然后通过proc查看一下这个进程所有打开的文件句柄。
localhost:/ > ls -l /proc/3063/fd
total 0
lrwx------ 1 root root 64 Sep  8 04:29 0 -> /dev/pts/3
lrwx------ 1 root root 64 Sep  9 00:49 1 -> /dev/pts/3
lrwx------ 1 root root 64 Sep  9 00:49 2 -> /dev/pts/3
lrwx------ 1 root root 64 Sep  9 00:49 255 -> /dev/pts/3

    
 
 

您可能感兴趣的文章:

  • Linux c字符串中不可打印字符转换成16进制
  • linux c 中怎么从字符串中截取从第5为开始长4个字符的数剧?
  • linux c/c++ IP字符串转换成可比较大小的数字
  • linux装的是英文的,他的默认字符集是什么字符集?
  • linux c下利用srand和rand函数生成随机字符串
  • linux下如何查看当前配置的字符集,以及更改当前字符集(在命令行状态下)
  • linux下利用(cat,strings,head,sed)命令生成随机字符串
  • 请问在linux下,怎样把unicode字符转化为gbk字符,急用,谢谢
  • Linux/CentOS/fedora下vim显示的字符编码设置
  • linux里字符串开头为空字符是什么意思
  • linux bash shell命令:文本搜索工具grep中用于egrep和 grep -E的元字符扩展集
  • Linux下的C语言字符串和字符有几种类型?和Windows下区别是不是很大?
  • Linux下C语言strstr()查找子字符串位置函数详细介绍(strstr原型、实现及用法)
  • 在linux下写一个shell:if(字符串1==“”(空) 或字符串2====“”(空))怎马写啊,急
  • linux bash shell命令:文本搜索工具grep正则表达式元字符集(基本集)
  • Linux字符界面下,怎么控制已经打印出的字符啊?谢谢了!!
  • linux下目录名或文件名是限制在256字符内吗?名称上有什么特殊要求?字符界面下能用中文吗?
  • 请问:linux下C/C++编程,怎样把含有中英文及数字其他字符的字符串,转化成utf-8编码,又怎样将其转换回来。iconv好像不支持混合?
  • Linux c语言 如何统计utf-8编码的包含中英文和各种符号的字符串中各个字符的个数
  • linux文本的末位字符是什么
  • linux下做C++ 字符编码的问题
  • UIO(linux Userspace I/O子系统)用户空间设备驱动I/O技术介绍
  • Linux设备驱动(第三版)- 字符设备驱动 - 例子
  • linux 启动的时候 可以检查出很多设备 并给设备配以驱动程序
  • Linux下写了一个字符设备驱动,找不到设备文件在哪个目录
  • linux2.4如何在设备拔出后将无效的设备节点也删除
  • linux无法认出USB设备,说设备不响应
  • 有人在Linux下用过1394接口的设备吗?怎么装载一个1394接口的存储设备呢?
  • Linux的设备和设备号是指什么?可否简单的解释一下?
  • 一个arm-linux有ppp0设备和eth0设备.怎么做这样的应用.
  • 各位设备驱动开发的朋友,请问,linux设备驱动开发和网络编程开发哪一样工资比较高呀?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请教Linux设备驱动的具体应用(基于PC)
  • linux USB从口设备驱动问题
  • 跪求linux下usb音视频设备驱动
  • LCD设备驱动 LCD-Linux
  • linux上的USB从设备驱动!
  • 想走嵌入式linux设备驱动方向,请多指点
  • linux设备驱动开发
  • linux 设备驱动开发&调试技术---!!!!!!!
  • 求 linux 设备驱动第二版 中文版 电子书下载 100分
  • 关于linux设备驱动的第一个例子
  • linux下块设备驱动中对于坏扇区的处理是那个部分?
  • 怎么学习Linux 设备驱动程序开发?
  • 初学linux设备驱动,菜鸟级问题,请指教,感激不尽
  • 请高人推荐几本关于linux设备驱动的好书。。
  • 【求教】《精通linux设备驱动开发》这本书怎么样?
  • linux设备驱动执行完__init之后就执行__devinit吗
  • 求<Linux设备驱动>(第二版)的电子书
  • 哪有《Linux设备驱动开发技术及应用》PDF下载啊
  • linux块设备驱动开发的问题
  • 关于Linux 2.6平台下,自定义的USB HID设备是系统提供驱动程序还是需要自己完成驱动程序?
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • secureCRT下Linux终端汉字乱码解决方法
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • Linux c++虚函数(virtual function)简单用法示例代码


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3