diff options
Diffstat (limited to 'drivers/pci/hotplug')
| -rw-r--r-- | drivers/pci/hotplug/acpiphp_ibm.c | 2 | ||||
| -rw-r--r-- | drivers/pci/hotplug/rpadlpar_core.c | 8 | ||||
| -rw-r--r-- | drivers/pci/hotplug/rpaphp_core.c | 4 | ||||
| -rw-r--r-- | drivers/pci/hotplug/rpaphp_pci.c | 4 | 
4 files changed, 10 insertions, 8 deletions
| diff --git a/drivers/pci/hotplug/acpiphp_ibm.c b/drivers/pci/hotplug/acpiphp_ibm.c index 2f6d3a1c1726..f6221d739f59 100644 --- a/drivers/pci/hotplug/acpiphp_ibm.c +++ b/drivers/pci/hotplug/acpiphp_ibm.c @@ -138,6 +138,8 @@ static union apci_descriptor *ibm_slot_from_id(int id)  	char *table;  	size = ibm_get_table_from_acpi(&table); +	if (size < 0) +		return NULL;  	des = (union apci_descriptor *)table;  	if (memcmp(des->header.sig, "aPCI", 4) != 0)  		goto ibm_slot_done; diff --git a/drivers/pci/hotplug/rpadlpar_core.c b/drivers/pci/hotplug/rpadlpar_core.c index b46b57d870fc..dc67f39779ec 100644 --- a/drivers/pci/hotplug/rpadlpar_core.c +++ b/drivers/pci/hotplug/rpadlpar_core.c @@ -175,7 +175,7 @@ static int dlpar_add_pci_slot(char *drc_name, struct device_node *dn)  	struct pci_dev *dev;  	struct pci_controller *phb; -	if (pcibios_find_pci_bus(dn)) +	if (pci_find_bus_by_node(dn))  		return -EINVAL;  	/* Add pci bus */ @@ -212,7 +212,7 @@ static int dlpar_remove_phb(char *drc_name, struct device_node *dn)  	struct pci_dn *pdn;  	int rc = 0; -	if (!pcibios_find_pci_bus(dn)) +	if (!pci_find_bus_by_node(dn))  		return -EINVAL;  	/* If pci slot is hotpluggable, use hotplug to remove it */ @@ -356,7 +356,7 @@ int dlpar_remove_pci_slot(char *drc_name, struct device_node *dn)  	pci_lock_rescan_remove(); -	bus = pcibios_find_pci_bus(dn); +	bus = pci_find_bus_by_node(dn);  	if (!bus) {  		ret = -EINVAL;  		goto out; @@ -380,7 +380,7 @@ int dlpar_remove_pci_slot(char *drc_name, struct device_node *dn)  	}  	/* Remove all devices below slot */ -	pcibios_remove_pci_devices(bus); +	pci_hp_remove_devices(bus);  	/* Unmap PCI IO space */  	if (pcibios_unmap_io_space(bus)) { diff --git a/drivers/pci/hotplug/rpaphp_core.c b/drivers/pci/hotplug/rpaphp_core.c index 611f6056221a..8d132024f06e 100644 --- a/drivers/pci/hotplug/rpaphp_core.c +++ b/drivers/pci/hotplug/rpaphp_core.c @@ -404,7 +404,7 @@ static int enable_slot(struct hotplug_slot *hotplug_slot)  	if (state == PRESENT) {  		pci_lock_rescan_remove(); -		pcibios_add_pci_devices(slot->bus); +		pci_hp_add_devices(slot->bus);  		pci_unlock_rescan_remove();  		slot->state = CONFIGURED;  	} else if (state == EMPTY) { @@ -426,7 +426,7 @@ static int disable_slot(struct hotplug_slot *hotplug_slot)  		return -EINVAL;  	pci_lock_rescan_remove(); -	pcibios_remove_pci_devices(slot->bus); +	pci_hp_remove_devices(slot->bus);  	pci_unlock_rescan_remove();  	vm_unmap_aliases(); diff --git a/drivers/pci/hotplug/rpaphp_pci.c b/drivers/pci/hotplug/rpaphp_pci.c index 7836d6913e67..ea41ea1d3c00 100644 --- a/drivers/pci/hotplug/rpaphp_pci.c +++ b/drivers/pci/hotplug/rpaphp_pci.c @@ -93,7 +93,7 @@ int rpaphp_enable_slot(struct slot *slot)  	if (rc)  		return rc; -	bus = pcibios_find_pci_bus(slot->dn); +	bus = pci_find_bus_by_node(slot->dn);  	if (!bus) {  		err("%s: no pci_bus for dn %s\n", __func__, slot->dn->full_name);  		return -EINVAL; @@ -116,7 +116,7 @@ int rpaphp_enable_slot(struct slot *slot)  		}  		if (list_empty(&bus->devices)) -			pcibios_add_pci_devices(bus); +			pci_hp_add_devices(bus);  		if (!list_empty(&bus->devices)) {  			info->adapter_status = CONFIGURED; |