mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
Fixes for ie31200 driver that missed the first pull
-----BEGIN PGP SIGNATURE----- iIoEABYIADIWIQQW3WBGcnu5yJnSXn0kTJLX0iGMLAUCXzcrQRQcdG9ueS5sdWNr QGludGVsLmNvbQAKCRAkTJLX0iGMLHeUAP9mEdU4W+7STNaXuzJ/5PyWbDIHPB3m X/KXBlPRyQ5lXgD6A+IRTY3Ob7fBjs9i+sTuH5yMY6oi9YneC4lt1uqmmQc= =fg/o -----END PGP SIGNATURE----- Merge tag 'edac_updates_for_5.9_pt2' of git://git.kernel.org/pub/scm/linux/kernel/git/ras/ras Pull edac fix from Tony Luck: "Fix for the ie31200 driver that missed the first pull" * tag 'edac_updates_for_5.9_pt2' of git://git.kernel.org/pub/scm/linux/kernel/git/ras/ras: EDAC/ie31200: Fallback if host bridge device is already initialized
This commit is contained in:
commit
6ffdcde4ee
@ -170,6 +170,8 @@
|
|||||||
(n << (28 + (2 * skl) - PAGE_SHIFT))
|
(n << (28 + (2 * skl) - PAGE_SHIFT))
|
||||||
|
|
||||||
static int nr_channels;
|
static int nr_channels;
|
||||||
|
static struct pci_dev *mci_pdev;
|
||||||
|
static int ie31200_registered = 1;
|
||||||
|
|
||||||
struct ie31200_priv {
|
struct ie31200_priv {
|
||||||
void __iomem *window;
|
void __iomem *window;
|
||||||
@ -538,12 +540,16 @@ static int ie31200_probe1(struct pci_dev *pdev, int dev_idx)
|
|||||||
static int ie31200_init_one(struct pci_dev *pdev,
|
static int ie31200_init_one(struct pci_dev *pdev,
|
||||||
const struct pci_device_id *ent)
|
const struct pci_device_id *ent)
|
||||||
{
|
{
|
||||||
edac_dbg(0, "MC:\n");
|
int rc;
|
||||||
|
|
||||||
|
edac_dbg(0, "MC:\n");
|
||||||
if (pci_enable_device(pdev) < 0)
|
if (pci_enable_device(pdev) < 0)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
rc = ie31200_probe1(pdev, ent->driver_data);
|
||||||
|
if (rc == 0 && !mci_pdev)
|
||||||
|
mci_pdev = pci_dev_get(pdev);
|
||||||
|
|
||||||
return ie31200_probe1(pdev, ent->driver_data);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ie31200_remove_one(struct pci_dev *pdev)
|
static void ie31200_remove_one(struct pci_dev *pdev)
|
||||||
@ -552,6 +558,8 @@ static void ie31200_remove_one(struct pci_dev *pdev)
|
|||||||
struct ie31200_priv *priv;
|
struct ie31200_priv *priv;
|
||||||
|
|
||||||
edac_dbg(0, "\n");
|
edac_dbg(0, "\n");
|
||||||
|
pci_dev_put(mci_pdev);
|
||||||
|
mci_pdev = NULL;
|
||||||
mci = edac_mc_del_mc(&pdev->dev);
|
mci = edac_mc_del_mc(&pdev->dev);
|
||||||
if (!mci)
|
if (!mci)
|
||||||
return;
|
return;
|
||||||
@ -593,17 +601,53 @@ static struct pci_driver ie31200_driver = {
|
|||||||
|
|
||||||
static int __init ie31200_init(void)
|
static int __init ie31200_init(void)
|
||||||
{
|
{
|
||||||
|
int pci_rc, i;
|
||||||
|
|
||||||
edac_dbg(3, "MC:\n");
|
edac_dbg(3, "MC:\n");
|
||||||
/* Ensure that the OPSTATE is set correctly for POLL or NMI */
|
/* Ensure that the OPSTATE is set correctly for POLL or NMI */
|
||||||
opstate_init();
|
opstate_init();
|
||||||
|
|
||||||
return pci_register_driver(&ie31200_driver);
|
pci_rc = pci_register_driver(&ie31200_driver);
|
||||||
|
if (pci_rc < 0)
|
||||||
|
goto fail0;
|
||||||
|
|
||||||
|
if (!mci_pdev) {
|
||||||
|
ie31200_registered = 0;
|
||||||
|
for (i = 0; ie31200_pci_tbl[i].vendor != 0; i++) {
|
||||||
|
mci_pdev = pci_get_device(ie31200_pci_tbl[i].vendor,
|
||||||
|
ie31200_pci_tbl[i].device,
|
||||||
|
NULL);
|
||||||
|
if (mci_pdev)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (!mci_pdev) {
|
||||||
|
edac_dbg(0, "ie31200 pci_get_device fail\n");
|
||||||
|
pci_rc = -ENODEV;
|
||||||
|
goto fail1;
|
||||||
|
}
|
||||||
|
pci_rc = ie31200_init_one(mci_pdev, &ie31200_pci_tbl[i]);
|
||||||
|
if (pci_rc < 0) {
|
||||||
|
edac_dbg(0, "ie31200 init fail\n");
|
||||||
|
pci_rc = -ENODEV;
|
||||||
|
goto fail1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
fail1:
|
||||||
|
pci_unregister_driver(&ie31200_driver);
|
||||||
|
fail0:
|
||||||
|
pci_dev_put(mci_pdev);
|
||||||
|
|
||||||
|
return pci_rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __exit ie31200_exit(void)
|
static void __exit ie31200_exit(void)
|
||||||
{
|
{
|
||||||
edac_dbg(3, "MC:\n");
|
edac_dbg(3, "MC:\n");
|
||||||
pci_unregister_driver(&ie31200_driver);
|
pci_unregister_driver(&ie31200_driver);
|
||||||
|
if (!ie31200_registered)
|
||||||
|
ie31200_remove_one(mci_pdev);
|
||||||
}
|
}
|
||||||
|
|
||||||
module_init(ie31200_init);
|
module_init(ie31200_init);
|
||||||
|
Loading…
Reference in New Issue
Block a user