关于USB的问题 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 4092|回复: 1
打印 上一主题 下一主题

关于USB的问题

[复制链接]

13

主题

41

帖子

1181

积分

金牌会员

Rank: 6Rank: 6

积分
1181
QQ
跳转到指定楼层
楼主
发表于 2016-12-1 09:25:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
     小弟最近做了5块板子,用的创龙的核心板,其中4块USB2.0 host都没有问题,只有一块老是周期性报如下错误:+ x+ M1 ^2 C# Q$ f& E
hub 2-0:1.0: over-current condition on port 1
1 W4 Q: d7 w# n6 G0 m3 m  {da8xx_musb_interrupt 538: VBUS error workaround (delay coming)
# I% ]/ N  |5 B" I6 ~6 Z我的电路图如附件,我用示波器测量过了,开始USB0_DRVVBUS脚起始是低电平,开机瞬间,它会变成高电平,USB0_VBUS也会/ K* c$ C3 g" ]9 o* t3 c2 G
随着上升至5V,开机瞬间,USB0_VBUS并没有出现跌落至低于4.4V,从电路上没有发现问题,然后开始追踪linux3.3 USB驱动代码,9 H& a$ z& @2 P* f9 `% D& h
发现,在da8xx_musb_interrupt函数中,有如下代码:
, B: s3 A/ W3 {. }9 p/ Kif (status & (DA8XX_INTR_DRVVBUS << DA8XX_INTR_USB_SHIFT)) {; F1 @; x/ @0 I
                int drvvbus = musb_readl(reg_base, DA8XX_USB_STAT_REG);: u* |% |0 S# f. U
                void __iomem *mregs = musb->mregs;
' g) K: X# \$ }                u8 devctl = musb_readb(mregs, MUSB_DEVCTL);) g+ Y7 s- q/ q; \8 I+ i
                int err;" p2 y" ^: |/ |  q3 N+ m. K7 b& [

8 s9 D+ l8 G7 n& r! w  h2 X; C                err = is_host_enabled(musb) && (musb->int_usb &( x) v9 k) s$ s# X1 O- S
                                                MUSB_INTR_VBUSERROR);& j0 c* S* B2 g" D+ [* a, Q! T
                if (err) {& z5 o  l  ]3 U% _
                        /*7 t: E  h$ W2 e& h! f/ J
                         * The Mentor core doesn't debounce VBUS as needed
. ^! U. f2 k- b: g( B9 m                         * 。。。
3 I/ K8 l, ^& |+ V* F2 N6 L                         */
1 L1 X! Y+ s0 d; f2 s3 h                        musb->int_usb &= ~MUSB_INTR_VBUSERROR;
; q: Q: X$ M& Q  c                        musb->xceiv->state = OTG_STATE_A_WAIT_VFALL;9 y& x3 O; |- e
                        mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);) b8 |. S7 V6 F; W2 o
                        WARNING("VBUS error workaround (delay coming)\n");
% D9 M4 B% f7 W  T7 y  o( i  D: M                }
$ t( L1 Q& p6 G  Q: H! C
; M% K1 w& a* Z1 Z5 J) ]: V一直发生MUSB_INTR_VBUSERROR错误,然后会启动定时器,周期调用otg_timer函数,. J7 D" F( V6 T; ^. k8 J  N, `
跳入如下分支:6 o- `# r# }/ S
devctl = musb_readb(mregs, MUSB_DEVCTL);
) v; j* Z/ Y$ x% M1 t7 v。。。
$ }0 o7 S& |* Ecase OTG_STATE_A_WAIT_VFALL:
: m. {# q; v+ K+ s8 {0 s                /*
5 \3 q2 ?% B! B! |! W                 * Wait till VBUS falls below SessionEnd (~0.2 V); the 1.35 u) c- y2 y7 P7 m: s" ~+ a
                 * RTL seems to mis-handle session "start" otherwise (or in! u* Y7 H7 }9 O5 U1 t+ M1 M/ B
                 * our case "recover"), in routine "VBUS was valid by the time. m* A# f5 \, J. c4 C3 Z- k. W2 a' |
                 * VBUSERR got reported during enumeration" cases.
5 [. `# G3 D& }% u  R                 */
4 Q. X9 v7 M, N/ p" G5 G                if (devctl & MUSB_DEVCTL_VBUS) {
5 L3 p* G+ e) }/ F: H6 I                        mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);2 h: U% P4 F: G; G! |& N/ s# t
                        break;
0 H$ ^; R' J4 i0 h  D& v  v. J                }1 n5 g: W  G7 v- x; V$ _
                musb->xceiv->state = OTG_STATE_A_WAIT_VRISE;# e& z* i' D1 q$ T, ]5 e; H
                musb_writel(musb->ctrl_base, DA8XX_USB_INTR_SRC_SET_REG,
" u* \6 k" f+ M5 p# @* r                            MUSB_INTR_VBUSERROR << DA8XX_INTR_USB_SHIFT);/ i/ }/ l' |5 U
                break;
- q! U. s, [" q- D$ p  c% F5 J0 c" g# E6 q
其中,devctl是设备控制寄存器,我打印了它的直,是0x80, 也就是位7是1,代表着是B device,,明明是A类,
4 _6 O- R) I, X+ A不知道为啥自动变成B类了。而且VBUS一直是5V,正常的啊,可是驱动也无法修复。。$ P2 p1 h- d9 l! l; d: a. k$ o
        不知道亲们有没有遇到类似的情况,是怎么解决的?8 P1 g5 w/ r( w% _

本帖子中包含更多资源

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

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

3

主题

852

帖子

3538

积分

创龙

Rank: 8Rank: 8

积分
3538
沙发
发表于 2016-12-1 22:01:12 | 只看该作者
如果4块正常的话,那驱动应该是没问题的,多半是硬件的问题
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2025-4-30 10:21 , Processed in 0.045112 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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