1. 05 10月, 2017 10 次提交
    • A
      usb: xhci: reduce device initiated resume time variance. · 0914ea66
      Anshuman Gupta 提交于
      This patch will improve the variable auto-resume latency of an usb-port.
      
      The attempt to sync the start of root hub polling with resume time
      signaling finish was ruined by a later request to start immediate
      root hub polling.
      
      When xhci gets a port status change event interrupt due to PORT_PLC
      (port link state transition), linux Host controller driver drives the
      resume signalling on the bus for the amount of time defined by
      USB_REUME_TIMEOUT(40ms) macro.
      
      This 40ms delay for resume signalling is in acceptable limit, but
      it get worse when xhci goes for polling mode in order to detect other
      events on its ports and modify rh_timer timer with a variable time out of
      1ms to (HZ/4)ms.
      
      drivers/usb/core/hcd.c line 799
      mod_timer (&hcd->rh_timer, (jiffies/(HZ/4) + 1) * (HZ/4)).
      
      Due to above variable timeout usb auto-resume latency varies from
      40ms to ~300ms.
      
      Log Snippet:
      ~128ms latency
      [   53.112049] hub 1-0:1.0: state 7 ports 12 chg 0000 evt 0000
      [   53.229200] hub 1-0:1.0: state 7 ports 12 chg 0000 evt 0004
      [   53.240177] usb 1-2: usb wakeup-resume
      [   53.240195] usb 1-2: finish resume
      [   53.240357] usb usb1-port2: resume, status 0
      -----------------------------------------------------------------
      ~300ms latency
      [   59.946620] hub 1-0:1.0: state 7 ports 12 chg 0000 evt 0000
      [   59.979341] hub 1-0:1.0: state 7 ports 12 chg 0000 evt 0000
      [   60.229342] hub 1-0:1.0: state 7 ports 12 chg 0000 evt 0004
      [   60.251321] usb 1-2: usb wakeup-resume
      [   60.251335] usb 1-2: finish resume
      [   60.251539] usb usb1-port2: resume, status 0
      
      This variable resume latency can be optimized, as in case of PORT_PLC
      change event rh_timer has already been modified with USB_RESUME_TIMEOUT
      (40ms) delay,leaving the rest to GetPortStatus and started polling for
      root hub status (invoking usb_hcd_poll_rh_status).
      We can avoid polling as we have already modified rh_timer with
      delay of 40ms.
      
      This patch set the HCD_FLAG_POLL_RH to hcd->flags after modification of
      rh_timer, and avoids polling of root hub status. so rh_timer can fire
      after 40ms and usb device auto-resuem latency will be around 40ms.
      
      [topic and first two senctences of commit message changed -Mathias]
      Signed-off-by: NAnshuman Gupta <anshuman.gupta@intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      0914ea66
    • L
      usb: xhci: Handle USB transaction error on address command · 651aaf36
      Lu Baolu 提交于
      Xhci driver handles USB transaction errors on transfer events,
      but transaction errors are possible on address device command
      completion events as well.
      
      The xHCI specification (section 4.6.5) says: A USB Transaction
      Error Completion Code for an Address Device Command may be due
      to a Stall response from a device. Software should issue a Disable
      Slot Command for the Device Slot then an Enable Slot Command to
      recover from this error.
      
      This patch handles USB transaction errors on address command
      completion events. The related discussion threads can be found
      through below links.
      
      http://marc.info/?l=linux-usb&m=149362010728921&w=2
      http://marc.info/?l=linux-usb&m=149252752825755&w=2Suggested-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      651aaf36
    • L
      usb: xhci: Remove xhci->mutex from xhci_alloc_dev() · 089ed490
      Lu Baolu 提交于
      xhci->mutex was added in xhci_alloc_dev()  to protect two race sources
      (xhci->slot_id and xhci->addr_dev) by commit a00918d0 ("usb: host:
      xhci: add mutex for non-thread-safe data").
      
      While xhci->slot_id has been discarded in commit c2d3d49b ("usb:
      xhci: move slot_id from xhci_hcd to xhci_command structure"), and
      xhci->addr_dev has been removed in commit 87e44f2a ("usb: xhci:
      remove the use of xhci->addr_dev"), it's now safe to remove the use of
      xhci->mutex in xhci_alloc_dev().
      
      Link: https://marc.info/?l=linux-usb&m=150306294725821&w=2Suggested-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      089ed490
    • L
      usb: xhci: Return error when host is dead in xhci_disable_slot() · dcabc76f
      Lu Baolu 提交于
      xhci_disable_slot() is a helper for disabling a slot when a device
      goes away or recovers from error situations. Currently, it returns
      success when it sees a dead host. This is not the right way to go.
      It should return error and let the invoker know that disable slot
      command was failed due to a dead host.
      
      Fixes: f9e609b8 ("usb: xhci: Add helper function xhci_disable_slot().")
      Cc: Guoqing Zhang <guoqing.zhang@intel.com>
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      dcabc76f
    • L
      usb: xhci: Fix memory leak when xhci_disable_slot() returns error · 11ec7588
      Lu Baolu 提交于
      If xhci_disable_slot() returns success, a disable slot command
      trb was queued in the command ring. The command completion
      handler will free the virtual device data structure associated
      with the slot. On the other hand, when xhci_disable_slot()
      returns error, the invokers should take the responsibilities to
      free the slot related data structure. Otherwise, memory leakage
      happens.
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      11ec7588
    • L
      usb: xhci: Fix potential memory leak in xhci_disable_slot() · cd3f1790
      Lu Baolu 提交于
      xhci_disable_slot() allows the invoker to pass a command pointer
      as paramenter. Otherwise, it will allocate one. This will cause
      memory leak when a command structure was allocated inside of this
      function while queuing command trb fails. Another problem comes up
      when the invoker passed a command pointer, but xhci_disable_slot()
      frees it when it detects a dead host.
      
      This patch fixes these two problems by removing the command parameter
      from xhci_disable_slot().
      
      Fixes: f9e609b8 ("usb: xhci: Add helper function xhci_disable_slot().")
      Cc: Guoqing Zhang <guoqing.zhang@intel.com>
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      cd3f1790
    • L
      usb: xhci: Disable slot even when virt-dev is null · b64149ca
      Lu Baolu 提交于
      xhci_disable_slot() is a helper for disabling a slot when a device
      goes away or recovers from error situations. Currently, it checks
      the corespoding virt-dev pointer and returns directly (w/o issuing
      disable slot command) if it's null.
      
      This is unnecessary and will cause problems in case where virt-dev
      allocation fails and xhci_disable_slot() is called to roll back the
      hardware state. Refer to the implementation of xhci_alloc_dev().
      
      This patch removes lines to check virt-dev in xhci_disable_slot().
      
      Fixes: f9e609b8 ("usb: xhci: Add helper function xhci_disable_slot().")
      Cc: Guoqing Zhang <guoqing.zhang@intel.com>
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      b64149ca
    • L
      usb: xhci: Add debugfs interface for xHCI driver · 02b6fdc2
      Lu Baolu 提交于
      This adds debugfs consumer for xHCI driver. The debugfs entries
      read all host registers, device/endpoint contexts, command ring,
      event ring and various endpoint rings. With these entries, users
      can check the registers and memory spaces used by a host during
      run time, or save all the information with a simple 'cp -r' for
      post-mortem programs.
      
      The file hierarchy looks like this.
      
      [root of debugfs]
      |__usb
      |____[e,u,o]hci                 <---------[root for other HCIs]
      |____xhci                       <---------------[root for xHCI]
      |______0000:00:14.0             <--------------[xHCI host name]
      |________reg-cap                <--------[capability registers]
      |________reg-op                 <-------[operational registers]
      |________reg-runtime            <-----------[runtime registers]
      |________reg-ext-#cap_name      <----[extended capability regs]
      |________command-ring           <-------[root for command ring]
      |__________cycle                <------------------[ring cycle]
      |__________dequeue              <--------[ring dequeue pointer]
      |__________enqueue              <--------[ring enqueue pointer]
      |__________trbs                 <-------------------[ring trbs]
      |________event-ring             <---------[root for event ring]
      |__________cycle                <------------------[ring cycle]
      |__________dequeue              <--------[ring dequeue pointer]
      |__________enqueue              <--------[ring enqueue pointer]
      |__________trbs                 <-------------------[ring trbs]
      |________devices                <------------[root for devices]
      |__________#slot_id             <-----------[root for a device]
      |____________name               <-----------------[device name]
      |____________slot-context       <----------------[slot context]
      |____________ep-context         <-----------[endpoint contexts]
      |____________ep#ep_index        <--------[root for an endpoint]
      |______________cycle            <------------------[ring cycle]
      |______________dequeue          <--------[ring dequeue pointer]
      |______________enqueue          <--------[ring enqueue pointer]
      |______________trbs             <-------------------[ring trbs]
      Signed-off-by: NLu Baolu <baolu.lu@linux.intel.com>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      02b6fdc2
    • M
      xhci: add port speed ID to portsc tracing · 8f114877
      Mathias Nyman 提交于
      Shows the port speed protocol speed ID (PSID) in use.
      speed ID may map to custom speeds, but in most cases it uses default
      
      1 = Full-Speed        12 MB/s
      2 = Low-Speed         1.5 Mb/s
      3 = High-speed        480 Mb/s
      4 = SuperSpeed        5 Gb/s
      5 = SuperSpeedPlus    10 Gb/s
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      8f114877
    • T
      usb: host: xhci support option to disable the xHCI USB2 HW LPM · 4750bc78
      Thang Q. Nguyen 提交于
      XHCI specification 1.1 does not require xHCI-compliant controllers
      to always enable hardware USB2 LPM. However, the current xHCI
      driver always enable it when seeing HLC=1.
      This patch supports an option for users to control disabling
      USB2 Hardware LPM via DT/ACPI attribute.
      This option is needed in case user would like to disable this
      feature. For example, their xHCI controller has its USB2 HW LPM
      broken.
      Signed-off-by: NTung Nguyen <tunguyen@apm.com>
      Signed-off-by: NThang Q. Nguyen <tqnguyen@apm.com>
      Acked-by: NRob Herring <robh@kernel.org>
      Signed-off-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4750bc78
  2. 04 10月, 2017 5 次提交
  3. 01 9月, 2017 4 次提交
  4. 28 8月, 2017 2 次提交
    • J
      usb: xhci: Support enabling of compliance mode for xhci 1.1 · 4b562bd2
      Jack Pham 提交于
      To perform SuperSpeed compliance testing the port should first
      be placed into compliance mode. For xHCI 1.0 and prior this
      transition happens automatically when the port is in Training
      and encounters an LFPS timeout. Thus running compliance tests
      against a test appliance may simply just work by simply plugging
      in to the downstream port.
      
      However starting with xHCI 1.1 the transition from Polling.LFPS
      to compliance mode may be disabled by default and needs to be
      explicitly enabled by writing to the PLS field of the PORTSC
      register, which sets an internal 'CTE' (Compliance Transition
      Enabled) flag so that the port will perform the transition the
      next time it encounters LFPS timeout. Whether this is disabled or
      not is determined by the 'CTC' (Compliance Transition Capability)
      bit in the HCCPARAMS2 capability register.
      
      In order to allow a test operator to change this if needed, allow
      a test driver (such as drivers/usb/misc/lvstest.c) to send a
      SET_FEATURE(PORT_LINK_STATE) control message to the root hub to
      update the link state prior to connecting to the port. Subsequently,
      placing the port in warm reset would then disable the flag.
      Signed-off-by: NJack Pham <jackp@codeaurora.org>
      Acked-by: NMathias Nyman <mathias.nyman@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4b562bd2
    • S
      usb:xhci:Fix regression when ATI chipsets detected · e6b422b8
      Sandeep Singh 提交于
      The following commit cause a regression on ATI chipsets.
      'commit e788787e ("usb:xhci:Add quirk for Certain
      failing HP keyboard on reset after resume")'
      
      This causes pinfo->smbus_dev to be wrongly set to NULL on
      systems with the ATI chipset that this function checks for first.
      
      Added conditional check for AMD chipsets to avoid the overwriting
      pinfo->smbus_dev.
      Reported-by: NBen Hutchings <ben@decadent.org.uk>
      Fixes: e788787e ("usb:xhci:Add quirk for Certain
      failing HP keyboard on reset after resume")
      cc: Nehal Shah <Nehal-bakulchandra.Shah@amd.com>
      cc: <stable@vger.kernel.org>
      Signed-off-by: NSandeep Singh <Sandeep.Singh@amd.com>
      Signed-off-by: NShyam Sundar S K <Shyam-sundar.S-k@amd.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      e6b422b8
  5. 17 8月, 2017 8 次提交
  6. 15 8月, 2017 1 次提交
  7. 11 8月, 2017 4 次提交
  8. 03 8月, 2017 1 次提交
  9. 30 7月, 2017 5 次提交