[PATCH] driver core: Fix races in driver_detach()
authorAlan Stern <stern@rowland.harvard.edu>
Fri, 6 May 2005 19:38:33 +0000 (15:38 -0400)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 20 Jun 2005 22:15:28 +0000 (15:15 -0700)
commitc95a6b057b108c2b7add35cba1354f9af921349e
tree5a312f634b0aec295201a93020ba025d840e5f21
parent6623415687eaffef49429292ab062bb046ee3311
[PATCH] driver core: Fix races in driver_detach()

This patch is intended for your "driver" tree.  It fixes several subtle
races in driver_detach() and device_release_driver() in the driver-model
core.

The major change is to use klist_remove() rather than klist_del() when
taking a device off its driver's list.  There's no other way to guarantee
that the list pointers will be updated before some other driver binds to
the device.  For this to work driver_detach() can't use a klist iterator,
so the loop over the devices must be written out in full.  In addition the
patch protects against the possibility that, when a driver and a device
are unregistered at the same time, one may be unloaded from memory before
the other is finished using it.

Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/base/dd.c