|
|
小弟最近做了5块板子,用的创龙的核心板,其中4块USB2.0 host都没有问题,只有一块老是周期性报如下错误:
! S( k* S7 c$ v2 L: Chub 2-0:1.0: over-current condition on port 1
+ @! L. S* S$ g$ \* ^3 bda8xx_musb_interrupt 538: VBUS error workaround (delay coming)5 }, L; P9 Q: W' j' D8 S/ O
我的电路图如附件,我用示波器测量过了,开始USB0_DRVVBUS脚起始是低电平,开机瞬间,它会变成高电平,USB0_VBUS也会1 n0 T5 _( C' T6 m
随着上升至5V,开机瞬间,USB0_VBUS并没有出现跌落至低于4.4V,从电路上没有发现问题,然后开始追踪linux3.3 USB驱动代码,
4 P/ `3 \' A; P9 }发现,在da8xx_musb_interrupt函数中,有如下代码:
4 {1 r$ [ b/ c, z2 G) `if (status & (DA8XX_INTR_DRVVBUS << DA8XX_INTR_USB_SHIFT)) {. T* N& K! e# a. Z+ M
int drvvbus = musb_readl(reg_base, DA8XX_USB_STAT_REG);
. L, Q2 L% k2 g6 y& [* V& u3 K0 u void __iomem *mregs = musb->mregs;
8 I* I2 |( A4 D- W; b u8 devctl = musb_readb(mregs, MUSB_DEVCTL);
/ ~8 e% d. M7 U3 C1 x) d# V- G int err;
7 J! O# p, ~9 X# z- c' \$ h* ]9 Y% [$ W7 A/ P
err = is_host_enabled(musb) && (musb->int_usb &
5 U+ W( _: X4 e4 M+ U+ X M6 t, e1 I MUSB_INTR_VBUSERROR);
' {1 r1 E1 |$ Q. e if (err) { s. m1 v( y R5 A0 Y) c
/*6 q1 ~1 g8 t: Q1 z
* The Mentor core doesn't debounce VBUS as needed: H2 l: v$ f5 F
* 。。。; P5 N# ?$ J+ j2 ?8 \) z
*/! U7 x8 S; A) d' I+ \$ A# R
musb->int_usb &= ~MUSB_INTR_VBUSERROR;8 E( G! N$ Q8 D/ V1 g4 [* [5 b
musb->xceiv->state = OTG_STATE_A_WAIT_VFALL;
) ~ l7 z4 E: S0 i: j: E mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
7 q* Z0 O+ |% ]8 d/ s7 M. F WARNING("VBUS error workaround (delay coming)\n");( ?9 f7 |, p5 p# F# z' Y ]* ]
}( j/ D J" T+ @( p) h
9 f. r0 b. X0 |, S
一直发生MUSB_INTR_VBUSERROR错误,然后会启动定时器,周期调用otg_timer函数,8 @+ T( Z# M* M" H$ e$ k
跳入如下分支:
3 V% F4 K3 @" W4 l1 E$ wdevctl = musb_readb(mregs, MUSB_DEVCTL);/ c8 y9 R0 [% l" E/ }* S; k' e
。。。
4 R: f* M4 R' b; b) Kcase OTG_STATE_A_WAIT_VFALL:
8 _, x. A ]# g* M$ v# @ /*. l3 N4 Q0 T3 D7 i: p/ X
* Wait till VBUS falls below SessionEnd (~0.2 V); the 1.3: E$ f; n5 G5 N. _/ }: X. K
* RTL seems to mis-handle session "start" otherwise (or in
0 D( U6 |; n$ C * our case "recover"), in routine "VBUS was valid by the time
/ ^/ d1 @+ y/ t, K * VBUSERR got reported during enumeration" cases.
i6 t! u9 j. x# E6 Q0 j0 ? */% M+ [" g4 b/ `: X
if (devctl & MUSB_DEVCTL_VBUS) {
8 O, `9 ^ D4 s! s& K mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);' G6 V3 I2 i, u$ G) d3 T2 N" q; E/ R7 |
break;$ q$ @& o& }; [( b0 V
}
4 W9 L2 X0 i% E% f9 _ musb->xceiv->state = OTG_STATE_A_WAIT_VRISE;
4 }) V' A: Y8 D% f7 h" z musb_writel(musb->ctrl_base, DA8XX_USB_INTR_SRC_SET_REG,
5 y0 O2 f* m. [ MUSB_INTR_VBUSERROR << DA8XX_INTR_USB_SHIFT);0 U: D) i2 ^& |% M8 v7 I! I% g
break;
8 i) V$ H- j8 i' e4 g; A7 |/ v9 M ^+ P4 H9 r5 E6 J
其中,devctl是设备控制寄存器,我打印了它的直,是0x80, 也就是位7是1,代表着是B device,,明明是A类,
* G \: [1 `+ B不知道为啥自动变成B类了。而且VBUS一直是5V,正常的啊,可是驱动也无法修复。。( c+ l1 L- g7 M* t8 b# a
不知道亲们有没有遇到类似的情况,是怎么解决的?
/ f7 Q; c7 L) O; \/ U |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
|