|
|
小弟最近做了5块板子,用的创龙的核心板,其中4块USB2.0 host都没有问题,只有一块老是周期性报如下错误:
: U5 H. [( |) Z& G& R8 Phub 2-0:1.0: over-current condition on port 1
9 O* [5 q1 m/ h+ q- a% B: K! Rda8xx_musb_interrupt 538: VBUS error workaround (delay coming)& z( K" t) m# T
我的电路图如附件,我用示波器测量过了,开始USB0_DRVVBUS脚起始是低电平,开机瞬间,它会变成高电平,USB0_VBUS也会! Y$ A0 B/ r0 a8 I8 v a( x4 H, n9 q
随着上升至5V,开机瞬间,USB0_VBUS并没有出现跌落至低于4.4V,从电路上没有发现问题,然后开始追踪linux3.3 USB驱动代码,( @& T% f; @/ w, K
发现,在da8xx_musb_interrupt函数中,有如下代码:
& e# ^# {2 V# V3 {" nif (status & (DA8XX_INTR_DRVVBUS << DA8XX_INTR_USB_SHIFT)) {
. ~( ~& H# I3 w. A int drvvbus = musb_readl(reg_base, DA8XX_USB_STAT_REG);
( x" g2 D, m2 l% q& Q void __iomem *mregs = musb->mregs;
" L+ t2 F. @% l% n u8 devctl = musb_readb(mregs, MUSB_DEVCTL);
9 R; x) o+ Z+ N0 ^4 E- G7 N7 K int err;
! ^; G& x9 K* e* H8 y+ l3 `5 K$ \9 k, \ n% G+ H* ~! F
err = is_host_enabled(musb) && (musb->int_usb &
+ w4 H3 y" |9 z3 B MUSB_INTR_VBUSERROR);
6 X3 D/ r" J" x b3 k6 ] if (err) {
) c' w! N1 |# w, ^9 M# v0 q- v /*" D' B8 I$ M# q) r3 B3 `
* The Mentor core doesn't debounce VBUS as needed" @4 e0 P7 u4 }, T. ]
* 。。。. n+ g( I4 u! G3 A
*/
% z! V' } j- L* e2 k, d% D$ z6 @ musb->int_usb &= ~MUSB_INTR_VBUSERROR;3 U4 m& g4 R: j8 j
musb->xceiv->state = OTG_STATE_A_WAIT_VFALL;
0 `3 f8 e- i, W* [$ m3 f mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
: R* c6 M# l2 i& J& @) R WARNING("VBUS error workaround (delay coming)\n");6 T6 j# L1 X( O* v
}% c4 m3 r5 d" ?7 C' C- Q( \) C
5 i- F5 o! l- u/ C9 ^. y7 W
一直发生MUSB_INTR_VBUSERROR错误,然后会启动定时器,周期调用otg_timer函数,' C% u4 l/ H' L* f/ N. ]
跳入如下分支:# k% f R+ ]' [ E: o6 J/ _1 j1 o
devctl = musb_readb(mregs, MUSB_DEVCTL);
1 D! d5 O0 ^8 V! U3 r* |" q6 R。。。* M' v( K4 w0 @$ v4 u
case OTG_STATE_A_WAIT_VFALL:6 G( @, y4 v( q7 n: f; q6 F9 w' B
/*/ y' v. a1 E1 p( N% s
* Wait till VBUS falls below SessionEnd (~0.2 V); the 1.3
0 j3 D' D0 }4 \" X * RTL seems to mis-handle session "start" otherwise (or in
; E( q: }9 X2 O * our case "recover"), in routine "VBUS was valid by the time# x) h% D: j1 h( I
* VBUSERR got reported during enumeration" cases.* T9 B( X7 A5 v d
*/. y7 p; G8 f1 \5 g% Q9 M
if (devctl & MUSB_DEVCTL_VBUS) {
7 a$ j: j c6 }4 {3 x% M/ [ mod_timer(&otg_workaround, jiffies + POLL_SECONDS * HZ);
- z# I5 M" f, T/ `2 } break;) |: v) {7 p* ?9 ~( q
}
( g- V2 w. w9 X6 R) K, S$ u- u musb->xceiv->state = OTG_STATE_A_WAIT_VRISE;8 K8 c+ p+ ?( p
musb_writel(musb->ctrl_base, DA8XX_USB_INTR_SRC_SET_REG,
6 R5 C$ r% G+ K+ U MUSB_INTR_VBUSERROR << DA8XX_INTR_USB_SHIFT);
" ^' q5 h4 D; }, s$ k break; i$ D3 {: x3 t. t% U7 R# |1 _
* D4 I/ v* n y8 c其中,devctl是设备控制寄存器,我打印了它的直,是0x80, 也就是位7是1,代表着是B device,,明明是A类,
+ _5 F6 `1 m' _- P) r( L; M不知道为啥自动变成B类了。而且VBUS一直是5V,正常的啊,可是驱动也无法修复。。
6 R( U- V( l; g% j1 @ 不知道亲们有没有遇到类似的情况,是怎么解决的?
+ n& m9 f$ I' u5 U7 z |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
|