|
小弟最近做了5块板子,用的创龙的核心板,其中4块USB2.0 host都没有问题,只有一块老是周期性报如下错误:+ P. R! y: a( i* z
hub 2-0:1.0: over-current condition on port 1( S- D, i7 x& _) M- d$ s
da8xx_musb_interrupt 538: VBUS error workaround (delay coming)2 s7 f0 ]2 b0 r& U m/ J
我的电路图如附件,我用示波器测量过了,开始USB0_DRVVBUS脚起始是低电平,开机瞬间,它会变成高电平,USB0_VBUS也会( ]7 e" n/ K. |7 t m" u+ o
随着上升至5V,开机瞬间,USB0_VBUS并没有出现跌落至低于4.4V,从电路上没有发现问题,然后开始追踪linux3.3 USB驱动代码,0 ~% l- {" }/ O% x9 E# o/ }5 D
发现,在da8xx_musb_interrupt函数中,有如下代码:
+ p- P2 }3 Q% @ j" @; C: y! B) ]if (status & (DA8XX_INTR_DRVVBUS << DA8XX_INTR_USB_SHIFT)) {% h) X e# d/ T! l# H! b" t2 f
int drvvbus = musb_readl(reg_base, DA8XX_USB_STAT_REG);
! ~) _2 N7 }% G void __iomem *mregs = musb->mregs;; Z7 K! S4 r# E0 P
u8 devctl = musb_readb(mregs, MUSB_DEVCTL);0 ]! p! Q; a; n, P/ ?' R
int err;
$ ^$ ~; n) v# [" Y3 C* g5 S/ v3 C6 q7 u: E/ N
err = is_host_enabled(musb) && (musb->int_usb &
! j1 h1 ?8 }- @7 y% x% M6 `: O MUSB_INTR_VBUSERROR);
' A" ~. f4 v3 e# \' f' e6 V* } if (err) {
+ q/ t* c4 v& e2 u2 \3 l3 b! B /*
s* G$ y% @! _/ Q9 ]+ y% u5 m% s * The Mentor core doesn't debounce VBUS as needed, S V$ d% D: N
* 。。。) {6 F7 k; u3 [
*/
, L* p5 Q/ S4 N K7 V5 d. Q+ P musb->int_usb &= ~MUSB_INTR_VBUSERROR;4 {% l# w* B. z/ t' J; t% X1 p
musb->xceiv->state = OTG_STATE_A_WAIT_VFALL;
# H) j M6 d1 {+ e* F& e mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
4 L% u; P+ w" y( t WARNING("VBUS error workaround (delay coming)\n");
1 l: v3 Y. ?' F/ V( ` }
( D0 S$ b6 Y% n* |, [4 C T8 E( o! m
. R* J0 J% U! ]# |7 k& g8 c一直发生MUSB_INTR_VBUSERROR错误,然后会启动定时器,周期调用otg_timer函数,& Z) V$ Y" q5 F' y/ E
跳入如下分支:
7 ?# R. C$ ^% q/ f0 v' ~# ndevctl = musb_readb(mregs, MUSB_DEVCTL);( W" L' h, \) M( A% \
。。。
9 Z7 G. F2 P$ ]; Scase OTG_STATE_A_WAIT_VFALL:* m) G' X4 L; {0 `0 c4 l' J
/*5 ^6 t. M' d- l! q; n- T4 t
* Wait till VBUS falls below SessionEnd (~0.2 V); the 1.39 {1 t9 ^& q3 n# ~$ [. P3 Q4 j
* RTL seems to mis-handle session "start" otherwise (or in
: Q/ k" `. V( z6 S5 I2 y! A * our case "recover"), in routine "VBUS was valid by the time
4 g! x$ u" _0 y$ R- i# Y * VBUSERR got reported during enumeration" cases.
7 L2 l/ i& @; c: P4 |( ` */4 Z9 L& `5 T& K% V; X F6 u% \
if (devctl & MUSB_DEVCTL_VBUS) {
5 x9 I: l3 A! \1 e mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
2 u8 L- @$ Q# X7 A break;
) {) d8 I2 {% \ Z. O }4 U3 w7 M+ d: }3 e( N5 q; E5 W5 U
musb->xceiv->state = OTG_STATE_A_WAIT_VRISE;
6 Q) [' M7 m S) Q musb_writel(musb->ctrl_base, DA8XX_USB_INTR_SRC_SET_REG,/ T# U* F; D5 a1 Y
MUSB_INTR_VBUSERROR << DA8XX_INTR_USB_SHIFT);8 p2 |6 u; s* Z) F* h5 P
break;# F+ N' C; x2 D0 V7 h
5 G; P0 z" s% C: S其中,devctl是设备控制寄存器,我打印了它的直,是0x80, 也就是位7是1,代表着是B device,,明明是A类,% R3 N$ z9 y* A
不知道为啥自动变成B类了。而且VBUS一直是5V,正常的啊,可是驱动也无法修复。。
! ]( t" c, S; l" v 不知道亲们有没有遇到类似的情况,是怎么解决的?
, X6 g: v7 f2 u; _3 L; A7 i1 M$ c |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
|