ARM: keystone: fix PM domain initcall to be keystone only
authorKevin Hilman <khilman@linaro.org>
Mon, 14 Oct 2013 17:30:11 +0000 (10:30 -0700)
committerKevin Hilman <khilman@linaro.org>
Mon, 14 Oct 2013 18:10:33 +0000 (11:10 -0700)
initcalls need to have platform specific checks so they are not run in
multi-platform builds.

Acked-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Signed-off-by: Kevin Hilman <khilman@linaro.org>
arch/arm/mach-keystone/pm_domain.c

index beac3fb1d205e66ec50df08c892ef984ff9f7e08..29625232e9543aba107f29bc8cd6260c4f12c658 100644 (file)
@@ -17,6 +17,7 @@
 #include <linux/pm_clock.h>
 #include <linux/platform_device.h>
 #include <linux/clk-provider.h>
+#include <linux/of.h>
 
 #ifdef CONFIG_PM_RUNTIME
 static int keystone_pm_runtime_suspend(struct device *dev)
@@ -60,8 +61,19 @@ static struct pm_clk_notifier_block platform_domain_notifier = {
        .pm_domain = &keystone_pm_domain,
 };
 
+static struct of_device_id of_keystone_table[] = {
+       {.compatible = "ti,keystone"},
+       { /* end of list */ },
+};
+
 int __init keystone_pm_runtime_init(void)
 {
+       struct device_node *np;
+
+       np = of_find_matching_node(NULL, of_keystone_table);
+       if (!np)
+               return 0;
+
        of_clk_init(NULL);
        pm_clk_add_notifier(&platform_bus_type, &platform_domain_notifier);