aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sh/mm/fault_32.c
diff options
context:
space:
mode:
authorStuart Menefy <stuart.menefy@st.com>2008-09-05 03:17:15 -0400
committerPaul Mundt <lethal@linux-sh.org>2008-09-07 21:35:04 -0400
commit96e14e54a6abd5a4bcd75e33962f87bef145d1f6 (patch)
tree4c7c60823e05872304812ce181822b1d2cc609e5 /arch/sh/mm/fault_32.c
parent28d6e52cf7e881834d2dab370afa20b6223f726c (diff)
sh: vmalloc pgtable sync fix.
This fixes a problem in the code which copies the vmalloc portion of the kernel's page table into the current user space page table. The addition of the four level page table code breaks on folded page tables, because the pud level is always present (although folded). This updates the code to use the same style of updates for the pud as is used for the pgd level. Signed-off-by: Stuart Menefy <stuart.menefy@st.com> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/mm/fault_32.c')
-rw-r--r--arch/sh/mm/fault_32.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/arch/sh/mm/fault_32.c b/arch/sh/mm/fault_32.c
index 0c776fdfbdda..e8efda9846bb 100644
--- a/arch/sh/mm/fault_32.c
+++ b/arch/sh/mm/fault_32.c
@@ -61,7 +61,6 @@ asmlinkage void __kprobes do_page_fault(struct pt_regs *regs,
61 pgd = get_TTB() + offset; 61 pgd = get_TTB() + offset;
62 pgd_k = swapper_pg_dir + offset; 62 pgd_k = swapper_pg_dir + offset;
63 63
64 /* This will never happen with the folded page table. */
65 if (!pgd_present(*pgd)) { 64 if (!pgd_present(*pgd)) {
66 if (!pgd_present(*pgd_k)) 65 if (!pgd_present(*pgd_k))
67 goto bad_area_nosemaphore; 66 goto bad_area_nosemaphore;
@@ -71,9 +70,13 @@ asmlinkage void __kprobes do_page_fault(struct pt_regs *regs,
71 70
72 pud = pud_offset(pgd, address); 71 pud = pud_offset(pgd, address);
73 pud_k = pud_offset(pgd_k, address); 72 pud_k = pud_offset(pgd_k, address);
74 if (pud_present(*pud) || !pud_present(*pud_k)) 73
75 goto bad_area_nosemaphore; 74 if (!pud_present(*pud)) {
76 set_pud(pud, *pud_k); 75 if (!pud_present(*pud_k))
76 goto bad_area_nosemaphore;
77 set_pud(pud, *pud_k);
78 return;
79 }
77 80
78 pmd = pmd_offset(pud, address); 81 pmd = pmd_offset(pud, address);
79 pmd_k = pmd_offset(pud_k, address); 82 pmd_k = pmd_offset(pud_k, address);