summaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorPeter Xu <peterx@redhat.com>2018-12-28 03:38:47 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2018-12-28 15:11:51 -0500
commit3cfd22be0ad663248fadfc8f6ffa3e255c394552 (patch)
tree80ff16175ad74737c24414f9a714a510d72cf12b /fs
parent125b860b251ad226b1384b6db06be37485127f69 (diff)
userfaultfd: clear flag if remap event not enabled
When the process being tracked does mremap() without UFFD_FEATURE_EVENT_REMAP on the corresponding tracking uffd file handle, we should not generate the remap event, and at the same time we should clear all the uffd flags on the new VMA. Without this patch, we can still have the VM_UFFD_MISSING|VM_UFFD_WP flags on the new VMA even the fault handling process does not even know the existance of the VMA. Link: http://lkml.kernel.org/r/20181211053409.20317-1-peterx@redhat.com Signed-off-by: Peter Xu <peterx@redhat.com> Reviewed-by: Andrea Arcangeli <aarcange@redhat.com> Acked-by: Mike Rapoport <rppt@linux.vnet.ibm.com> Reviewed-by: William Kucharski <william.kucharski@oracle.com> Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: Mike Rapoport <rppt@linux.vnet.ibm.com> Cc: Kirill A. Shutemov <kirill@shutemov.name> Cc: Hugh Dickins <hughd@google.com> Cc: Pavel Emelyanov <xemul@virtuozzo.com> Cc: Pravin Shedge <pravin.shedge4linux@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs')
-rw-r--r--fs/userfaultfd.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/fs/userfaultfd.c b/fs/userfaultfd.c
index e211b99d33c4..89800fc7dc9d 100644
--- a/fs/userfaultfd.c
+++ b/fs/userfaultfd.c
@@ -735,10 +735,18 @@ void mremap_userfaultfd_prep(struct vm_area_struct *vma,
735 struct userfaultfd_ctx *ctx; 735 struct userfaultfd_ctx *ctx;
736 736
737 ctx = vma->vm_userfaultfd_ctx.ctx; 737 ctx = vma->vm_userfaultfd_ctx.ctx;
738 if (ctx && (ctx->features & UFFD_FEATURE_EVENT_REMAP)) { 738
739 if (!ctx)
740 return;
741
742 if (ctx->features & UFFD_FEATURE_EVENT_REMAP) {
739 vm_ctx->ctx = ctx; 743 vm_ctx->ctx = ctx;
740 userfaultfd_ctx_get(ctx); 744 userfaultfd_ctx_get(ctx);
741 WRITE_ONCE(ctx->mmap_changing, true); 745 WRITE_ONCE(ctx->mmap_changing, true);
746 } else {
747 /* Drop uffd context if remap feature not enabled */
748 vma->vm_userfaultfd_ctx = NULL_VM_UFFD_CTX;
749 vma->vm_flags &= ~(VM_UFFD_WP | VM_UFFD_MISSING);
742 } 750 }
743} 751}
744 752