]> git.karo-electronics.de Git - karo-tx-linux.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)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Apr 2013 19:51:17 +0000 (12:51 -0700)
commite644d5af6228ef011179bae1ba7052fd2c481a3f
tree35cd6ac04ad62a609e4f0080382d3fc84a6fae90
parentdd135b0d8977ef119c7908c0153c3e94d8110e58
ARM: 7696/1: Fix kexec by setting outer_cache.inv_all for Feroceon

commit cd272d1ea71583170e95dde02c76166c7f9017e6 upstream.

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.

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>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/arm/mm/cache-feroceon-l2.c