在wince5下usb鼠标的问题让我困惑了好久,为什么同样的硬件(2440+usb鼠标)在wince4.2下就可以用,而在wince5下就偶尔才行呢。难道非要插拔一下鼠标才能行。问题很显然,要不就是系统的配置(各频率,但是usb只是和upll-48M有关),要不就是usbhcd的设置有问题。虽然如此,但是由于usb的复杂性也懒的去摸索代码了。下面转一篇文档,虽然和我的问题不太一样,但是这种多角度思考的方式是值得做软件的我应该学习的:
今天tpu拿出一块2440板子调试,发现尽管采取了种种措施,USBHOST总是会偶尔不工作.把UCLK通过CLKOUT0引出,用示波器查看,发现不工作的时候,UCLK根本就没有稳定下来.于是仔细思考,影响USB的有这几个地方:
1.外部晶振16.9344Mhz
2.LOCKTIME寄存器的UPLL LOCKTIME
3.UPLLCON 4.CLKSLOW寄存器的UPLL开关
接下来逐个排除:
1.晶振是MPLL和UPLL公用,从来没听说过MPLL不稳定的.
2.怀疑LOCKTIME太大(0xffff),但改小了没有效果.
3.在UCLK不稳定的时候,重复设置UPLLCON是没有用的.
4.在UCLK不稳定的时候,开关UPLL,有效果!在UCLK稳定的情况下,开关UPLL,同样会出现不稳定的情况. 那么就是说,UPLL在启动的时候,可能会同步失败.但是为什么呢?UPLL与MPLL应该是同样的结构,MPLL就从来不出问题.UPLL只是频率比MPLL低一些.那就从频率上再找找看. 现对UPLLCON设置了一个比较低的频率(比如7Mhz),此时无论如何开关UPLL,UCLK始终稳定不起来.好了,曙光已经出现了!然后设置了一个超高的频率(112Mhz),哈哈,不关如何开关UPLL,还是上电启动,UCLK都非常稳定.
问题于是可以这样描述了:UPLL在低频率下不能可靠的启动. 问题的解决办法:首先给UPLL一个较高的频率,待其稳定工作后,再设置所需的频率. 注意:如果要开关CLKSLOW里面的UPLL开关,也要遵循这个设置步骤. 这样改过之后,tpu开关电源一百多次,UCLK始终非常稳定.这只是2440的情况,但对2410应该同样适用.各位可以实际测试验证一下.
很抱歉,没有找到原文的出处(从别人的转帖中拷贝来的)。
我的问题,现在换了一个鼠标(我本子的原装usb鼠标),tmd现在就好了。