Manuel Lauss wrote: >>From cad526401dcfa6d0d56f80d86e8eaac12a17757f Mon Sep 17 00:00:00 2001 > From: Manuel Lauss <[EMAIL PROTECTED]> > Date: Sat, 7 Jun 2008 12:14:37 +0200 > Subject: [PATCH] au1550_spi: proper platform device > > Remove the Au1550 resource table and instead extract MMIO/IRQ/DMA > resources from platform resource information like any well-behaved > platform driver. > > Signed-off-by: Manuel Lauss <[EMAIL PROTECTED]>
Thanks. Signed-off-by: Jan Nikitenko <[EMAIL PROTECTED]> > --- > drivers/spi/au1550_spi.c | 138 +++++++++++++++------------- > include/asm-mips/mach-au1x00/au1550_spi.h | 1 - > 2 files changed, 74 insertions(+), 65 deletions(-) > > diff --git a/drivers/spi/au1550_spi.c b/drivers/spi/au1550_spi.c > index 072c4a5..3860dd2 100644 > --- a/drivers/spi/au1550_spi.c > +++ b/drivers/spi/au1550_spi.c > @@ -26,6 +26,7 @@ > #include <linux/errno.h> > #include <linux/device.h> > #include <linux/platform_device.h> > +#include <linux/resource.h> > #include <linux/spi/spi.h> > #include <linux/spi/spi_bitbang.h> > #include <linux/dma-mapping.h> > @@ -81,6 +82,7 @@ struct au1550_spi { > struct spi_master *master; > struct device *dev; > struct au1550_spi_info *pdata; > + struct resource *ioarea; > }; > > > @@ -96,6 +98,8 @@ static dbdev_tab_t au1550_spi_mem_dbdev = > .dev_intpolarity = 0 > }; > > +static int ddma_memid; /* id to above mem dma device */ > + > static void au1550_spi_bits_handlers_set(struct au1550_spi *hw, int bpw); > > > @@ -732,6 +736,7 @@ static int __init au1550_spi_probe(struct platform_device > *pdev) > { > struct au1550_spi *hw; > struct spi_master *master; > + struct resource *r; > int err = 0; > > master = spi_alloc_master(&pdev->dev, sizeof(struct au1550_spi)); > @@ -753,76 +758,64 @@ static int __init au1550_spi_probe(struct > platform_device *pdev) > goto err_no_pdata; > } > > - platform_set_drvdata(pdev, hw); > - > - init_completion(&hw->master_done); > - > - hw->bitbang.master = hw->master; > - hw->bitbang.setup_transfer = au1550_spi_setupxfer; > - hw->bitbang.chipselect = au1550_spi_chipsel; > - hw->bitbang.master->setup = au1550_spi_setup; > - hw->bitbang.txrx_bufs = au1550_spi_txrx_bufs; > + r = platform_get_resource(pdev, IORESOURCE_IRQ, 0); > + if (!r) { > + dev_err(&pdev->dev, "no IRQ\n"); > + err = -ENODEV; > + goto err_no_iores; > + } > + hw->irq = r->start; > + > + hw->usedma = 0; > + r = platform_get_resource(pdev, IORESOURCE_DMA, 0); > + if (r) { > + hw->dma_tx_id = r->start; > + r = platform_get_resource(pdev, IORESOURCE_DMA, 1); > + if (r) { > + hw->dma_rx_id = r->start; > + if (usedma && ddma_memid) { > + if (pdev->dev.dma_mask == NULL) > + dev_warn(&pdev->dev, "no dma mask\n"); > + else > + hw->usedma = 1; > + } > + } > + } > > - switch (hw->pdata->bus_num) { > - case 0: > - hw->irq = AU1550_PSC0_INT; > - hw->regs = (volatile psc_spi_t *)PSC0_BASE_ADDR; > - hw->dma_rx_id = DSCR_CMD0_PSC0_RX; > - hw->dma_tx_id = DSCR_CMD0_PSC0_TX; > - break; > - case 1: > - hw->irq = AU1550_PSC1_INT; > - hw->regs = (volatile psc_spi_t *)PSC1_BASE_ADDR; > - hw->dma_rx_id = DSCR_CMD0_PSC1_RX; > - hw->dma_tx_id = DSCR_CMD0_PSC1_TX; > - break; > - case 2: > - hw->irq = AU1550_PSC2_INT; > - hw->regs = (volatile psc_spi_t *)PSC2_BASE_ADDR; > - hw->dma_rx_id = DSCR_CMD0_PSC2_RX; > - hw->dma_tx_id = DSCR_CMD0_PSC2_TX; > - break; > - case 3: > - hw->irq = AU1550_PSC3_INT; > - hw->regs = (volatile psc_spi_t *)PSC3_BASE_ADDR; > - hw->dma_rx_id = DSCR_CMD0_PSC3_RX; > - hw->dma_tx_id = DSCR_CMD0_PSC3_TX; > - break; > - default: > - dev_err(&pdev->dev, "Wrong bus_num of SPI\n"); > - err = -ENOENT; > - goto err_no_pdata; > + r = platform_get_resource(pdev, IORESOURCE_MEM, 0); > + if (!r) { > + dev_err(&pdev->dev, "no mmio resource\n"); > + err = -ENODEV; > + goto err_no_iores; > } > > - if (request_mem_region((unsigned long)hw->regs, sizeof(psc_spi_t), > - pdev->name) == NULL) { > + hw->ioarea = request_mem_region(r->start, sizeof(psc_spi_t), > + pdev->name); > + if (!hw->ioarea) { > dev_err(&pdev->dev, "Cannot reserve iomem region\n"); > err = -ENXIO; > goto err_no_iores; > } > > - > - if (usedma) { > - if (pdev->dev.dma_mask == NULL) > - dev_warn(&pdev->dev, "no dma mask\n"); > - else > - hw->usedma = 1; > + hw->regs = (psc_spi_t __iomem *)ioremap(r->start, sizeof(psc_spi_t)); > + if (!hw->regs) { > + dev_err(&pdev->dev, "cannot ioremap\n"); > + err = -ENXIO; > + goto err_ioremap; > } > > - if (hw->usedma) { > - /* > - * create memory device with 8 bits dev_devwidth > - * needed for proper byte ordering to spi fifo > - */ > - int memid = au1xxx_ddma_add_device(&au1550_spi_mem_dbdev); > - if (!memid) { > - dev_err(&pdev->dev, > - "Cannot create dma 8 bit mem device\n"); > - err = -ENXIO; > - goto err_dma_add_dev; > - } > + platform_set_drvdata(pdev, hw); > > - hw->dma_tx_ch = au1xxx_dbdma_chan_alloc(memid, > + init_completion(&hw->master_done); > + > + hw->bitbang.master = hw->master; > + hw->bitbang.setup_transfer = au1550_spi_setupxfer; > + hw->bitbang.chipselect = au1550_spi_chipsel; > + hw->bitbang.master->setup = au1550_spi_setup; > + hw->bitbang.txrx_bufs = au1550_spi_txrx_bufs; > + > + if (hw->usedma) { > + hw->dma_tx_ch = au1xxx_dbdma_chan_alloc(ddma_memid, > hw->dma_tx_id, NULL, (void *)hw); > if (hw->dma_tx_ch == 0) { > dev_err(&pdev->dev, > @@ -841,7 +834,7 @@ static int __init au1550_spi_probe(struct platform_device > *pdev) > > > hw->dma_rx_ch = au1xxx_dbdma_chan_alloc(hw->dma_rx_id, > - memid, NULL, (void *)hw); > + ddma_memid, NULL, (void *)hw); > if (hw->dma_rx_ch == 0) { > dev_err(&pdev->dev, > "Cannot allocate rx dma channel\n"); > @@ -874,7 +867,7 @@ static int __init au1550_spi_probe(struct platform_device > *pdev) > goto err_no_irq; > } > > - master->bus_num = hw->pdata->bus_num; > + master->bus_num = pdev->id; > master->num_chipselect = hw->pdata->num_chipselect; > > /* > @@ -924,8 +917,11 @@ err_no_txdma_descr: > au1xxx_dbdma_chan_free(hw->dma_tx_ch); > > err_no_txdma: > -err_dma_add_dev: > - release_mem_region((unsigned long)hw->regs, sizeof(psc_spi_t)); > + iounmap((void __iomem *)hw->regs); > + > +err_ioremap: > + release_resource(hw->ioarea); > + kfree(hw->ioarea); > > err_no_iores: > err_no_pdata: > @@ -944,7 +940,9 @@ static int __exit au1550_spi_remove(struct > platform_device *pdev) > > spi_bitbang_stop(&hw->bitbang); > free_irq(hw->irq, hw); > - release_mem_region((unsigned long)hw->regs, sizeof(psc_spi_t)); > + iounmap((void __iomem *)hw->regs); > + release_resource(hw->ioarea); > + kfree(hw->ioarea); > > if (hw->usedma) { > au1550_spi_dma_rxtmp_free(hw); > @@ -971,12 +969,24 @@ static struct platform_driver au1550_spi_drv = { > > static int __init au1550_spi_init(void) > { > + /* > + * create memory device with 8 bits dev_devwidth > + * needed for proper byte ordering to spi fifo > + */ > + if (usedma) { > + ddma_memid = au1xxx_ddma_add_device(&au1550_spi_mem_dbdev); > + if (!ddma_memid) > + printk(KERN_ERR "au1550-spi: cannot add memory" > + "dbdma device\n"); > + } > return platform_driver_probe(&au1550_spi_drv, au1550_spi_probe); > } > module_init(au1550_spi_init); > > static void __exit au1550_spi_exit(void) > { > + if (usedma && ddma_memid) > + au1xxx_ddma_del_device(ddma_memid); > platform_driver_unregister(&au1550_spi_drv); > } > module_exit(au1550_spi_exit); > diff --git a/include/asm-mips/mach-au1x00/au1550_spi.h > b/include/asm-mips/mach-au1x00/au1550_spi.h > index 40e6c48..08e1958 100644 > --- a/include/asm-mips/mach-au1x00/au1550_spi.h > +++ b/include/asm-mips/mach-au1x00/au1550_spi.h > @@ -6,7 +6,6 @@ > #define _AU1550_SPI_H_ > > struct au1550_spi_info { > - s16 bus_num; /* defines which PSC and IRQ to use */ > u32 mainclk_hz; /* main input clock frequency of PSC */ > u16 num_chipselect; /* number of chipselects supported */ > void (*activate_cs)(struct au1550_spi_info *spi, int cs, int polarity); ------------------------------------------------------------------------- Check out the new SourceForge.net Marketplace. It's the best place to buy or sell services for just about anything Open Source. http://sourceforge.net/services/buy/index.php _______________________________________________ spi-devel-general mailing list spi-devel-general@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/spi-devel-general