aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
authorKirill A. Shutemov <kirill.shutemov@linux.intel.com>2013-09-12 18:14:01 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2013-09-12 18:38:03 -0400
commit3122359a64829afd231bad6ed899b557f46280e9 (patch)
tree988ce8e120c6bacf69c611458f4528baac1d3d66 /mm
parent66a0c8ee3dce78362d59f00a8efbd752fbeddfb1 (diff)
thp: move maybe_pmd_mkwrite() out of mk_huge_pmd()
It's confusing that mk_huge_pmd() has semantics different from mk_pte() or mk_pmd(). I spent some time on debugging issue cased by this inconsistency. Let's move maybe_pmd_mkwrite() out of mk_huge_pmd() and adjust prototype to match mk_pte(). Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Acked-by: Dave Hansen <dave.hansen@linux.intel.com> Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: Hugh Dickins <hughd@google.com> Cc: Wu Fengguang <fengguang.wu@intel.com> Cc: Jan Kara <jack@suse.cz> Cc: Mel Gorman <mgorman@suse.de> Cc: Andi Kleen <ak@linux.intel.com> Cc: Matthew Wilcox <willy@linux.intel.com> Cc: Hillf Danton <dhillf@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r--mm/huge_memory.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/mm/huge_memory.c b/mm/huge_memory.c
index 7cef0c098630..60836870c6f7 100644
--- a/mm/huge_memory.c
+++ b/mm/huge_memory.c
@@ -690,11 +690,10 @@ pmd_t maybe_pmd_mkwrite(pmd_t pmd, struct vm_area_struct *vma)
690 return pmd; 690 return pmd;
691} 691}
692 692
693static inline pmd_t mk_huge_pmd(struct page *page, struct vm_area_struct *vma) 693static inline pmd_t mk_huge_pmd(struct page *page, pgprot_t prot)
694{ 694{
695 pmd_t entry; 695 pmd_t entry;
696 entry = mk_pmd(page, vma->vm_page_prot); 696 entry = mk_pmd(page, prot);
697 entry = maybe_pmd_mkwrite(pmd_mkdirty(entry), vma);
698 entry = pmd_mkhuge(entry); 697 entry = pmd_mkhuge(entry);
699 return entry; 698 return entry;
700} 699}
@@ -727,7 +726,8 @@ static int __do_huge_pmd_anonymous_page(struct mm_struct *mm,
727 pte_free(mm, pgtable); 726 pte_free(mm, pgtable);
728 } else { 727 } else {
729 pmd_t entry; 728 pmd_t entry;
730 entry = mk_huge_pmd(page, vma); 729 entry = mk_huge_pmd(page, vma->vm_page_prot);
730 entry = maybe_pmd_mkwrite(pmd_mkdirty(entry), vma);
731 page_add_new_anon_rmap(page, vma, haddr); 731 page_add_new_anon_rmap(page, vma, haddr);
732 pgtable_trans_huge_deposit(mm, pmd, pgtable); 732 pgtable_trans_huge_deposit(mm, pmd, pgtable);
733 set_pmd_at(mm, haddr, pmd, entry); 733 set_pmd_at(mm, haddr, pmd, entry);
@@ -1210,7 +1210,8 @@ alloc:
1210 goto out_mn; 1210 goto out_mn;
1211 } else { 1211 } else {
1212 pmd_t entry; 1212 pmd_t entry;
1213 entry = mk_huge_pmd(new_page, vma); 1213 entry = mk_huge_pmd(new_page, vma->vm_page_prot);
1214 entry = maybe_pmd_mkwrite(pmd_mkdirty(entry), vma);
1214 pmdp_clear_flush(vma, haddr, pmd); 1215 pmdp_clear_flush(vma, haddr, pmd);
1215 page_add_new_anon_rmap(new_page, vma, haddr); 1216 page_add_new_anon_rmap(new_page, vma, haddr);
1216 set_pmd_at(mm, haddr, pmd, entry); 1217 set_pmd_at(mm, haddr, pmd, entry);
@@ -2358,7 +2359,8 @@ static void collapse_huge_page(struct mm_struct *mm,
2358 __SetPageUptodate(new_page); 2359 __SetPageUptodate(new_page);
2359 pgtable = pmd_pgtable(_pmd); 2360 pgtable = pmd_pgtable(_pmd);
2360 2361
2361 _pmd = mk_huge_pmd(new_page, vma); 2362 _pmd = mk_huge_pmd(new_page, vma->vm_page_prot);
2363 _pmd = maybe_pmd_mkwrite(pmd_mkdirty(_pmd), vma);
2362 2364
2363 /* 2365 /*
2364 * spin_lock() below is not the equivalent of smp_wmb(), so 2366 * spin_lock() below is not the equivalent of smp_wmb(), so