Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S261543AbVBNTuR (ORCPT ); Mon, 14 Feb 2005 14:50:17 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S261545AbVBNTuR (ORCPT ); Mon, 14 Feb 2005 14:50:17 -0500 Received: from ns.suse.de ([195.135.220.2]:54172 "EHLO Cantor.suse.de") by vger.kernel.org with ESMTP id S261543AbVBNTuF (ORCPT ); Mon, 14 Feb 2005 14:50:05 -0500 Date: Mon, 14 Feb 2005 20:50:04 +0100 Message-ID: From: Takashi Iwai To: Greg KH Cc: Jeff Garzik , Linux Kernel , Andrew Morton , Alan Cox Subject: Re: avoiding pci_disable_device()... In-Reply-To: <20050214193413.GA10231@kroah.com> References: <4210021F.7060401@pobox.com> <20050214190619.GA9241@kroah.com> <20050214193413.GA10231@kroah.com> User-Agent: Wanderlust/2.10.1 (Watching The Wheels) SEMI/1.14.5 (Awara-Onsen) FLIM/1.14.5 (Demachiyanagi) APEL/10.6 MULE XEmacs/21.4 (patch 15) (Security Through Obscurity) (i386-suse-linux) MIME-Version: 1.0 (generated by SEMI 1.14.5 - "Awara-Onsen") Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1736 Lines: 45 At Mon, 14 Feb 2005 11:34:13 -0800, Greg KH wrote: > > On Mon, Feb 14, 2005 at 08:24:29PM +0100, Takashi Iwai wrote: > > At Mon, 14 Feb 2005 11:06:19 -0800, > > Greg KH wrote: > > > > > > > As a result, I have committed the attached patch to libata-2.6. In many > > > > cases, it is a "semantic fix", addressing the case > > > > > > > > * pci_request_regions() indicates hardware is in use > > > > * we rudely disable the in-use hardware > > > > > > > > that would not occur in practice. > > > > > > > > But better safe than sorry. Code cuts cut-n-pasted all over the place. > > > > > > > > I'm hoping one or two things will happen now: > > > > * janitors fix up the other PCI drivers along these lines > > > > * improve the PCI API so that pci_request_regions() is axiomatic > > > > > > Do you have any suggestions for how to do this? > > > > How about to add an exclusiveness check in pci_enable_device()? > > Most drivers suppose that the given pci resources are exclusively > > available. > > You mean only allow pci_enable_device() to work for the first caller of > it? I don't see how that would help this issue out. Well, for example, add a new pointer to indicate the driver accessing exclusively. And pci_enable_device() (maybe a new variant would be better for compatibility) checks whether this is free. The second caller wouldn't reach even to pci_request_regions() because of this check. So, no side-effect of pci_disable_device() in the error path. Takashi - 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/