mirror of
https://github.com/adulau/aha.git
synced 2025-01-04 23:23:18 +00:00
[POWERPC] EEH: restructure multi-function support
Rework how multi-function PCI devices are identified and traversed. This fixes a bug with multi-function recovery on Power4 that was introduced by a recent Power4 EEH patch. Signed-off-by: Linas Vepstas <linas@austin.ibm.com> Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
parent
fa1be476a2
commit
4980d5eb75
2 changed files with 16 additions and 18 deletions
|
@ -282,7 +282,7 @@ void eeh_mark_slot (struct device_node *dn, int mode_flag)
|
||||||
dn = find_device_pe (dn);
|
dn = find_device_pe (dn);
|
||||||
|
|
||||||
/* Back up one, since config addrs might be shared */
|
/* Back up one, since config addrs might be shared */
|
||||||
if (PCI_DN(dn) && PCI_DN(dn)->eeh_pe_config_addr)
|
if (!pcibios_find_pci_bus(dn) && PCI_DN(dn->parent))
|
||||||
dn = dn->parent;
|
dn = dn->parent;
|
||||||
|
|
||||||
PCI_DN(dn)->eeh_mode |= mode_flag;
|
PCI_DN(dn)->eeh_mode |= mode_flag;
|
||||||
|
@ -316,7 +316,7 @@ void eeh_clear_slot (struct device_node *dn, int mode_flag)
|
||||||
dn = find_device_pe (dn);
|
dn = find_device_pe (dn);
|
||||||
|
|
||||||
/* Back up one, since config addrs might be shared */
|
/* Back up one, since config addrs might be shared */
|
||||||
if (PCI_DN(dn) && PCI_DN(dn)->eeh_pe_config_addr)
|
if (!pcibios_find_pci_bus(dn) && PCI_DN(dn->parent))
|
||||||
dn = dn->parent;
|
dn = dn->parent;
|
||||||
|
|
||||||
PCI_DN(dn)->eeh_mode &= ~mode_flag;
|
PCI_DN(dn)->eeh_mode &= ~mode_flag;
|
||||||
|
|
|
@ -249,6 +249,7 @@ static void eeh_report_failure(struct pci_dev *dev, void *userdata)
|
||||||
|
|
||||||
static int eeh_reset_device (struct pci_dn *pe_dn, struct pci_bus *bus)
|
static int eeh_reset_device (struct pci_dn *pe_dn, struct pci_bus *bus)
|
||||||
{
|
{
|
||||||
|
struct device_node *dn;
|
||||||
int cnt, rc;
|
int cnt, rc;
|
||||||
|
|
||||||
/* pcibios will clear the counter; save the value */
|
/* pcibios will clear the counter; save the value */
|
||||||
|
@ -264,23 +265,20 @@ static int eeh_reset_device (struct pci_dn *pe_dn, struct pci_bus *bus)
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
/* New-style config addrs might be shared across multiple devices,
|
/* Walk over all functions on this device. */
|
||||||
* Walk over all functions on this device */
|
dn = pe_dn->node;
|
||||||
if (pe_dn->eeh_pe_config_addr) {
|
if (!pcibios_find_pci_bus(dn) && PCI_DN(dn->parent))
|
||||||
struct device_node *pe = pe_dn->node;
|
dn = dn->parent->child;
|
||||||
pe = pe->parent->child;
|
|
||||||
while (pe) {
|
while (dn) {
|
||||||
struct pci_dn *ppe = PCI_DN(pe);
|
struct pci_dn *ppe = PCI_DN(dn);
|
||||||
if (pe_dn->eeh_pe_config_addr == ppe->eeh_pe_config_addr) {
|
/* On Power4, always true because eeh_pe_config_addr=0 */
|
||||||
rtas_configure_bridge(ppe);
|
if (pe_dn->eeh_pe_config_addr == ppe->eeh_pe_config_addr) {
|
||||||
eeh_restore_bars(ppe);
|
rtas_configure_bridge(ppe);
|
||||||
}
|
eeh_restore_bars(ppe);
|
||||||
pe = pe->sibling;
|
|
||||||
}
|
}
|
||||||
} else {
|
dn = dn->sibling;
|
||||||
rtas_configure_bridge(pe_dn);
|
}
|
||||||
eeh_restore_bars(pe_dn);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Give the system 5 seconds to finish running the user-space
|
/* Give the system 5 seconds to finish running the user-space
|
||||||
* hotplug shutdown scripts, e.g. ifdown for ethernet. Yes,
|
* hotplug shutdown scripts, e.g. ifdown for ethernet. Yes,
|
||||||
|
|
Loading…
Reference in a new issue