From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Thu, 6 Jun 2002 12:46:42 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Thu, 6 Jun 2002 12:46:41 -0400 Received: from neon-gw-l3.transmeta.com ([63.209.4.196]:2314 "EHLO neon-gw.transmeta.com") by vger.kernel.org with ESMTP id ; Thu, 6 Jun 2002 12:46:41 -0400 To: linux-kernel@vger.kernel.org From: torvalds@transmeta.com (Linus Torvalds) Subject: Re: device model update 2/2 Date: Thu, 6 Jun 2002 16:45:25 +0000 (UTC) Organization: Transmeta Corporation Message-ID: In-Reply-To: X-Trace: palladium.transmeta.com 1023381990 22356 127.0.0.1 (6 Jun 2002 16:46:30 GMT) X-Complaints-To: news@transmeta.com NNTP-Posting-Date: 6 Jun 2002 16:46:30 GMT Cache-Post-Path: palladium.transmeta.com!unknown@penguin.transmeta.com X-Cache: nntpcache 2.4.0b5 (see http://www.nntpcache.org/) Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org In article , Patrick Mochel wrote: >- > /* detach from driver */ > if (dev->driver->remove) > dev->driver->remove(dev); > put_driver(dev->driver); >+ >+ lock_device(dev); >+ dev->driver = NULL; >+ unlock_device(dev); Code like the above just basically can _never_ be correct. The locking just doesn't make any sense like that. Real locking looks something like this: lock_device(dev); driver = dev->driver; dev->driver = NULL; unlock_device(dev); if (driver->remove) driver->remove(dev); put_driver(driver); together with some promise that "dev" cannot go away from under us (ie a refcount on "dev" itself). Linus