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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

关于USB的问题

[复制链接]

13

主题

41

帖子

1181

积分

金牌会员

Rank: 6Rank: 6

积分
1181
QQ
跳转到指定楼层
楼主
发表于 2016-12-1 09:25:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
     小弟最近做了5块板子,用的创龙的核心板,其中4块USB2.0 host都没有问题,只有一块老是周期性报如下错误:
3 @+ N& i" |$ I7 Ahub 2-0:1.0: over-current condition on port 1
- P" t8 o2 m4 E- k! x7 V7 nda8xx_musb_interrupt 538: VBUS error workaround (delay coming)* k  z: u+ f+ L8 g0 R0 P+ C
我的电路图如附件,我用示波器测量过了,开始USB0_DRVVBUS脚起始是低电平,开机瞬间,它会变成高电平,USB0_VBUS也会
2 e( @$ a+ S5 r- b; Y9 E& c随着上升至5V,开机瞬间,USB0_VBUS并没有出现跌落至低于4.4V,从电路上没有发现问题,然后开始追踪linux3.3 USB驱动代码,
0 C# p6 C5 g2 q; Q发现,在da8xx_musb_interrupt函数中,有如下代码:2 q( O; ?8 j( r* r: @5 N
if (status & (DA8XX_INTR_DRVVBUS << DA8XX_INTR_USB_SHIFT)) {
" K' K5 R& D/ y6 ]" D* T) x                int drvvbus = musb_readl(reg_base, DA8XX_USB_STAT_REG);
6 R$ @" J" I* y% |$ Z4 u& [                void __iomem *mregs = musb->mregs;
/ \2 `5 j; I/ q  R  c- l3 T' L' d                u8 devctl = musb_readb(mregs, MUSB_DEVCTL);- V# Z* Z  G0 x
                int err;
* z0 `$ e: X; Q
: o# k7 y' p5 d3 Z                err = is_host_enabled(musb) && (musb->int_usb &1 [2 Q* [- D2 ^5 l" M- F4 V
                                                MUSB_INTR_VBUSERROR);- D! H. E* m$ ^
                if (err) {+ o, \1 [, b  W  i9 q% Y
                        /*
8 H$ W" p" Q7 U+ y1 C. u9 }                         * The Mentor core doesn't debounce VBUS as needed
3 Q0 a2 R" a* O* ^                         * 。。。
1 S3 Z( x# g+ q# ^1 J- z5 q                         */
6 I1 a* u& P: Y- E+ ?/ l  c                        musb->int_usb &= ~MUSB_INTR_VBUSERROR;4 P9 m+ f$ Q9 s4 y, u) Y* @5 m
                        musb->xceiv->state = OTG_STATE_A_WAIT_VFALL;# O! C7 e5 E: N6 f
                        mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
# d7 S# C- g7 r                        WARNING("VBUS error workaround (delay coming)\n");
1 W) t; S$ b1 ]                }
$ L% V" o/ R2 Y# j2 x, m. H' i0 E' \) k) ^+ A9 o) S& l
一直发生MUSB_INTR_VBUSERROR错误,然后会启动定时器,周期调用otg_timer函数,
+ i4 X! w9 F3 F) X4 h0 F跳入如下分支:
: e  X' `- }! y' |, a; u" u% X9 Xdevctl = musb_readb(mregs, MUSB_DEVCTL);7 N% a$ X! Q( Z8 l7 D, e
。。。
- ?3 E! _3 b. [/ `: Y+ h9 p. @+ J2 ncase OTG_STATE_A_WAIT_VFALL:) v# W$ z5 ]. L
                /*
3 n4 A: f+ E: B                 * Wait till VBUS falls below SessionEnd (~0.2 V); the 1.3
/ R. \$ F! B( x4 L/ s6 i                 * RTL seems to mis-handle session "start" otherwise (or in
# s$ g3 g- ]# p9 h% ~0 D9 T                 * our case "recover"), in routine "VBUS was valid by the time9 U% R$ \" V& O) y; @& @
                 * VBUSERR got reported during enumeration" cases.7 g3 B- k0 x4 m$ M3 X% n& X
                 */- J& E- N4 d  v5 I1 W
                if (devctl & MUSB_DEVCTL_VBUS) {
- v7 H4 A! ^7 j2 ^" t' L; R                        mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);/ H2 i/ k/ F) q/ Z& f
                        break;/ g0 G% Q1 E- I6 ]5 @0 S1 t
                }3 ^6 J" z" g) _" o/ ?( q( q
                musb->xceiv->state = OTG_STATE_A_WAIT_VRISE;9 M2 Z# R! x$ O0 y$ I3 }0 I
                musb_writel(musb->ctrl_base, DA8XX_USB_INTR_SRC_SET_REG,1 }+ Q# X3 ]2 m
                            MUSB_INTR_VBUSERROR << DA8XX_INTR_USB_SHIFT);5 b7 y4 ]& P( y/ l  c7 N5 `
                break;; P3 F. e, K6 M* n' F1 W+ ]  E

9 S2 Z7 A: G; X2 F# o其中,devctl是设备控制寄存器,我打印了它的直,是0x80, 也就是位7是1,代表着是B device,,明明是A类,
, W/ d4 Z( Z" B不知道为啥自动变成B类了。而且VBUS一直是5V,正常的啊,可是驱动也无法修复。。
8 t" i9 ]3 F9 t$ ~2 z0 r        不知道亲们有没有遇到类似的情况,是怎么解决的?
6 Z7 C4 m9 c  Z8 ?, O3 b$ x

本帖子中包含更多资源

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

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

使用道具 举报

3

主题

852

帖子

3538

积分

创龙

Rank: 8Rank: 8

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-21 09:20 , Processed in 0.040127 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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