diff options
Diffstat (limited to 'arch/parisc/include/asm/pgtable.h')
| -rw-r--r-- | arch/parisc/include/asm/pgtable.h | 13 | 
1 files changed, 10 insertions, 3 deletions
| diff --git a/arch/parisc/include/asm/pgtable.h b/arch/parisc/include/asm/pgtable.h index ee99f2339356..7df49fad29f9 100644 --- a/arch/parisc/include/asm/pgtable.h +++ b/arch/parisc/include/asm/pgtable.h @@ -12,11 +12,10 @@  #include <linux/bitops.h>  #include <linux/spinlock.h> +#include <linux/mm_types.h>  #include <asm/processor.h>  #include <asm/cache.h> -struct vm_area_struct; -  /*   * kern_addr_valid(ADDR) tests if ADDR is pointing to valid kernel   * memory.  For the return value to be meaningful, ADDR must be >= @@ -40,7 +39,14 @@ struct vm_area_struct;          do{                                                     \                  *(pteptr) = (pteval);                           \          } while(0) -#define set_pte_at(mm,addr,ptep,pteval) set_pte(ptep,pteval) + +extern void purge_tlb_entries(struct mm_struct *, unsigned long); + +#define set_pte_at(mm, addr, ptep, pteval)                      \ +	do {                                                    \ +		set_pte(ptep, pteval);                          \ +		purge_tlb_entries(mm, addr);                    \ +	} while (0)  #endif /* !__ASSEMBLY__ */ @@ -466,6 +472,7 @@ static inline void ptep_set_wrprotect(struct mm_struct *mm, unsigned long addr,  		old = pte_val(*ptep);  		new = pte_val(pte_wrprotect(__pte (old)));  	} while (cmpxchg((unsigned long *) ptep, old, new) != old); +	purge_tlb_entries(mm, addr);  #else  	pte_t old_pte = *ptep;  	set_pte_at(mm, addr, ptep, pte_wrprotect(old_pte)); | 
