aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorAlan Stern <stern@rowland.harvard.edu>2007-05-30 15:35:16 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2007-07-12 19:34:29 -0400
commit624d6c0732d2c4ac00945ad79dbb6ff39ba90ee3 (patch)
tree411f9288fcc640a1ae935144e950ad44765157ba /drivers
parent686314cfbdac21c9019c0e04487b5d940db62406 (diff)
USB: remove excess code from hub.c
This patch (as917) removes a now-unnecessary level of subroutine nesting from hub.c. Since usb_port_suspend() does nothing but call hub_port_suspend(), and usb_port_resume() does nothing but call hub_port_resume(), there's no reason to keep the routines separate. Also included in the patch are a few cosmetic changes involving whitespace and use of braces. Signed-off-by: Alan Stern <stern@rowland.harvard.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/usb/core/hub.c175
1 files changed, 71 insertions, 104 deletions
diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c
index ac1ef1527dd2..ca3dbf84e800 100644
--- a/drivers/usb/core/hub.c
+++ b/drivers/usb/core/hub.c
@@ -1625,6 +1625,19 @@ static int hub_port_reset(struct usb_hub *hub, int port1,
1625#ifdef CONFIG_USB_SUSPEND 1625#ifdef CONFIG_USB_SUSPEND
1626 1626
1627/* 1627/*
1628 * usb_port_suspend - suspend a usb device's upstream port
1629 * @udev: device that's no longer in active use, not a root hub
1630 * Context: must be able to sleep; device not locked; pm locks held
1631 *
1632 * Suspends a USB device that isn't in active use, conserving power.
1633 * Devices may wake out of a suspend, if anything important happens,
1634 * using the remote wakeup mechanism. They may also be taken out of
1635 * suspend by the host, using usb_port_resume(). It's also routine
1636 * to disconnect devices while they are suspended.
1637 *
1638 * This only affects the USB hardware for a device; its interfaces
1639 * (and, for hubs, child devices) must already have been suspended.
1640 *
1628 * Selective port suspend reduces power; most suspended devices draw 1641 * Selective port suspend reduces power; most suspended devices draw
1629 * less than 500 uA. It's also used in OTG, along with remote wakeup. 1642 * less than 500 uA. It's also used in OTG, along with remote wakeup.
1630 * All devices below the suspended port are also suspended. 1643 * All devices below the suspended port are also suspended.
@@ -1633,11 +1646,35 @@ static int hub_port_reset(struct usb_hub *hub, int port1,
1633 * also support "remote wakeup", where the device can activate the USB 1646 * also support "remote wakeup", where the device can activate the USB
1634 * tree above them to deliver data, such as a keypress or packet. In 1647 * tree above them to deliver data, such as a keypress or packet. In
1635 * some cases, this wakes the USB host. 1648 * some cases, this wakes the USB host.
1649 *
1650 * Suspending OTG devices may trigger HNP, if that's been enabled
1651 * between a pair of dual-role devices. That will change roles, such
1652 * as from A-Host to A-Peripheral or from B-Host back to B-Peripheral.
1653 *
1654 * Devices on USB hub ports have only one "suspend" state, corresponding
1655 * to ACPI D2, "may cause the device to lose some context".
1656 * State transitions include:
1657 *
1658 * - suspend, resume ... when the VBUS power link stays live
1659 * - suspend, disconnect ... VBUS lost
1660 *
1661 * Once VBUS drop breaks the circuit, the port it's using has to go through
1662 * normal re-enumeration procedures, starting with enabling VBUS power.
1663 * Other than re-initializing the hub (plug/unplug, except for root hubs),
1664 * Linux (2.6) currently has NO mechanisms to initiate that: no khubd
1665 * timer, no SRP, no requests through sysfs.
1666 *
1667 * If CONFIG_USB_SUSPEND isn't enabled, devices only really suspend when
1668 * the root hub for their bus goes into global suspend ... so we don't
1669 * (falsely) update the device power state to say it suspended.
1670 *
1671 * Returns 0 on success, else negative errno.
1636 */ 1672 */
1637static int hub_port_suspend(struct usb_hub *hub, int port1, 1673int usb_port_suspend(struct usb_device *udev)
1638 struct usb_device *udev)
1639{ 1674{
1640 int status; 1675 struct usb_hub *hub = hdev_to_hub(udev->parent);
1676 int port1 = udev->portnum;
1677 int status;
1641 1678
1642 // dev_dbg(hub->intfdev, "suspend port %d\n", port1); 1679 // dev_dbg(hub->intfdev, "suspend port %d\n", port1);
1643 1680
@@ -1654,17 +1691,15 @@ static int hub_port_suspend(struct usb_hub *hub, int port1,
1654 NULL, 0, 1691 NULL, 0,
1655 USB_CTRL_SET_TIMEOUT); 1692 USB_CTRL_SET_TIMEOUT);
1656 if (status) 1693 if (status)
1657 dev_dbg(&udev->dev, 1694 dev_dbg(&udev->dev, "won't remote wakeup, status %d\n",
1658 "won't remote wakeup, status %d\n", 1695 status);
1659 status);
1660 } 1696 }
1661 1697
1662 /* see 7.1.7.6 */ 1698 /* see 7.1.7.6 */
1663 status = set_port_feature(hub->hdev, port1, USB_PORT_FEAT_SUSPEND); 1699 status = set_port_feature(hub->hdev, port1, USB_PORT_FEAT_SUSPEND);
1664 if (status) { 1700 if (status) {
1665 dev_dbg(hub->intfdev, 1701 dev_dbg(hub->intfdev, "can't suspend port %d, status %d\n",
1666 "can't suspend port %d, status %d\n", 1702 port1, status);
1667 port1, status);
1668 /* paranoia: "should not happen" */ 1703 /* paranoia: "should not happen" */
1669 (void) usb_control_msg(udev, usb_sndctrlpipe(udev, 0), 1704 (void) usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
1670 USB_REQ_CLEAR_FEATURE, USB_RECIP_DEVICE, 1705 USB_REQ_CLEAR_FEATURE, USB_RECIP_DEVICE,
@@ -1682,52 +1717,6 @@ static int hub_port_suspend(struct usb_hub *hub, int port1,
1682} 1717}
1683 1718
1684/* 1719/*
1685 * usb_port_suspend - suspend a usb device's upstream port
1686 * @udev: device that's no longer in active use
1687 * Context: must be able to sleep; device not locked; pm locks held
1688 *
1689 * Suspends a USB device that isn't in active use, conserving power.
1690 * Devices may wake out of a suspend, if anything important happens,
1691 * using the remote wakeup mechanism. They may also be taken out of
1692 * suspend by the host, using usb_port_resume(). It's also routine
1693 * to disconnect devices while they are suspended.
1694 *
1695 * This only affects the USB hardware for a device; its interfaces
1696 * (and, for hubs, child devices) must already have been suspended.
1697 *
1698 * Suspending OTG devices may trigger HNP, if that's been enabled
1699 * between a pair of dual-role devices. That will change roles, such
1700 * as from A-Host to A-Peripheral or from B-Host back to B-Peripheral.
1701 *
1702 * Devices on USB hub ports have only one "suspend" state, corresponding
1703 * to ACPI D2, "may cause the device to lose some context".
1704 * State transitions include:
1705 *
1706 * - suspend, resume ... when the VBUS power link stays live
1707 * - suspend, disconnect ... VBUS lost
1708 *
1709 * Once VBUS drop breaks the circuit, the port it's using has to go through
1710 * normal re-enumeration procedures, starting with enabling VBUS power.
1711 * Other than re-initializing the hub (plug/unplug, except for root hubs),
1712 * Linux (2.6) currently has NO mechanisms to initiate that: no khubd
1713 * timer, no SRP, no requests through sysfs.
1714 *
1715 * If CONFIG_USB_SUSPEND isn't enabled, devices only really suspend when
1716 * the root hub for their bus goes into global suspend ... so we don't
1717 * (falsely) update the device power state to say it suspended.
1718 *
1719 * Returns 0 on success, else negative errno.
1720 */
1721int usb_port_suspend(struct usb_device *udev)
1722{
1723 int status = 0;
1724
1725 status = hub_port_suspend(hdev_to_hub(udev->parent),
1726 udev->portnum, udev);
1727 return status;
1728}
1729
1730/*
1731 * If the USB "suspend" state is in use (rather than "global suspend"), 1720 * If the USB "suspend" state is in use (rather than "global suspend"),
1732 * many devices will be individually taken out of suspend state using 1721 * many devices will be individually taken out of suspend state using
1733 * special" resume" signaling. These routines kick in shortly after 1722 * special" resume" signaling. These routines kick in shortly after
@@ -1760,11 +1749,10 @@ static int finish_port_resume(struct usb_device *udev)
1760 if (status >= 0) 1749 if (status >= 0)
1761 status = (status == 2 ? 0 : -ENODEV); 1750 status = (status == 2 ? 0 : -ENODEV);
1762 1751
1763 if (status) 1752 if (status) {
1764 dev_dbg(&udev->dev, 1753 dev_dbg(&udev->dev, "gone after usb resume? status %d\n",
1765 "gone after usb resume? status %d\n", 1754 status);
1766 status); 1755 } else if (udev->actconfig) {
1767 else if (udev->actconfig) {
1768 le16_to_cpus(&devstatus); 1756 le16_to_cpus(&devstatus);
1769 if (devstatus & (1 << USB_DEVICE_REMOTE_WAKEUP)) { 1757 if (devstatus & (1 << USB_DEVICE_REMOTE_WAKEUP)) {
1770 status = usb_control_msg(udev, 1758 status = usb_control_msg(udev,
@@ -1783,11 +1771,25 @@ static int finish_port_resume(struct usb_device *udev)
1783 return status; 1771 return status;
1784} 1772}
1785 1773
1786static int 1774/*
1787hub_port_resume(struct usb_hub *hub, int port1, struct usb_device *udev) 1775 * usb_port_resume - re-activate a suspended usb device's upstream port
1776 * @udev: device to re-activate, not a root hub
1777 * Context: must be able to sleep; device not locked; pm locks held
1778 *
1779 * This will re-activate the suspended device, increasing power usage
1780 * while letting drivers communicate again with its endpoints.
1781 * USB resume explicitly guarantees that the power session between
1782 * the host and the device is the same as it was when the device
1783 * suspended.
1784 *
1785 * Returns 0 on success, else negative errno.
1786 */
1787int usb_port_resume(struct usb_device *udev)
1788{ 1788{
1789 int status; 1789 struct usb_hub *hub = hdev_to_hub(udev->parent);
1790 u16 portchange, portstatus; 1790 int port1 = udev->portnum;
1791 int status;
1792 u16 portchange, portstatus;
1791 1793
1792 /* Skip the initial Clear-Suspend step for a remote wakeup */ 1794 /* Skip the initial Clear-Suspend step for a remote wakeup */
1793 status = hub_port_status(hub, port1, &portstatus, &portchange); 1795 status = hub_port_status(hub, port1, &portstatus, &portchange);
@@ -1802,9 +1804,8 @@ hub_port_resume(struct usb_hub *hub, int port1, struct usb_device *udev)
1802 status = clear_port_feature(hub->hdev, 1804 status = clear_port_feature(hub->hdev,
1803 port1, USB_PORT_FEAT_SUSPEND); 1805 port1, USB_PORT_FEAT_SUSPEND);
1804 if (status) { 1806 if (status) {
1805 dev_dbg(hub->intfdev, 1807 dev_dbg(hub->intfdev, "can't resume port %d, status %d\n",
1806 "can't resume port %d, status %d\n", 1808 port1, status);
1807 port1, status);
1808 } else { 1809 } else {
1809 /* drive resume for at least 20 msec */ 1810 /* drive resume for at least 20 msec */
1810 dev_dbg(&udev->dev, "usb %sresume\n", 1811 dev_dbg(&udev->dev, "usb %sresume\n",
@@ -1839,8 +1840,10 @@ SuspendCleared:
1839 status = finish_port_resume(udev); 1840 status = finish_port_resume(udev);
1840 } 1841 }
1841 } 1842 }
1842 if (status < 0) 1843 if (status < 0) {
1844 dev_dbg(&udev->dev, "can't resume, status %d\n", status);
1843 hub_port_logical_disconnect(hub, port1); 1845 hub_port_logical_disconnect(hub, port1);
1846 }
1844 1847
1845 clear_bit(port1, hub->busy_bits); 1848 clear_bit(port1, hub->busy_bits);
1846 if (!hub->hdev->parent && !hub->busy_bits[0]) 1849 if (!hub->hdev->parent && !hub->busy_bits[0])
@@ -1849,30 +1852,6 @@ SuspendCleared:
1849 return status; 1852 return status;
1850} 1853}
1851 1854
1852/*
1853 * usb_port_resume - re-activate a suspended usb device's upstream port
1854 * @udev: device to re-activate
1855 * Context: must be able to sleep; device not locked; pm locks held
1856 *
1857 * This will re-activate the suspended device, increasing power usage
1858 * while letting drivers communicate again with its endpoints.
1859 * USB resume explicitly guarantees that the power session between
1860 * the host and the device is the same as it was when the device
1861 * suspended.
1862 *
1863 * Returns 0 on success, else negative errno.
1864 */
1865int usb_port_resume(struct usb_device *udev)
1866{
1867 int status;
1868
1869 status = hub_port_resume(hdev_to_hub(udev->parent),
1870 udev->portnum, udev);
1871 if (status < 0)
1872 dev_dbg(&udev->dev, "can't resume, status %d\n", status);
1873 return status;
1874}
1875
1876static int remote_wakeup(struct usb_device *udev) 1855static int remote_wakeup(struct usb_device *udev)
1877{ 1856{
1878 int status = 0; 1857 int status = 0;
@@ -1896,18 +1875,6 @@ int usb_port_suspend(struct usb_device *udev)
1896 return 0; 1875 return 0;
1897} 1876}
1898 1877
1899static inline int
1900finish_port_resume(struct usb_device *udev)
1901{
1902 return 0;
1903}
1904
1905static inline int
1906hub_port_resume(struct usb_hub *hub, int port1, struct usb_device *udev)
1907{
1908 return 0;
1909}
1910
1911int usb_port_resume(struct usb_device *udev) 1878int usb_port_resume(struct usb_device *udev)
1912{ 1879{
1913 return 0; 1880 return 0;