1#ifndef __ASM_SH_TLBFLUSH_H
2#define __ASM_SH_TLBFLUSH_H
3
4/*
5 * TLB flushing:
6 *
7 *  - flush_tlb_all() flushes all processes TLBs
8 *  - flush_tlb_mm(mm) flushes the specified mm context TLB's
9 *  - flush_tlb_page(vma, vmaddr) flushes one page
10 *  - flush_tlb_range(vma, start, end) flushes a range of pages
11 *  - flush_tlb_kernel_range(start, end) flushes a range of kernel pages
12 */
13extern void local_flush_tlb_all(void);
14extern void local_flush_tlb_mm(struct mm_struct *mm);
15extern void local_flush_tlb_range(struct vm_area_struct *vma,
16				  unsigned long start,
17				  unsigned long end);
18extern void local_flush_tlb_page(struct vm_area_struct *vma,
19				 unsigned long page);
20extern void local_flush_tlb_kernel_range(unsigned long start,
21					 unsigned long end);
22extern void local_flush_tlb_one(unsigned long asid, unsigned long page);
23
24extern void __flush_tlb_global(void);
25
26#ifdef CONFIG_SMP
27
28extern void flush_tlb_all(void);
29extern void flush_tlb_mm(struct mm_struct *mm);
30extern void flush_tlb_range(struct vm_area_struct *vma, unsigned long start,
31			    unsigned long end);
32extern void flush_tlb_page(struct vm_area_struct *vma, unsigned long page);
33extern void flush_tlb_kernel_range(unsigned long start, unsigned long end);
34extern void flush_tlb_one(unsigned long asid, unsigned long page);
35
36#else
37
38#define flush_tlb_all()			local_flush_tlb_all()
39#define flush_tlb_mm(mm)		local_flush_tlb_mm(mm)
40#define flush_tlb_page(vma, page)	local_flush_tlb_page(vma, page)
41#define flush_tlb_one(asid, page)	local_flush_tlb_one(asid, page)
42
43#define flush_tlb_range(vma, start, end)	\
44	local_flush_tlb_range(vma, start, end)
45
46#define flush_tlb_kernel_range(start, end)	\
47	local_flush_tlb_kernel_range(start, end)
48
49#endif /* CONFIG_SMP */
50
51#endif /* __ASM_SH_TLBFLUSH_H */
52