Commit e22dc2b2 authored by Joseph Lo's avatar Joseph Lo Committed by Stephen Warren

ARM: tegra: cpuidle: move the init function behind the suspend init function

One of the state of CPUidle on Tegra can power gate the CPU and the
vdd_cpu rail. But it depends on some configurations from DT and a common
hook function for different Tegra SoCs to power gate the CPU rail. And
these stuffs are initialized after common Tegra suspend init function. So
we move the CPUidle init behind the suspend init function. And making the
CPUidle driver more generic.
Signed-off-by: default avatarJoseph Lo <josephl@nvidia.com>
Signed-off-by: default avatarStephen Warren <swarren@nvidia.com>
parent af7f322e
...@@ -29,6 +29,7 @@ ...@@ -29,6 +29,7 @@
#include "board.h" #include "board.h"
#include "common.h" #include "common.h"
#include "cpuidle.h"
#include "fuse.h" #include "fuse.h"
#include "iomap.h" #include "iomap.h"
#include "irq.h" #include "irq.h"
...@@ -108,5 +109,6 @@ void __init tegra_init_early(void) ...@@ -108,5 +109,6 @@ void __init tegra_init_early(void)
void __init tegra_init_late(void) void __init tegra_init_late(void)
{ {
tegra_init_suspend(); tegra_init_suspend();
tegra_cpuidle_init();
tegra_powergate_debugfs_init(); tegra_powergate_debugfs_init();
} }
...@@ -27,25 +27,19 @@ ...@@ -27,25 +27,19 @@
#include "fuse.h" #include "fuse.h"
#include "cpuidle.h" #include "cpuidle.h"
static int __init tegra_cpuidle_init(void) void __init tegra_cpuidle_init(void)
{ {
int ret;
switch (tegra_chip_id) { switch (tegra_chip_id) {
case TEGRA20: case TEGRA20:
ret = tegra20_cpuidle_init(); tegra20_cpuidle_init();
break; break;
case TEGRA30: case TEGRA30:
ret = tegra30_cpuidle_init(); tegra30_cpuidle_init();
break; break;
case TEGRA114: case TEGRA114:
ret = tegra114_cpuidle_init(); tegra114_cpuidle_init();
break; break;
default: default:
ret = -ENODEV;
break; break;
} }
return ret;
} }
device_initcall(tegra_cpuidle_init);
...@@ -35,4 +35,10 @@ int tegra114_cpuidle_init(void); ...@@ -35,4 +35,10 @@ int tegra114_cpuidle_init(void);
static inline int tegra114_cpuidle_init(void) { return -ENODEV; } static inline int tegra114_cpuidle_init(void) { return -ENODEV; }
#endif #endif
#ifdef CONFIG_CPU_IDLE
void tegra_cpuidle_init(void);
#else
static inline void tegra_cpuidle_init(void) {}
#endif
#endif #endif
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