mm: remove rest usage of VM_NONLINEAR and pte_file()

One bit in ->vm_flags is unused now!

Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Dan Carpenter <dan.carpenter@oracle.com>
Cc: Michal Hocko <mhocko@suse.cz>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Kirill A. Shutemov 2015-02-10 14:10:04 -08:00 committed by Linus Torvalds
parent ac51b934f3
commit 0661a33611
13 changed files with 45 additions and 67 deletions

View File

@ -50,8 +50,7 @@
* *
* You must not use multiple offset managers on a single address_space. * You must not use multiple offset managers on a single address_space.
* Otherwise, mm-core will be unable to tear down memory mappings as the VM will * Otherwise, mm-core will be unable to tear down memory mappings as the VM will
* no longer be linear. Please use VM_NONLINEAR in that case and implement your * no longer be linear.
* own offset managers.
* *
* This offset manager works on page-based addresses. That is, every argument * This offset manager works on page-based addresses. That is, every argument
* and return code (with the exception of drm_vma_node_offset_addr()) is given * and return code (with the exception of drm_vma_node_offset_addr()) is given

View File

@ -138,7 +138,6 @@ extern unsigned int kobjsize(const void *objp);
#define VM_ACCOUNT 0x00100000 /* Is a VM accounted object */ #define VM_ACCOUNT 0x00100000 /* Is a VM accounted object */
#define VM_NORESERVE 0x00200000 /* should the VM suppress accounting */ #define VM_NORESERVE 0x00200000 /* should the VM suppress accounting */
#define VM_HUGETLB 0x00400000 /* Huge TLB Page VM */ #define VM_HUGETLB 0x00400000 /* Huge TLB Page VM */
#define VM_NONLINEAR 0x00800000 /* Is non-linear (remap_file_pages) */
#define VM_ARCH_1 0x01000000 /* Architecture-specific flag */ #define VM_ARCH_1 0x01000000 /* Architecture-specific flag */
#define VM_ARCH_2 0x02000000 #define VM_ARCH_2 0x02000000
#define VM_DONTDUMP 0x04000000 /* Do not include in the core dump */ #define VM_DONTDUMP 0x04000000 /* Do not include in the core dump */

View File

@ -54,7 +54,7 @@ static inline pgoff_t swp_offset(swp_entry_t entry)
/* check whether a pte points to a swap entry */ /* check whether a pte points to a swap entry */
static inline int is_swap_pte(pte_t pte) static inline int is_swap_pte(pte_t pte)
{ {
return !pte_none(pte) && !pte_present_nonuma(pte) && !pte_file(pte); return !pte_none(pte) && !pte_present_nonuma(pte);
} }
#endif #endif
@ -66,7 +66,6 @@ static inline swp_entry_t pte_to_swp_entry(pte_t pte)
{ {
swp_entry_t arch_entry; swp_entry_t arch_entry;
BUG_ON(pte_file(pte));
if (pte_swp_soft_dirty(pte)) if (pte_swp_soft_dirty(pte))
pte = pte_swp_clear_soft_dirty(pte); pte = pte_swp_clear_soft_dirty(pte);
arch_entry = __pte_to_swp_entry(pte); arch_entry = __pte_to_swp_entry(pte);
@ -82,7 +81,6 @@ static inline pte_t swp_entry_to_pte(swp_entry_t entry)
swp_entry_t arch_entry; swp_entry_t arch_entry;
arch_entry = __swp_entry(swp_type(entry), swp_offset(entry)); arch_entry = __swp_entry(swp_type(entry), swp_offset(entry));
BUG_ON(pte_file(__swp_entry_to_pte(arch_entry)));
return __swp_entry_to_pte(arch_entry); return __swp_entry_to_pte(arch_entry);
} }

View File

