ARC: [mm] consolidate icache/dcache sync code

Now that we have same helper used for all icache invalidates (i.e.
vaddr+paddr based exact line invalidate), consolidate the open coded
calls into one place.

Also rename flush_icache_range_vaddr => __sync_icache_dcache

Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
This commit is contained in:
Vineet Gupta 2013-04-12 12:20:23 +05:30
parent 7586bf7286
commit 94bad1afee
2 changed files with 18 additions and 19 deletions

View File

@ -31,8 +31,7 @@
void flush_cache_all(void); void flush_cache_all(void);
void flush_icache_range(unsigned long start, unsigned long end); void flush_icache_range(unsigned long start, unsigned long end);
void flush_icache_range_vaddr(unsigned long paddr, unsigned long u_vaddr, void __sync_icache_dcache(unsigned long paddr, unsigned long vaddr, int len);
int len);
void __inv_icache_page(unsigned long paddr, unsigned long vaddr); void __inv_icache_page(unsigned long paddr, unsigned long vaddr);
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1 #define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
@ -66,7 +65,7 @@ void dma_cache_wback(unsigned long start, unsigned long sz);
do { \ do { \
memcpy(dst, src, len); \ memcpy(dst, src, len); \
if (vma->vm_flags & VM_EXEC) \ if (vma->vm_flags & VM_EXEC) \
flush_icache_range_vaddr((unsigned long)(dst), vaddr, len);\ __sync_icache_dcache((unsigned long)(dst), vaddr, len); \
} while (0) } while (0)
#define copy_from_user_page(vma, page, vaddr, dst, src, len) \ #define copy_from_user_page(vma, page, vaddr, dst, src, len) \

View File

@ -652,7 +652,6 @@ void flush_icache_range(unsigned long kstart, unsigned long kend)
{ {
unsigned int tot_sz, off, sz; unsigned int tot_sz, off, sz;
unsigned long phy, pfn; unsigned long phy, pfn;
unsigned long flags;
/* printk("Kernel Cache Cohenercy: %lx to %lx\n",kstart, kend); */ /* printk("Kernel Cache Cohenercy: %lx to %lx\n",kstart, kend); */
@ -679,8 +678,7 @@ void flush_icache_range(unsigned long kstart, unsigned long kend)
* given the callers for this case: kprobe/kgdb in built-in * given the callers for this case: kprobe/kgdb in built-in
* kernel code only. * kernel code only.
*/ */
__ic_line_inv_vaddr(kstart, kstart, kend - kstart); __sync_icache_dcache(kstart, kstart, kend - kstart);
__dc_line_op(kstart, kend - kstart, OP_FLUSH);
return; return;
} }
@ -698,28 +696,30 @@ void flush_icache_range(unsigned long kstart, unsigned long kend)
pfn = vmalloc_to_pfn((void *)kstart); pfn = vmalloc_to_pfn((void *)kstart);
phy = (pfn << PAGE_SHIFT) + off; phy = (pfn << PAGE_SHIFT) + off;
sz = min_t(unsigned int, tot_sz, PAGE_SIZE - off); sz = min_t(unsigned int, tot_sz, PAGE_SIZE - off);
local_irq_save(flags); __sync_icache_dcache(phy, kstart, sz);
__dc_line_op(phy, sz, OP_FLUSH);
__ic_line_inv_vaddr(phy, kstart, sz);
local_irq_restore(flags);
kstart += sz; kstart += sz;
tot_sz -= sz; tot_sz -= sz;
} }
} }
/* /*
* Optimised ver of flush_icache_range() with spec callers: ptrace/signals * General purpose helper to make I and D cache lines consistent.
* where vaddr is also available. This allows passing both vaddr and paddr * @paddr is phy addr of region
* bits to CDU for cache flush, short-circuting the current pessimistic algo * @vaddr is typically user or kernel vaddr (vmalloc)
* which kills all possible aliases. * Howver in one instance, flush_icache_range() by kprobe (for a breakpt in
* An added adv of knowing that vaddr is user-vaddr avoids various checks * builtin kernel code) @vaddr will be paddr only, meaning CDU operation will
* and handling for k-vaddr, k-paddr as done in orig ver above * use a paddr to index the cache (despite VIPT). This is fine since since a
* built-in kernel page will not have any virtual mappings (not even kernel)
* kprobe on loadable module is different as it will have kvaddr.
*/ */
void flush_icache_range_vaddr(unsigned long paddr, unsigned long u_vaddr, void __sync_icache_dcache(unsigned long paddr, unsigned long vaddr, int len)
int len)
{ {
__ic_line_inv_vaddr(paddr, u_vaddr, len); unsigned long flags;
local_irq_save(flags);
__ic_line_inv_vaddr(paddr, vaddr, len);
__dc_line_op(paddr, len, OP_FLUSH); __dc_line_op(paddr, len, OP_FLUSH);
local_irq_restore(flags);
} }
/* wrapper to compile time eliminate alignment checks in flush loop */ /* wrapper to compile time eliminate alignment checks in flush loop */