Commit 84ebc102 authored by Alan Stern's avatar Alan Stern Committed by Greg Kroah-Hartman

USB: remove CONFIG_USB_SUSPEND option

This patch (as1675) removes the CONFIG_USB_SUSPEND option, essentially
replacing it everywhere with CONFIG_PM_RUNTIME (except for one place
in hub.c, where it is replaced with CONFIG_PM because the code needs
to be used in both runtime and system PM).  The net result is code
shrinkage and simplification.

There's very little point in keeping CONFIG_USB_SUSPEND because almost
everybody enables it.  The few that don't will find that the usbcore
module has gotten somewhat bigger and they will have to take active
measures if they want to prevent hubs from being runtime suspended.
Signed-off-by: default avatarAlan Stern <stern@rowland.harvard.edu>
CC: Peter Chen <peter.chen@freescale.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0aa2832d
...@@ -38,22 +38,6 @@ config USB_DYNAMIC_MINORS ...@@ -38,22 +38,6 @@ config USB_DYNAMIC_MINORS
If you are unsure about this, say N here. If you are unsure about this, say N here.
config USB_SUSPEND
bool "USB runtime power management (autosuspend) and wakeup"
depends on USB && PM_RUNTIME
help
If you say Y here, you can use driver calls or the sysfs
"power/control" file to enable or disable autosuspend for
individual USB peripherals (see
Documentation/usb/power-management.txt for more details).
Also, USB "remote wakeup" signaling is supported, whereby some
USB devices (like keyboards and network adapters) can wake up
their parent hub. That wakeup cascades up the USB tree, and
could wake the system from states like suspend-to-RAM.
If you are unsure about this, say N here.
config USB_OTG config USB_OTG
bool "OTG support" bool "OTG support"
depends on USB depends on USB
......
...@@ -1412,7 +1412,7 @@ int usb_resume(struct device *dev, pm_message_t msg) ...@@ -1412,7 +1412,7 @@ int usb_resume(struct device *dev, pm_message_t msg)
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
/** /**
* usb_enable_autosuspend - allow a USB device to be autosuspended * usb_enable_autosuspend - allow a USB device to be autosuspended
...@@ -1780,7 +1780,7 @@ int usb_set_usb2_hardware_lpm(struct usb_device *udev, int enable) ...@@ -1780,7 +1780,7 @@ int usb_set_usb2_hardware_lpm(struct usb_device *udev, int enable)
return ret; return ret;
} }
#endif /* CONFIG_USB_SUSPEND */ #endif /* CONFIG_PM_RUNTIME */
struct bus_type usb_bus_type = { struct bus_type usb_bus_type = {
.name = "usb", .name = "usb",
......
...@@ -2125,7 +2125,7 @@ int hcd_bus_resume(struct usb_device *rhdev, pm_message_t msg) ...@@ -2125,7 +2125,7 @@ int hcd_bus_resume(struct usb_device *rhdev, pm_message_t msg)
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
/* Workqueue routine for root-hub remote wakeup */ /* Workqueue routine for root-hub remote wakeup */
static void hcd_resume_work(struct work_struct *work) static void hcd_resume_work(struct work_struct *work)
...@@ -2160,7 +2160,7 @@ void usb_hcd_resume_root_hub (struct usb_hcd *hcd) ...@@ -2160,7 +2160,7 @@ void usb_hcd_resume_root_hub (struct usb_hcd *hcd)
} }
EXPORT_SYMBOL_GPL(usb_hcd_resume_root_hub); EXPORT_SYMBOL_GPL(usb_hcd_resume_root_hub);
#endif /* CONFIG_USB_SUSPEND */ #endif /* CONFIG_PM_RUNTIME */
/*-------------------------------------------------------------------------*/ /*-------------------------------------------------------------------------*/
...@@ -2336,7 +2336,7 @@ struct usb_hcd *usb_create_shared_hcd(const struct hc_driver *driver, ...@@ -2336,7 +2336,7 @@ struct usb_hcd *usb_create_shared_hcd(const struct hc_driver *driver,
init_timer(&hcd->rh_timer); init_timer(&hcd->rh_timer);
hcd->rh_timer.function = rh_timer_func; hcd->rh_timer.function = rh_timer_func;
hcd->rh_timer.data = (unsigned long) hcd; hcd->rh_timer.data = (unsigned long) hcd;
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
INIT_WORK(&hcd->wakeup_work, hcd_resume_work); INIT_WORK(&hcd->wakeup_work, hcd_resume_work);
#endif #endif
...@@ -2590,7 +2590,7 @@ int usb_add_hcd(struct usb_hcd *hcd, ...@@ -2590,7 +2590,7 @@ int usb_add_hcd(struct usb_hcd *hcd,
hcd->rh_registered = 0; hcd->rh_registered = 0;
spin_unlock_irq(&hcd_root_hub_lock); spin_unlock_irq(&hcd_root_hub_lock);
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
cancel_work_sync(&hcd->wakeup_work); cancel_work_sync(&hcd->wakeup_work);
#endif #endif
mutex_lock(&usb_bus_list_lock); mutex_lock(&usb_bus_list_lock);
...@@ -2645,7 +2645,7 @@ void usb_remove_hcd(struct usb_hcd *hcd) ...@@ -2645,7 +2645,7 @@ void usb_remove_hcd(struct usb_hcd *hcd)
hcd->rh_registered = 0; hcd->rh_registered = 0;
spin_unlock_irq (&hcd_root_hub_lock); spin_unlock_irq (&hcd_root_hub_lock);
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
cancel_work_sync(&hcd->wakeup_work); cancel_work_sync(&hcd->wakeup_work);
#endif #endif
......
...@@ -2827,7 +2827,7 @@ void usb_enable_ltm(struct usb_device *udev) ...@@ -2827,7 +2827,7 @@ void usb_enable_ltm(struct usb_device *udev)
} }
EXPORT_SYMBOL_GPL(usb_enable_ltm); EXPORT_SYMBOL_GPL(usb_enable_ltm);
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM
/* /*
* usb_disable_function_remotewakeup - disable usb3.0 * usb_disable_function_remotewakeup - disable usb3.0
* device's function remote wakeup * device's function remote wakeup
...@@ -2886,7 +2886,7 @@ static int usb_disable_function_remotewakeup(struct usb_device *udev) ...@@ -2886,7 +2886,7 @@ static int usb_disable_function_remotewakeup(struct usb_device *udev)
* Linux (2.6) currently has NO mechanisms to initiate that: no khubd * Linux (2.6) currently has NO mechanisms to initiate that: no khubd
* timer, no SRP, no requests through sysfs. * timer, no SRP, no requests through sysfs.
* *
* If CONFIG_USB_SUSPEND isn't enabled, non-SuperSpeed devices really get * If Runtime PM isn't enabled or used, non-SuperSpeed devices really get
* suspended only when their bus goes into global suspend (i.e., the root * suspended only when their bus goes into global suspend (i.e., the root
* hub is suspended). Nevertheless, we change @udev->state to * hub is suspended). Nevertheless, we change @udev->state to
* USB_STATE_SUSPENDED as this is the device's "logical" state. The actual * USB_STATE_SUSPENDED as this is the device's "logical" state. The actual
...@@ -3247,6 +3247,10 @@ int usb_port_resume(struct usb_device *udev, pm_message_t msg) ...@@ -3247,6 +3247,10 @@ int usb_port_resume(struct usb_device *udev, pm_message_t msg)
return status; return status;
} }
#endif /* CONFIG_PM */
#ifdef CONFIG_PM_RUNTIME
/* caller has locked udev */ /* caller has locked udev */
int usb_remote_wakeup(struct usb_device *udev) int usb_remote_wakeup(struct usb_device *udev)
{ {
...@@ -3263,38 +3267,6 @@ int usb_remote_wakeup(struct usb_device *udev) ...@@ -3263,38 +3267,6 @@ int usb_remote_wakeup(struct usb_device *udev)
return status; return status;
} }
#else /* CONFIG_USB_SUSPEND */
/* When CONFIG_USB_SUSPEND isn't set, we never suspend or resume any ports. */
int usb_port_suspend(struct usb_device *udev, pm_message_t msg)
{
return 0;
}
/* However we may need to do a reset-resume */
int usb_port_resume(struct usb_device *udev, pm_message_t msg)
{
struct usb_hub *hub = usb_hub_to_struct_hub(udev->parent);
int port1 = udev->portnum;
int status;
u16 portchange, portstatus;
status = hub_port_status(hub, port1, &portstatus, &portchange);
status = check_port_resume_type(udev,
hub, port1, status, portchange, portstatus);
if (status) {
dev_dbg(&udev->dev, "can't resume, status %d\n", status);
hub_port_logical_disconnect(hub, port1);
} else if (udev->reset_resume) {
dev_dbg(&udev->dev, "reset-resume\n");
status = usb_reset_and_verify_device(udev);
}
return status;
}
#endif #endif
static int check_ports_changed(struct usb_hub *hub) static int check_ports_changed(struct usb_hub *hub)
...@@ -4356,7 +4328,7 @@ static void hub_port_connect_change(struct usb_hub *hub, int port1, ...@@ -4356,7 +4328,7 @@ static void hub_port_connect_change(struct usb_hub *hub, int port1,
if (portstatus & USB_PORT_STAT_ENABLE) { if (portstatus & USB_PORT_STAT_ENABLE) {
status = 0; /* Nothing to do */ status = 0; /* Nothing to do */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
} else if (udev->state == USB_STATE_SUSPENDED && } else if (udev->state == USB_STATE_SUSPENDED &&
udev->persist_enabled) { udev->persist_enabled) {
/* For a suspended device, treat this as a /* For a suspended device, treat this as a
......
...@@ -71,7 +71,7 @@ static void usb_port_device_release(struct device *dev) ...@@ -71,7 +71,7 @@ static void usb_port_device_release(struct device *dev)
kfree(port_dev); kfree(port_dev);
} }
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
static int usb_port_runtime_resume(struct device *dev) static int usb_port_runtime_resume(struct device *dev)
{ {
struct usb_port *port_dev = to_usb_port(dev); struct usb_port *port_dev = to_usb_port(dev);
...@@ -139,7 +139,7 @@ static int usb_port_runtime_suspend(struct device *dev) ...@@ -139,7 +139,7 @@ static int usb_port_runtime_suspend(struct device *dev)
#endif #endif
static const struct dev_pm_ops usb_port_pm_ops = { static const struct dev_pm_ops usb_port_pm_ops = {
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
.runtime_suspend = usb_port_runtime_suspend, .runtime_suspend = usb_port_runtime_suspend,
.runtime_resume = usb_port_runtime_resume, .runtime_resume = usb_port_runtime_resume,
.runtime_idle = pm_generic_runtime_idle, .runtime_idle = pm_generic_runtime_idle,
......
...@@ -338,7 +338,7 @@ static void remove_persist_attributes(struct device *dev) ...@@ -338,7 +338,7 @@ static void remove_persist_attributes(struct device *dev)
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
static ssize_t static ssize_t
show_connected_duration(struct device *dev, struct device_attribute *attr, show_connected_duration(struct device *dev, struct device_attribute *attr,
...@@ -544,7 +544,7 @@ static void remove_power_attributes(struct device *dev) ...@@ -544,7 +544,7 @@ static void remove_power_attributes(struct device *dev)
#define add_power_attributes(dev) 0 #define add_power_attributes(dev) 0
#define remove_power_attributes(dev) do {} while (0) #define remove_power_attributes(dev) do {} while (0)
#endif /* CONFIG_USB_SUSPEND */ #endif /* CONFIG_PM_RUNTIME */
/* Descriptor fields */ /* Descriptor fields */
......
...@@ -49,7 +49,7 @@ const char *usbcore_name = "usbcore"; ...@@ -49,7 +49,7 @@ const char *usbcore_name = "usbcore";
static bool nousb; /* Disable USB when built into kernel image */ static bool nousb; /* Disable USB when built into kernel image */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
static int usb_autosuspend_delay = 2; /* Default delay value, static int usb_autosuspend_delay = 2; /* Default delay value,
* in seconds */ * in seconds */
module_param_named(autosuspend, usb_autosuspend_delay, int, 0644); module_param_named(autosuspend, usb_autosuspend_delay, int, 0644);
...@@ -307,7 +307,7 @@ static const struct dev_pm_ops usb_device_pm_ops = { ...@@ -307,7 +307,7 @@ static const struct dev_pm_ops usb_device_pm_ops = {
.thaw = usb_dev_thaw, .thaw = usb_dev_thaw,
.poweroff = usb_dev_poweroff, .poweroff = usb_dev_poweroff,
.restore = usb_dev_restore, .restore = usb_dev_restore,
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
.runtime_suspend = usb_runtime_suspend, .runtime_suspend = usb_runtime_suspend,
.runtime_resume = usb_runtime_resume, .runtime_resume = usb_runtime_resume,
.runtime_idle = usb_runtime_idle, .runtime_idle = usb_runtime_idle,
......
...@@ -93,7 +93,7 @@ static inline int usb_port_resume(struct usb_device *udev, pm_message_t msg) ...@@ -93,7 +93,7 @@ static inline int usb_port_resume(struct usb_device *udev, pm_message_t msg)
#endif #endif
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
extern void usb_autosuspend_device(struct usb_device *udev); extern void usb_autosuspend_device(struct usb_device *udev);
extern int usb_autoresume_device(struct usb_device *udev); extern int usb_autoresume_device(struct usb_device *udev);
......
...@@ -292,17 +292,7 @@ static int ehci_pci_setup(struct usb_hcd *hcd) ...@@ -292,17 +292,7 @@ static int ehci_pci_setup(struct usb_hcd *hcd)
} }
} }
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
/* REVISIT: the controller works fine for wakeup iff the root hub
* itself is "globally" suspended, but usbcore currently doesn't
* understand such things.
*
* System suspend currently expects to be able to suspend the entire
* device tree, device-at-a-time. If we failed selective suspend
* reports, system suspend would fail; so the root hub code must claim
* success. That's lying to usbcore, and it matters for runtime
* PM scenarios with selective suspend and remote wakeup...
*/
if (ehci->no_selective_suspend && device_can_wakeup(&pdev->dev)) if (ehci->no_selective_suspend && device_can_wakeup(&pdev->dev))
ehci_warn(ehci, "selective suspend/wakeup unavailable\n"); ehci_warn(ehci, "selective suspend/wakeup unavailable\n");
#endif #endif
......
...@@ -580,14 +580,8 @@ static int ohci_start_port_reset (struct usb_hcd *hcd, unsigned port) ...@@ -580,14 +580,8 @@ static int ohci_start_port_reset (struct usb_hcd *hcd, unsigned port)
/* See usb 7.1.7.5: root hubs must issue at least 50 msec reset signaling, /* See usb 7.1.7.5: root hubs must issue at least 50 msec reset signaling,
* not necessarily continuous ... to guard against resume signaling. * not necessarily continuous ... to guard against resume signaling.
* The short timeout is safe for non-root hubs, and is backward-compatible
* with earlier Linux hosts.
*/ */
#ifdef CONFIG_USB_SUSPEND
#define PORT_RESET_MSEC 50 #define PORT_RESET_MSEC 50
#else
#define PORT_RESET_MSEC 10
#endif
/* this timer value might be vendor-specific ... */ /* this timer value might be vendor-specific ... */
#define PORT_RESET_HW_MSEC 10 #define PORT_RESET_HW_MSEC 10
......
...@@ -1755,7 +1755,7 @@ sl811h_probe(struct platform_device *dev) ...@@ -1755,7 +1755,7 @@ sl811h_probe(struct platform_device *dev)
/* for this device there's no useful distinction between the controller /* for this device there's no useful distinction between the controller
* and its root hub, except that the root hub only gets direct PM calls * and its root hub, except that the root hub only gets direct PM calls
* when CONFIG_USB_SUSPEND is enabled. * when CONFIG_PM_RUNTIME is enabled.
*/ */
static int static int
......
...@@ -3141,10 +3141,11 @@ static int u132_probe(struct platform_device *pdev) ...@@ -3141,10 +3141,11 @@ static int u132_probe(struct platform_device *pdev)
#ifdef CONFIG_PM #ifdef CONFIG_PM
/* for this device there's no useful distinction between the controller /*
* and its root hub, except that the root hub only gets direct PM calls * for this device there's no useful distinction between the controller
* when CONFIG_USB_SUSPEND is enabled. * and its root hub, except that the root hub only gets direct PM calls
*/ * when CONFIG_PM_RUNTIME is enabled.
*/
static int u132_suspend(struct platform_device *pdev, pm_message_t state) static int u132_suspend(struct platform_device *pdev, pm_message_t state)
{ {
struct usb_hcd *hcd = platform_get_drvdata(pdev); struct usb_hcd *hcd = platform_get_drvdata(pdev);
......
...@@ -1075,7 +1075,7 @@ int xhci_bus_suspend(struct usb_hcd *hcd) ...@@ -1075,7 +1075,7 @@ int xhci_bus_suspend(struct usb_hcd *hcd)
set_bit(port_index, &bus_state->bus_suspended); set_bit(port_index, &bus_state->bus_suspended);
} }
/* USB core sets remote wake mask for USB 3.0 hubs, /* USB core sets remote wake mask for USB 3.0 hubs,
* including the USB 3.0 roothub, but only if CONFIG_USB_SUSPEND * including the USB 3.0 roothub, but only if CONFIG_PM_RUNTIME
* is enabled, so also enable remote wake here. * is enabled, so also enable remote wake here.
*/ */
if (hcd->self.root_hub->do_remote_wakeup) { if (hcd->self.root_hub->do_remote_wakeup) {
......
...@@ -3801,7 +3801,7 @@ int xhci_find_raw_port_number(struct usb_hcd *hcd, int port1) ...@@ -3801,7 +3801,7 @@ int xhci_find_raw_port_number(struct usb_hcd *hcd, int port1)
return raw_port; return raw_port;
} }
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
/* BESL to HIRD Encoding array for USB2 LPM */ /* BESL to HIRD Encoding array for USB2 LPM */
static int xhci_besl_encoding[16] = {125, 150, 200, 300, 400, 500, 1000, 2000, static int xhci_besl_encoding[16] = {125, 150, 200, 300, 400, 500, 1000, 2000,
...@@ -4051,7 +4051,7 @@ int xhci_update_device(struct usb_hcd *hcd, struct usb_device *udev) ...@@ -4051,7 +4051,7 @@ int xhci_update_device(struct usb_hcd *hcd, struct usb_device *udev)
return 0; return 0;
} }
#endif /* CONFIG_USB_SUSPEND */ #endif /* CONFIG_PM_RUNTIME */
/*---------------------- USB 3.0 Link PM functions ------------------------*/ /*---------------------- USB 3.0 Link PM functions ------------------------*/
......
...@@ -617,7 +617,7 @@ static inline bool usb_acpi_power_manageable(struct usb_device *hdev, int index) ...@@ -617,7 +617,7 @@ static inline bool usb_acpi_power_manageable(struct usb_device *hdev, int index)
#endif #endif
/* USB autosuspend and autoresume */ /* USB autosuspend and autoresume */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
extern void usb_enable_autosuspend(struct usb_device *udev); extern void usb_enable_autosuspend(struct usb_device *udev);
extern void usb_disable_autosuspend(struct usb_device *udev); extern void usb_disable_autosuspend(struct usb_device *udev);
......
...@@ -84,7 +84,7 @@ struct usb_hcd { ...@@ -84,7 +84,7 @@ struct usb_hcd {
struct timer_list rh_timer; /* drives root-hub polling */ struct timer_list rh_timer; /* drives root-hub polling */
struct urb *status_urb; /* the current status urb */ struct urb *status_urb; /* the current status urb */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
struct work_struct wakeup_work; /* for remote wakeup */ struct work_struct wakeup_work; /* for remote wakeup */
#endif #endif
...@@ -593,14 +593,14 @@ extern int hcd_bus_suspend(struct usb_device *rhdev, pm_message_t msg); ...@@ -593,14 +593,14 @@ extern int hcd_bus_suspend(struct usb_device *rhdev, pm_message_t msg);
extern int hcd_bus_resume(struct usb_device *rhdev, pm_message_t msg); extern int hcd_bus_resume(struct usb_device *rhdev, pm_message_t msg);
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
#ifdef CONFIG_USB_SUSPEND #ifdef CONFIG_PM_RUNTIME
extern void usb_hcd_resume_root_hub(struct usb_hcd *hcd); extern void usb_hcd_resume_root_hub(struct usb_hcd *hcd);
#else #else
static inline void usb_hcd_resume_root_hub(struct usb_hcd *hcd) static inline void usb_hcd_resume_root_hub(struct usb_hcd *hcd)
{ {
return; return;
} }
#endif /* CONFIG_USB_SUSPEND */ #endif /* CONFIG_PM_RUNTIME */
/*-------------------------------------------------------------------------*/ /*-------------------------------------------------------------------------*/
......
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