Skip to content

Commit

Permalink
dax: ensure that zero pages are removed from other processes
Browse files Browse the repository at this point in the history
If the first access to a huge page was a store, there would be no existing
zero pmd in this process's page tables.  There could be a zero pmd in
another process's page tables, if it had done a load.  We can detect this
case by noticing that the buffer_head returned from the filesystem is New,
and ensure that other processes mapping this huge page have their page
tables flushed.

Signed-off-by: Matthew Wilcox <[email protected]>
Reported-by: Kirill A. Shutemov <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
Matthew Wilcox authored and torvalds committed Sep 8, 2015
1 parent d295e34 commit 73a6ec4
Showing 1 changed file with 5 additions and 1 deletion.
6 changes: 5 additions & 1 deletion fs/dax.c
Original file line number Diff line number Diff line change
Expand Up @@ -568,7 +568,11 @@ int __dax_pmd_fault(struct vm_area_struct *vma, unsigned long address,
if ((pgoff | PG_PMD_COLOUR) >= size)
goto fallback;

if (is_huge_zero_pmd(*pmd))
/*
* If we allocated new storage, make sure no process has any
* zero pages covering this hole
*/
if (buffer_new(&bh))
unmap_mapping_range(mapping, pgoff << PAGE_SHIFT, PMD_SIZE, 0);

if (!write && !buffer_mapped(&bh) && buffer_uptodate(&bh)) {
Expand Down

0 comments on commit 73a6ec4

Please sign in to comment.