mm: fix exec activate_mm vs TLB shootdown and lazy tlb switching race
[linux/fpc-iii.git] / arch / parisc / include / asm / tlb.h
blob0c881e74d8a62cd6a4e6082178299a118b58a5d9
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _PARISC_TLB_H
3 #define _PARISC_TLB_H
5 #define tlb_flush(tlb) \
6 do { if ((tlb)->fullmm) \
7 flush_tlb_mm((tlb)->mm);\
8 } while (0)
10 #define tlb_start_vma(tlb, vma) \
11 do { if (!(tlb)->fullmm) \
12 flush_cache_range(vma, vma->vm_start, vma->vm_end); \
13 } while (0)
15 #define tlb_end_vma(tlb, vma) \
16 do { if (!(tlb)->fullmm) \
17 flush_tlb_range(vma, vma->vm_start, vma->vm_end); \
18 } while (0)
20 #define __tlb_remove_tlb_entry(tlb, pte, address) \
21 do { } while (0)
23 #include <asm-generic/tlb.h>
25 #define __pmd_free_tlb(tlb, pmd, addr) pmd_free((tlb)->mm, pmd)
26 #define __pte_free_tlb(tlb, pte, addr) pte_free((tlb)->mm, pte)
28 #endif