summaryrefslogtreecommitdiffstats
path: root/arch/powerpc/mm/pgtable.c
diff options
context:
space:
mode:
authorAneesh Kumar K.V <aneesh.kumar@linux.ibm.com>2018-06-01 10:24:24 +0200
committerMichael Ellerman <mpe@ellerman.id.au>2018-06-03 12:40:37 +0200
commited515b6898c36775ddd99ff9ffeda4e83917acda (patch)
tree565dfa28eaa7de9126c40c0e0d052e59ab9445a0 /arch/powerpc/mm/pgtable.c
parentpowerpc/mm/hash: Add missing isync prior to kernel stack SLB switch (diff)
downloadlinux-ed515b6898c36775ddd99ff9ffeda4e83917acda.tar.xz
linux-ed515b6898c36775ddd99ff9ffeda4e83917acda.zip
powerpc/mm/hugetlb: Update hugetlb related locks
With split pmd page table lock enabled, we don't use mm->page_table_lock when updating pmd entries. This patch update hugetlb path to use the right lock when inserting huge page directory entries into page table. ex: if we are using hugepd and inserting hugepd entry at the pmd level, we use pmd_lockptr, which based on config can be split pmd lock. For update huge page directory entries itself we use mm->page_table_lock. We do have a helper huge_pte_lockptr() for that. Fixes: 675d99529 ("powerpc/book3s64: Enable split pmd ptlock") Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.ibm.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Diffstat (limited to 'arch/powerpc/mm/pgtable.c')
-rw-r--r--arch/powerpc/mm/pgtable.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/arch/powerpc/mm/pgtable.c b/arch/powerpc/mm/pgtable.c
index 5281c2c064af..d71c7777669c 100644
--- a/arch/powerpc/mm/pgtable.c
+++ b/arch/powerpc/mm/pgtable.c
@@ -249,8 +249,13 @@ extern int huge_ptep_set_access_flags(struct vm_area_struct *vma,
if (changed) {
#ifdef CONFIG_PPC_BOOK3S_64
- struct hstate *hstate = hstate_file(vma->vm_file);
- psize = hstate_get_psize(hstate);
+ struct hstate *h = hstate_vma(vma);
+
+ psize = hstate_get_psize(h);
+#ifdef CONFIG_DEBUG_VM
+ assert_spin_locked(huge_pte_lockptr(h, vma->vm_mm, ptep));
+#endif
+
#else
/*
* Not used on non book3s64 platforms. But 8xx
@@ -258,9 +263,6 @@ extern int huge_ptep_set_access_flags(struct vm_area_struct *vma,
*/
psize = 0;
#endif
-#ifdef CONFIG_DEBUG_VM
- assert_spin_locked(&vma->vm_mm->page_table_lock);
-#endif
__ptep_set_access_flags(vma, ptep, pte, addr, psize);
}
return changed;