搜索
bottom↓
回复: 4

USB BULK无法收到ACK,传输出现TIMEOUT

[复制链接]

出0入0汤圆

发表于 2013-11-27 11:17:23 | 显示全部楼层 |阅读模式
一个用8051 IP核控制USB 1.1IP核进行U盘的数据读写的项目,枚举可以成功,用BULK传输获取U盘USN、容量等都正常,但是一旦开始连续读取扇区,在读取若干的扇区以后,发送BULK OUT包后单片机读取到的返回状态就变成TIMEOUT。
金士顿的DT101和DT108遇到TIMEOUT的时候是因为设备没有回应,重新尝试发送几次数据包就可以了,这也是正常的情况。但是通过逻辑分析仪抓取USB波形发现另外3个U盘收到BULK OUT包之后确实发送了回应的ACK包,但是程序读取到的状态却是TIMEOUT,似乎USB 1.1的IP核根本没有接收到这个ACK信号。
这样就导致程序认为U盘没有接收到BULK OUT包,重新发送BULK OUT包,而U盘期望的是BULK IN请求,于是U盘就一直返回NAK,导致传输无法进行。
我曾经怀疑是USB IP核的TIMEOUT时间设置过短,于是将超时时间从18bit增加到250bit,但是没有任何效果。
请教各位这个问题应该怎么解决?

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2013-11-27 11:23:30 | 显示全部楼层
不知道你是什么IP,你那IP核的超时设置对大家没有任何帮助。

估计你要从IP找原因,分析其结构、时序。

出0入0汤圆

 楼主| 发表于 2013-11-27 11:24:33 | 显示全部楼层
这个是串口打印的调试信息,第一次BULK OUT传输返回TIMEOUT。
这个是逻辑分析仪捕捉到的USB总线数据,可以看到总线上确实有ACK信号,之后由于主机认为是TIMEOUT而不是ACK,所以后面一直重复发送BULK OUT包。
有人遇到过类似的问题吗?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入0汤圆

 楼主| 发表于 2013-11-27 11:31:13 | 显示全部楼层
sme 发表于 2013-11-27 11:23
不知道你是什么IP,你那IP核的超时设置对大家没有任何帮助。

估计你要从IP找原因,分析其结构、时序。 ...

USB的超时位数是USB2.0标准里规定的(168页的7.1.19.1),最小是18bit,我改成了250bit。
我用的USB 1.1 IP核是从opencores上下载的USB 1.1 Host and Function IP core,经过了我们几个人的修改可以用的。

出0入0汤圆

发表于 2013-11-27 11:35:01 | 显示全部楼层
cssuss 发表于 2013-11-27 11:31
USB的超时位数是USB2.0标准里规定的(168页的7.1.19.1),最小是18bit,我改成了250bit。
我用的USB 1.1  ...

18位的超时是USB协议规定的,这个不应该改。

网上的IP不一定没有bug。既然你们都做了改动,应该对其时序比较了解。用片内逻辑分析仪(chipscope/identify等)抓一些关键点的信号,看看IP收到ACK之后的一些流程哪个地方出错了。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 05:15

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表