Commit 7c0f812a authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

[media] omap3isp: Defer probe when the IOMMU is not available

When the OMAP3 ISP driver is compiled in the kernel the device can be
probed before the corresponding IOMMU is available. Defer the probe in
that case, and fix a crash in the error path.
Reported-by: default avatarJavier Martin <javier.martin@vista-silicon.com>
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 31036441
...@@ -2249,6 +2249,7 @@ static int isp_probe(struct platform_device *pdev) ...@@ -2249,6 +2249,7 @@ static int isp_probe(struct platform_device *pdev)
ret = iommu_attach_device(isp->domain, &pdev->dev); ret = iommu_attach_device(isp->domain, &pdev->dev);
if (ret) { if (ret) {
dev_err(&pdev->dev, "can't attach iommu device: %d\n", ret); dev_err(&pdev->dev, "can't attach iommu device: %d\n", ret);
ret = -EPROBE_DEFER;
goto free_domain; goto free_domain;
} }
...@@ -2287,6 +2288,7 @@ static int isp_probe(struct platform_device *pdev) ...@@ -2287,6 +2288,7 @@ static int isp_probe(struct platform_device *pdev)
iommu_detach_device(isp->domain, &pdev->dev); iommu_detach_device(isp->domain, &pdev->dev);
free_domain: free_domain:
iommu_domain_free(isp->domain); iommu_domain_free(isp->domain);
isp->domain = NULL;
error_isp: error_isp:
isp_xclk_cleanup(isp); isp_xclk_cleanup(isp);
omap3isp_put(isp); omap3isp_put(isp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment