summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDmitry Osipenko <digetx@gmail.com>2014-10-10 17:24:47 +0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2015-01-08 10:27:46 -0800
commitffb2f7e95eea245e725d93f6d1d00d9a508083a3 (patch)
treed7fa50c397e4268fc1a5d9616325b082cc1ff09a
parenta2585bd7780db89432a2a06b28d9af9a8b6ed8ca (diff)
downloadlinux-stable-ffb2f7e95eea245e725d93f6d1d00d9a508083a3.tar.gz
linux-stable-ffb2f7e95eea245e725d93f6d1d00d9a508083a3.tar.bz2
linux-stable-ffb2f7e95eea245e725d93f6d1d00d9a508083a3.zip
ARM: tegra: Re-add removed SoC id macro to tegra_resume()
commit e4a680099a6e97ecdbb81081cff9e4a489a4dc44 upstream. Commit d127e9c ("ARM: tegra: make tegra_resume can work with current and later chips") removed tegra_get_soc_id macro leaving used cpu register corrupted after branching to v7_invalidate_l1() and as result causing execution of unintended code on tegra20. Possibly it was expected that r6 would be SoC id func argument since common cpu reset handler is setting r6 before branching to tegra_resume(), but neither tegra20_lp1_reset() nor tegra30_lp1_reset() aren't setting r6 register before jumping to resume function. Fix it by re-adding macro. Fixes: d127e9c (ARM: tegra: make tegra_resume can work with current and later chips) Reviewed-by: Felipe Balbi <balbi@ti.com> Signed-off-by: Dmitry Osipenko <digetx@gmail.com> Signed-off-by: Thierry Reding <treding@nvidia.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--arch/arm/mach-tegra/reset-handler.S1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/arm/mach-tegra/reset-handler.S b/arch/arm/mach-tegra/reset-handler.S
index 7b2baab0f0bd..71be4af5e975 100644
--- a/arch/arm/mach-tegra/reset-handler.S
+++ b/arch/arm/mach-tegra/reset-handler.S
@@ -51,6 +51,7 @@ ENTRY(tegra_resume)
THUMB( it ne )
bne cpu_resume @ no
+ tegra_get_soc_id TEGRA_APB_MISC_BASE, r6
/* Are we on Tegra20? */
cmp r6, #TEGRA20
beq 1f @ Yes