@ -130,7 +130,6 @@ static const struct trace_print_flags vmaflags_names[] = {
{VM_ACCOUNT, "account" }, {VM_ACCOUNT, "account" },
{VM_NORESERVE, "noreserve" }, {VM_NORESERVE, "noreserve" },
{VM_HUGETLB, "hugetlb" }, {VM_HUGETLB, "hugetlb" },
{VM_NONLINEAR, "nonlinear" },
#if defined(CONFIG_X86) #if defined(CONFIG_X86)
{VM_PAT, "pat" }, {VM_PAT, "pat" },
#elif defined(CONFIG_PPC) #elif defined(CONFIG_PPC)

View File

@ -55,7 +55,7 @@ retry:
*/ */
if (likely(!(flags & FOLL_MIGRATION))) if (likely(!(flags & FOLL_MIGRATION)))
goto no_page; goto no_page;
if (pte_none(pte) || pte_file(pte)) if (pte_none(pte))
goto no_page; goto no_page;
entry = pte_to_swp_entry(pte); entry = pte_to_swp_entry(pte);
if (!is_migration_entry(entry)) if (!is_migration_entry(entry))

View File

@ -1748,7 +1748,7 @@ int ksm_madvise(struct vm_area_struct *vma, unsigned long start,
*/ */
if (*vm_flags & (VM_MERGEABLE | VM_SHARED | VM_MAYSHARE | if (*vm_flags & (VM_MERGEABLE | VM_SHARED | VM_MAYSHARE |
VM_PFNMAP | VM_IO | VM_DONTEXPAND | VM_PFNMAP | VM_IO | VM_DONTEXPAND |
VM_HUGETLB | VM_NONLINEAR | VM_MIXEDMAP)) VM_HUGETLB | VM_MIXEDMAP))
return 0; /* just ignore the advice */ return 0; /* just ignore the advice */
#ifdef VM_SAO #ifdef VM_SAO

View File

@ -155,7 +155,7 @@ static int swapin_walk_pmd_entry(pmd_t *pmd, unsigned long start,
pte = *(orig_pte + ((index - start) / PAGE_SIZE)); pte = *(orig_pte + ((index - start) / PAGE_SIZE));
pte_unmap_unlock(orig_pte, ptl); pte_unmap_unlock(orig_pte, ptl);
if (pte_present(pte) || pte_none(pte) || pte_file(pte)) if (pte_present(pte) || pte_none(pte))
continue; continue;
entry = pte_to_swp_entry(pte); entry = pte_to_swp_entry(pte);
if (unlikely(non_swap_entry(entry))) if (unlikely(non_swap_entry(entry)))
@ -296,7 +296,7 @@ static long madvise_remove(struct vm_area_struct *vma,
*prev = NULL; /* tell sys_madvise we drop mmap_sem */ *prev = NULL; /* tell sys_madvise we drop mmap_sem */
if (vma->vm_flags & (VM_LOCKED|VM_NONLINEAR|VM_HUGETLB)) if (vma->vm_flags & (VM_LOCKED | VM_HUGETLB))
return -EINVAL; return -EINVAL;
f = vma->vm_file; f = vma->vm_file;

View File

@ -4926,10 +4926,7 @@ static struct page *mc_handle_file_pte(struct vm_area_struct *vma,
return NULL; return NULL;
mapping = vma->vm_file->f_mapping; mapping = vma->vm_file->f_mapping;
if (pte_none(ptent)) pgoff = linear_page_index(vma, addr);
pgoff = linear_page_index(vma, addr);
else /* pte_file(ptent) is true */
pgoff = pte_to_pgoff(ptent);
/* page is moved even if it's not RSS of this task(page-faulted). */ /* page is moved even if it's not RSS of this task(page-faulted). */
#ifdef CONFIG_SWAP #ifdef CONFIG_SWAP
@ -4961,7 +4958,7 @@ static enum mc_target_type get_mctgt_type(struct vm_area_struct *vma,
page = mc_handle_present_pte(vma, addr, ptent); page = mc_handle_present_pte(vma, addr, ptent);
else if (is_swap_pte(ptent)) else if (is_swap_pte(ptent))
page = mc_handle_swap_pte(vma, addr, ptent, &ent); page = mc_handle_swap_pte(vma, addr, ptent, &ent);
else if (pte_none(ptent) || pte_file(ptent)) else if (pte_none(ptent))
page = mc_handle_file_pte(vma, addr, ptent, &ent); page = mc_handle_file_pte(vma, addr, ptent, &ent);
if (!page && !ent.val) if (!page && !ent.val)

View File

@ -811,42 +811,40 @@ copy_one_pte(struct mm_struct *dst_mm, struct mm_struct *src_mm,
/* pte contains position in swap or file, so copy. */ /* pte contains position in swap or file, so copy. */
if (unlikely(!pte_present(pte))) { if (unlikely(!pte_present(pte))) {
if (!pte_file(pte)) { swp_entry_t entry = pte_to_swp_entry(pte);
swp_entry_t entry = pte_to_swp_entry(pte);
if (likely(!non_swap_entry(entry))) { if (likely(!non_swap_entry(entry))) {
if (swap_duplicate(entry) < 0) if (swap_duplicate(entry) < 0)
return entry.val; return entry.val;
/* make sure dst_mm is on swapoff's mmlist. */ /* make sure dst_mm is on swapoff's mmlist. */
if (unlikely(list_empty(&dst_mm->mmlist))) { if (unlikely(list_empty(&dst_mm->mmlist))) {
spin_lock(&mmlist_lock); spin_lock(&mmlist_lock);
if (list_empty(&dst_mm->mmlist)) if (list_empty(&dst_mm->mmlist))
list_add(&dst_mm->mmlist, list_add(&dst_mm->mmlist,
&src_mm->mmlist); &src_mm->mmlist);
spin_unlock(&mmlist_lock); spin_unlock(&mmlist_lock);
} }
rss[MM_SWAPENTS]++; rss[MM_SWAPENTS]++;
} else if (is_migration_entry(entry)) { } else if (is_migration_entry(entry)) {
page = migration_entry_to_page(entry); page = migration_entry_to_page(entry);
if (PageAnon(page)) if (PageAnon(page))
rss[MM_ANONPAGES]++; rss[MM_ANONPAGES]++;
else else
rss[MM_FILEPAGES]++; rss[MM_FILEPAGES]++;
if (is_write_migration_entry(entry) && if (is_write_migration_entry(entry) &&
is_cow_mapping(vm_flags)) { is_cow_mapping(vm_flags)) {
/* /*
* COW mappings require pages in both * COW mappings require pages in both
* parent and child to be set to read. * parent and child to be set to read.
*/ */
make_migration_entry_read(&entry); make_migration_entry_read(&entry);
pte = swp_entry_to_pte(entry); pte = swp_entry_to_pte(entry);
if (pte_swp_soft_dirty(*src_pte)) if (pte_swp_soft_dirty(*src_pte))
pte = pte_swp_mksoft_dirty(pte); pte = pte_swp_mksoft_dirty(pte);
set_pte_at(src_mm, addr, src_pte, pte); set_pte_at(src_mm, addr, src_pte, pte);
}
} }
} }
goto out_set_pte; goto out_set_pte;
@ -1020,11 +1018,9 @@ int copy_page_range(struct mm_struct *dst_mm, struct mm_struct *src_mm,
* readonly mappings. The tradeoff is that copy_page_range is more * readonly mappings. The tradeoff is that copy_page_range is more
* efficient than faulting. * efficient than faulting.
*/ */
if (!(vma->vm_flags & (VM_HUGETLB | VM_NONLINEAR | if (!(vma->vm_flags & (VM_HUGETLB | VM_PFNMAP | VM_MIXEDMAP)) &&
VM_PFNMAP | VM_MIXEDMAP))) { !vma->anon_vma)
if (!vma->anon_vma) return 0;
return 0;
}
if (is_vm_hugetlb_page(vma)) if (is_vm_hugetlb_page(vma))
return copy_hugetlb_page_range(dst_mm, src_mm, vma); return copy_hugetlb_page_range(dst_mm, src_mm, vma);

View File

@ -124,17 +124,13 @@ static void mincore_pte_range(struct vm_area_struct *vma, pmd_t *pmd,
ptep = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl); ptep = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);
do { do {
pte_t pte = *ptep; pte_t pte = *ptep;
pgoff_t pgoff;
next = addr + PAGE_SIZE; next = addr + PAGE_SIZE;
if (pte_none(pte)) if (pte_none(pte))
mincore_unmapped_range(vma, addr, next, vec); mincore_unmapped_range(vma, addr, next, vec);
else if (pte_present(pte)) else if (pte_present(pte))
*vec = 1; *vec = 1;
else if (pte_file(pte)) { else { /* pte is a swap entry */
pgoff = pte_to_pgoff(pte);
*vec = mincore_page(vma->vm_file->f_mapping, pgoff);
} else { /* pte is a swap entry */
swp_entry_t entry = pte_to_swp_entry(pte); swp_entry_t entry = pte_to_swp_entry(pte);
if (non_swap_entry(entry)) { if (non_swap_entry(entry)) {
@ -145,9 +141,8 @@ static void mincore_pte_range(struct vm_area_struct *vma, pmd_t *pmd,
*vec = 1; *vec = 1;
} else { } else {
#ifdef CONFIG_SWAP #ifdef CONFIG_SWAP
pgoff = entry.val;
*vec = mincore_page(swap_address_space(entry), *vec = mincore_page(swap_address_space(entry),
pgoff); entry.val);
#else #else
WARN_ON(1); WARN_ON(1);
*vec = 1; *vec = 1;

View File

@ -105,7 +105,7 @@ static unsigned long change_pte_range(struct vm_area_struct *vma, pmd_t *pmd,
} }
if (updated) if (updated)
pages++; pages++;
} else if (IS_ENABLED(CONFIG_MIGRATION) && !pte_file(oldpte)) { } else if (IS_ENABLED(CONFIG_MIGRATION)) {
swp_entry_t entry = pte_to_swp_entry(oldpte); swp_entry_t entry = pte_to_swp_entry(oldpte);
if (is_write_migration_entry(entry)) { if (is_write_migration_entry(entry)) {

View File

@ -81,8 +81,6 @@ static pte_t move_soft_dirty_pte(pte_t pte)
pte = pte_mksoft_dirty(pte); pte = pte_mksoft_dirty(pte);
else if (is_swap_pte(pte)) else if (is_swap_pte(pte))
pte = pte_swp_mksoft_dirty(pte); pte = pte_swp_mksoft_dirty(pte);
else if (pte_file(pte))
pte = pte_file_mksoft_dirty(pte);
#endif #endif
return pte; return pte;
} }

View File

@ -86,10 +86,7 @@ SYSCALL_DEFINE3(msync, unsigned long, start, size_t, len, int, flags)
(vma->vm_flags & VM_SHARED)) { (vma->vm_flags & VM_SHARED)) {
get_file(file); get_file(file);
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
if (vma->vm_flags & VM_NONLINEAR) error = vfs_fsync_range(file, fstart, fend, 1);
error = vfs_fsync(file, 1);
else
error = vfs_fsync_range(file, fstart, fend, 1);
fput(file); fput(file);
if (error || start >= end) if (error || start >= end)
goto out; goto out;