Commit b4e6f66e authored by Matthew Wilcox (Oracle)'s avatar Matthew Wilcox (Oracle) Committed by Andrew Morton

ksm: use a folio in replace_page()

Replace three calls to compound_head() with one.

Link: https://lkml.kernel.org/r/20220902194653.1739778-46-willy@infradead.orgSigned-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 5fcd079a
...@@ -1110,6 +1110,7 @@ static int replace_page(struct vm_area_struct *vma, struct page *page, ...@@ -1110,6 +1110,7 @@ static int replace_page(struct vm_area_struct *vma, struct page *page,
struct page *kpage, pte_t orig_pte) struct page *kpage, pte_t orig_pte)
{ {
struct mm_struct *mm = vma->vm_mm; struct mm_struct *mm = vma->vm_mm;
struct folio *folio;
pmd_t *pmd; pmd_t *pmd;
pmd_t pmde; pmd_t pmde;
pte_t *ptep; pte_t *ptep;
...@@ -1178,10 +1179,11 @@ static int replace_page(struct vm_area_struct *vma, struct page *page, ...@@ -1178,10 +1179,11 @@ static int replace_page(struct vm_area_struct *vma, struct page *page,
ptep_clear_flush(vma, addr, ptep); ptep_clear_flush(vma, addr, ptep);
set_pte_at_notify(mm, addr, ptep, newpte); set_pte_at_notify(mm, addr, ptep, newpte);
folio = page_folio(page);
page_remove_rmap(page, vma, false); page_remove_rmap(page, vma, false);
if (!page_mapped(page)) if (!folio_mapped(folio))
try_to_free_swap(page); folio_free_swap(folio);
put_page(page); folio_put(folio);
pte_unmap_unlock(ptep, ptl); pte_unmap_unlock(ptep, ptl);
err = 0; err = 0;
......
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