Commit a573e054 authored by Luiz Capitulino's avatar Luiz Capitulino Committed by Greg Kroah-Hartman

[PATCH] PCI: add missing checks in drivers/pci/probe.c.

 I noticed drivers/pci/probe.c::pci_scan_bus_parented() has some functions which
the return value is not checked.

 The patch bellow adds the check for device_register(), class_device_register(),
class_device_create_file() and sysfs_create_link().

(hope the error label names are not too ugly).
Signed-off-by: default avatarLuiz Capitulino <lcapitulino@conectiva.com.br>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent c52e920c
...@@ -750,6 +750,7 @@ unsigned int __devinit pci_do_scan_bus(struct pci_bus *bus) ...@@ -750,6 +750,7 @@ unsigned int __devinit pci_do_scan_bus(struct pci_bus *bus)
struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus, struct pci_ops *ops, void *sysdata) struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus, struct pci_ops *ops, void *sysdata)
{ {
int error;
struct pci_bus *b; struct pci_bus *b;
struct device *dev; struct device *dev;
...@@ -769,9 +770,7 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus, ...@@ -769,9 +770,7 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus,
if (pci_find_bus(pci_domain_nr(b), bus)) { if (pci_find_bus(pci_domain_nr(b), bus)) {
/* If we already got to this bus through a different bridge, ignore it */ /* If we already got to this bus through a different bridge, ignore it */
DBG("PCI: Bus %02x already known\n", bus); DBG("PCI: Bus %02x already known\n", bus);
kfree(dev); goto err_out;
kfree(b);
return NULL;
} }
list_add_tail(&b->node, &pci_root_buses); list_add_tail(&b->node, &pci_root_buses);
...@@ -779,15 +778,23 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus, ...@@ -779,15 +778,23 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus,
dev->parent = parent; dev->parent = parent;
dev->release = pci_release_bus_bridge_dev; dev->release = pci_release_bus_bridge_dev;
sprintf(dev->bus_id, "pci%04x:%02x", pci_domain_nr(b), bus); sprintf(dev->bus_id, "pci%04x:%02x", pci_domain_nr(b), bus);
device_register(dev); error = device_register(dev);
if (error)
goto dev_reg_err;
b->bridge = get_device(dev); b->bridge = get_device(dev);
b->class_dev.class = &pcibus_class; b->class_dev.class = &pcibus_class;
sprintf(b->class_dev.class_id, "%04x:%02x", pci_domain_nr(b), bus); sprintf(b->class_dev.class_id, "%04x:%02x", pci_domain_nr(b), bus);
class_device_register(&b->class_dev); error = class_device_register(&b->class_dev);
class_device_create_file(&b->class_dev, &class_device_attr_cpuaffinity); if (error)
goto class_dev_reg_err;
error = class_device_create_file(&b->class_dev, &class_device_attr_cpuaffinity);
if (error)
goto class_dev_create_file_err;
sysfs_create_link(&b->class_dev.kobj, &b->bridge->kobj, "bridge"); error = sysfs_create_link(&b->class_dev.kobj, &b->bridge->kobj, "bridge");
if (error)
goto sys_create_link_err;
b->number = b->secondary = bus; b->number = b->secondary = bus;
b->resource[0] = &ioport_resource; b->resource[0] = &ioport_resource;
...@@ -798,6 +805,19 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus, ...@@ -798,6 +805,19 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent, int bus,
pci_bus_add_devices(b); pci_bus_add_devices(b);
return b; return b;
sys_create_link_err:
class_device_remove_file(&b->class_dev, &class_device_attr_cpuaffinity);
class_dev_create_file_err:
class_device_unregister(&b->class_dev);
class_dev_reg_err:
device_unregister(dev);
dev_reg_err:
list_del(&b->node);
err_out:
kfree(dev);
kfree(b);
return NULL;
} }
EXPORT_SYMBOL(pci_scan_bus_parented); EXPORT_SYMBOL(pci_scan_bus_parented);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment