提交 1e924e2f 编写于 作者: G Graf Yang 提交者: Mike Frysinger

Blackfin: SMP: flush CoreB cache when shutting down

When CoreB wakes up, it needs to read variables that CoreA might have
modified, and might be in CoreB's cache.  So kill CoreB's cache before
going to sleep so that when we wake up, we are in a coherent state.
Signed-off-by: NGraf Yang <graf.yang@analog.com>
Signed-off-by: NMike Frysinger <vapier@gentoo.org>
上级 f741a79e
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
#include <linux/smp.h> #include <linux/smp.h>
#include <asm/blackfin.h> #include <asm/blackfin.h>
#include <asm/cacheflush.h>
#include <mach/pll.h> #include <mach/pll.h>
int hotplug_coreb; int hotplug_coreb;
...@@ -14,8 +15,16 @@ int hotplug_coreb; ...@@ -14,8 +15,16 @@ int hotplug_coreb;
void platform_cpu_die(void) void platform_cpu_die(void)
{ {
unsigned long iwr; unsigned long iwr;
hotplug_coreb = 1; hotplug_coreb = 1;
/*
* When CoreB wakes up, the code in _coreb_trampoline_start cannot
* turn off the data cache. This causes the CoreB failed to boot.
* As a workaround, we invalidate all the data cache before sleep.
*/
blackfin_invalidate_entire_dcache();
/* disable core timer */ /* disable core timer */
bfin_write_TCNTL(0); bfin_write_TCNTL(0);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册