Commit e0fe9869 authored by Heiner Kallweit's avatar Heiner Kallweit Committed by Greg Kroah-Hartman

usb: host: xhci-plat: prepare operation w/o shared hcd

This patch prepares xhci-plat for the following scenario
- If either of the root hubs has no ports, then omit shared hcd
- Main hcd can be USB3 if there are no USB2 ports
Signed-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: default avatarMathias Nyman <mathias.nyman@linux.intel.com>
Link: https://lore.kernel.org/r/20220511220450.85367-5-mathias.nyman@linux.intel.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0cf1ea04
...@@ -180,7 +180,7 @@ static int xhci_plat_probe(struct platform_device *pdev) ...@@ -180,7 +180,7 @@ static int xhci_plat_probe(struct platform_device *pdev)
struct device *sysdev, *tmpdev; struct device *sysdev, *tmpdev;
struct xhci_hcd *xhci; struct xhci_hcd *xhci;
struct resource *res; struct resource *res;
struct usb_hcd *hcd; struct usb_hcd *hcd, *usb3_hcd;
int ret; int ret;
int irq; int irq;
struct xhci_plat_priv *priv = NULL; struct xhci_plat_priv *priv = NULL;
...@@ -327,6 +327,7 @@ static int xhci_plat_probe(struct platform_device *pdev) ...@@ -327,6 +327,7 @@ static int xhci_plat_probe(struct platform_device *pdev)
if (ret) if (ret)
goto disable_usb_phy; goto disable_usb_phy;
if (!xhci_has_one_roothub(xhci)) {
xhci->shared_hcd = __usb_create_hcd(driver, sysdev, &pdev->dev, xhci->shared_hcd = __usb_create_hcd(driver, sysdev, &pdev->dev,
dev_name(&pdev->dev), hcd); dev_name(&pdev->dev), hcd);
if (!xhci->shared_hcd) { if (!xhci->shared_hcd) {
...@@ -335,13 +336,17 @@ static int xhci_plat_probe(struct platform_device *pdev) ...@@ -335,13 +336,17 @@ static int xhci_plat_probe(struct platform_device *pdev)
} }
xhci->shared_hcd->tpl_support = hcd->tpl_support; xhci->shared_hcd->tpl_support = hcd->tpl_support;
}
if (HCC_MAX_PSA(xhci->hcc_params) >= 4) usb3_hcd = xhci_get_usb3_hcd(xhci);
xhci->shared_hcd->can_do_streams = 1; if (usb3_hcd && HCC_MAX_PSA(xhci->hcc_params) >= 4)
usb3_hcd->can_do_streams = 1;
if (xhci->shared_hcd) {
ret = usb_add_hcd(xhci->shared_hcd, irq, IRQF_SHARED); ret = usb_add_hcd(xhci->shared_hcd, irq, IRQF_SHARED);
if (ret) if (ret)
goto put_usb3_hcd; goto put_usb3_hcd;
}
device_enable_async_suspend(&pdev->dev); device_enable_async_suspend(&pdev->dev);
pm_runtime_put_noidle(&pdev->dev); pm_runtime_put_noidle(&pdev->dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment