mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-27 22:59:53 +00:00
8cc7ac54b6
Manually rebased: generic/backport-5.4/370-netfilter-nf_flow_table-fix-offloaded-connection-tim.patch generic/pending-5.4/800-bcma-get-SoC-device-struct-copy-its-DMA-params-to-th.patch mvebu/patches-5.4/021-arm64-dts-marvell-armada-37xx-Move-PCIe-comphy-handl.patch Removed upstreamed: generic/backport-5.4/040-ARM-8918-2-only-build-return_address-if-needed.patch layerscape/patches-5.4/819-uart-0004-MLK-18137-fsl_lpuart-Fix-loopback-mode.patch All others updated automatically. Compile-tested on: lantiq/xrx200, armvirt/64 Runtime-tested on: lantiq/xrx200, armvirt/64 Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
46 lines
1.7 KiB
Diff
46 lines
1.7 KiB
Diff
From b5c498026a95f9d80be23711dd6c178cc78d6c33 Mon Sep 17 00:00:00 2001
|
|
From: Peter Chen <peter.chen@nxp.com>
|
|
Date: Wed, 15 Aug 2018 14:59:55 +0800
|
|
Subject: [PATCH] MLK-18794-1 usb: host: xhci: add .bus_suspend override
|
|
|
|
Some platforms (eg: Cadence USB3) have special requirements to add
|
|
platform USB register setting between xhci_bus_suspend and
|
|
platform USB controller suspend routine. Eg, The Cadence USB3 needs
|
|
RX detect clock switch from 24Mhz to 32Khz within 100ms after set
|
|
port to U3, but sometimes, for USB3 HUB connection, the USB2
|
|
bus suspend will cost more than 100ms, and introduce the disconnection
|
|
before the PHY enters low power mode, then the state is in mess from
|
|
controller side.
|
|
|
|
So in this commit, we introduce .bus_suspend for xhci_driver_overrides
|
|
for above use cases.
|
|
|
|
Signed-off-by: Peter Chen <peter.chen@nxp.com>
|
|
(cherry picked from commit f6baa57913ceb40da14a945820cb87e8d6ceb7c7)
|
|
---
|
|
drivers/usb/host/xhci.c | 2 ++
|
|
drivers/usb/host/xhci.h | 1 +
|
|
2 files changed, 3 insertions(+)
|
|
|
|
--- a/drivers/usb/host/xhci.c
|
|
+++ b/drivers/usb/host/xhci.c
|
|
@@ -5406,6 +5406,8 @@ void xhci_init_driver(struct hc_driver *
|
|
drv->check_bandwidth = over->check_bandwidth;
|
|
if (over->reset_bandwidth)
|
|
drv->reset_bandwidth = over->reset_bandwidth;
|
|
+ if (over->bus_suspend)
|
|
+ drv->bus_suspend = over->bus_suspend;
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(xhci_init_driver);
|
|
--- a/drivers/usb/host/xhci.h
|
|
+++ b/drivers/usb/host/xhci.h
|
|
@@ -1920,6 +1920,7 @@ struct xhci_driver_overrides {
|
|
int (*start)(struct usb_hcd *hcd);
|
|
int (*check_bandwidth)(struct usb_hcd *, struct usb_device *);
|
|
void (*reset_bandwidth)(struct usb_hcd *, struct usb_device *);
|
|
+ int (*bus_suspend)(struct usb_hcd *hcd);
|
|
};
|
|
|
|
#define XHCI_CFC_DELAY 10
|