linux/arch/mips/include/asm/tlbflush.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0 */
   2#ifndef __ASM_TLBFLUSH_H
   3#define __ASM_TLBFLUSH_H
   4
   5#include <linux/mm.h>
   6
   7/*
   8 * TLB flushing:
   9 *
  10 *  - flush_tlb_all() flushes all processes TLB entries
  11 *  - flush_tlb_mm(mm) flushes the specified mm context TLB entries
  12 *  - flush_tlb_page(vma, vmaddr) flushes one page
  13 *  - flush_tlb_range(vma, start, end) flushes a range of pages
  14 *  - flush_tlb_kernel_range(start, end) flushes a range of kernel pages
  15 */
  16extern void local_flush_tlb_all(void);
  17extern void local_flush_tlb_range(struct vm_area_struct *vma,
  18        unsigned long start, unsigned long end);
  19extern void local_flush_tlb_kernel_range(unsigned long start,
  20        unsigned long end);
  21extern void local_flush_tlb_page(struct vm_area_struct *vma,
  22        unsigned long page);
  23extern void local_flush_tlb_one(unsigned long vaddr);
  24
  25#include <asm/mmu_context.h>
  26
  27#ifdef CONFIG_SMP
  28
  29extern void flush_tlb_all(void);
  30extern void flush_tlb_mm(struct mm_struct *);
  31extern void flush_tlb_range(struct vm_area_struct *vma, unsigned long,
  32        unsigned long);
  33extern void flush_tlb_kernel_range(unsigned long, unsigned long);
  34extern void flush_tlb_page(struct vm_area_struct *, unsigned long);
  35extern void flush_tlb_one(unsigned long vaddr);
  36
  37#else /* CONFIG_SMP */
  38
  39#define flush_tlb_all()                 local_flush_tlb_all()
  40#define flush_tlb_mm(mm)                drop_mmu_context(mm)
  41#define flush_tlb_range(vma, vmaddr, end)       local_flush_tlb_range(vma, vmaddr, end)
  42#define flush_tlb_kernel_range(vmaddr,end) \
  43        local_flush_tlb_kernel_range(vmaddr, end)
  44#define flush_tlb_page(vma, page)       local_flush_tlb_page(vma, page)
  45#define flush_tlb_one(vaddr)            local_flush_tlb_one(vaddr)
  46
  47#endif /* CONFIG_SMP */
  48
  49#endif /* __ASM_TLBFLUSH_H */
  50