aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/platform/coda.c
diff options
context:
space:
mode:
authorPhilipp Zabel <p.zabel@pengutronix.de>2013-04-29 19:17:14 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2013-04-29 21:28:13 -0400
commit657eee7d25fb1422422ca32d5619185ae56a245d (patch)
tree0591c85ff0b4757c0392396b3b1b0029241f8957 /drivers/media/platform/coda.c
parent4984c6f5e56c3e68922fd979347ba7aff385783b (diff)
media: coda: use genalloc API
This patch depends on "genalloc: add devres support, allow to find a managed pool by device", which provides the of_get_named_gen_pool and dev_get_gen_pool functions. Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de> Acked-by: Javier Martin <javier.martin@vista-silicon.com> Acked-by: Grant Likely <grant.likely@secretlab.ca> Cc: Michal Simek <monstr@monstr.eu> Cc: Dong Aisheng <dong.aisheng@linaro.org> Cc: Fabio Estevam <fabio.estevam@freescale.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Huang Shijie <shijie8@gmail.com> Cc: Matt Porter <mporter@ti.com> Cc: Paul Gortmaker <paul.gortmaker@windriver.com> Cc: Rob Herring <rob.herring@calxeda.com> Cc: Shawn Guo <shawn.guo@linaro.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/media/platform/coda.c')
-rw-r--r--drivers/media/platform/coda.c45
1 files changed, 31 insertions, 14 deletions
diff --git a/drivers/media/platform/coda.c b/drivers/media/platform/coda.c
index 20827ba168fc..b931c2a5c7fc 100644
--- a/drivers/media/platform/coda.c
+++ b/drivers/media/platform/coda.c
@@ -14,6 +14,7 @@
14#include <linux/clk.h> 14#include <linux/clk.h>
15#include <linux/delay.h> 15#include <linux/delay.h>
16#include <linux/firmware.h> 16#include <linux/firmware.h>
17#include <linux/genalloc.h>
17#include <linux/interrupt.h> 18#include <linux/interrupt.h>
18#include <linux/io.h> 19#include <linux/io.h>
19#include <linux/irq.h> 20#include <linux/irq.h>
@@ -23,7 +24,7 @@
23#include <linux/slab.h> 24#include <linux/slab.h>
24#include <linux/videodev2.h> 25#include <linux/videodev2.h>
25#include <linux/of.h> 26#include <linux/of.h>
26#include <linux/platform_data/imx-iram.h> 27#include <linux/platform_data/coda.h>
27 28
28#include <media/v4l2-ctrls.h> 29#include <media/v4l2-ctrls.h>
29#include <media/v4l2-device.h> 30#include <media/v4l2-device.h>
@@ -43,6 +44,7 @@
43#define CODA7_WORK_BUF_SIZE (512 * 1024 + CODA_FMO_BUF_SIZE * 8 * 1024) 44#define CODA7_WORK_BUF_SIZE (512 * 1024 + CODA_FMO_BUF_SIZE * 8 * 1024)
44#define CODA_PARA_BUF_SIZE (10 * 1024) 45#define CODA_PARA_BUF_SIZE (10 * 1024)
45#define CODA_ISRAM_SIZE (2048 * 2) 46#define CODA_ISRAM_SIZE (2048 * 2)
47#define CODADX6_IRAM_SIZE 0xb000
46#define CODA7_IRAM_SIZE 0x14000 /* 81920 bytes */ 48#define CODA7_IRAM_SIZE 0x14000 /* 81920 bytes */
47 49
48#define CODA_MAX_FRAMEBUFFERS 2 50#define CODA_MAX_FRAMEBUFFERS 2
@@ -128,7 +130,10 @@ struct coda_dev {
128 130
129 struct coda_aux_buf codebuf; 131 struct coda_aux_buf codebuf;
130 struct coda_aux_buf workbuf; 132 struct coda_aux_buf workbuf;
133 struct gen_pool *iram_pool;
134 long unsigned int iram_vaddr;
131 long unsigned int iram_paddr; 135 long unsigned int iram_paddr;
136 unsigned long iram_size;
132 137
133 spinlock_t irqlock; 138 spinlock_t irqlock;
134 struct mutex dev_mutex; 139 struct mutex dev_mutex;
@@ -1926,6 +1931,9 @@ static int coda_probe(struct platform_device *pdev)
1926 const struct of_device_id *of_id = 1931 const struct of_device_id *of_id =
1927 of_match_device(of_match_ptr(coda_dt_ids), &pdev->dev); 1932 of_match_device(of_match_ptr(coda_dt_ids), &pdev->dev);
1928 const struct platform_device_id *pdev_id; 1933 const struct platform_device_id *pdev_id;
1934 struct coda_platform_data *pdata = pdev->dev.platform_data;
1935 struct device_node *np = pdev->dev.of_node;
1936 struct gen_pool *pool;
1929 struct coda_dev *dev; 1937 struct coda_dev *dev;
1930 struct resource *res; 1938 struct resource *res;
1931 int ret, irq; 1939 int ret, irq;
@@ -1988,6 +1996,16 @@ static int coda_probe(struct platform_device *pdev)
1988 return -ENOENT; 1996 return -ENOENT;
1989 } 1997 }
1990 1998
1999 /* Get IRAM pool from device tree or platform data */
2000 pool = of_get_named_gen_pool(np, "iram", 0);
2001 if (!pool && pdata)
2002 pool = dev_get_gen_pool(pdata->iram_dev);
2003 if (!pool) {
2004 dev_err(&pdev->dev, "iram pool not available\n");
2005 return -ENOMEM;
2006 }
2007 dev->iram_pool = pool;
2008
1991 ret = v4l2_device_register(&pdev->dev, &dev->v4l2_dev); 2009 ret = v4l2_device_register(&pdev->dev, &dev->v4l2_dev);
1992 if (ret) 2010 if (ret)
1993 return ret; 2011 return ret;
@@ -2022,18 +2040,17 @@ static int coda_probe(struct platform_device *pdev)
2022 return -ENOMEM; 2040 return -ENOMEM;
2023 } 2041 }
2024 2042
2025 if (dev->devtype->product == CODA_DX6) { 2043 if (dev->devtype->product == CODA_DX6)
2026 dev->iram_paddr = 0xffff4c00; 2044 dev->iram_size = CODADX6_IRAM_SIZE;
2027 } else { 2045 else
2028 void __iomem *iram_vaddr; 2046 dev->iram_size = CODA7_IRAM_SIZE;
2029 2047 dev->iram_vaddr = gen_pool_alloc(dev->iram_pool, dev->iram_size);
2030 iram_vaddr = iram_alloc(CODA7_IRAM_SIZE, 2048 if (!dev->iram_vaddr) {
2031 &dev->iram_paddr); 2049 dev_err(&pdev->dev, "unable to alloc iram\n");
2032 if (!iram_vaddr) { 2050 return -ENOMEM;
2033 dev_err(&pdev->dev, "unable to alloc iram\n");
2034 return -ENOMEM;
2035 }
2036 } 2051 }
2052 dev->iram_paddr = gen_pool_virt_to_phys(dev->iram_pool,
2053 dev->iram_vaddr);
2037 2054
2038 platform_set_drvdata(pdev, dev); 2055 platform_set_drvdata(pdev, dev);
2039 2056
@@ -2050,8 +2067,8 @@ static int coda_remove(struct platform_device *pdev)
2050 if (dev->alloc_ctx) 2067 if (dev->alloc_ctx)
2051 vb2_dma_contig_cleanup_ctx(dev->alloc_ctx); 2068 vb2_dma_contig_cleanup_ctx(dev->alloc_ctx);
2052 v4l2_device_unregister(&dev->v4l2_dev); 2069 v4l2_device_unregister(&dev->v4l2_dev);
2053 if (dev->iram_paddr) 2070 if (dev->iram_vaddr)
2054 iram_free(dev->iram_paddr, CODA7_IRAM_SIZE); 2071 gen_pool_free(dev->iram_pool, dev->iram_vaddr, dev->iram_size);
2055 if (dev->codebuf.vaddr) 2072 if (dev->codebuf.vaddr)
2056 dma_free_coherent(&pdev->dev, dev->codebuf.size, 2073 dma_free_coherent(&pdev->dev, dev->codebuf.size,
2057 &dev->codebuf.vaddr, dev->codebuf.paddr); 2074 &dev->codebuf.vaddr, dev->codebuf.paddr);