1. 23 12月, 2015 8 次提交
    • Y
      usb: dwc2: reduce dwc2 driver probe time · 20bde643
      Yunzhi Li 提交于
      I found that the probe function of dwc2 driver takes much time
      when kernel boot up. There are many long delays in the probe
      function these take almost 1 second.
      
      This patch trying to reduce unnecessary delay time.
      
      In dwc2_core_reset() I see it use two at least 20ms delays to
      wait AHB idle and core soft reset, but dwc2 data book said that
      dwc2 core soft reset and AHB idle just need a few clocks (I think
      it refers to AHB clock, and AHB clock run at 150MHz in my RK3288
      board), so 20ms is too long, delay 1us for wait AHB idle and soft
      reset is enough.
      
      And in dwc2_get_hwparams() it takes 150ms to wait ForceHostMode
      and ForceDeviceMode valid but in data book it said software must
      wait at least 25ms before the change to take effect, so I reduce
      this time to 25ms~50ms. By the way, is there any state bit show
      that the force mode take effect ? Could we poll curmod bit for
      figuring out if the change take effect ?
      
      It seems that usleep_range() at boot time will pick the longest
      value in the range. In dwc2_core_reset() there is a very long
      delay takes 200ms, and this function run twice when probe, could
      any one tell me is this delay time resonable ?
      
      I have tried this patch in my RK3288-evb board. It works well.
      Signed-off-by: NYunzhi Li <lyz@rock-chips.com>
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      20bde643
    • D
      usb: dwc2: Speed dwc2_get_hwparams() on some host-only ports · f6194731
      Douglas Anderson 提交于
      On some host-only DWC2 ports (like the one in rk3288) when we set
      GUSBCFG_FORCEHOSTMODE in GUSBCFG and then read back, we don't see the
      bit set.  Presumably that's because the port is always forced to HOST
      mode so there's no reason to implement these status bits.
      
      Since we know dwc2_core_reset() is always called before
      dwc2_get_hwparams() and we know dwc2_core_reset() should have set
      GUSBCFG_FORCEHOSTMODE whenever hsotg->dr_mode == USB_DR_MODE_HOST, we
      can just check hsotg->dr_mode to decide that we can skip the delays in
      dwc2_get_hwparams().
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      f6194731
    • D
      usb: dwc2: Avoid double-reset at boot time · 0fe239bc
      Douglas Anderson 提交于
      In (usb: dwc2: reset dwc2 core before dwc2_get_hwparams()) we added an
      extra reset to the probe path for the dwc2 USB controllers.  This
      allowed proper detection of parameters even if the firmware had already
      used the USB part.
      
      Unfortunately, this extra reset is quite slow and is affecting boot
      speed.  We can avoid the double-reset by skipping the extra reset that
      would happen just after the one we added.  Logic that explains why this
      is safe:
      
      * As of the CL mentioned above, we now always call dwc2_core_reset() in
        dwc2_driver_probe() before dwc2_hcd_init().
      
      * The only caller of dwc2_hcd_init() is dwc2_driver_probe(), so we're
        guaranteed that dwc2_core_reset() was called before dwc2_hdc_init().
      
      * dwc2_hdc_init() is the only caller that passes an irq other than -1 to
        dwc2_core_init().  Thus if dwc2_core_init() is called with an irq
        other than -1 we're guaranteed that dwc2_core_reset was called before
        dwc2_core_init().
      
      ...this allows us to remove the dwc2_core_reset() in dwc2_core_init() if
      irq is not < 0.
      
      Note that since "irq" wasn't used in the function dwc2_core_init()
      anyway and since select_phy was always set at exactly the same times we
      could avoid the reset, we remove "irq" and rename "select_phy" to
      "initial_setup" and adjust the callers accordingly.
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      0fe239bc
    • Y
      usb: dwc2: reset dwc2 core before dwc2_get_hwparams() · cebfdbf3
      Yunzhi Li 提交于
      We initiate dwc2 usb controller in BIOS, dwc2_core_reset() should
      be called before dwc2_get_hwparams() to reset core registers to
      default value. Without this the FIFO setting might be incorrect
      because calculating FIFO size need power-on value of
      GRXFSIZ/GNPTXFSIZ/HPTXFSIZ registers.
      
      This patch could avoid warnning massage like in rk3288 platform:
      [    2.074764] dwc2 ff580000.usb: 256 invalid for
      host_perio_tx_fifo_size. Check HW configuration.
      Signed-off-by: NYunzhi Li <lyz@rock-chips.com>
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      cebfdbf3
    • D
      usb: dwc2: Restore GUSBCFG in dwc2_get_hwparams() · 99182467
      Douglas Anderson 提交于
      Previously dwc2_get_hwparams() was changing GUSBCFG and not putting it
      back the way it was (specifically it set and cleared FORCEHOSTMODE).
      Since we want to move dwc2_core_reset() _before_ dwc2_get_hwparams() we
      should make sure dwc2_get_hwparams() isn't messing with things in a
      permanent way.
      
      Since we're now looking at GUSBCFG, it's obvious that we shouldn't need
      all the extra delays if FORCEHOSTMODE was already set.  This will avoid
      some delays for any ports that have forced host mode.
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      99182467
    • G
      usb: dwc2: gadget: don't overwrite DCTL register on NAKEFF interrupts · 3be99cd0
      Gregory Herrero 提交于
      When receiving GINTSTS_GINNAKEFF or GINTSTS_GOUTNAKEFF interrupt,
      DCTL will be overwritten with DCTL_CGOUTNAK or DCTL_CGNPINNAK values.
      Instead of overwriting it, write only needed bits.
      
      It could cause an issue if GINTSTS_GINNAKEFF or GINTSTS_GOUTNAKEFF
      interrupt is received after dwc2 disabled pullup by writing
      DCTL_SFTDISCON bit.
      Pullup will then be re-enabled whereas it should not.
      Acked-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NGregory Herrero <gregory.herrero@intel.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      3be99cd0
    • D
      usb: dwc2: fix transfer stop programming for out endpoint · 0676c7e7
      Du, Changbin 提交于
      To stop an out endpoint, software should set sets the Global OUT NAK,
      but not the Global Non-periodic IN NAK. This driver bug leads the out-ep
      failed be in disabled state with below error.
      
      dwc2_hsotg_ep_stop_xfr: timeout DOEPCTL.EPDisable
      Acked-by: NJohn Youn <johnyoun@synopsys.com>
      Signed-off-by: NDu, Changbin <changbin.du@intel.com>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      0676c7e7
    • B
      usb: gadget: Add the console support for usb-to-serial port · a5beaaf3
      Baolin Wang 提交于
      It dose not work when we want to use the usb-to-serial port based
      on one usb gadget as a console. Thus this patch adds the console
      initialization to support this request.
      
      To avoid the re-entrance when transferring data with usb endpoint,
      it introduces a kthread to do the IO transmission.
      Signed-off-by: NBaolin Wang <baolin.wang@linaro.org>
      Signed-off-by: NFelipe Balbi <balbi@ti.com>
      a5beaaf3
  2. 17 12月, 2015 21 次提交
  3. 15 12月, 2015 11 次提交
反馈
建议
客服 返回
顶部