diff options
author | Sonic Zhang <sonic.zhang@analog.com> | 2009-06-10 04:57:08 -0400 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2009-06-13 07:20:07 -0400 |
commit | 47e9dedb720364e0adff0e99960fa294c6161f71 (patch) | |
tree | fa5bcb532023a89fa11995e5ceca5ed5dfeabbba /arch/blackfin/mach-common/smp.c | |
parent | 2466ac65560ee8b7506eea3987aba9519355fd02 (diff) |
Blackfin: add blackfin_invalidate_entire_icache for SMP systems
The KGDB code uses this when switching processors to make sure the icache
is in a valid state.
Signed-off-by: Sonic Zhang <sonic.zhang@analog.com>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Diffstat (limited to 'arch/blackfin/mach-common/smp.c')
-rw-r--r-- | arch/blackfin/mach-common/smp.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/arch/blackfin/mach-common/smp.c b/arch/blackfin/mach-common/smp.c index 3b8ebaee77f2..c187da2448bf 100644 --- a/arch/blackfin/mach-common/smp.c +++ b/arch/blackfin/mach-common/smp.c | |||
@@ -468,6 +468,17 @@ void smp_icache_flush_range_others(unsigned long start, unsigned long end) | |||
468 | } | 468 | } |
469 | EXPORT_SYMBOL_GPL(smp_icache_flush_range_others); | 469 | EXPORT_SYMBOL_GPL(smp_icache_flush_range_others); |
470 | 470 | ||
471 | #ifdef __ARCH_SYNC_CORE_ICACHE | ||
472 | void resync_core_icache(void) | ||
473 | { | ||
474 | unsigned int cpu = get_cpu(); | ||
475 | blackfin_invalidate_entire_icache(); | ||
476 | ++per_cpu(cpu_data, cpu).icache_invld_count; | ||
477 | put_cpu(); | ||
478 | } | ||
479 | EXPORT_SYMBOL(resync_core_icache); | ||
480 | #endif | ||
481 | |||
471 | #ifdef __ARCH_SYNC_CORE_DCACHE | 482 | #ifdef __ARCH_SYNC_CORE_DCACHE |
472 | unsigned long barrier_mask __attribute__ ((__section__(".l2.bss"))); | 483 | unsigned long barrier_mask __attribute__ ((__section__(".l2.bss"))); |
473 | 484 | ||