diff options
author | Joseph Lo <josephl@nvidia.com> | 2013-01-04 04:32:21 -0500 |
---|---|---|
committer | Stephen Warren <swarren@nvidia.com> | 2013-01-28 12:21:51 -0500 |
commit | 8c627fa6583a4894189a47a0bf868f7848b51748 (patch) | |
tree | f969ca47529b0e4def47e6629bfb520646442db4 | |
parent | b811943160cf3b040341c50d23440cf6d68ae079 (diff) |
ARM: tegra: clean up the CPUINIT section
There are some redundant codes in the CPUINIT section that was caused by
some codes not be organized well in "headsmp.S". Currently all the codes
in "headsmp.S" were put into CPUINIT section. But actually it doesn't
need to be loacted in CPUINIT section. There is no fuction access them
in CPUINIT section and we will relocate them to IRAM.
These codes also caused some unnecessary functions that access these
codes been put into CPUINIT section too. This patch clean it up and put
them into normal text section.
Signed-off-by: Joseph Lo <josephl@nvidia.com>
Signed-off-by: Stephen Warren <swarren@nvidia.com>
-rw-r--r-- | arch/arm/mach-tegra/cpuidle-tegra30.c | 6 | ||||
-rw-r--r-- | arch/arm/mach-tegra/headsmp.S | 2 | ||||
-rw-r--r-- | arch/arm/mach-tegra/pm.c | 4 |
3 files changed, 5 insertions, 7 deletions
diff --git a/arch/arm/mach-tegra/cpuidle-tegra30.c b/arch/arm/mach-tegra/cpuidle-tegra30.c index 5e8cbf5b799f..82530bd9b8c2 100644 --- a/arch/arm/mach-tegra/cpuidle-tegra30.c +++ b/arch/arm/mach-tegra/cpuidle-tegra30.c | |||
@@ -121,9 +121,9 @@ static inline bool tegra30_cpu_core_power_down(struct cpuidle_device *dev, | |||
121 | } | 121 | } |
122 | #endif | 122 | #endif |
123 | 123 | ||
124 | static int __cpuinit tegra30_idle_lp2(struct cpuidle_device *dev, | 124 | static int tegra30_idle_lp2(struct cpuidle_device *dev, |
125 | struct cpuidle_driver *drv, | 125 | struct cpuidle_driver *drv, |
126 | int index) | 126 | int index) |
127 | { | 127 | { |
128 | u32 cpu = is_smp() ? cpu_logical_map(dev->cpu) : dev->cpu; | 128 | u32 cpu = is_smp() ? cpu_logical_map(dev->cpu) : dev->cpu; |
129 | bool entered_lp2 = false; | 129 | bool entered_lp2 = false; |
diff --git a/arch/arm/mach-tegra/headsmp.S b/arch/arm/mach-tegra/headsmp.S index 4a317fae6860..23f487da7a57 100644 --- a/arch/arm/mach-tegra/headsmp.S +++ b/arch/arm/mach-tegra/headsmp.S | |||
@@ -16,8 +16,6 @@ | |||
16 | #define RESET_DATA(x) ((TEGRA_RESET_##x)*4) | 16 | #define RESET_DATA(x) ((TEGRA_RESET_##x)*4) |
17 | 17 | ||
18 | .section ".text.head", "ax" | 18 | .section ".text.head", "ax" |
19 | __CPUINIT | ||
20 | |||
21 | /* | 19 | /* |
22 | * Tegra specific entry point for secondary CPUs. | 20 | * Tegra specific entry point for secondary CPUs. |
23 | * The secondary kernel init calls v7_flush_dcache_all before it enables | 21 | * The secondary kernel init calls v7_flush_dcache_all before it enables |
diff --git a/arch/arm/mach-tegra/pm.c b/arch/arm/mach-tegra/pm.c index 1b11707eaca0..498d70b33775 100644 --- a/arch/arm/mach-tegra/pm.c +++ b/arch/arm/mach-tegra/pm.c | |||
@@ -148,7 +148,7 @@ static void suspend_cpu_complex(void) | |||
148 | save_cpu_arch_register(); | 148 | save_cpu_arch_register(); |
149 | } | 149 | } |
150 | 150 | ||
151 | void __cpuinit tegra_clear_cpu_in_lp2(int phy_cpu_id) | 151 | void tegra_clear_cpu_in_lp2(int phy_cpu_id) |
152 | { | 152 | { |
153 | u32 *cpu_in_lp2 = tegra_cpu_lp2_mask; | 153 | u32 *cpu_in_lp2 = tegra_cpu_lp2_mask; |
154 | 154 | ||
@@ -160,7 +160,7 @@ void __cpuinit tegra_clear_cpu_in_lp2(int phy_cpu_id) | |||
160 | spin_unlock(&tegra_lp2_lock); | 160 | spin_unlock(&tegra_lp2_lock); |
161 | } | 161 | } |
162 | 162 | ||
163 | bool __cpuinit tegra_set_cpu_in_lp2(int phy_cpu_id) | 163 | bool tegra_set_cpu_in_lp2(int phy_cpu_id) |
164 | { | 164 | { |
165 | bool last_cpu = false; | 165 | bool last_cpu = false; |
166 | cpumask_t *cpu_lp2_mask = tegra_cpu_lp2_mask; | 166 | cpumask_t *cpu_lp2_mask = tegra_cpu_lp2_mask; |