Re: refcounting drivers' data structures used in sysfs buffers

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Alan Stern
Date: Friday, March 9, 2007 - 12:32 pm

On Fri, 9 Mar 2007, Dmitry Torokhov wrote:


Dmitry, you're not viewing this correctly.

Adding a new release() callback would solve the problem by creating 
another.  Drivers need to release their data as soon as possible after
they unbind from a device, not when the device itself goes away.  Think
about what would happen if you tried to rmmod a driver.  The rmmod process 
would block until the device was unregistered.

Oliver, your idea won't work either.  Think about what would happen if 
someone did

	rmmod driver_module </sys/devices/.../attribute_file

The rmmod process would never actually read the attribute, so until it 
exited the private data structure would have a positive refcount.  But 
rmmod can't exit until the driver has been unloaded from memory, and it 
can't be unloaded while its data structure is still allocated.  Thus we 
would end up with deadlock; rmmod would hang forever.

It might be better to keep your earlier patch and fix the deadlock you
mentioned earlier, the one that occurs when unbinding a driver through
sysfs.  How exactly does that deadlock work?

Alan Stern

-
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
Re: refcounting drivers' data structures used in sysfs buffers, Alan Stern, (Fri Mar 9, 12:32 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Alan Stern, (Tue Mar 13, 8:00 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Cornelia Huck, (Tue Mar 13, 11:42 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Hugh Dickins, (Tue Mar 13, 12:00 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Alan Stern, (Tue Mar 13, 1:09 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Hugh Dickins, (Tue Mar 13, 1:55 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Dmitry Torokhov, (Tue Mar 13, 2:08 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Linus Torvalds, (Tue Mar 13, 2:20 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Alan Stern, (Tue Mar 13, 2:20 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Alan Stern, (Wed Mar 14, 9:12 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Cornelia Huck, (Wed Mar 14, 11:43 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Alan Stern, (Wed Mar 14, 12:23 pm)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Cornelia Huck, (Thu Mar 15, 3:27 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Hugh Dickins, (Thu Mar 15, 5:31 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Oliver Neukum, (Thu Mar 15, 6:02 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Dmitry Torokhov, (Thu Mar 15, 6:22 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Hugh Dickins, (Thu Mar 15, 6:59 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Alan Stern, (Thu Mar 15, 7:27 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Cornelia Huck, (Thu Mar 15, 8:32 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Hugh Dickins, (Thu Mar 15, 9:29 am)
Re: 2.6.21-rc suspend regression: sysfs deadlock, Linus Torvalds, (Thu Mar 15, 9:51 am)