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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

关于USB的问题

[复制链接]

13

主题

41

帖子

1181

积分

金牌会员

Rank: 6Rank: 6

积分
1181
QQ
跳转到指定楼层
楼主
发表于 2016-12-1 09:25:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
     小弟最近做了5块板子,用的创龙的核心板,其中4块USB2.0 host都没有问题,只有一块老是周期性报如下错误:
& k6 g5 O" p$ e; r' Y9 F8 J* A  Rhub 2-0:1.0: over-current condition on port 1
# K# g  J1 @6 N. A, ~% Q8 Cda8xx_musb_interrupt 538: VBUS error workaround (delay coming)
* c3 {  Z+ s; u- N. g. B我的电路图如附件,我用示波器测量过了,开始USB0_DRVVBUS脚起始是低电平,开机瞬间,它会变成高电平,USB0_VBUS也会! }4 Z) L0 a( g! t9 z- {
随着上升至5V,开机瞬间,USB0_VBUS并没有出现跌落至低于4.4V,从电路上没有发现问题,然后开始追踪linux3.3 USB驱动代码,( v2 H; G# N- V3 R& y
发现,在da8xx_musb_interrupt函数中,有如下代码:
) f0 w- D& ~- j, h9 V  |" Z  Hif (status & (DA8XX_INTR_DRVVBUS << DA8XX_INTR_USB_SHIFT)) {4 F; C2 i% I3 [$ b
                int drvvbus = musb_readl(reg_base, DA8XX_USB_STAT_REG);
* Y$ F' M6 s- `                void __iomem *mregs = musb->mregs;1 S) W" i$ G7 E0 X# B
                u8 devctl = musb_readb(mregs, MUSB_DEVCTL);
9 N7 _4 v! S  Y1 ^                int err;8 q  I4 m( A( ?* X

4 m+ K  i' o# D* x4 S                err = is_host_enabled(musb) && (musb->int_usb &
' n8 t" X. m* G% q                                                MUSB_INTR_VBUSERROR);
/ X: l% C$ d* c3 N$ V, [                if (err) {! Q7 S1 V! |9 W. Q
                        /*
" E; Y5 `" B, k5 j* F) n% X: l8 q8 C                         * The Mentor core doesn't debounce VBUS as needed! P0 X3 ^, D- G) P. i) k
                         * 。。。; j9 J* f1 Y9 @! g
                         *// j6 R$ q& S6 v1 d4 I
                        musb->int_usb &= ~MUSB_INTR_VBUSERROR;  l( q0 W% U/ q
                        musb->xceiv->state = OTG_STATE_A_WAIT_VFALL;  e$ Y* l! A7 p4 b
                        mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);/ ^2 c/ w6 W9 S% L
                        WARNING("VBUS error workaround (delay coming)\n");
5 }  g0 [) E3 f0 P9 g+ ~                }
( m$ E% {5 l0 s& c
5 v2 H: U8 q. i/ u- p. E* c一直发生MUSB_INTR_VBUSERROR错误,然后会启动定时器,周期调用otg_timer函数,
4 w# q; w$ ?$ Y3 f跳入如下分支:8 d, Q2 s; r# M% \; Y1 y
devctl = musb_readb(mregs, MUSB_DEVCTL);
1 E/ R( C3 d4 a+ ]# R. @. D& z0 R。。。- D+ `* j# n, S/ n
case OTG_STATE_A_WAIT_VFALL:
1 g5 g9 H. N4 e                /*! S( v4 i( I) y- f
                 * Wait till VBUS falls below SessionEnd (~0.2 V); the 1.3
7 t  B1 O1 [# G! k. Y                 * RTL seems to mis-handle session "start" otherwise (or in
- K# Q: f$ L" l8 G: ]- T/ w                 * our case "recover"), in routine "VBUS was valid by the time& c! k7 k+ z4 x$ C) l/ W+ ]
                 * VBUSERR got reported during enumeration" cases.
  u( M; s+ M6 c                 */
3 @# D, C, z! k% u9 w                if (devctl & MUSB_DEVCTL_VBUS) {
2 u3 G/ s8 B0 y5 n4 }7 m" U% F                        mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
1 b# i  Z' S4 c- p: e/ R                        break;2 z) B' e  p& }- r) D* ?
                }
8 ~7 X# ?6 v& ^" G# m                musb->xceiv->state = OTG_STATE_A_WAIT_VRISE;& V) O6 A: b# f/ M3 }
                musb_writel(musb->ctrl_base, DA8XX_USB_INTR_SRC_SET_REG,
$ \5 U# v8 n0 P0 j5 f  Y                            MUSB_INTR_VBUSERROR << DA8XX_INTR_USB_SHIFT);6 e0 o; S1 X9 ?, N( G: h: R
                break;
) ?, Z" d2 ]" G5 `4 k+ [0 h) x, q( f( x; ~- R7 y
其中,devctl是设备控制寄存器,我打印了它的直,是0x80, 也就是位7是1,代表着是B device,,明明是A类,
, n& k$ U$ M) x: ?5 m不知道为啥自动变成B类了。而且VBUS一直是5V,正常的啊,可是驱动也无法修复。。
0 [% g  Y) V" m4 Q& n        不知道亲们有没有遇到类似的情况,是怎么解决的?: @; z" h' \# 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-7-9 18:57 , Processed in 0.039956 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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