diff options
Diffstat (limited to 'drivers/pci')
-rw-r--r-- | drivers/pci/hotplug/pciehp.h | 1 | ||||
-rw-r--r-- | drivers/pci/hotplug/pciehp_core.c | 14 |
2 files changed, 2 insertions, 13 deletions
diff --git a/drivers/pci/hotplug/pciehp.h b/drivers/pci/hotplug/pciehp.h index 202e4967a941..b505515a07ae 100644 --- a/drivers/pci/hotplug/pciehp.h +++ b/drivers/pci/hotplug/pciehp.h | |||
@@ -78,7 +78,6 @@ struct controller { | |||
78 | int num_slots; /* Number of slots on ctlr */ | 78 | int num_slots; /* Number of slots on ctlr */ |
79 | int slot_num_inc; /* 1 or -1 */ | 79 | int slot_num_inc; /* 1 or -1 */ |
80 | struct pci_dev *pci_dev; | 80 | struct pci_dev *pci_dev; |
81 | struct pci_bus *pci_bus; | ||
82 | struct list_head slot_list; | 81 | struct list_head slot_list; |
83 | struct event_info event_queue[MAX_EVENTS]; | 82 | struct event_info event_queue[MAX_EVENTS]; |
84 | struct slot *slot; | 83 | struct slot *slot; |
diff --git a/drivers/pci/hotplug/pciehp_core.c b/drivers/pci/hotplug/pciehp_core.c index a315685b2d37..b617613381d6 100644 --- a/drivers/pci/hotplug/pciehp_core.c +++ b/drivers/pci/hotplug/pciehp_core.c | |||
@@ -346,13 +346,6 @@ static int pciehp_probe(struct pcie_device *dev, const struct pcie_port_service_ | |||
346 | 346 | ||
347 | pci_set_drvdata(pdev, ctrl); | 347 | pci_set_drvdata(pdev, ctrl); |
348 | 348 | ||
349 | ctrl->pci_bus = kmalloc(sizeof(*ctrl->pci_bus), GFP_KERNEL); | ||
350 | if (!ctrl->pci_bus) { | ||
351 | err("%s: out of memory\n", __FUNCTION__); | ||
352 | rc = -ENOMEM; | ||
353 | goto err_out_unmap_mmio_region; | ||
354 | } | ||
355 | memcpy (ctrl->pci_bus, pdev->bus, sizeof (*ctrl->pci_bus)); | ||
356 | ctrl->bus = pdev->bus->number; /* ctrl bus */ | 349 | ctrl->bus = pdev->bus->number; /* ctrl bus */ |
357 | ctrl->slot_bus = pdev->subordinate->number; /* bus controlled by this HPC */ | 350 | ctrl->slot_bus = pdev->subordinate->number; /* bus controlled by this HPC */ |
358 | 351 | ||
@@ -365,7 +358,7 @@ static int pciehp_probe(struct pcie_device *dev, const struct pcie_port_service_ | |||
365 | rc = init_slots(ctrl); | 358 | rc = init_slots(ctrl); |
366 | if (rc) { | 359 | if (rc) { |
367 | err(msg_initialization_err, 6); | 360 | err(msg_initialization_err, 6); |
368 | goto err_out_free_ctrl_slot; | 361 | goto err_out_release_ctlr; |
369 | } | 362 | } |
370 | 363 | ||
371 | t_slot = pciehp_find_slot(ctrl, ctrl->slot_device_offset); | 364 | t_slot = pciehp_find_slot(ctrl, ctrl->slot_device_offset); |
@@ -404,8 +397,7 @@ static int pciehp_probe(struct pcie_device *dev, const struct pcie_port_service_ | |||
404 | 397 | ||
405 | err_out_free_ctrl_slot: | 398 | err_out_free_ctrl_slot: |
406 | cleanup_slots(ctrl); | 399 | cleanup_slots(ctrl); |
407 | kfree(ctrl->pci_bus); | 400 | err_out_release_ctlr: |
408 | err_out_unmap_mmio_region: | ||
409 | ctrl->hpc_ops->release_ctlr(ctrl); | 401 | ctrl->hpc_ops->release_ctlr(ctrl); |
410 | err_out_free_ctrl: | 402 | err_out_free_ctrl: |
411 | kfree(ctrl); | 403 | kfree(ctrl); |
@@ -439,8 +431,6 @@ static void __exit unload_pciehpd(void) | |||
439 | while (ctrl) { | 431 | while (ctrl) { |
440 | cleanup_slots(ctrl); | 432 | cleanup_slots(ctrl); |
441 | 433 | ||
442 | kfree (ctrl->pci_bus); | ||
443 | |||
444 | ctrl->hpc_ops->release_ctlr(ctrl); | 434 | ctrl->hpc_ops->release_ctlr(ctrl); |
445 | 435 | ||
446 | tctrl = ctrl; | 436 | tctrl = ctrl; |