usb host驱动程序崩溃的问题
来源:互联网 发布:手机蜂窝数据打不开 编辑:程序博客网 时间:2024/05/29 07:56
最近在调试一个usb主芯片,外接了四个devices.芯片->hub->4 devices.
开机启动时,时好时坏.有时候能正常识别,有时候会崩溃掉.
现象为:
[ 468.495391] PC is at UBIRunIntIN0+0x378/0x5d0 [hcd903x]
反汇编看代码总是崩溃在bulkin的数据接收上,一直没明白,以为是芯片驱动问题.
后来经过仔细测试发现开机启动时,每次启动时,只要识别不出devices时就会崩溃.
发现是hub_port_reset函数中的set_port_feature失败,发现进入cannot reset port %d (err = %d)\n",打印-110.内核中-110为,ETIMEDOUT.
跟踪代码发现是usb_fill_control_urb返回失败.
目前的现象纠结于两个问题:1,为什么hub会识别不出device.2,即使识别不出来device,也不应该崩溃掉.
现在没有什么结论.
问题已解决,主要是由于usb_submit_urb的参数用的是GFP_KERNEL,把其用到的地方,全改为GFP_ATOMIC,重启几十次,没有发现崩溃的现象.
总结得失:
这次崩溃现象之所以花了两天才解决,还是因为对linux的调度不熟悉.崩溃之后,总是纠结于最底层驱动的锁,信号量之类的地方,看结构体是否被抢占,而没有想到是驱动应用层直接调用时就是可抢占的权限.后来在网上查了查,有一英文网站提了一句这个地方,没想到真解决了.
以后得注意两方面:
1,加强利用网络知识,尤其是谷歌的利用.
2,多学习linux知识,多从原理上想问题.而不是去瞎猜.
作者:张亮校
写于:2012.12.27
更改:2012.12.28
- usb host驱动程序崩溃的问题
- usb host问题
- USB驱动程序的加载
- USB驱动程序的编写
- 关于kernel2.6中USB host controller driver 的问题
- 关于Usb直接拔出导致的进程崩溃问题
- 关于通过驱动程序读取usb接口数据的问题?
- USB Host和USB Device的区别
- 对USB驱动程序的理解
- 对USB驱动程序的理解
- 对USB驱动程序的理解
- USB设备驱动程序的设计
- USB驱动程序的加载(一)
- USB驱动程序的加载(二)
- android 手机的USB 驱动程序
- USB驱动程序的加载(二)
- USB驱动程序的加载(一)
- USB驱动程序的匹配分析
- 银行系统1.1
- [Android]破解android安卓apk软件所需的工具
- ubuntu下安装SSH服务
- Cpulimit
- kruscal 和 prim模板
- usb host驱动程序崩溃的问题
- JBPM学习(1):搭建JBPM4.4开发环境
- 【2013微软校招面试题】将链表的奇偶位交换,不能使用交换链表中的值这种做法。
- 一些CSDN的网址备份
- 定义事件过程类型
- PYTHON编码转换小记
- vs2005 生成的应用程序 在win7下以管理员权限运行
- Ant commend
- response.setContentType()参数