加入收藏 | 设为首页 | 会员中心 | 我要投稿 | RSSRSS-巴斯仪表网
您当前的位置:首页 > 电子发烧 > 单片机学习

s3c2440(2410) USB HOST不稳定的原因及解决方法

时间:2013-09-08  来源:123485.com  作者:9stone

       今天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应该同样适用.各位可以实际测试验证一下.


分享到:
来顶一下
返回首页
返回首页
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表
栏目导航->单片机学习
  • 电子应用基础
  • 电源技术
  • 无线传输技术
  • 信号处理
  • PCB设计
  • EDA技术
  • 单片机学习
  • 电子工具设备
  • 技术文章
  • 精彩拆解欣赏
  • 推荐资讯
    使用普通运放的仪表放大器
    使用普通运放的仪表放
    3V与5V混合系统中逻辑器接口问题
    3V与5V混合系统中逻辑
    数字PID控制及其改进算法的应用
    数字PID控制及其改进
    恶劣环境下的高性价比AD信号处理数据采集系统
    恶劣环境下的高性价比
    栏目更新
    栏目热门