Commit b98b98f9 authored by Oliver Neukum's avatar Oliver Neukum Committed by Greg Kroah-Hartman

USB: power management for kaweth

- implements suspend when the network interface is down
- fixes a typo in comments
- adds debugging output for power management
- fixes a compiler warning
Signed-off-by: default avatarOliver Neukum <oneukum@suse.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 511779fd
...@@ -179,6 +179,7 @@ static struct usb_driver kaweth_driver = { ...@@ -179,6 +179,7 @@ static struct usb_driver kaweth_driver = {
.suspend = kaweth_suspend, .suspend = kaweth_suspend,
.resume = kaweth_resume, .resume = kaweth_resume,
.id_table = usb_klsi_table, .id_table = usb_klsi_table,
.supports_autosuspend = 1,
}; };
typedef __u8 eth_addr_t[6]; typedef __u8 eth_addr_t[6];
...@@ -225,6 +226,7 @@ struct kaweth_device ...@@ -225,6 +226,7 @@ struct kaweth_device
struct delayed_work lowmem_work; struct delayed_work lowmem_work;
struct usb_device *dev; struct usb_device *dev;
struct usb_interface *intf;
struct net_device *net; struct net_device *net;
wait_queue_head_t term_wait; wait_queue_head_t term_wait;
...@@ -662,9 +664,14 @@ static int kaweth_open(struct net_device *net) ...@@ -662,9 +664,14 @@ static int kaweth_open(struct net_device *net)
dbg("Opening network device."); dbg("Opening network device.");
res = usb_autopm_get_interface(kaweth->intf);
if (res) {
err("Interface cannot be resumed.");
return -EIO;
}
res = kaweth_resubmit_rx_urb(kaweth, GFP_KERNEL); res = kaweth_resubmit_rx_urb(kaweth, GFP_KERNEL);
if (res) if (res)
return -EIO; goto err_out;
usb_fill_int_urb( usb_fill_int_urb(
kaweth->irq_urb, kaweth->irq_urb,
...@@ -681,7 +688,7 @@ static int kaweth_open(struct net_device *net) ...@@ -681,7 +688,7 @@ static int kaweth_open(struct net_device *net)
res = usb_submit_urb(kaweth->irq_urb, GFP_KERNEL); res = usb_submit_urb(kaweth->irq_urb, GFP_KERNEL);
if (res) { if (res) {
usb_kill_urb(kaweth->rx_urb); usb_kill_urb(kaweth->rx_urb);
return -EIO; goto err_out;
} }
kaweth->opened = 1; kaweth->opened = 1;
...@@ -689,10 +696,14 @@ static int kaweth_open(struct net_device *net) ...@@ -689,10 +696,14 @@ static int kaweth_open(struct net_device *net)
kaweth_async_set_rx_mode(kaweth); kaweth_async_set_rx_mode(kaweth);
return 0; return 0;
err_out:
usb_autopm_enable(kaweth->intf);
return -EIO;
} }
/**************************************************************** /****************************************************************
* kaweth_close * kaweth_kill_urbs
****************************************************************/ ****************************************************************/
static void kaweth_kill_urbs(struct kaweth_device *kaweth) static void kaweth_kill_urbs(struct kaweth_device *kaweth)
{ {
...@@ -724,6 +735,8 @@ static int kaweth_close(struct net_device *net) ...@@ -724,6 +735,8 @@ static int kaweth_close(struct net_device *net)
kaweth->status &= ~KAWETH_STATUS_CLOSING; kaweth->status &= ~KAWETH_STATUS_CLOSING;
usb_autopm_enable(kaweth->intf);
return 0; return 0;
} }
...@@ -908,6 +921,7 @@ static int kaweth_suspend(struct usb_interface *intf, pm_message_t message) ...@@ -908,6 +921,7 @@ static int kaweth_suspend(struct usb_interface *intf, pm_message_t message)
struct kaweth_device *kaweth = usb_get_intfdata(intf); struct kaweth_device *kaweth = usb_get_intfdata(intf);
unsigned long flags; unsigned long flags;
dbg("Suspending device");
spin_lock_irqsave(&kaweth->device_lock, flags); spin_lock_irqsave(&kaweth->device_lock, flags);
kaweth->status |= KAWETH_STATUS_SUSPENDING; kaweth->status |= KAWETH_STATUS_SUSPENDING;
spin_unlock_irqrestore(&kaweth->device_lock, flags); spin_unlock_irqrestore(&kaweth->device_lock, flags);
...@@ -924,6 +938,7 @@ static int kaweth_resume(struct usb_interface *intf) ...@@ -924,6 +938,7 @@ static int kaweth_resume(struct usb_interface *intf)
struct kaweth_device *kaweth = usb_get_intfdata(intf); struct kaweth_device *kaweth = usb_get_intfdata(intf);
unsigned long flags; unsigned long flags;
dbg("Resuming device");
spin_lock_irqsave(&kaweth->device_lock, flags); spin_lock_irqsave(&kaweth->device_lock, flags);
kaweth->status &= ~KAWETH_STATUS_SUSPENDING; kaweth->status &= ~KAWETH_STATUS_SUSPENDING;
spin_unlock_irqrestore(&kaweth->device_lock, flags); spin_unlock_irqrestore(&kaweth->device_lock, flags);
...@@ -1086,6 +1101,8 @@ err_fw: ...@@ -1086,6 +1101,8 @@ err_fw:
dbg("Initializing net device."); dbg("Initializing net device.");
kaweth->intf = intf;
kaweth->tx_urb = usb_alloc_urb(0, GFP_KERNEL); kaweth->tx_urb = usb_alloc_urb(0, GFP_KERNEL);
if (!kaweth->tx_urb) if (!kaweth->tx_urb)
goto err_free_netdev; goto err_free_netdev;
...@@ -1265,7 +1282,7 @@ static int kaweth_internal_control_msg(struct usb_device *usb_dev, ...@@ -1265,7 +1282,7 @@ static int kaweth_internal_control_msg(struct usb_device *usb_dev,
{ {
struct urb *urb; struct urb *urb;
int retv; int retv;
int length; int length = 0; /* shut up GCC */
urb = usb_alloc_urb(0, GFP_NOIO); urb = usb_alloc_urb(0, GFP_NOIO);
if (!urb) if (!urb)
......
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