powerpc/pseries/eeh: Handle functional reset on non-PCIe device
authorRichard A Lary <rlary@linux.vnet.ibm.com>
Fri, 22 Apr 2011 10:00:05 +0000 (10:00 +0000)
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>
Wed, 4 May 2011 06:02:38 +0000 (16:02 +1000)
  Fundamental reset is an optional reset type supported only by PCIe adapters.
  Handle the unexpected case where a non-PCIe device has requested a
  fundamental reset. Try hot-reset as a fallback to handle this case.

Signed-off-by: Richard A Lary <rlary@linux.vnet.ibm.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/platforms/pseries/eeh.c

index 6cb3e7bd175dfefae4d10a108e82447aecd9f48a..46b55cf563e3a482943e3c2c6c03925f985e8b8c 100644 (file)
@@ -728,15 +728,24 @@ rtas_pci_slot_reset(struct pci_dn *pdn, int state)
        if (pdn->eeh_pe_config_addr)
                config_addr = pdn->eeh_pe_config_addr;
 
-       rc = rtas_call(ibm_set_slot_reset,4,1, NULL,
+       rc = rtas_call(ibm_set_slot_reset, 4, 1, NULL,
                       config_addr,
                       BUID_HI(pdn->phb->buid),
                       BUID_LO(pdn->phb->buid),
                       state);
-       if (rc)
-               printk (KERN_WARNING "EEH: Unable to reset the failed slot,"
-                       " (%d) #RST=%d dn=%s\n",
-                       rc, state, pdn->node->full_name);
+
+       /* Fundamental-reset not supported on this PE, try hot-reset */
+       if (rc == -8 && state == 3) {
+               rc = rtas_call(ibm_set_slot_reset, 4, 1, NULL,
+                              config_addr,
+                              BUID_HI(pdn->phb->buid),
+                              BUID_LO(pdn->phb->buid), 1);
+               if (rc)
+                       printk(KERN_WARNING
+                               "EEH: Unable to reset the failed slot,"
+                               " #RST=%d dn=%s\n",
+                               rc, pdn->node->full_name);
+       }
 }
 
 /**