Commit 733b3e27 authored by Heiner Kallweit's avatar Heiner Kallweit Committed by Jakub Kicinski

r8169: use dev_err_probe in all appropriate places in rtl_init_one()

In addition to properly handling probe deferrals dev_err_probe()
conveniently combines printing an error message with returning
the errno. So let's use it for every error path in rtl_init_one()
to simplify the code.
Signed-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Reviewed-by: default avatarSimon Horman <simon.horman@corigine.com>
Link: https://lore.kernel.org/r/f0596a19-d517-e301-b649-304f9247b75a@gmail.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent b345b2a6
...@@ -5196,44 +5196,35 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -5196,44 +5196,35 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
/* enable device (incl. PCI PM wakeup and hotplug setup) */ /* enable device (incl. PCI PM wakeup and hotplug setup) */
rc = pcim_enable_device(pdev); rc = pcim_enable_device(pdev);
if (rc < 0) { if (rc < 0)
dev_err(&pdev->dev, "enable failure\n"); return dev_err_probe(&pdev->dev, rc, "enable failure\n");
return rc;
}
if (pcim_set_mwi(pdev) < 0) if (pcim_set_mwi(pdev) < 0)
dev_info(&pdev->dev, "Mem-Wr-Inval unavailable\n"); dev_info(&pdev->dev, "Mem-Wr-Inval unavailable\n");
/* use first MMIO region */ /* use first MMIO region */
region = ffs(pci_select_bars(pdev, IORESOURCE_MEM)) - 1; region = ffs(pci_select_bars(pdev, IORESOURCE_MEM)) - 1;
if (region < 0) { if (region < 0)
dev_err(&pdev->dev, "no MMIO resource found\n"); return dev_err_probe(&pdev->dev, -ENODEV, "no MMIO resource found\n");
return -ENODEV;
}
rc = pcim_iomap_regions(pdev, BIT(region), KBUILD_MODNAME); rc = pcim_iomap_regions(pdev, BIT(region), KBUILD_MODNAME);
if (rc < 0) { if (rc < 0)
dev_err(&pdev->dev, "cannot remap MMIO, aborting\n"); return dev_err_probe(&pdev->dev, rc, "cannot remap MMIO, aborting\n");
return rc;
}
tp->mmio_addr = pcim_iomap_table(pdev)[region]; tp->mmio_addr = pcim_iomap_table(pdev)[region];
txconfig = RTL_R32(tp, TxConfig); txconfig = RTL_R32(tp, TxConfig);
if (txconfig == ~0U) { if (txconfig == ~0U)
dev_err(&pdev->dev, "PCI read failed\n"); return dev_err_probe(&pdev->dev, -EIO, "PCI read failed\n");
return -EIO;
}
xid = (txconfig >> 20) & 0xfcf; xid = (txconfig >> 20) & 0xfcf;
/* Identify chip attached to board */ /* Identify chip attached to board */
chipset = rtl8169_get_mac_version(xid, tp->supports_gmii); chipset = rtl8169_get_mac_version(xid, tp->supports_gmii);
if (chipset == RTL_GIGA_MAC_NONE) { if (chipset == RTL_GIGA_MAC_NONE)
dev_err(&pdev->dev, "unknown chip XID %03x, contact r8169 maintainers (see MAINTAINERS file)\n", xid); return dev_err_probe(&pdev->dev, -ENODEV,
return -ENODEV; "unknown chip XID %03x, contact r8169 maintainers (see MAINTAINERS file)\n",
} xid);
tp->mac_version = chipset; tp->mac_version = chipset;
tp->dash_type = rtl_check_dash(tp); tp->dash_type = rtl_check_dash(tp);
...@@ -5253,10 +5244,9 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -5253,10 +5244,9 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
rtl_hw_reset(tp); rtl_hw_reset(tp);
rc = rtl_alloc_irq(tp); rc = rtl_alloc_irq(tp);
if (rc < 0) { if (rc < 0)
dev_err(&pdev->dev, "Can't allocate interrupt\n"); return dev_err_probe(&pdev->dev, rc, "Can't allocate interrupt\n");
return rc;
}
tp->irq = pci_irq_vector(pdev, 0); tp->irq = pci_irq_vector(pdev, 0);
INIT_WORK(&tp->wk.work, rtl_task); INIT_WORK(&tp->wk.work, rtl_task);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment