powerpc/fsl-pci: Unify pci/pcie initialization code
We unified the Freescale pci/pcie initialization by changing the fsl_pci to a platform driver. In previous PCI code architecture the initialization routine is called at board_setup_arch stage. Now the initialization is done in probe function which is architectural better. Also It's convenient for adding PM support for PCI controller in later patch. Now we registered pci controllers as platform devices. So we combine two initialization code as one platform driver. Signed-off-by: Jia Hongtao <B38951@freescale.com> Signed-off-by: Li Yang <leoli@freescale.com> Signed-off-by: Chunhe Lan <Chunhe.Lan@freescale.com> Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Этот коммит содержится в:

коммит произвёл
Kumar Gala

родитель
9e67886bec
Коммит
905e75c46d
@@ -212,7 +212,7 @@ static irqreturn_t mpc85xx_pci_isr(int irq, void *dev_id)
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
static int __devinit mpc85xx_pci_err_probe(struct platform_device *op)
|
||||
int __devinit mpc85xx_pci_err_probe(struct platform_device *op)
|
||||
{
|
||||
struct edac_pci_ctl_info *pci;
|
||||
struct mpc85xx_pci_pdata *pdata;
|
||||
@@ -226,6 +226,16 @@ static int __devinit mpc85xx_pci_err_probe(struct platform_device *op)
|
||||
if (!pci)
|
||||
return -ENOMEM;
|
||||
|
||||
/* make sure error reporting method is sane */
|
||||
switch (edac_op_state) {
|
||||
case EDAC_OPSTATE_POLL:
|
||||
case EDAC_OPSTATE_INT:
|
||||
break;
|
||||
default:
|
||||
edac_op_state = EDAC_OPSTATE_INT;
|
||||
break;
|
||||
}
|
||||
|
||||
pdata = pci->pvt_info;
|
||||
pdata->name = "mpc85xx_pci_err";
|
||||
pdata->irq = NO_IRQ;
|
||||
@@ -315,6 +325,7 @@ err:
|
||||
devres_release_group(&op->dev, mpc85xx_pci_err_probe);
|
||||
return res;
|
||||
}
|
||||
EXPORT_SYMBOL(mpc85xx_pci_err_probe);
|
||||
|
||||
static int mpc85xx_pci_err_remove(struct platform_device *op)
|
||||
{
|
||||
@@ -338,27 +349,6 @@ static int mpc85xx_pci_err_remove(struct platform_device *op)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct of_device_id mpc85xx_pci_err_of_match[] = {
|
||||
{
|
||||
.compatible = "fsl,mpc8540-pcix",
|
||||
},
|
||||
{
|
||||
.compatible = "fsl,mpc8540-pci",
|
||||
},
|
||||
{},
|
||||
};
|
||||
MODULE_DEVICE_TABLE(of, mpc85xx_pci_err_of_match);
|
||||
|
||||
static struct platform_driver mpc85xx_pci_err_driver = {
|
||||
.probe = mpc85xx_pci_err_probe,
|
||||
.remove = __devexit_p(mpc85xx_pci_err_remove),
|
||||
.driver = {
|
||||
.name = "mpc85xx_pci_err",
|
||||
.owner = THIS_MODULE,
|
||||
.of_match_table = mpc85xx_pci_err_of_match,
|
||||
},
|
||||
};
|
||||
|
||||
#endif /* CONFIG_PCI */
|
||||
|
||||
/**************************** L2 Err device ***************************/
|
||||
@@ -1210,12 +1200,6 @@ static int __init mpc85xx_mc_init(void)
|
||||
if (res)
|
||||
printk(KERN_WARNING EDAC_MOD_STR "L2 fails to register\n");
|
||||
|
||||
#ifdef CONFIG_PCI
|
||||
res = platform_driver_register(&mpc85xx_pci_err_driver);
|
||||
if (res)
|
||||
printk(KERN_WARNING EDAC_MOD_STR "PCI fails to register\n");
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_FSL_SOC_BOOKE
|
||||
pvr = mfspr(SPRN_PVR);
|
||||
|
||||
@@ -1251,9 +1235,6 @@ static void __exit mpc85xx_mc_exit(void)
|
||||
(PVR_VER(pvr) == PVR_VER_E500V2)) {
|
||||
on_each_cpu(mpc85xx_mc_restore_hid1, NULL, 0);
|
||||
}
|
||||
#endif
|
||||
#ifdef CONFIG_PCI
|
||||
platform_driver_unregister(&mpc85xx_pci_err_driver);
|
||||
#endif
|
||||
platform_driver_unregister(&mpc85xx_l2_err_driver);
|
||||
platform_driver_unregister(&mpc85xx_mc_err_driver);
|
||||
|
Ссылка в новой задаче
Block a user