日期:2014-05-16  浏览次数:20762 次

对OHCI规范了解的来看看
 
  我的板子的usb host外接了一个4-pin的usb transceiver,在调试时发现板子可以检测到设备插入,但是无法挂载设备,出现的提示信息如下:
usb 1-2: new full speed USB device using ohci-omap3 and address 3
usb 1-2: device descriptor read/64, error -62
usb 1-2: device descriptor read/64, error -62
usb 1-2: new full speed USB device using ohci-omap3 and address 4
usb 1-2: device descriptor read/64, error -62
usb 1-2: device descriptor read/64, error -62
usb 1-2: new full speed USB device using ohci-omap3 and address 5
usb 1-2: device not accepting address 5, error -62
usb 1-2: new full speed USB device using ohci-omap3 and address 6
usb 1-2: device not accepting address 6, error -71
hub 1-0:1.0: unable to enumerate USB device on port 2
hub 1-0:1.0: connect-debounce failed, port 2 disabled

我查了下,错误代码62,是timer expire。 跟踪代码发现驱动在将urb包提交后,尝试OHCI的command status的bit1置1,这 应该是告诉OHCI控制器有数据发送了吧? 现在发现2个问题:
  1,驱动尝试将command status寄存器的bit1 置1,写完后我马上将寄存器的值读出来,发现bit1是0,而如果我往bit2写1后,读出来就是1. 不会是代码将bit1置1后,OHCI发完数据马上有将bit1置0了,应该没这么快吧。
  2,插入设备时,通过示波器,我只看到控制器控制usb transceiver使能的信号,而数据线上并没有检测到正常的通信数据。

有高手知道是怎么回事吗?

ps:usb模块的时钟,在加载usb驱动的时候都已经使能了。我试过了,如果没有使能时钟,那么cpu里相关的usb寄存器是没法访问的。
  只有20分可用分,还希望大家多帮帮忙。谢谢。

------解决方案--------------------
加一段延迟在去读试试,OHCI以前弄过,传输速率很慢的。