Commit 344afa65 authored by Ralf Baechle's avatar Ralf Baechle

MIPS: Hugetlbfs: Handle huge pages correctly in pmd_bad()

Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent 359187d6
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
#ifndef _ASM_PGTABLE_64_H #ifndef _ASM_PGTABLE_64_H
#define _ASM_PGTABLE_64_H #define _ASM_PGTABLE_64_H
#include <linux/compiler.h>
#include <linux/linkage.h> #include <linux/linkage.h>
#include <asm/addrspace.h> #include <asm/addrspace.h>
...@@ -172,7 +173,19 @@ static inline int pmd_none(pmd_t pmd) ...@@ -172,7 +173,19 @@ static inline int pmd_none(pmd_t pmd)
return pmd_val(pmd) == (unsigned long) invalid_pte_table; return pmd_val(pmd) == (unsigned long) invalid_pte_table;
} }
#define pmd_bad(pmd) (pmd_val(pmd) & ~PAGE_MASK) static inline int pmd_bad(pmd_t pmd)
{
#ifdef CONFIG_HUGETLB_PAGE
/* pmd_huge(pmd) but inline */
if (unlikely(pmd_val(pmd) & _PAGE_HUGE))
return 0;
#endif
if (unlikely(pmd_val(pmd) & ~PAGE_MASK))
return 1;
return 0;
}
static inline int pmd_present(pmd_t pmd) static inline int pmd_present(pmd_t pmd)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment