LCOV - code coverage report
Current view: top level - drivers/usb/host - xhci-pci.c (source / functions) Hit Total Coverage
Test: combined.info Lines: 6 252 2.4 %
Date: 2022-04-01 13:59:58 Functions: 1 11 9.1 %
Branches: 0 176 0.0 %

           Branch data     Line data    Source code
       1                 :            : // SPDX-License-Identifier: GPL-2.0
       2                 :            : /*
       3                 :            :  * xHCI host controller driver PCI Bus Glue.
       4                 :            :  *
       5                 :            :  * Copyright (C) 2008 Intel Corp.
       6                 :            :  *
       7                 :            :  * Author: Sarah Sharp
       8                 :            :  * Some code borrowed from the Linux EHCI driver.
       9                 :            :  */
      10                 :            : 
      11                 :            : #include <linux/pci.h>
      12                 :            : #include <linux/slab.h>
      13                 :            : #include <linux/module.h>
      14                 :            : #include <linux/acpi.h>
      15                 :            : 
      16                 :            : #include "xhci.h"
      17                 :            : #include "xhci-trace.h"
      18                 :            : 
      19                 :            : #define SSIC_PORT_NUM           2
      20                 :            : #define SSIC_PORT_CFG2          0x880c
      21                 :            : #define SSIC_PORT_CFG2_OFFSET   0x30
      22                 :            : #define PROG_DONE               (1 << 30)
      23                 :            : #define SSIC_PORT_UNUSED        (1 << 31)
      24                 :            : 
      25                 :            : /* Device for a quirk */
      26                 :            : #define PCI_VENDOR_ID_FRESCO_LOGIC      0x1b73
      27                 :            : #define PCI_DEVICE_ID_FRESCO_LOGIC_PDK  0x1000
      28                 :            : #define PCI_DEVICE_ID_FRESCO_LOGIC_FL1009       0x1009
      29                 :            : #define PCI_DEVICE_ID_FRESCO_LOGIC_FL1400       0x1400
      30                 :            : 
      31                 :            : #define PCI_VENDOR_ID_ETRON             0x1b6f
      32                 :            : #define PCI_DEVICE_ID_EJ168             0x7023
      33                 :            : 
      34                 :            : #define PCI_DEVICE_ID_INTEL_LYNXPOINT_XHCI      0x8c31
      35                 :            : #define PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_XHCI   0x9c31
      36                 :            : #define PCI_DEVICE_ID_INTEL_WILDCATPOINT_LP_XHCI        0x9cb1
      37                 :            : #define PCI_DEVICE_ID_INTEL_CHERRYVIEW_XHCI             0x22b5
      38                 :            : #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_H_XHCI         0xa12f
      39                 :            : #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_XHCI        0x9d2f
      40                 :            : #define PCI_DEVICE_ID_INTEL_BROXTON_M_XHCI              0x0aa8
      41                 :            : #define PCI_DEVICE_ID_INTEL_BROXTON_B_XHCI              0x1aa8
      42                 :            : #define PCI_DEVICE_ID_INTEL_APL_XHCI                    0x5aa8
      43                 :            : #define PCI_DEVICE_ID_INTEL_DNV_XHCI                    0x19d0
      44                 :            : #define PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_2C_XHCI        0x15b5
      45                 :            : #define PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_4C_XHCI        0x15b6
      46                 :            : #define PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_C_2C_XHCI      0x15db
      47                 :            : #define PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_C_4C_XHCI      0x15d4
      48                 :            : #define PCI_DEVICE_ID_INTEL_TITAN_RIDGE_2C_XHCI         0x15e9
      49                 :            : #define PCI_DEVICE_ID_INTEL_TITAN_RIDGE_4C_XHCI         0x15ec
      50                 :            : #define PCI_DEVICE_ID_INTEL_TITAN_RIDGE_DD_XHCI         0x15f0
      51                 :            : #define PCI_DEVICE_ID_INTEL_ICE_LAKE_XHCI               0x8a13
      52                 :            : #define PCI_DEVICE_ID_INTEL_CML_XHCI                    0xa3af
      53                 :            : 
      54                 :            : #define PCI_DEVICE_ID_AMD_PROMONTORYA_4                 0x43b9
      55                 :            : #define PCI_DEVICE_ID_AMD_PROMONTORYA_3                 0x43ba
      56                 :            : #define PCI_DEVICE_ID_AMD_PROMONTORYA_2                 0x43bb
      57                 :            : #define PCI_DEVICE_ID_AMD_PROMONTORYA_1                 0x43bc
      58                 :            : #define PCI_DEVICE_ID_ASMEDIA_1042A_XHCI                0x1142
      59                 :            : 
      60                 :            : static const char hcd_name[] = "xhci_hcd";
      61                 :            : 
      62                 :            : static struct hc_driver __read_mostly xhci_pci_hc_driver;
      63                 :            : 
      64                 :            : static int xhci_pci_setup(struct usb_hcd *hcd);
      65                 :            : 
      66                 :            : static const struct xhci_driver_overrides xhci_pci_overrides __initconst = {
      67                 :            :         .reset = xhci_pci_setup,
      68                 :            : };
      69                 :            : 
      70                 :            : /* called after powerup, by probe or system-pm "wakeup" */
      71                 :          0 : static int xhci_pci_reinit(struct xhci_hcd *xhci, struct pci_dev *pdev)
      72                 :            : {
      73                 :            :         /*
      74                 :            :          * TODO: Implement finding debug ports later.
      75                 :            :          * TODO: see if there are any quirks that need to be added to handle
      76                 :            :          * new extended capabilities.
      77                 :            :          */
      78                 :            : 
      79                 :            :         /* PCI Memory-Write-Invalidate cycle support is optional (uncommon) */
      80                 :          0 :         if (!pci_set_mwi(pdev))
      81                 :            :                 xhci_dbg(xhci, "MWI active\n");
      82                 :            : 
      83                 :          0 :         xhci_dbg(xhci, "Finished xhci_pci_reinit\n");
      84                 :          0 :         return 0;
      85                 :            : }
      86                 :            : 
      87                 :          0 : static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci)
      88                 :            : {
      89                 :          0 :         struct pci_dev          *pdev = to_pci_dev(dev);
      90                 :            : 
      91                 :            :         /* Look for vendor-specific quirks */
      92         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_FRESCO_LOGIC &&
      93         [ #  # ]:          0 :                         (pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK ||
      94                 :            :                          pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_FL1400)) {
      95         [ #  # ]:          0 :                 if (pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK &&
      96         [ #  # ]:          0 :                                 pdev->revision == 0x0) {
      97                 :          0 :                         xhci->quirks |= XHCI_RESET_EP_QUIRK;
      98                 :          0 :                         xhci_dbg_trace(xhci, trace_xhci_dbg_quirks,
      99                 :            :                                 "QUIRK: Fresco Logic xHC needs configure"
     100                 :            :                                 " endpoint cmd after reset endpoint");
     101                 :            :                 }
     102         [ #  # ]:          0 :                 if (pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK &&
     103         [ #  # ]:          0 :                                 pdev->revision == 0x4) {
     104                 :          0 :                         xhci->quirks |= XHCI_SLOW_SUSPEND;
     105                 :          0 :                         xhci_dbg_trace(xhci, trace_xhci_dbg_quirks,
     106                 :            :                                 "QUIRK: Fresco Logic xHC revision %u"
     107                 :            :                                 "must be suspended extra slowly",
     108                 :          0 :                                 pdev->revision);
     109                 :            :                 }
     110         [ #  # ]:          0 :                 if (pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK)
     111                 :          0 :                         xhci->quirks |= XHCI_BROKEN_STREAMS;
     112                 :            :                 /* Fresco Logic confirms: all revisions of this chip do not
     113                 :            :                  * support MSI, even though some of them claim to in their PCI
     114                 :            :                  * capabilities.
     115                 :            :                  */
     116                 :          0 :                 xhci->quirks |= XHCI_BROKEN_MSI;
     117                 :          0 :                 xhci_dbg_trace(xhci, trace_xhci_dbg_quirks,
     118                 :            :                                 "QUIRK: Fresco Logic revision %u "
     119                 :            :                                 "has broken MSI implementation",
     120                 :          0 :                                 pdev->revision);
     121                 :          0 :                 xhci->quirks |= XHCI_TRUST_TX_LENGTH;
     122                 :            :         }
     123                 :            : 
     124         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_FRESCO_LOGIC &&
     125                 :            :                         pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_FL1009)
     126                 :          0 :                 xhci->quirks |= XHCI_BROKEN_STREAMS;
     127                 :            : 
     128         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_NEC)
     129                 :          0 :                 xhci->quirks |= XHCI_NEC_HOST;
     130                 :            : 
     131   [ #  #  #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_AMD && xhci->hci_version == 0x96)
     132                 :          0 :                 xhci->quirks |= XHCI_AMD_0x96_HOST;
     133                 :            : 
     134                 :            :         /* AMD PLL quirk */
     135   [ #  #  #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_AMD && usb_amd_quirk_pll_check())
     136                 :          0 :                 xhci->quirks |= XHCI_AMD_PLL_FIX;
     137                 :            : 
     138         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_AMD &&
     139         [ #  # ]:          0 :                 (pdev->device == 0x145c ||
     140         [ #  # ]:          0 :                  pdev->device == 0x15e0 ||
     141         [ #  # ]:          0 :                  pdev->device == 0x15e1 ||
     142                 :            :                  pdev->device == 0x43bb))
     143                 :          0 :                 xhci->quirks |= XHCI_SUSPEND_DELAY;
     144                 :            : 
     145         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_AMD &&
     146         [ #  # ]:          0 :             (pdev->device == 0x15e0 || pdev->device == 0x15e1))
     147                 :          0 :                 xhci->quirks |= XHCI_SNPS_BROKEN_SUSPEND;
     148                 :            : 
     149         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_AMD)
     150                 :          0 :                 xhci->quirks |= XHCI_TRUST_TX_LENGTH;
     151                 :            : 
     152         [ #  # ]:          0 :         if ((pdev->vendor == PCI_VENDOR_ID_AMD) &&
     153                 :          0 :                 ((pdev->device == PCI_DEVICE_ID_AMD_PROMONTORYA_4) ||
     154                 :            :                 (pdev->device == PCI_DEVICE_ID_AMD_PROMONTORYA_3) ||
     155         [ #  # ]:          0 :                 (pdev->device == PCI_DEVICE_ID_AMD_PROMONTORYA_2) ||
     156                 :            :                 (pdev->device == PCI_DEVICE_ID_AMD_PROMONTORYA_1)))
     157                 :          0 :                 xhci->quirks |= XHCI_U2_DISABLE_WAKE;
     158                 :            : 
     159         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL) {
     160                 :          0 :                 xhci->quirks |= XHCI_LPM_SUPPORT;
     161                 :          0 :                 xhci->quirks |= XHCI_INTEL_HOST;
     162                 :          0 :                 xhci->quirks |= XHCI_AVOID_BEI;
     163                 :            :         }
     164         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     165                 :            :                         pdev->device == PCI_DEVICE_ID_INTEL_PANTHERPOINT_XHCI) {
     166                 :          0 :                 xhci->quirks |= XHCI_EP_LIMIT_QUIRK;
     167                 :          0 :                 xhci->limit_active_eps = 64;
     168                 :          0 :                 xhci->quirks |= XHCI_SW_BW_CHECKING;
     169                 :            :                 /*
     170                 :            :                  * PPT desktop boards DH77EB and DH77DF will power back on after
     171                 :            :                  * a few seconds of being shutdown.  The fix for this is to
     172                 :            :                  * switch the ports from xHCI to EHCI on shutdown.  We can't use
     173                 :            :                  * DMI information to find those particular boards (since each
     174                 :            :                  * vendor will change the board name), so we have to key off all
     175                 :            :                  * PPT chipsets.
     176                 :            :                  */
     177                 :          0 :                 xhci->quirks |= XHCI_SPURIOUS_REBOOT;
     178                 :            :         }
     179         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     180         [ #  # ]:          0 :                 (pdev->device == PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_XHCI ||
     181                 :            :                  pdev->device == PCI_DEVICE_ID_INTEL_WILDCATPOINT_LP_XHCI)) {
     182                 :          0 :                 xhci->quirks |= XHCI_SPURIOUS_REBOOT;
     183                 :          0 :                 xhci->quirks |= XHCI_SPURIOUS_WAKEUP;
     184                 :            :         }
     185         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     186         [ #  # ]:          0 :                 (pdev->device == PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_XHCI ||
     187         [ #  # ]:          0 :                  pdev->device == PCI_DEVICE_ID_INTEL_SUNRISEPOINT_H_XHCI ||
     188         [ #  # ]:          0 :                  pdev->device == PCI_DEVICE_ID_INTEL_CHERRYVIEW_XHCI ||
     189         [ #  # ]:          0 :                  pdev->device == PCI_DEVICE_ID_INTEL_BROXTON_M_XHCI ||
     190         [ #  # ]:          0 :                  pdev->device == PCI_DEVICE_ID_INTEL_BROXTON_B_XHCI ||
     191         [ #  # ]:          0 :                  pdev->device == PCI_DEVICE_ID_INTEL_APL_XHCI ||
     192         [ #  # ]:          0 :                  pdev->device == PCI_DEVICE_ID_INTEL_DNV_XHCI ||
     193                 :            :                  pdev->device == PCI_DEVICE_ID_INTEL_CML_XHCI)) {
     194                 :          0 :                 xhci->quirks |= XHCI_PME_STUCK_QUIRK;
     195                 :            :         }
     196         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     197                 :            :             pdev->device == PCI_DEVICE_ID_INTEL_CHERRYVIEW_XHCI)
     198                 :          0 :                 xhci->quirks |= XHCI_SSIC_PORT_UNUSED;
     199         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     200         [ #  # ]:          0 :             (pdev->device == PCI_DEVICE_ID_INTEL_CHERRYVIEW_XHCI ||
     201         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_XHCI ||
     202                 :            :              pdev->device == PCI_DEVICE_ID_INTEL_APL_XHCI))
     203                 :          0 :                 xhci->quirks |= XHCI_INTEL_USB_ROLE_SW;
     204         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     205         [ #  # ]:          0 :             (pdev->device == PCI_DEVICE_ID_INTEL_CHERRYVIEW_XHCI ||
     206         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_XHCI ||
     207         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_SUNRISEPOINT_H_XHCI ||
     208         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_APL_XHCI ||
     209                 :            :              pdev->device == PCI_DEVICE_ID_INTEL_DNV_XHCI))
     210                 :          0 :                 xhci->quirks |= XHCI_MISSING_CAS;
     211                 :            : 
     212         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
     213                 :          0 :             (pdev->device == PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_2C_XHCI ||
     214         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_4C_XHCI ||
     215         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_C_2C_XHCI ||
     216         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_ALPINE_RIDGE_C_4C_XHCI ||
     217         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_TITAN_RIDGE_2C_XHCI ||
     218         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_TITAN_RIDGE_4C_XHCI ||
     219         [ #  # ]:          0 :              pdev->device == PCI_DEVICE_ID_INTEL_TITAN_RIDGE_DD_XHCI ||
     220                 :            :              pdev->device == PCI_DEVICE_ID_INTEL_ICE_LAKE_XHCI))
     221                 :          0 :                 xhci->quirks |= XHCI_DEFAULT_PM_RUNTIME_ALLOW;
     222                 :            : 
     223         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_ETRON &&
     224                 :            :                         pdev->device == PCI_DEVICE_ID_EJ168) {
     225                 :          0 :                 xhci->quirks |= XHCI_RESET_ON_RESUME;
     226                 :          0 :                 xhci->quirks |= XHCI_TRUST_TX_LENGTH;
     227                 :          0 :                 xhci->quirks |= XHCI_BROKEN_STREAMS;
     228                 :            :         }
     229         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_RENESAS &&
     230                 :            :             pdev->device == 0x0014) {
     231                 :          0 :                 xhci->quirks |= XHCI_TRUST_TX_LENGTH;
     232                 :          0 :                 xhci->quirks |= XHCI_ZERO_64B_REGS;
     233                 :            :         }
     234         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_RENESAS &&
     235                 :            :             pdev->device == 0x0015) {
     236                 :          0 :                 xhci->quirks |= XHCI_RESET_ON_RESUME;
     237                 :          0 :                 xhci->quirks |= XHCI_ZERO_64B_REGS;
     238                 :            :         }
     239         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_VIA)
     240                 :          0 :                 xhci->quirks |= XHCI_RESET_ON_RESUME;
     241                 :            : 
     242                 :            :         /* See https://bugzilla.kernel.org/show_bug.cgi?id=79511 */
     243         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_VIA &&
     244                 :            :                         pdev->device == 0x3432)
     245                 :          0 :                 xhci->quirks |= XHCI_BROKEN_STREAMS;
     246                 :            : 
     247         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_ASMEDIA &&
     248                 :            :                         pdev->device == 0x1042)
     249                 :          0 :                 xhci->quirks |= XHCI_BROKEN_STREAMS;
     250         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_ASMEDIA &&
     251                 :            :                         pdev->device == 0x1142)
     252                 :          0 :                 xhci->quirks |= XHCI_TRUST_TX_LENGTH;
     253                 :            : 
     254         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_ASMEDIA &&
     255                 :            :                 pdev->device == PCI_DEVICE_ID_ASMEDIA_1042A_XHCI)
     256                 :          0 :                 xhci->quirks |= XHCI_ASMEDIA_MODIFY_FLOWCONTROL;
     257                 :            : 
     258         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_TI && pdev->device == 0x8241)
     259                 :          0 :                 xhci->quirks |= XHCI_LIMIT_ENDPOINT_INTERVAL_7;
     260                 :            : 
     261         [ #  # ]:          0 :         if ((pdev->vendor == PCI_VENDOR_ID_BROADCOM ||
     262                 :          0 :              pdev->vendor == PCI_VENDOR_ID_CAVIUM) &&
     263         [ #  # ]:          0 :              pdev->device == 0x9026)
     264                 :          0 :                 xhci->quirks |= XHCI_RESET_PLL_ON_DISCONNECT;
     265                 :            : 
     266         [ #  # ]:          0 :         if (xhci->quirks & XHCI_RESET_ON_RESUME)
     267                 :          0 :                 xhci_dbg_trace(xhci, trace_xhci_dbg_quirks,
     268                 :            :                                 "QUIRK: Resetting on resume");
     269                 :          0 : }
     270                 :            : 
     271                 :            : #ifdef CONFIG_ACPI
     272                 :            : static void xhci_pme_acpi_rtd3_enable(struct pci_dev *dev)
     273                 :            : {
     274                 :            :         static const guid_t intel_dsm_guid =
     275                 :            :                 GUID_INIT(0xac340cb7, 0xe901, 0x45bf,
     276                 :            :                           0xb7, 0xe6, 0x2b, 0x34, 0xec, 0x93, 0x1e, 0x23);
     277                 :            :         union acpi_object *obj;
     278                 :            : 
     279                 :            :         obj = acpi_evaluate_dsm(ACPI_HANDLE(&dev->dev), &intel_dsm_guid, 3, 1,
     280                 :            :                                 NULL);
     281                 :            :         ACPI_FREE(obj);
     282                 :            : }
     283                 :            : #else
     284                 :            : static void xhci_pme_acpi_rtd3_enable(struct pci_dev *dev) { }
     285                 :            : #endif /* CONFIG_ACPI */
     286                 :            : 
     287                 :            : /* called during probe() after chip reset completes */
     288                 :          0 : static int xhci_pci_setup(struct usb_hcd *hcd)
     289                 :            : {
     290                 :          0 :         struct xhci_hcd         *xhci;
     291                 :          0 :         struct pci_dev          *pdev = to_pci_dev(hcd->self.controller);
     292                 :          0 :         int                     retval;
     293                 :            : 
     294                 :          0 :         xhci = hcd_to_xhci(hcd);
     295         [ #  # ]:          0 :         if (!xhci->sbrn)
     296                 :          0 :                 pci_read_config_byte(pdev, XHCI_SBRN_OFFSET, &xhci->sbrn);
     297                 :            : 
     298                 :            :         /* imod_interval is the interrupt moderation value in nanoseconds. */
     299                 :          0 :         xhci->imod_interval = 40000;
     300                 :            : 
     301                 :          0 :         retval = xhci_gen_setup(hcd, xhci_pci_quirks);
     302         [ #  # ]:          0 :         if (retval)
     303                 :            :                 return retval;
     304                 :            : 
     305         [ #  # ]:          0 :         if (!usb_hcd_is_primary_hcd(hcd))
     306                 :            :                 return 0;
     307                 :            : 
     308         [ #  # ]:          0 :         if (xhci->quirks & XHCI_PME_STUCK_QUIRK)
     309                 :          0 :                 xhci_pme_acpi_rtd3_enable(pdev);
     310                 :            : 
     311                 :          0 :         xhci_dbg(xhci, "Got SBRN %u\n", (unsigned int) xhci->sbrn);
     312                 :            : 
     313                 :            :         /* Find any debug ports */
     314                 :          0 :         return xhci_pci_reinit(xhci, pdev);
     315                 :            : }
     316                 :            : 
     317                 :            : /*
     318                 :            :  * We need to register our own PCI probe function (instead of the USB core's
     319                 :            :  * function) in order to create a second roothub under xHCI.
     320                 :            :  */
     321                 :          0 : static int xhci_pci_probe(struct pci_dev *dev, const struct pci_device_id *id)
     322                 :            : {
     323                 :          0 :         int retval;
     324                 :          0 :         struct xhci_hcd *xhci;
     325                 :          0 :         struct hc_driver *driver;
     326                 :          0 :         struct usb_hcd *hcd;
     327                 :            : 
     328                 :          0 :         driver = (struct hc_driver *)id->driver_data;
     329                 :            : 
     330                 :            :         /* Prevent runtime suspending between USB-2 and USB-3 initialization */
     331                 :          0 :         pm_runtime_get_noresume(&dev->dev);
     332                 :            : 
     333                 :            :         /* Register the USB 2.0 roothub.
     334                 :            :          * FIXME: USB core must know to register the USB 2.0 roothub first.
     335                 :            :          * This is sort of silly, because we could just set the HCD driver flags
     336                 :            :          * to say USB 2.0, but I'm not sure what the implications would be in
     337                 :            :          * the other parts of the HCD code.
     338                 :            :          */
     339                 :          0 :         retval = usb_hcd_pci_probe(dev, id);
     340                 :            : 
     341         [ #  # ]:          0 :         if (retval)
     342                 :          0 :                 goto put_runtime_pm;
     343                 :            : 
     344                 :            :         /* USB 2.0 roothub is stored in the PCI device now. */
     345                 :          0 :         hcd = dev_get_drvdata(&dev->dev);
     346                 :          0 :         xhci = hcd_to_xhci(hcd);
     347         [ #  # ]:          0 :         xhci->shared_hcd = usb_create_shared_hcd(driver, &dev->dev,
     348                 :            :                                 pci_name(dev), hcd);
     349         [ #  # ]:          0 :         if (!xhci->shared_hcd) {
     350                 :          0 :                 retval = -ENOMEM;
     351                 :          0 :                 goto dealloc_usb2_hcd;
     352                 :            :         }
     353                 :            : 
     354                 :          0 :         retval = xhci_ext_cap_init(xhci);
     355         [ #  # ]:          0 :         if (retval)
     356                 :          0 :                 goto put_usb3_hcd;
     357                 :            : 
     358                 :          0 :         retval = usb_add_hcd(xhci->shared_hcd, dev->irq,
     359                 :            :                         IRQF_SHARED);
     360         [ #  # ]:          0 :         if (retval)
     361                 :          0 :                 goto put_usb3_hcd;
     362                 :            :         /* Roothub already marked as USB 3.0 speed */
     363                 :            : 
     364         [ #  # ]:          0 :         if (!(xhci->quirks & XHCI_BROKEN_STREAMS) &&
     365         [ #  # ]:          0 :                         HCC_MAX_PSA(xhci->hcc_params) >= 4)
     366                 :          0 :                 xhci->shared_hcd->can_do_streams = 1;
     367                 :            : 
     368                 :            :         /* USB-2 and USB-3 roothubs initialized, allow runtime pm suspend */
     369                 :          0 :         pm_runtime_put_noidle(&dev->dev);
     370                 :            : 
     371         [ #  # ]:          0 :         if (xhci->quirks & XHCI_DEFAULT_PM_RUNTIME_ALLOW)
     372                 :          0 :                 pm_runtime_allow(&dev->dev);
     373                 :            : 
     374                 :            :         return 0;
     375                 :            : 
     376                 :          0 : put_usb3_hcd:
     377                 :          0 :         usb_put_hcd(xhci->shared_hcd);
     378                 :          0 : dealloc_usb2_hcd:
     379                 :          0 :         usb_hcd_pci_remove(dev);
     380                 :          0 : put_runtime_pm:
     381                 :          0 :         pm_runtime_put_noidle(&dev->dev);
     382                 :          0 :         return retval;
     383                 :            : }
     384                 :            : 
     385                 :          0 : static void xhci_pci_remove(struct pci_dev *dev)
     386                 :            : {
     387                 :          0 :         struct xhci_hcd *xhci;
     388                 :            : 
     389                 :          0 :         xhci = hcd_to_xhci(pci_get_drvdata(dev));
     390                 :          0 :         xhci->xhc_state |= XHCI_STATE_REMOVING;
     391                 :            : 
     392         [ #  # ]:          0 :         if (xhci->quirks & XHCI_DEFAULT_PM_RUNTIME_ALLOW)
     393                 :          0 :                 pm_runtime_forbid(&dev->dev);
     394                 :            : 
     395         [ #  # ]:          0 :         if (xhci->shared_hcd) {
     396                 :          0 :                 usb_remove_hcd(xhci->shared_hcd);
     397                 :          0 :                 usb_put_hcd(xhci->shared_hcd);
     398                 :          0 :                 xhci->shared_hcd = NULL;
     399                 :            :         }
     400                 :            : 
     401                 :            :         /* Workaround for spurious wakeups at shutdown with HSW */
     402         [ #  # ]:          0 :         if (xhci->quirks & XHCI_SPURIOUS_WAKEUP)
     403                 :          0 :                 pci_set_power_state(dev, PCI_D3hot);
     404                 :            : 
     405                 :          0 :         usb_hcd_pci_remove(dev);
     406                 :          0 : }
     407                 :            : 
     408                 :            : #ifdef CONFIG_PM
     409                 :            : /*
     410                 :            :  * In some Intel xHCI controllers, in order to get D3 working,
     411                 :            :  * through a vendor specific SSIC CONFIG register at offset 0x883c,
     412                 :            :  * SSIC PORT need to be marked as "unused" before putting xHCI
     413                 :            :  * into D3. After D3 exit, the SSIC port need to be marked as "used".
     414                 :            :  * Without this change, xHCI might not enter D3 state.
     415                 :            :  */
     416                 :          0 : static void xhci_ssic_port_unused_quirk(struct usb_hcd *hcd, bool suspend)
     417                 :            : {
     418                 :          0 :         struct xhci_hcd *xhci = hcd_to_xhci(hcd);
     419                 :          0 :         u32 val;
     420                 :          0 :         void __iomem *reg;
     421                 :          0 :         int i;
     422                 :            : 
     423         [ #  # ]:          0 :         for (i = 0; i < SSIC_PORT_NUM; i++) {
     424                 :          0 :                 reg = (void __iomem *) xhci->cap_regs +
     425                 :          0 :                                 SSIC_PORT_CFG2 +
     426                 :          0 :                                 i * SSIC_PORT_CFG2_OFFSET;
     427                 :            : 
     428                 :            :                 /* Notify SSIC that SSIC profile programming is not done. */
     429                 :          0 :                 val = readl(reg) & ~PROG_DONE;
     430                 :          0 :                 writel(val, reg);
     431                 :            : 
     432                 :            :                 /* Mark SSIC port as unused(suspend) or used(resume) */
     433                 :          0 :                 val = readl(reg);
     434         [ #  # ]:          0 :                 if (suspend)
     435                 :          0 :                         val |= SSIC_PORT_UNUSED;
     436                 :            :                 else
     437                 :          0 :                         val &= ~SSIC_PORT_UNUSED;
     438                 :          0 :                 writel(val, reg);
     439                 :            : 
     440                 :            :                 /* Notify SSIC that SSIC profile programming is done */
     441                 :          0 :                 val = readl(reg) | PROG_DONE;
     442                 :          0 :                 writel(val, reg);
     443                 :          0 :                 readl(reg);
     444                 :            :         }
     445                 :          0 : }
     446                 :            : 
     447                 :            : /*
     448                 :            :  * Make sure PME works on some Intel xHCI controllers by writing 1 to clear
     449                 :            :  * the Internal PME flag bit in vendor specific PMCTRL register at offset 0x80a4
     450                 :            :  */
     451                 :          0 : static void xhci_pme_quirk(struct usb_hcd *hcd)
     452                 :            : {
     453                 :          0 :         struct xhci_hcd *xhci = hcd_to_xhci(hcd);
     454                 :          0 :         void __iomem *reg;
     455                 :          0 :         u32 val;
     456                 :            : 
     457                 :          0 :         reg = (void __iomem *) xhci->cap_regs + 0x80a4;
     458                 :          0 :         val = readl(reg);
     459                 :          0 :         writel(val | BIT(28), reg);
     460                 :          0 :         readl(reg);
     461                 :          0 : }
     462                 :            : 
     463                 :          0 : static int xhci_pci_suspend(struct usb_hcd *hcd, bool do_wakeup)
     464                 :            : {
     465                 :          0 :         struct xhci_hcd *xhci = hcd_to_xhci(hcd);
     466                 :          0 :         struct pci_dev          *pdev = to_pci_dev(hcd->self.controller);
     467                 :          0 :         int                     ret;
     468                 :            : 
     469                 :            :         /*
     470                 :            :          * Systems with the TI redriver that loses port status change events
     471                 :            :          * need to have the registers polled during D3, so avoid D3cold.
     472                 :            :          */
     473         [ #  # ]:          0 :         if (xhci->quirks & XHCI_COMP_MODE_QUIRK)
     474                 :          0 :                 pci_d3cold_disable(pdev);
     475                 :            : 
     476         [ #  # ]:          0 :         if (xhci->quirks & XHCI_PME_STUCK_QUIRK)
     477                 :          0 :                 xhci_pme_quirk(hcd);
     478                 :            : 
     479         [ #  # ]:          0 :         if (xhci->quirks & XHCI_SSIC_PORT_UNUSED)
     480                 :          0 :                 xhci_ssic_port_unused_quirk(hcd, true);
     481                 :            : 
     482                 :          0 :         ret = xhci_suspend(xhci, do_wakeup);
     483   [ #  #  #  # ]:          0 :         if (ret && (xhci->quirks & XHCI_SSIC_PORT_UNUSED))
     484                 :          0 :                 xhci_ssic_port_unused_quirk(hcd, false);
     485                 :            : 
     486                 :          0 :         return ret;
     487                 :            : }
     488                 :            : 
     489                 :          0 : static int xhci_pci_resume(struct usb_hcd *hcd, bool hibernated)
     490                 :            : {
     491                 :          0 :         struct xhci_hcd         *xhci = hcd_to_xhci(hcd);
     492                 :          0 :         struct pci_dev          *pdev = to_pci_dev(hcd->self.controller);
     493                 :          0 :         int                     retval = 0;
     494                 :            : 
     495                 :            :         /* The BIOS on systems with the Intel Panther Point chipset may or may
     496                 :            :          * not support xHCI natively.  That means that during system resume, it
     497                 :            :          * may switch the ports back to EHCI so that users can use their
     498                 :            :          * keyboard to select a kernel from GRUB after resume from hibernate.
     499                 :            :          *
     500                 :            :          * The BIOS is supposed to remember whether the OS had xHCI ports
     501                 :            :          * enabled before resume, and switch the ports back to xHCI when the
     502                 :            :          * BIOS/OS semaphore is written, but we all know we can't trust BIOS
     503                 :            :          * writers.
     504                 :            :          *
     505                 :            :          * Unconditionally switch the ports back to xHCI after a system resume.
     506                 :            :          * It should not matter whether the EHCI or xHCI controller is
     507                 :            :          * resumed first. It's enough to do the switchover in xHCI because
     508                 :            :          * USB core won't notice anything as the hub driver doesn't start
     509                 :            :          * running again until after all the devices (including both EHCI and
     510                 :            :          * xHCI host controllers) have been resumed.
     511                 :            :          */
     512                 :            : 
     513         [ #  # ]:          0 :         if (pdev->vendor == PCI_VENDOR_ID_INTEL)
     514                 :          0 :                 usb_enable_intel_xhci_ports(pdev);
     515                 :            : 
     516         [ #  # ]:          0 :         if (xhci->quirks & XHCI_SSIC_PORT_UNUSED)
     517                 :          0 :                 xhci_ssic_port_unused_quirk(hcd, false);
     518                 :            : 
     519         [ #  # ]:          0 :         if (xhci->quirks & XHCI_PME_STUCK_QUIRK)
     520                 :          0 :                 xhci_pme_quirk(hcd);
     521                 :            : 
     522                 :          0 :         retval = xhci_resume(xhci, hibernated);
     523                 :          0 :         return retval;
     524                 :            : }
     525                 :            : 
     526                 :          0 : static void xhci_pci_shutdown(struct usb_hcd *hcd)
     527                 :            : {
     528                 :          0 :         struct xhci_hcd         *xhci = hcd_to_xhci(hcd);
     529                 :          0 :         struct pci_dev          *pdev = to_pci_dev(hcd->self.controller);
     530                 :            : 
     531                 :          0 :         xhci_shutdown(hcd);
     532                 :            : 
     533                 :            :         /* Yet another workaround for spurious wakeups at shutdown with HSW */
     534         [ #  # ]:          0 :         if (xhci->quirks & XHCI_SPURIOUS_WAKEUP)
     535                 :          0 :                 pci_set_power_state(pdev, PCI_D3hot);
     536                 :          0 : }
     537                 :            : #endif /* CONFIG_PM */
     538                 :            : 
     539                 :            : /*-------------------------------------------------------------------------*/
     540                 :            : 
     541                 :            : /* PCI driver selection metadata; PCI hotplugging uses this */
     542                 :            : static const struct pci_device_id pci_ids[] = { {
     543                 :            :         /* handle any USB 3.0 xHCI controller */
     544                 :            :         PCI_DEVICE_CLASS(PCI_CLASS_SERIAL_USB_XHCI, ~0),
     545                 :            :         .driver_data =  (unsigned long) &xhci_pci_hc_driver,
     546                 :            :         },
     547                 :            :         { /* end: all zeroes */ }
     548                 :            : };
     549                 :            : MODULE_DEVICE_TABLE(pci, pci_ids);
     550                 :            : 
     551                 :            : /* pci driver glue; this is a "new style" PCI driver module */
     552                 :            : static struct pci_driver xhci_pci_driver = {
     553                 :            :         .name =         (char *) hcd_name,
     554                 :            :         .id_table =     pci_ids,
     555                 :            : 
     556                 :            :         .probe =        xhci_pci_probe,
     557                 :            :         .remove =       xhci_pci_remove,
     558                 :            :         /* suspend and resume implemented later */
     559                 :            : 
     560                 :            :         .shutdown =     usb_hcd_pci_shutdown,
     561                 :            : #ifdef CONFIG_PM
     562                 :            :         .driver = {
     563                 :            :                 .pm = &usb_hcd_pci_pm_ops
     564                 :            :         },
     565                 :            : #endif
     566                 :            : };
     567                 :            : 
     568                 :         78 : static int __init xhci_pci_init(void)
     569                 :            : {
     570                 :         78 :         xhci_init_driver(&xhci_pci_hc_driver, &xhci_pci_overrides);
     571                 :            : #ifdef CONFIG_PM
     572                 :         78 :         xhci_pci_hc_driver.pci_suspend = xhci_pci_suspend;
     573                 :         78 :         xhci_pci_hc_driver.pci_resume = xhci_pci_resume;
     574                 :         78 :         xhci_pci_hc_driver.shutdown = xhci_pci_shutdown;
     575                 :            : #endif
     576                 :         78 :         return pci_register_driver(&xhci_pci_driver);
     577                 :            : }
     578                 :            : module_init(xhci_pci_init);
     579                 :            : 
     580                 :          0 : static void __exit xhci_pci_exit(void)
     581                 :            : {
     582                 :          0 :         pci_unregister_driver(&xhci_pci_driver);
     583                 :          0 : }
     584                 :            : module_exit(xhci_pci_exit);
     585                 :            : 
     586                 :            : MODULE_DESCRIPTION("xHCI PCI Host Controller Driver");
     587                 :            : MODULE_LICENSE("GPL");

Generated by: LCOV version 1.14