Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S261994AbVAYQL4 (ORCPT ); Tue, 25 Jan 2005 11:11:56 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S261997AbVAYQLz (ORCPT ); Tue, 25 Jan 2005 11:11:55 -0500 Received: from brmea-mail-3.Sun.COM ([192.18.98.34]:11167 "EHLO brmea-mail-3.sun.com") by vger.kernel.org with ESMTP id S261994AbVAYQLe (ORCPT ); Tue, 25 Jan 2005 11:11:34 -0500 Date: Tue, 25 Jan 2005 11:10:46 -0500 From: Mike Waychison Subject: Re: [PATCH] fix bad locking in drivers/base/driver.c In-reply-to: <41F64E87.8040501@tmr.com> To: Bill Davidsen Cc: Greg KH , Jirka Kosina , Patrick Mochel , Linus Torvalds , linux-kernel@vger.kernel.org Message-id: <41F66F86.4000609@sun.com> MIME-version: 1.0 Content-type: multipart/mixed; boundary="Boundary_(ID_+EaSiKU55S6+zOn3/jurnA)" X-Accept-Language: en-us, en User-Agent: Debian Thunderbird 1.0 (X11/20050116) X-Enigmail-Version: 0.90.0.0 X-Enigmail-Supports: pgp-inline, pgp-mime References: <20050125055651.GA1987@kroah.com> <41F5F623.5090903@sun.com> <41F64E87.8040501@tmr.com> Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4713 Lines: 132 This is a multi-part message in MIME format. --Boundary_(ID_+EaSiKU55S6+zOn3/jurnA) Content-type: text/plain; charset=ISO-8859-1 Content-transfer-encoding: 7BIT -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 Bill Davidsen wrote: > > Let's clean up the spelling as well >> - * Though, once that is done, we attempt to take @drv->unload_sem. >> + * Though, once that is done, we wait until @drv->unloaded is >> copmleted. > > ------------------------------------------------------------------>completed Thanks for pointing that out. Updated patch attached. - -- Mike Waychison Sun Microsystems, Inc. 1 (650) 352-5299 voice 1 (416) 202-8336 voice ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ NOTICE: The opinions expressed in this email are held by me, and may not represent the views of Sun Microsystems, Inc. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.2.5 (GNU/Linux) Comment: Using GnuPG with Thunderbird - http://enigmail.mozdev.org iD8DBQFB9m+FdQs4kOxk3/MRAtusAJ9S+DSVR4DaAK2fLHquYzgRxamq7ACfZNSN LkPoYAx27W1MpHiW24RL2yM= =HBQX -----END PGP SIGNATURE----- --Boundary_(ID_+EaSiKU55S6+zOn3/jurnA) Content-type: text/x-patch; name=convert_unload_sem_to_completion.patch Content-transfer-encoding: 7BIT Content-disposition: inline; filename=convert_unload_sem_to_completion.patch Get rid of semaphore abuse by converting device_driver->unload_sem semaphore to device_driver->unloaded completion. This should get rid of any confusion as well as save a few bytes in the process. Signed-off-by: Mike Waychison --- drivers/base/bus.c | 2 +- drivers/base/driver.c | 13 ++++++------- include/linux/device.h | 2 +- 3 files changed, 8 insertions(+), 9 deletions(-) Index: linux-2.6.10/drivers/base/bus.c =================================================================== --- linux-2.6.10.orig/drivers/base/bus.c 2004-12-24 16:34:26.000000000 -0500 +++ linux-2.6.10/drivers/base/bus.c 2005-01-25 02:14:10.000000000 -0500 @@ -65,7 +65,7 @@ static struct sysfs_ops driver_sysfs_ops static void driver_release(struct kobject * kobj) { struct device_driver * drv = to_driver(kobj); - up(&drv->unload_sem); + complete(&drv->unloaded); } static struct kobj_type ktype_driver = { Index: linux-2.6.10/drivers/base/driver.c =================================================================== --- linux-2.6.10.orig/drivers/base/driver.c 2004-12-24 16:35:25.000000000 -0500 +++ linux-2.6.10/drivers/base/driver.c 2005-01-25 11:09:23.579643112 -0500 @@ -79,14 +79,14 @@ void put_driver(struct device_driver * d * since most of the things we have to do deal with the bus * structures. * - * The one interesting aspect is that we initialize @drv->unload_sem - * to a locked state here. It will be unlocked when the driver - * reference count reaches 0. + * The one interesting aspect is that we setup @drv->unloaded + * as a completion that gets complete when the driver reference + * count reaches 0. */ int driver_register(struct device_driver * drv) { INIT_LIST_HEAD(&drv->devices); - init_MUTEX_LOCKED(&drv->unload_sem); + init_completion(&drv->unloaded); return bus_add_driver(drv); } @@ -97,7 +97,7 @@ int driver_register(struct device_driver * * Again, we pass off most of the work to the bus-level call. * - * Though, once that is done, we attempt to take @drv->unload_sem. + * Though, once that is done, we wait until @drv->unloaded is completed. * This will block until the driver refcount reaches 0, and it is * released. Only modular drivers will call this function, and we * have to guarantee that it won't complete, letting the driver @@ -107,8 +107,7 @@ int driver_register(struct device_driver void driver_unregister(struct device_driver * drv) { bus_remove_driver(drv); - down(&drv->unload_sem); - up(&drv->unload_sem); + wait_for_completion(&drv->unloaded); } /** Index: linux-2.6.10/include/linux/device.h =================================================================== --- linux-2.6.10.orig/include/linux/device.h 2004-12-24 16:35:28.000000000 -0500 +++ linux-2.6.10/include/linux/device.h 2005-01-25 02:13:13.000000000 -0500 @@ -102,7 +102,7 @@ struct device_driver { char * name; struct bus_type * bus; - struct semaphore unload_sem; + struct completion unloaded; struct kobject kobj; struct list_head devices; --Boundary_(ID_+EaSiKU55S6+zOn3/jurnA)-- - 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/