sh: Migrate SH-4 cacheflush ops to function pointers.
[pandora-kernel.git] / arch / sh / include / cpu-common / cpu / cacheflush.h
1 /*
2  * Copyright (C) 2003 Paul Mundt
3  *
4  * This file is subject to the terms and conditions of the GNU General Public
5  * License.  See the file "COPYING" in the main directory of this archive
6  * for more details.
7  */
8 #ifndef __ASM_CPU_SH_CACHEFLUSH_H
9 #define __ASM_CPU_SH_CACHEFLUSH_H
10
11 /*
12  * Cache flushing:
13  *
14  *  - flush_cache_all() flushes entire cache
15  *  - flush_cache_mm(mm) flushes the specified mm context's cache lines
16  *  - flush_cache_dup mm(mm) handles cache flushing when forking
17  *  - flush_cache_page(mm, vmaddr, pfn) flushes a single page
18  *  - flush_cache_range(vma, start, end) flushes a range of pages
19  *
20  *  - flush_dcache_page(pg) flushes(wback&invalidates) a page for dcache
21  *  - flush_icache_range(start, end) flushes(invalidates) a range for icache
22  *  - flush_icache_page(vma, pg) flushes(invalidates) a page for icache
23  *  - flush_cache_sigtramp(vaddr) flushes the signal trampoline
24  */
25 extern void (*flush_cache_all)(void);
26 extern void (*flush_cache_mm)(struct mm_struct *mm);
27 extern void (*flush_cache_dup_mm)(struct mm_struct *mm);
28 extern void (*flush_cache_page)(struct vm_area_struct *vma,
29                                 unsigned long addr, unsigned long pfn);
30 extern void (*flush_cache_range)(struct vm_area_struct *vma,
31                                  unsigned long start, unsigned long end);
32 extern void (*flush_dcache_page)(struct page *page);
33 extern void (*flush_icache_range)(unsigned long start, unsigned long end);
34 extern void (*flush_icache_page)(struct vm_area_struct *vma,
35                                  struct page *page);
36 extern void (*flush_cache_sigtramp)(unsigned long address);
37
38 extern void (*__flush_wback_region)(void *start, int size);
39 extern void (*__flush_purge_region)(void *start, int size);
40 extern void (*__flush_invalidate_region)(void *start, int size);
41
42 #endif /* __ASM_CPU_SH_CACHEFLUSH_H */