summaryrefslogtreecommitdiff
path: root/tools/os_support.c
diff options
context:
space:
mode:
authorAneesh V <aneesh@ti.com>2011-11-21 23:33:58 +0000
committerAlbert ARIBAUD <albert.u.boot@aribaud.net>2011-12-06 23:59:33 +0100
commitdc7100f4080952798413fb63bb4134b22c57623a (patch)
tree7bfcccdda9fd068d855fb8f20cf110c831678bb8 /tools/os_support.c
parent8f1da53508c78789ebeea98a92a3f55c3f84dc5d (diff)
armv7: disable L2 cache in cleanup_before_linux()
We were not disabling external caches before jumping to kernel. We were flushing all caches including external caches and disabling caches globally in CP15 System Control register. Apparently this is not enough. The bootstrap loader in Linux kernel that does decompression enables data-caches again, flush them after use and disable them before jumping to kernel proper. However, it's not aware of the external caches. Since we have left external cache enabled, external cache will get used once caches are enabled globally, but it's not flushed because decompressor is not aware of external caches. When it jumps to kernel with caches disabled globally, we have stale data in the external cache and a coherency problem. This was breaking the boot for OMAP4 with latest mainline kernel. The solution is to disable external caches in cleanup_before_linux(). With this fix kernel is booting again. Cc: Albert Aribaud <albert.u.boot@aribaud.net> Signed-off-by: Aneesh V <aneesh@ti.com>
Diffstat (limited to 'tools/os_support.c')
0 files changed, 0 insertions, 0 deletions