On Wednesday 30 March 2005 4:44 am, Colin Leroy wrote:
> Hi,
>
> this patch enables power management (suspend, resume) support for
> zd1201. It fixes problems after wakeup for me, but these problems did
> not appear everytime without this patch. it's a bit empirical, based on
> what the usbnet does, so maybe not correct... Maybe someone can give it
> a look before it's applied.
Looked ok to me, other than needing to change "u32 state" into
a "pm_message_t message". And I'm not sure why "mac_enabled"
would be the right test, rather than maybe netif_running().
You might want to forward it to the netdev list; at least
Jeff Garzik wants those folk to be able to review network
driver updates.
- Dave
> Thanks.
>
> Signed-off-by: Colin Leroy <[EMAIL PROTECTED]>
> --- a/drivers/usb/net/zd1201.c 2005-03-30 14:35:23.000000000 +0200
> +++ b/drivers/usb/net/zd1201.c 2005-03-30 14:31:04.000000000 +0200
> @@ -1896,12 +1896,49 @@
> kfree(zd);
> }
>
> +#ifdef CONFIG_PM
> +
> +static int zd1201_suspend (struct usb_interface *interface, u32 state)
> +{
> + struct zd1201 *zd = (struct zd1201 *)usb_get_intfdata(interface);
> +
> + netif_device_detach(zd->dev);
> +
> + zd->was_enabled = zd->mac_enabled;
> +
> + if (zd->was_enabled)
> + return zd1201_disable(zd);
> + else
> + return 0;
> +}
> +
> +static int zd1201_resume (struct usb_interface *interface)
> +{
> + struct zd1201 *zd = (struct zd1201 *)usb_get_intfdata(interface);
> +
> + netif_device_attach(zd->dev);
> +
> + if (zd->was_enabled)
> + return zd1201_enable(zd);
> + else
> + return 0;
> +}
> +
> +#else
> +
> +#define zd1201_suspend NULL
> +#define zd1201_resume NULL
> +
> +#endif
> +
> struct usb_driver zd1201_usb = {
> .owner = THIS_MODULE,
> .name = "zd1201",
> .probe = zd1201_probe,
> .disconnect = zd1201_disconnect,
> .id_table = zd1201_table,
> + .suspend = zd1201_suspend,
> + .resume = zd1201_resume,
> };
>
> static int __init zd1201_init(void)
> --- a/drivers/usb/net/zd1201.h 2005-03-30 14:35:36.000000000 +0200
> +++ b/drivers/usb/net/zd1201.h 2005-03-30 14:24:33.000000000 +0200
> @@ -46,6 +46,7 @@
> char essid[IW_ESSID_MAX_SIZE+1];
> int essidlen;
> int mac_enabled;
> + int was_enabled;
> int monitor;
> int encode_enabled;
> int encode_restricted;
>
>
-------------------------------------------------------
SF email is sponsored by - The IT Product Guide
Read honest & candid reviews on hundreds of IT Products from real users.
Discover which products truly live up to the hype. Start reading now.
http://ads.osdn.com/?ad_id=6595&alloc_id=14396&op=click
_______________________________________________
[email protected]
To unsubscribe, use the last form field at:
https://lists.sourceforge.net/lists/listinfo/linux-usb-devel