Commit 37769939 authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Greg Kroah-Hartman

USB: EHCI: Export the ehci_hub_control function

Platform drivers sometimes need to perform specific handling of hub
control requests. Make this possible by exporting the ehci_hub_control()
function which can then be called from a custom hub control handler in
the default case.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Acked-by: default avatarStephen Warren <swarren@nvidia.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 42b59eba
...@@ -33,15 +33,6 @@ ...@@ -33,15 +33,6 @@
#ifdef CONFIG_PM #ifdef CONFIG_PM
static int ehci_hub_control(
struct usb_hcd *hcd,
u16 typeReq,
u16 wValue,
u16 wIndex,
char *buf,
u16 wLength
);
static int persist_enabled_on_companion(struct usb_device *udev, void *unused) static int persist_enabled_on_companion(struct usb_device *udev, void *unused)
{ {
return !udev->maxchild && udev->persist_enabled && return !udev->maxchild && udev->persist_enabled &&
...@@ -865,7 +856,7 @@ static int ehset_single_step_set_feature(struct usb_hcd *hcd, int port) ...@@ -865,7 +856,7 @@ static int ehset_single_step_set_feature(struct usb_hcd *hcd, int port)
#endif /* CONFIG_USB_HCD_TEST_MODE */ #endif /* CONFIG_USB_HCD_TEST_MODE */
/*-------------------------------------------------------------------------*/ /*-------------------------------------------------------------------------*/
static int ehci_hub_control ( int ehci_hub_control(
struct usb_hcd *hcd, struct usb_hcd *hcd,
u16 typeReq, u16 typeReq,
u16 wValue, u16 wValue,
...@@ -1285,6 +1276,7 @@ static int ehci_hub_control ( ...@@ -1285,6 +1276,7 @@ static int ehci_hub_control (
spin_unlock_irqrestore (&ehci->lock, flags); spin_unlock_irqrestore (&ehci->lock, flags);
return retval; return retval;
} }
EXPORT_SYMBOL_GPL(ehci_hub_control);
static void ehci_relinquish_port(struct usb_hcd *hcd, int portnum) static void ehci_relinquish_port(struct usb_hcd *hcd, int portnum)
{ {
......
...@@ -51,10 +51,6 @@ struct tegra_ehci_soc_config { ...@@ -51,10 +51,6 @@ struct tegra_ehci_soc_config {
bool has_hostpc; bool has_hostpc;
}; };
static int (*orig_hub_control)(struct usb_hcd *hcd,
u16 typeReq, u16 wValue, u16 wIndex,
char *buf, u16 wLength);
struct tegra_ehci_hcd { struct tegra_ehci_hcd {
struct tegra_usb_phy *phy; struct tegra_usb_phy *phy;
struct clk *clk; struct clk *clk;
...@@ -236,7 +232,7 @@ static int tegra_ehci_hub_control( ...@@ -236,7 +232,7 @@ static int tegra_ehci_hub_control(
spin_unlock_irqrestore(&ehci->lock, flags); spin_unlock_irqrestore(&ehci->lock, flags);
/* Handle the hub control events here */ /* Handle the hub control events here */
return orig_hub_control(hcd, typeReq, wValue, wIndex, buf, wLength); return ehci_hub_control(hcd, typeReq, wValue, wIndex, buf, wLength);
done: done:
spin_unlock_irqrestore(&ehci->lock, flags); spin_unlock_irqrestore(&ehci->lock, flags);
...@@ -554,8 +550,6 @@ static int __init ehci_tegra_init(void) ...@@ -554,8 +550,6 @@ static int __init ehci_tegra_init(void)
* too easy. * too easy.
*/ */
orig_hub_control = tegra_ehci_hc_driver.hub_control;
tegra_ehci_hc_driver.map_urb_for_dma = tegra_ehci_map_urb_for_dma; tegra_ehci_hc_driver.map_urb_for_dma = tegra_ehci_map_urb_for_dma;
tegra_ehci_hc_driver.unmap_urb_for_dma = tegra_ehci_unmap_urb_for_dma; tegra_ehci_hc_driver.unmap_urb_for_dma = tegra_ehci_unmap_urb_for_dma;
tegra_ehci_hc_driver.hub_control = tegra_ehci_hub_control; tegra_ehci_hc_driver.hub_control = tegra_ehci_hub_control;
......
...@@ -872,4 +872,7 @@ extern int ehci_suspend(struct usb_hcd *hcd, bool do_wakeup); ...@@ -872,4 +872,7 @@ extern int ehci_suspend(struct usb_hcd *hcd, bool do_wakeup);
extern int ehci_resume(struct usb_hcd *hcd, bool hibernated); extern int ehci_resume(struct usb_hcd *hcd, bool hibernated);
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
extern int ehci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue,
u16 wIndex, char *buf, u16 wLength);
#endif /* __LINUX_EHCI_HCD_H */ #endif /* __LINUX_EHCI_HCD_H */
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