From e74b8188505d6fae69237e9f546d0fb93cb83d88 Mon Sep 17 00:00:00 2001 From: David Woodhouse Date: Wed, 12 Dec 2007 17:40:56 -0500 Subject: [PATCH] --- yaml --- r: 79192 b: refs/heads/master c: d1f7a5b8cfefdb443a05a9e3d636fe7fef57459a h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/net/wireless/libertas/if_usb.c | 16 +++++++++++----- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/[refs] b/[refs] index ab6b2733b58b..1f4cbe1fd8ad 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: ab25ecaea5459f2206dbae25106cff67a24d309e +refs/heads/master: d1f7a5b8cfefdb443a05a9e3d636fe7fef57459a diff --git a/trunk/drivers/net/wireless/libertas/if_usb.c b/trunk/drivers/net/wireless/libertas/if_usb.c index 74fec9dfca07..15715a6b59e0 100644 --- a/trunk/drivers/net/wireless/libertas/if_usb.c +++ b/trunk/drivers/net/wireless/libertas/if_usb.c @@ -242,6 +242,10 @@ static int if_usb_probe(struct usb_interface *intf, if_usb_set_boot2_ver(priv); + /* Set suspend/resume configuration: + wake via GPIO2 after a 20ms delay */ + lbs_host_sleep_cfg(priv, EHS_WAKE_ON_UNICAST_DATA, 2, 20); + usb_get_dev(udev); usb_set_intfdata(intf, cardp); @@ -969,21 +973,24 @@ static int if_usb_suspend(struct usb_interface *intf, pm_message_t message) { struct usb_card_rec *cardp = usb_get_intfdata(intf); struct lbs_private *priv = cardp->priv; + int ret; lbs_deb_enter(LBS_DEB_USB); if (priv->psstate != PS_STATE_FULL_POWER) return -1; - netif_device_detach(priv->dev); - netif_device_detach(priv->mesh_dev); + ret = lbs_suspend(priv); + if (ret) + goto out; /* Unlink tx & rx urb */ usb_kill_urb(cardp->tx_urb); usb_kill_urb(cardp->rx_urb); + out: lbs_deb_leave(LBS_DEB_USB); - return 0; + return ret; } static int if_usb_resume(struct usb_interface *intf) @@ -995,8 +1002,7 @@ static int if_usb_resume(struct usb_interface *intf) if_usb_submit_rx_urb(cardp); - netif_device_attach(priv->dev); - netif_device_attach(priv->mesh_dev); + lbs_resume(priv); lbs_deb_leave(LBS_DEB_USB); return 0;