diff options
Diffstat (limited to 'arch/arm/include/asm/pgtable.h')
| -rw-r--r-- | arch/arm/include/asm/pgtable.h | 18 | 
1 files changed, 11 insertions, 7 deletions
diff --git a/arch/arm/include/asm/pgtable.h b/arch/arm/include/asm/pgtable.h index 5478e5d6ad89..01baef07cd0c 100644 --- a/arch/arm/include/asm/pgtable.h +++ b/arch/arm/include/asm/pgtable.h @@ -214,18 +214,22 @@ static inline pte_t *pmd_page_vaddr(pmd_t pmd)  #define pte_clear(mm,addr,ptep)	set_pte_ext(ptep, __pte(0), 0) +#define pte_isset(pte, val)	((u32)(val) == (val) ? pte_val(pte) & (val) \ +						: !!(pte_val(pte) & (val))) +#define pte_isclear(pte, val)	(!(pte_val(pte) & (val))) +  #define pte_none(pte)		(!pte_val(pte)) -#define pte_present(pte)	(pte_val(pte) & L_PTE_PRESENT) -#define pte_valid(pte)		(pte_val(pte) & L_PTE_VALID) +#define pte_present(pte)	(pte_isset((pte), L_PTE_PRESENT)) +#define pte_valid(pte)		(pte_isset((pte), L_PTE_VALID))  #define pte_accessible(mm, pte)	(mm_tlb_flush_pending(mm) ? pte_present(pte) : pte_valid(pte)) -#define pte_write(pte)		(!(pte_val(pte) & L_PTE_RDONLY)) -#define pte_dirty(pte)		(pte_val(pte) & L_PTE_DIRTY) -#define pte_young(pte)		(pte_val(pte) & L_PTE_YOUNG) -#define pte_exec(pte)		(!(pte_val(pte) & L_PTE_XN)) +#define pte_write(pte)		(pte_isclear((pte), L_PTE_RDONLY)) +#define pte_dirty(pte)		(pte_isset((pte), L_PTE_DIRTY)) +#define pte_young(pte)		(pte_isset((pte), L_PTE_YOUNG)) +#define pte_exec(pte)		(pte_isclear((pte), L_PTE_XN))  #define pte_special(pte)	(0)  #define pte_valid_user(pte)	\ -	(pte_valid(pte) && (pte_val(pte) & L_PTE_USER) && pte_young(pte)) +	(pte_valid(pte) && pte_isset((pte), L_PTE_USER) && pte_young(pte))  #if __LINUX_ARM_ARCH__ < 6  static inline void __sync_icache_dcache(pte_t pteval)  |