mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-21 20:08:24 +00:00
e95b1b23f1
Ran update_kernel.sh in a fresh clone without any existing toolchains. Manually rebased: bcm27xx 950-0267-xhci-add-quirk-for-host-controllers-that-don-t-updat.patch bcm53xx 180-usb-xhci-add-support-for-performing-fake-doorbell.patch layerscape 302-dts-0008-arm64-dts-ls1046a-accumulated-change-to-ls1046a-boar.patch 820-usb-0016-MLK-16735-usb-host-add-XHCI_CDNS_HOST-flag.patch 820-usb-0018-MLK-18794-1-usb-host-xhci-add-.bus_suspend-override.patch Build system: x86_64 Build-tested: bcm27xx/bcm2711, ipq806x/R7800 Run-tested: ipq806x/R7800 No dmesg regressions/everything functional. Signed-off-by: John Audia <graysky@archlinux.us> [remove quilt comment, fix/adjust 820-usb-* layerscape patches] Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.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
|
|
@@ -5385,6 +5385,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
|
|
@@ -1915,6 +1915,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
|