.. | .. |
---|
5 | 5 | #include <linux/sched.h> |
---|
6 | 6 | #include <linux/mm.h> |
---|
7 | 7 | #include <asm/nds32.h> |
---|
8 | | -#include <asm/pgtable.h> |
---|
9 | 8 | #include <asm/tlbflush.h> |
---|
10 | 9 | #include <asm/cacheflush.h> |
---|
11 | 10 | #include <asm/l2_cache.h> |
---|
.. | .. |
---|
19 | 18 | pmd_t *pmd; |
---|
20 | 19 | pte_t *ptep, pte; |
---|
21 | 20 | |
---|
22 | | - pmd = pmd_offset(pgd_offset_k(addr), addr); |
---|
| 21 | + pmd = pmd_off_k(addr); |
---|
23 | 22 | if (!pmd_none(*pmd)) { |
---|
24 | 23 | ptep = pte_offset_map(pmd, addr); |
---|
25 | 24 | pte = *ptep; |
---|
.. | .. |
---|
32 | 31 | pte_t va_present(struct mm_struct * mm, unsigned long addr) |
---|
33 | 32 | { |
---|
34 | 33 | pgd_t *pgd; |
---|
| 34 | + p4d_t *p4d; |
---|
35 | 35 | pud_t *pud; |
---|
36 | 36 | pmd_t *pmd; |
---|
37 | 37 | pte_t *ptep, pte; |
---|
38 | 38 | |
---|
39 | 39 | pgd = pgd_offset(mm, addr); |
---|
40 | 40 | if (!pgd_none(*pgd)) { |
---|
41 | | - pud = pud_offset(pgd, addr); |
---|
42 | | - if (!pud_none(*pud)) { |
---|
43 | | - pmd = pmd_offset(pud, addr); |
---|
44 | | - if (!pmd_none(*pmd)) { |
---|
45 | | - ptep = pte_offset_map(pmd, addr); |
---|
46 | | - pte = *ptep; |
---|
47 | | - if (pte_present(pte)) |
---|
48 | | - return pte; |
---|
| 41 | + p4d = p4d_offset(pgd, addr); |
---|
| 42 | + if (!p4d_none(*p4d)) { |
---|
| 43 | + pud = pud_offset(p4d, addr); |
---|
| 44 | + if (!pud_none(*pud)) { |
---|
| 45 | + pmd = pmd_offset(pud, addr); |
---|
| 46 | + if (!pmd_none(*pmd)) { |
---|
| 47 | + ptep = pte_offset_map(pmd, addr); |
---|
| 48 | + pte = *ptep; |
---|
| 49 | + if (pte_present(pte)) |
---|
| 50 | + return pte; |
---|
| 51 | + } |
---|
49 | 52 | } |
---|
50 | 53 | } |
---|
51 | 54 | } |
---|