Re: [Pcihpd-discuss] [patch 2/4] acpiphp: handle dock bridges

From: Greg KH
Date: Wed Jan 18 2006 - 00:11:02 EST


On Wed, Jan 18, 2006 at 11:26:41AM +0900, Kenji Kaneshige wrote:
> Hi,
>
> > +static struct acpiphp_func * get_func(struct acpiphp_slot *slot,
> > + struct pci_dev *dev)
> > +{
> > + struct list_head *l;
> > + struct acpiphp_func *func;
> > + struct pci_bus *bus = slot->bridge->pci_bus;
> > +
> > + list_for_each (l, &slot->funcs) {
> > + func = list_entry(l, struct acpiphp_func, sibling);
> > + if (pci_get_slot(bus, PCI_DEVFN(slot->device,
> > + func->function)) == dev)
> > + return func;
> > + }
>
> This seems to leak reference counter of pci_dev. I think you
> must call pci_dev_put() also.

Yes, good catch.

thanks,

greg k-h
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/