diff options
Diffstat (limited to 'drivers/pci')
-rw-r--r-- | drivers/pci/hotplug/rpadlpar_core.c | 6 | ||||
-rw-r--r-- | drivers/pci/hotplug/rpaphp.h | 2 | ||||
-rw-r--r-- | drivers/pci/hotplug/rpaphp_core.c | 32 | ||||
-rw-r--r-- | drivers/pci/hotplug/rpaphp_pci.c | 12 |
4 files changed, 23 insertions, 29 deletions
diff --git a/drivers/pci/hotplug/rpadlpar_core.c b/drivers/pci/hotplug/rpadlpar_core.c index 6c148106518e..15e853e5e689 100644 --- a/drivers/pci/hotplug/rpadlpar_core.c +++ b/drivers/pci/hotplug/rpadlpar_core.c | |||
@@ -380,7 +380,11 @@ int dlpar_remove_pci_slot(char *drc_name, struct device_node *dn) | |||
380 | return -EIO; | 380 | return -EIO; |
381 | } | 381 | } |
382 | } else { | 382 | } else { |
383 | rpaphp_unconfig_pci_adapter(bus); | 383 | struct pci_dev *dev, *tmp; |
384 | list_for_each_entry_safe(dev, tmp, &bus->devices, bus_list) { | ||
385 | eeh_remove_bus_device(dev); | ||
386 | pci_remove_bus_device(dev); | ||
387 | } | ||
384 | } | 388 | } |
385 | 389 | ||
386 | if (unmap_bus_range(bus)) { | 390 | if (unmap_bus_range(bus)) { |
diff --git a/drivers/pci/hotplug/rpaphp.h b/drivers/pci/hotplug/rpaphp.h index 89d705c7c502..6e4f93ba6555 100644 --- a/drivers/pci/hotplug/rpaphp.h +++ b/drivers/pci/hotplug/rpaphp.h | |||
@@ -92,8 +92,6 @@ extern int rpaphp_enable_pci_slot(struct slot *slot); | |||
92 | extern int register_pci_slot(struct slot *slot); | 92 | extern int register_pci_slot(struct slot *slot); |
93 | extern int rpaphp_get_pci_adapter_status(struct slot *slot, int is_init, u8 * value); | 93 | extern int rpaphp_get_pci_adapter_status(struct slot *slot, int is_init, u8 * value); |
94 | 94 | ||
95 | extern int rpaphp_unconfig_pci_adapter(struct pci_bus *bus); | ||
96 | |||
97 | /* rpaphp_core.c */ | 95 | /* rpaphp_core.c */ |
98 | extern int rpaphp_add_slot(struct device_node *dn); | 96 | extern int rpaphp_add_slot(struct device_node *dn); |
99 | extern int rpaphp_remove_slot(struct slot *slot); | 97 | extern int rpaphp_remove_slot(struct slot *slot); |
diff --git a/drivers/pci/hotplug/rpaphp_core.c b/drivers/pci/hotplug/rpaphp_core.c index cf075c34b578..acf17645fd8a 100644 --- a/drivers/pci/hotplug/rpaphp_core.c +++ b/drivers/pci/hotplug/rpaphp_core.c | |||
@@ -412,27 +412,31 @@ exit: | |||
412 | return retval; | 412 | return retval; |
413 | } | 413 | } |
414 | 414 | ||
415 | static int disable_slot(struct hotplug_slot *hotplug_slot) | 415 | static int __disable_slot(struct slot *slot) |
416 | { | 416 | { |
417 | int retval = -EINVAL; | 417 | struct pci_dev *dev, *tmp; |
418 | struct slot *slot = (struct slot *)hotplug_slot->private; | ||
419 | 418 | ||
420 | dbg("%s - Entry: slot[%s]\n", __FUNCTION__, slot->name); | 419 | if (slot->state == NOT_CONFIGURED) |
420 | return -EINVAL; | ||
421 | 421 | ||
422 | if (slot->state == NOT_CONFIGURED) { | 422 | list_for_each_entry_safe(dev, tmp, &slot->bus->devices, bus_list) { |
423 | dbg("%s: %s is already disabled\n", __FUNCTION__, slot->name); | 423 | eeh_remove_bus_device(dev); |
424 | goto exit; | 424 | pci_remove_bus_device(dev); |
425 | } | 425 | } |
426 | 426 | ||
427 | dbg("DISABLING SLOT %s\n", slot->name); | 427 | slot->state = NOT_CONFIGURED; |
428 | return 0; | ||
429 | } | ||
430 | |||
431 | static int disable_slot(struct hotplug_slot *hotplug_slot) | ||
432 | { | ||
433 | struct slot *slot = (struct slot *)hotplug_slot->private; | ||
434 | int retval; | ||
435 | |||
428 | down(&rpaphp_sem); | 436 | down(&rpaphp_sem); |
429 | retval = rpaphp_unconfig_pci_adapter(slot->bus); | 437 | retval = __disable_slot (slot); |
430 | up(&rpaphp_sem); | 438 | up(&rpaphp_sem); |
431 | slot->state = NOT_CONFIGURED; | 439 | |
432 | info("%s: devices in slot[%s] unconfigured.\n", __FUNCTION__, | ||
433 | slot->name); | ||
434 | exit: | ||
435 | dbg("%s - Exit: rc[%d]\n", __FUNCTION__, retval); | ||
436 | return retval; | 440 | return retval; |
437 | } | 441 | } |
438 | 442 | ||
diff --git a/drivers/pci/hotplug/rpaphp_pci.c b/drivers/pci/hotplug/rpaphp_pci.c index 1f5e73be47c7..ce7ebec05933 100644 --- a/drivers/pci/hotplug/rpaphp_pci.c +++ b/drivers/pci/hotplug/rpaphp_pci.c | |||
@@ -116,18 +116,6 @@ static void print_slot_pci_funcs(struct pci_bus *bus) | |||
116 | return; | 116 | return; |
117 | } | 117 | } |
118 | 118 | ||
119 | int rpaphp_unconfig_pci_adapter(struct pci_bus *bus) | ||
120 | { | ||
121 | struct pci_dev *dev, *tmp; | ||
122 | |||
123 | list_for_each_entry_safe(dev, tmp, &bus->devices, bus_list) { | ||
124 | eeh_remove_bus_device(dev); | ||
125 | pci_remove_bus_device(dev); | ||
126 | } | ||
127 | return 0; | ||
128 | } | ||
129 | EXPORT_SYMBOL_GPL(rpaphp_unconfig_pci_adapter); | ||
130 | |||
131 | static int setup_pci_hotplug_slot_info(struct slot *slot) | 119 | static int setup_pci_hotplug_slot_info(struct slot *slot) |
132 | { | 120 | { |
133 | struct hotplug_slot_info *hotplug_slot_info = slot->hotplug_slot->info; | 121 | struct hotplug_slot_info *hotplug_slot_info = slot->hotplug_slot->info; |