--- x/mm/filemap.c +++ y/mm/filemap.c @@ -3636,6 +3636,10 @@ static vm_fault_t filemap_map_folio_rang continue; skip: if (count) { + for (unsigned int i = 0; i < count; i++) { + if (page_folio(page + i) != folio) + goto out; + } set_pte_range(vmf, folio, page, count, addr); *rss += count; folio_ref_add(folio, count); @@ -3658,6 +3662,7 @@ skip: ret = VM_FAULT_NOPAGE; } +out: vmf->pte = old_ptep; return ret;