login
Login
/
Register
Search
Search this site:
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2007
»
October
»
30
Re: [linux-usb-devel] [PATCH 1/2] usb_gigaset: suspend support
view
thread
Previous message: [thread] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
[view in full thread]
From: Oliver Neukum
Subject:
Re: [linux-usb-devel] [PATCH 1/2] usb_gigaset: suspend support
Date: Tuesday, October 30, 2007 - 1:52 am
Am Montag 29 Oktober 2007 schrieb Tilman Schmidt:
quoted text
> From: Tilman Schmidt <tilman@imap.cc> > > Add basic suspend/resume support to the usb_gigaset driver. > > Signed-off-by: Tilman Schmidt <tilman@imap.cc> > --- > > drivers/isdn/gigaset/usb-gigaset.c | 69 ++++++++++++++++++++++++++++++++++++- > 1 file changed, 68 insertions(+), 1 deletion(-) > > --- a/drivers/isdn/gigaset/usb-gigaset.c 2007-10-23 01:48:12.000000000 +0200 > +++ b/drivers/isdn/gigaset/usb-gigaset.c 2007-10-24 00:47:32.000000000 +0200 > @@ -104,10 +104,15 @@ MODULE_DEVICE_TABLE(usb, gigaset_table); > * flags per packet. > */ > > +/* functions called if a device of this driver is connected/disconnected */ > static int gigaset_probe(struct usb_interface *interface, > const struct usb_device_id *id); > static void gigaset_disconnect(struct usb_interface *interface); > > +/* functions called before/after suspend */ > +static int gigaset_suspend(struct usb_interface *intf, pm_message_t message); > +static int gigaset_resume(struct usb_interface *intf); > + > static struct gigaset_driver *driver = NULL; > static struct cardstate *cardstate = NULL; > > @@ -117,6 +122,11 @@ static struct usb_driver gigaset_usb_dri > .probe = gigaset_probe, > .disconnect = gigaset_disconnect, > .id_table = gigaset_table, > + .suspend = gigaset_suspend, > + .resume = gigaset_resume, > + .reset_resume = gigaset_resume, > + .pre_reset = gigaset_suspend, > + .post_reset = gigaset_resume, > }; > > struct usb_cardstate { > @@ -831,7 +843,7 @@ static void gigaset_disconnect(struct us > usb_set_intfdata(interface, NULL); > tasklet_kill(&cs->write_tasklet); > > - usb_kill_urb(ucs->bulk_out_urb); /* FIXME: only if active? */ > + usb_kill_urb(ucs->bulk_out_urb); > > kfree(ucs->bulk_out_buffer); > usb_free_urb(ucs->bulk_out_urb); > @@ -847,6 +859,63 @@ static void gigaset_disconnect(struct us > gigaset_unassign(cs); > } > > +/* gigaset_suspend > + * This function is called before the USB connection is suspended or reset. > + */ > +static int gigaset_suspend(struct usb_interface *intf, pm_message_t message) > +{ > + struct cardstate *cs; > + struct usb_cardstate *ucs; > + int rc; > + > + if ((cs = usb_get_intfdata(intf)) == NULL || > + (ucs = cs->hw.usb) == NULL) { > + err("%s: no cardstate", __func__); > + return -EFAULT; > + } > + > + //FIXME stop common module activities? ISDN_STAT_STOP? block open()? > + > + /* stop submitting bulk URBs */ > + tasklet_disable(&cs->write_tasklet); > + > + /* kill pending read URB */ > + usb_kill_urb(ucs->read_urb);
no pending write URB? Regards Oliver -
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [thread] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
Messages in current thread:
Re: [linux-usb-devel] [PATCH 1/2] usb_gigaset: suspend support
, Oliver Neukum
, (Tue Oct 30, 1:52 am)
Re: [linux-usb-devel] [PATCH 1/2] usb_gigaset: suspend support
, Tilman Schmidt
, (Thu Nov 1, 1:17 pm)
Navigation
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Fortier,Vincent [Montreal]
2.6.21.5 june 30th to july 1st date hang?
Jeff Dike
[ PATCH 2/6 ] UML - Formatting fixes around os_{read_write}_file callers
Liam Girdwood
[PATCH 07/13] regulator: regulator test harness
Oleg Nesterov
Re: Getting the new RxRPC patches upstream
Stefan Seyfried
Re: 2.6.19-rc5: grub is much slower resuming from suspend-to-disk than in 2.6.18
linux-netdev
:
Arnaud Ebalard
Re: [REGRESSION,BISECTED] MIPv6 support broken by f4f914b58019f0
Jan Engelhardt
Re: [PATCH iptables] extension: add xt_cpu match
Jarek Poplawski
Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock().
Sebastian Andrzej Siewior
[PATCH 8/8] net/emergency: remove locking from reycling pool if emergncy pools are...
David Miller
Re: [PATCH] qlcnic: dont assume NET_IP_ALIGN is 2
git
:
Jakub Narebski
Re: git on MacOSX and files with decomposed utf-8 file names
Brandon Casey
Re: Thunderbird and patches (was Re: [PATCH v2] Enable setting attach as the def...
Christian Couder
[PATCH 1/3] rev-parse: add test script for "--verify"
Ramkumar Ramachandra
Re: [GSoC update] git-remote-svn: The final one
Junio C Hamano
Re: git-rm isn't the inverse action of git-add
openbsd-misc
:
Joachim Schipper
Re: UVC Webcams
Florin Andrei
SOLVED [was: firewall is very slow, something's wrong]
Todd Alan Smith
Re: Microsoft gets the Most Secure Operating Systems award
Neal Hogan
Re: Need Advice: Thinkpad T60 or T61?
Sam Fourman Jr.
Re: Real men don't attack straw men
git-commits-head
:
Linux Kernel Mailing List
ACPI: Disable ARB_DISABLE on platforms where it is not needed
Linux Kernel Mailing List
m68knommu: add read_barrier_depends() and irqs_disabled_flags()
Linux Kernel Mailing List
[MTD] Add mtd panic_write function pointer
Linux Kernel Mailing List
[ARM] pxa: remove duplicate select statements from Kconfig
Linux Kernel Mailing List
mlx4_core: Don't read reserved fields in mlx4_QUERY_ADAPTER()
Colocation donated by:
Syndicate