summaryrefslogtreecommitdiff
path: root/drivers/media
diff options
context:
space:
mode:
authorKaz Fukuoka <kfukuoka@nvidia.com>2011-05-18 18:04:18 -0700
committerNiket Sirsi <nsirsi@nvidia.com>2011-05-23 17:02:18 -0700
commitdedd6a4d41c81333c54fd40b746d8189af2188c4 (patch)
treec532f0324a470c2dc59dea173bc185ad434b7f1f /drivers/media
parentd4bb47983433059b10b4f639affc12cce407425c (diff)
media: tegra: avp: Fix AVP kernel memory allocation
This change fixes AVP kernel startup problem on Tegra2. bug 828027 Change-Id: I6505e1690eb96c485cf8141d0d257cf7214837ca Reviewed-on: http://git-master/r/32107 Reviewed-by: Mayuresh Kulkarni <mkulkarni@nvidia.com> Reviewed-by: Kaz Fukuoka <kfukuoka@nvidia.com> Tested-by: Kaz Fukuoka <kfukuoka@nvidia.com> Reviewed-by: Yu-Huan Hsu <yhsu@nvidia.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/video/tegra/avp/avp.c27
1 files changed, 8 insertions, 19 deletions
diff --git a/drivers/media/video/tegra/avp/avp.c b/drivers/media/video/tegra/avp/avp.c
index 771631964a06..db7410e41230 100644
--- a/drivers/media/video/tegra/avp/avp.c
+++ b/drivers/media/video/tegra/avp/avp.c
@@ -1625,7 +1625,7 @@ static int tegra_avp_probe(struct platform_device *pdev)
}
#if defined(CONFIG_TEGRA_AVP_KERNEL_ON_MMU) /* Tegra2 with AVP MMU */
- heap_mask = NVMAP_HEAP_CARVEOUT_MASK;
+ heap_mask = NVMAP_HEAP_CARVEOUT_GENERIC;
#elif defined(CONFIG_TEGRA_AVP_KERNEL_ON_SMMU) /* Tegra3 with SMMU */
heap_mask = NVMAP_HEAP_IOVMM;
#else /* nvmem= carveout */
@@ -1639,20 +1639,12 @@ static int tegra_avp_probe(struct platform_device *pdev)
avp->kernel_phys = avp_early_kernel_phys;
}
- if (heap_mask == NVMAP_HEAP_CARVEOUT_MASK) {
- avp->kernel_handle = nvmap_create_handle(avp->nvmap_drv, SZ_1M);
+ if (heap_mask == NVMAP_HEAP_CARVEOUT_GENERIC) {
+ avp->kernel_handle = nvmap_alloc(avp->nvmap_drv, SZ_1M, SZ_1M,
+ NVMAP_HANDLE_WRITE_COMBINE);
if (IS_ERR_OR_NULL(avp->kernel_handle)) {
- pr_err("%s: cannot create kernel handle\n", __func__);
+ pr_err("%s: cannot create handle\n", __func__);
ret = PTR_ERR(avp->kernel_handle);
- goto err_nvmap_create_handle;
- }
-
- ret = nvmap_alloc_handle_id(avp->nvmap_drv,
- nvmap_ref_to_id(avp->kernel_handle),
- heap_mask, PAGE_SIZE,
- NVMAP_HANDLE_WRITE_COMBINE);
- if (ret) {
- pr_err("%s: cannot allocate kernel memory\n", __func__);
goto err_nvmap_alloc;
}
@@ -1663,15 +1655,15 @@ static int tegra_avp_probe(struct platform_device *pdev)
goto err_nvmap_mmap;
}
- avp->kernel_phys =
- nvmap_pin(avp->nvmap_drv, avp->kernel_handle);
+ avp->kernel_phys = nvmap_pin(avp->nvmap_drv,
+ avp->kernel_handle);
if (IS_ERR_OR_NULL((void *)avp->kernel_phys)) {
pr_err("%s: cannot pin kernel handle\n", __func__);
ret = PTR_ERR((void *)avp->kernel_phys);
goto err_nvmap_pin;
}
- pr_info("%s: allocated memory at %lx for AVP kernel\n",
+ pr_info("%s: allocated carveout memory at %lx for AVP kernel\n",
__func__, (unsigned long)avp->kernel_phys);
}
@@ -1807,9 +1799,6 @@ err_nvmap_pin:
err_nvmap_mmap:
nvmap_free(avp->nvmap_drv, avp->kernel_handle);
err_nvmap_alloc:
- nvmap_free_handle_id(avp->nvmap_drv,
- nvmap_ref_to_id(avp->kernel_handle));
-err_nvmap_create_handle:
nvmap_client_put(avp->nvmap_drv);
err_nvmap_create_drv_client:
kfree(avp);