i7core_edac: return -ENODEV when devices were already probed
authorMauro Carvalho Chehab <mchehab@redhat.com>
Sun, 24 Oct 2010 13:36:19 +0000 (11:36 -0200)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Sun, 24 Oct 2010 13:36:19 +0000 (11:36 -0200)
Due to the nature of i7core, we need to probe and attach all PCI
devices used by this driver during the first time probe is called.
However, PCI core will call the probe routine one time for each CPU
socket. If we return -EINVAL to those calls, it would seem that the
driver fails, when, in fact, there's no more devices left to initialize.

Changing the return code to -ENODEV solves this issue.

Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/edac/i7core_edac.c

index e3404b2bbaa27dbb6176f5daa9a6fdbe4e6a604e..362861c157794aa81561d485607824e87b8216d4 100644 (file)
@@ -2046,7 +2046,7 @@ static int __devinit i7core_probe(struct pci_dev *pdev,
         */
        if (unlikely(probed >= 1)) {
                mutex_unlock(&i7core_edac_lock);
-               return -EINVAL;
+               return -ENODEV;
        }
        probed++;