]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
musb_hdrc: Improve tusb host state handling for a_idle
authorTony Lindgren <tony@atomide.com>
Fri, 21 Sep 2007 00:37:14 +0000 (17:37 -0700)
committerTony Lindgren <tony@atomide.com>
Thu, 11 Oct 2007 21:31:34 +0000 (14:31 -0700)
This patch makes the changes happen based on vbus change.
This also seems to make enumeration work better.

Signed-off-by: Tony Lindgren <tony@atomide.com>
drivers/usb/musb/tusb6010.c

index b3e745d98d3fcf44ac9d9c2296afdcc1e87ee3cd..16eaa4825c3643ea5631ec15eadf0e956b65f778 100644 (file)
@@ -422,18 +422,15 @@ static void musb_do_idle(unsigned long _musb)
 
        switch (musb->xceiv.state) {
        case OTG_STATE_A_WAIT_BCON:
-       case OTG_STATE_A_WAIT_VRISE:
-       case OTG_STATE_A_IDLE:
                if ((musb->a_wait_bcon != 0)
                        && (musb->idle_timeout == 0
                                || time_after(jiffies, musb->idle_timeout))) {
                        DBG(4, "Nothing connected %s, turning off VBUS\n",
                                        otg_state_string(musb));
-                       tusb_source_power(musb, 0);
-                       musb->xceiv.state = OTG_STATE_A_WAIT_VFALL;
-                       musb->is_active = 0;
                }
-               break;
+               /* FALLTHROUGH */
+       case OTG_STATE_A_IDLE:
+               tusb_source_power(musb, 0);
        default:
                break;
        }
@@ -533,7 +530,6 @@ static void tusb_source_power(struct musb *musb, int is_on)
        if (is_on) {
                if (musb->set_clock)
                        musb->set_clock(musb->clock, 1);
-               musb->is_active = 1;
                timer = OTG_TIMER_MS(OTG_TIME_A_WAIT_VRISE);
                musb->xceiv.default_a = 1;
                musb->xceiv.state = OTG_STATE_A_WAIT_VRISE;
@@ -550,11 +546,13 @@ static void tusb_source_power(struct musb *musb, int is_on)
                otg_stat = musb_readl(tbase, TUSB_DEV_OTG_STAT);
                if (!(otg_stat & TUSB_DEV_OTG_STAT_ID_STATUS)) {
                        switch (musb->xceiv.state) {
-                       case OTG_STATE_A_WAIT_VFALL:
-                               break;
                        case OTG_STATE_A_WAIT_VRISE:
+                       case OTG_STATE_A_WAIT_BCON:
                                musb->xceiv.state = OTG_STATE_A_WAIT_VFALL;
                                break;
+                       case OTG_STATE_A_WAIT_VFALL:
+                               musb->xceiv.state = OTG_STATE_A_IDLE;
+                               break;
                        default:
                                musb->xceiv.state = OTG_STATE_A_IDLE;
                        }
@@ -798,6 +796,7 @@ tusb_otg_ints(struct musb *musb, u32 int_src, void __iomem *tbase)
                        break;
                }
        }
+       schedule_work(&musb->irq_work);
 
        return idle_timeout;
 }