From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jeff Garzik Subject: Re: [PATCH 2/3] pci: bcm43xx avoid pci_find_device Date: Fri, 26 May 2006 06:22:36 -0400 Message-ID: <4476D6EC.4060501@pobox.com> References: <20060526001053.D2349C7C58@atrey.karlin.mff.cuni.cz> <44764D4B.6050105@pobox.com> <4476D63E.8090207@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: Greg KH , Linux Kernel Mailing List , linux-pci@atrey.karlin.mff.cuni.cz, netdev@vger.kernel.org, mb@bu3sch.de, st3@riseup.net, linville@tuxdriver.com Return-path: Received: from srv5.dvmed.net ([207.36.208.214]:44744 "EHLO mail.dvmed.net") by vger.kernel.org with ESMTP id S1751344AbWEZKWn (ORCPT ); Fri, 26 May 2006 06:22:43 -0400 To: Jiri Slaby In-Reply-To: <4476D63E.8090207@gmail.com> Sender: netdev-owner@vger.kernel.org List-Id: netdev.vger.kernel.org Jiri Slaby wrote: > -----BEGIN PGP SIGNED MESSAGE----- > Hash: SHA1 > > Jeff Garzik napsal(a): >> Jiri Slaby wrote: >>> bcm43xx avoid pci_find_device >>> >>> Change pci_find_device to safer pci_get_device with support for more >>> devices. >>> >>> Signed-off-by: Jiri Slaby >>> >>> --- >>> commit 1d3b6caf027fe53351c645523587aeac40bc3e47 >>> tree ae37c86b633442cdf8a7a19ac287542724081c90 >>> parent ab3443d79c94d0ae6a9e020daefa4d29eccff50d >>> author Jiri Slaby Fri, 26 May 2006 01:49:12 >>> +0159 >>> committer Jiri Slaby Fri, 26 May 2006 >>> 01:49:12 +0159 >>> >>> drivers/net/wireless/bcm43xx/bcm43xx_main.c | 20 ++++++++++++++++---- >>> 1 files changed, 16 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/net/wireless/bcm43xx/bcm43xx_main.c >>> b/drivers/net/wireless/bcm43xx/bcm43xx_main.c >>> index b488f77..56d2fc6 100644 >>> --- a/drivers/net/wireless/bcm43xx/bcm43xx_main.c >>> +++ b/drivers/net/wireless/bcm43xx/bcm43xx_main.c >>> @@ -2131,6 +2131,13 @@ out: >>> return err; >>> } >>> >>> +#ifdef CONFIG_BCM947XX >>> +static struct pci_device_id bcm43xx_ids[] = { >>> + { PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4324) }, >>> + { 0 } >>> +}; >>> +#endif >>> + >>> static int bcm43xx_initialize_irq(struct bcm43xx_private *bcm) >>> { >>> int res; >>> @@ -2141,10 +2148,15 @@ static int bcm43xx_initialize_irq(struct >>> #ifdef CONFIG_BCM947XX >>> if (bcm->pci_dev->bus->number == 0) { >>> struct pci_dev *d = NULL; >>> - /* FIXME: we will probably need more device IDs here... */ >>> - d = pci_find_device(PCI_VENDOR_ID_BROADCOM, 0x4324, NULL); >>> - if (d != NULL) { >>> - bcm->irq = d->irq; >>> + struct pci_device_id *id = bcm43xx_ids; >>> + while (id->vendor) { >>> + d = pci_get_device(id->vendor, id->device, NULL); >>> + if (d != NULL) { >>> + bcm->irq = d->irq; >>> + pci_dev_put(d); >>> + break; >> You'll want to use pci_match_device() or pci_match_one_device() >> [I forget which one] > Why? Matching is done by pci_get_device() or pci_get_subsys(), respectively. > [pci_match_device() is for matching dev <-> drv, you meant pci_match_one_device()] The FIXME says "we will probably need more device IDs here." Thus, if you are touching this area, it would make sense to add the capability to easily add a second (and third, fourth...) PCI ID. And that means pci_match_one_device() and a pci_device_id table. Jeff