]> git.baikalelectronics.ru Git - kernel.git/commit
ARM: 7696/1: Fix kexec by setting outer_cache.inv_all for Feroceon
authorIllia Ragozin <illia.ragozin@grapecom.com>
Wed, 10 Apr 2013 18:43:34 +0000 (19:43 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Wed, 17 Apr 2013 15:53:27 +0000 (16:53 +0100)
commit3f4bd3097ec1819ad1266d19976ebc937bdf05e2
tree1b388e0d1a7e61584890e008e505a97f7be24c48
parent16c4a02218ee842792c750a31e4b6f825c51e42d
ARM: 7696/1: Fix kexec by setting outer_cache.inv_all for Feroceon

On Feroceon the L2 cache becomes non-coherent with the CPU
when the L1 caches are disabled. Thus the L2 needs to be invalidated
after both L1 caches are disabled.

On kexec before the starting the code for relocation the kernel,
the L1 caches are disabled in cpu_froc_fin (cpu_v7_proc_fin for Feroceon),
but after L2 cache is never invalidated, because inv_all is not set
in cache-feroceon-l2.c.
So kernel relocation and decompression may has (and usually has) errors.
Setting the function enables L2 invalidation and fixes the issue.

Cc: <stable@vger.kernel.org>
Signed-off-by: Illia Ragozin <illia.ragozin@grapecom.com>
Acked-by: Jason Cooper <jason@lakedaemon.net>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/mm/cache-feroceon-l2.c