An error occurred fetching the project authors.
  1. 16 Jun, 2009 3 commits
    • David Brownell's avatar
      musb: otg timer cleanup · f7f9d63e
      David Brownell authored
      Minor cleanup of OTG timer handling:
          * unify decls for OTG time constants, in the core header
          * set up and use that timer in a more normal way
          * move to the driver struct, so it's usable outside core
      
      And tighten use and setup of T(a_wait_bcon) so that if it's used,
      it's always valid.  (If that timer expires, the A-device will
      stop powering VBUS.  For non-OTG systems, that will be a surprise.)
      No behavioral changes, other than more consistency when applying
      that core HNP timeout.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      f7f9d63e
    • David Brownell's avatar
      musb: proper hookup to transceiver drivers · 84e250ff
      David Brownell authored
      Let the otg_transceiver in MUSB be managed by an external driver;
      don't assume it's integrated.  OMAP3 chips need it to be external,
      and there may be ways to interact with the transceiver which add
      functionality to the system.
      
      Platform init code is responsible for setting up the transeciver,
      probably using the NOP transceiver for integrated transceivers.
      External ones will use whatever the board init code provided,
      such as twl4030 or something more hands-off.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      84e250ff
    • Sergei Shtylyov's avatar
      musb_gadget: fix unhandled endpoint 0 IRQs · a5073b52
      Sergei Shtylyov authored
      The gadget EP0 code routinely ignores an interrupt at end of
      the data phase because of musb_g_ep0_giveback() resetting the
      state machine to "idle, waiting for SETUP" phase prematurely.
      
      The driver also prematurely leaves the status phase on
      receiving the SetupEnd interrupt.
      
      As there were still unhandled endpoint 0 interrupts happening
      from time to time after fixing these issues, there turned to
      be yet another culprit: two distinct gadget states collapsed
      into one.
      
      The (missing) state that comes after STATUS IN/OUT states was
      typically indiscernible from them since the corresponding
      interrupts tend to happen within too little period of time
      (due to only a zero-length status packet in between) and so
      they got coalesced; yet this state is not the same as the next
      one which is associated with the reception of a SETUP packet.
      
      Adding this extra state seems to have fixed the rest of the
      unhandled interrupts that generic_interrupt() and
      davinci_interrupt() hid by faking their result and only
      emitting a debug message -- so, stop doing that.
      Signed-off-by: default avatarSergei Shtylyov <sshtylyov@ru.mvista.com>
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
      a5073b52
  2. 24 Mar, 2009 2 commits
  3. 07 Jan, 2009 3 commits
  4. 21 Aug, 2008 1 commit
  5. 14 Aug, 2008 2 commits