Commit 8308a78d authored by Santosh Shilimkar's avatar Santosh Shilimkar

ARM: keystone: Make PM bus ready before populating platform devices

Keystone PM bus makes use of generic PM clock core backend. Since
generic PM clock core uses platform bus notifiers to track events like
ADD_DEVICE/DEL_DEVICE and to fill clock lists per each device, we need
to initialise Keystone PM domains before the platform devices have been
created.

Hence, fix it by moving keystone_pm_runtime_init() before platform
devices have been populated.
Reported-by: default avatarGrygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: default avatarSantosh Shilimkar <santosh.shilimkar@ti.com>
parent df595a9d
...@@ -41,6 +41,7 @@ static void __init keystone_init(void) ...@@ -41,6 +41,7 @@ static void __init keystone_init(void)
if (WARN_ON(!keystone_rstctrl)) if (WARN_ON(!keystone_rstctrl))
pr_warn("ti,keystone-reset iomap error\n"); pr_warn("ti,keystone-reset iomap error\n");
keystone_pm_runtime_init();
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
} }
......
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
extern struct smp_operations keystone_smp_ops; extern struct smp_operations keystone_smp_ops;
extern void secondary_startup(void); extern void secondary_startup(void);
extern u32 keystone_cpu_smc(u32 command, u32 cpu, u32 addr); extern u32 keystone_cpu_smc(u32 command, u32 cpu, u32 addr);
extern int keystone_pm_runtime_init(void);
#endif /* __ASSEMBLER__ */ #endif /* __ASSEMBLER__ */
#endif /* __KEYSTONE_H__ */ #endif /* __KEYSTONE_H__ */
...@@ -79,4 +79,3 @@ int __init keystone_pm_runtime_init(void) ...@@ -79,4 +79,3 @@ int __init keystone_pm_runtime_init(void)
return 0; return 0;
} }
subsys_initcall(keystone_pm_runtime_init);
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