Acked-by: Dragos Carp <[EMAIL PROTECTED]> Domen Puncer wrote: > Fix mpc5200 PSC SPI driver to actually work for CONFIG_PPC_MERGE > - s/mpc52xx/mpc5200/, as this was changed in device tree some time ago > - fix spi id detection > > > Signed-off-by: Domen Puncer <[EMAIL PROTECTED]> > > --- > drivers/spi/mpc52xx_psc_spi.c | 25 +++++++++++-------------- > 1 file changed, 11 insertions(+), 14 deletions(-) > > Index: work-powerpc.git/drivers/spi/mpc52xx_psc_spi.c > =================================================================== > --- work-powerpc.git.orig/drivers/spi/mpc52xx_psc_spi.c > +++ work-powerpc.git/drivers/spi/mpc52xx_psc_spi.c > @@ -329,8 +329,8 @@ static int mpc52xx_psc_spi_port_config(i > int ret = 0; > > #if defined(CONFIG_PPC_MERGE) > - cdm = mpc52xx_find_and_map("mpc52xx-cdm"); > - gpio = mpc52xx_find_and_map("mpc52xx-gpio"); > + cdm = mpc52xx_find_and_map("mpc5200-cdm"); > + gpio = mpc52xx_find_and_map("mpc5200-gpio"); > #else > cdm = ioremap(MPC52xx_PA(MPC52xx_CDM_OFFSET), MPC52xx_CDM_SIZE); > gpio = ioremap(MPC52xx_PA(MPC52xx_GPIO_OFFSET), MPC52xx_GPIO_SIZE); > @@ -445,9 +445,6 @@ static int __init mpc52xx_psc_spi_do_pro > struct spi_master *master; > int ret; > > - if (pdata == NULL) > - return -ENODEV; > - > master = spi_alloc_master(dev, sizeof *mps); > if (master == NULL) > return -ENOMEM; > @@ -594,17 +591,17 @@ static int __init mpc52xx_psc_spi_of_pro > } > regaddr64 = of_translate_address(op->node, regaddr_p); > > + /* get PSC id (1..6, used by port_config) */ > if (op->dev.platform_data == NULL) { > - struct device_node *np; > - int i = 0; > + const u32 *psc_nump; > > - for_each_node_by_type(np, "spi") { > - if (of_find_device_by_node(np) == op) { > - id = i; > - break; > - } > - i++; > + psc_nump = of_get_property(op->node, "cell-index", NULL); > + if (!psc_nump || *psc_nump > 5) { > + printk(KERN_ERR "mpc52xx_psc_spi: Device node %s has > invalid " > + "cell-index property\n", > op->node->full_name); > + return -EINVAL; > } > + id = *psc_nump + 1; > } > > return mpc52xx_psc_spi_do_probe(&op->dev, (u32)regaddr64, (u32)size64, > @@ -617,7 +614,7 @@ static int __exit mpc52xx_psc_spi_of_rem > } > > static struct of_device_id mpc52xx_psc_spi_of_match[] = { > - { .type = "spi", .compatible = "mpc52xx-psc-spi", }, > + { .type = "spi", .compatible = "mpc5200-psc-spi", }, > {}, > }; > > > >
-- Dragos Carp Research & Development Phone: +49 89 85837-159, Fax: +49 89 85837-200 Address: TOPTICA Photonics AG, Lochhamer Schlag 19, D-82166 Graefelfing, Germany TOPTICA – A Passion for Precision TOPTICA Photonics AG, Registered Office: 82166 Graefelfing, Germany Companies' Register: Amtsgericht München, HRB 137368 Executive Directors: Dr. Wilhelm Kaenders, Dr. Thomas Weber Chairman of the Supervisory Board: Dr. Kristian Hohla www.toptica.com _______________________________________________ Linuxppc-embedded mailing list Linuxppc-embedded@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-embedded