提交 da4a0f76 编写于 作者: A Aaro Koskinen 提交者: Tony Lindgren

arm: plat-omap: iommu: fix request_mem_region() error path

request_mem_region() error exit will leak ioremapped memory. Fix this
by moving the ioremap() after request_mem_region(), which is the proper
order to do this anyway.
Signed-off-by: NAaro Koskinen <aaro.koskinen@nokia.com>
Signed-off-by: NTony Lindgren <tony@atomide.com>
上级 b235e007
...@@ -982,11 +982,6 @@ static int __devinit omap_iommu_probe(struct platform_device *pdev) ...@@ -982,11 +982,6 @@ static int __devinit omap_iommu_probe(struct platform_device *pdev)
err = -ENODEV; err = -ENODEV;
goto err_mem; goto err_mem;
} }
obj->regbase = ioremap(res->start, resource_size(res));
if (!obj->regbase) {
err = -ENOMEM;
goto err_mem;
}
res = request_mem_region(res->start, resource_size(res), res = request_mem_region(res->start, resource_size(res),
dev_name(&pdev->dev)); dev_name(&pdev->dev));
...@@ -995,6 +990,12 @@ static int __devinit omap_iommu_probe(struct platform_device *pdev) ...@@ -995,6 +990,12 @@ static int __devinit omap_iommu_probe(struct platform_device *pdev)
goto err_mem; goto err_mem;
} }
obj->regbase = ioremap(res->start, resource_size(res));
if (!obj->regbase) {
err = -ENOMEM;
goto err_ioremap;
}
irq = platform_get_irq(pdev, 0); irq = platform_get_irq(pdev, 0);
if (irq < 0) { if (irq < 0) {
err = -ENODEV; err = -ENODEV;
...@@ -1023,8 +1024,9 @@ static int __devinit omap_iommu_probe(struct platform_device *pdev) ...@@ -1023,8 +1024,9 @@ static int __devinit omap_iommu_probe(struct platform_device *pdev)
err_pgd: err_pgd:
free_irq(irq, obj); free_irq(irq, obj);
err_irq: err_irq:
release_mem_region(res->start, resource_size(res));
iounmap(obj->regbase); iounmap(obj->regbase);
err_ioremap:
release_mem_region(res->start, resource_size(res));
err_mem: err_mem:
clk_put(obj->clk); clk_put(obj->clk);
err_clk: err_clk:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册