|
@@ -246,6 +246,7 @@ static inline pte_t pte_mkhuge(pte_t pte) { (pte).pte_low |= _PAGE_PSE; return p
|
|
|
# include <asm/pgtable-2level.h>
|
|
|
#endif
|
|
|
|
|
|
+#define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_DIRTY
|
|
|
static inline int ptep_test_and_clear_dirty(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep)
|
|
|
{
|
|
|
if (!pte_dirty(*ptep))
|
|
@@ -253,6 +254,7 @@ static inline int ptep_test_and_clear_dirty(struct vm_area_struct *vma, unsigned
|
|
|
return test_and_clear_bit(_PAGE_BIT_DIRTY, &ptep->pte_low);
|
|
|
}
|
|
|
|
|
|
+#define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_YOUNG
|
|
|
static inline int ptep_test_and_clear_young(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep)
|
|
|
{
|
|
|
if (!pte_young(*ptep))
|
|
@@ -260,6 +262,7 @@ static inline int ptep_test_and_clear_young(struct vm_area_struct *vma, unsigned
|
|
|
return test_and_clear_bit(_PAGE_BIT_ACCESSED, &ptep->pte_low);
|
|
|
}
|
|
|
|
|
|
+#define __HAVE_ARCH_PTEP_GET_AND_CLEAR_FULL
|
|
|
static inline pte_t ptep_get_and_clear_full(struct mm_struct *mm, unsigned long addr, pte_t *ptep, int full)
|
|
|
{
|
|
|
pte_t pte;
|
|
@@ -272,6 +275,7 @@ static inline pte_t ptep_get_and_clear_full(struct mm_struct *mm, unsigned long
|
|
|
return pte;
|
|
|
}
|
|
|
|
|
|
+#define __HAVE_ARCH_PTEP_SET_WRPROTECT
|
|
|
static inline void ptep_set_wrprotect(struct mm_struct *mm, unsigned long addr, pte_t *ptep)
|
|
|
{
|
|
|
clear_bit(_PAGE_BIT_RW, &ptep->pte_low);
|
|
@@ -441,12 +445,6 @@ extern void noexec_setup(const char *str);
|
|
|
#define GET_IOSPACE(pfn) 0
|
|
|
#define GET_PFN(pfn) (pfn)
|
|
|
|
|
|
-#define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_YOUNG
|
|
|
-#define __HAVE_ARCH_PTEP_TEST_AND_CLEAR_DIRTY
|
|
|
-#define __HAVE_ARCH_PTEP_GET_AND_CLEAR
|
|
|
-#define __HAVE_ARCH_PTEP_GET_AND_CLEAR_FULL
|
|
|
-#define __HAVE_ARCH_PTEP_SET_WRPROTECT
|
|
|
-#define __HAVE_ARCH_PTE_SAME
|
|
|
#include <asm-generic/pgtable.h>
|
|
|
|
|
|
#endif /* _I386_PGTABLE_H */
|