[PATCH] ARM: OMAP: make iommu subsys_initcall to fix builtin omap3isp
Ohad Ben-Cohen
ohad at wizery.com
Sun Feb 26 05:14:14 EST 2012
omap3isp depends on omap's iommu and will fail to probe if
initialized before it (which always happen if they are builtin).
Make omap's iommu subsys_initcall as an interim solution until
the probe deferral mechanism is merged.
Reported-by: James <angweiyang at gmail.com>
Debugged-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
Signed-off-by: Ohad Ben-Cohen <ohad at wizery.com>
Cc: stable <stable at vger.kernel.org>
Cc: Tony Lindgren <tony at atomide.com>
Cc: Hiroshi Doyu <hdoyu at nvidia.com>
Cc: Joerg Roedel <Joerg.Roedel at amd.com>
---
arch/arm/mach-omap2/mailbox.c | 3 ++-
drivers/iommu/omap-iommu.c | 3 ++-
2 files changed, 4 insertions(+), 2 deletions(-)
diff --git a/arch/arm/mach-omap2/mailbox.c b/arch/arm/mach-omap2/mailbox.c
index 609ea2d..a6db1e4 100644
--- a/arch/arm/mach-omap2/mailbox.c
+++ b/arch/arm/mach-omap2/mailbox.c
@@ -412,7 +412,8 @@ static void __exit omap2_mbox_exit(void)
platform_driver_unregister(&omap2_mbox_driver);
}
-module_init(omap2_mbox_init);
+/* must be ready before omap3isp is probed */
+subsys_initcall(omap2_mbox_init);
module_exit(omap2_mbox_exit);
MODULE_LICENSE("GPL v2");
diff --git a/drivers/iommu/omap-iommu.c b/drivers/iommu/omap-iommu.c
index 4e661f0..821062a 100644
--- a/drivers/iommu/omap-iommu.c
+++ b/drivers/iommu/omap-iommu.c
@@ -1222,7 +1222,8 @@ static int __init omap_iommu_init(void)
return platform_driver_register(&omap_iommu_driver);
}
-module_init(omap_iommu_init);
+/* must be ready before omap3isp is probed */
+subsys_initcall(omap_iommu_init);
static void __exit omap_iommu_exit(void)
{
--
1.7.5.4
More information about the linux-arm-kernel
mailing list