Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5126628imu; Tue, 8 Jan 2019 12:01:37 -0800 (PST) X-Google-Smtp-Source: ALg8bN5Lbr74L2Mr5RbQ0QsdOnk7EL8v/YaUDAwW2bAAtE+oSi5u2GpztePLORlOkQxj2mwty4Fm X-Received: by 2002:a63:101:: with SMTP id 1mr533286pgb.152.1546977697271; Tue, 08 Jan 2019 12:01:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546977697; cv=none; d=google.com; s=arc-20160816; b=VQdGBGe8xIpzyoqf/MGdyv3Cyb8Sh6ysdW0noWBAEWMz0M9dj4s1dvBt7TyZtSCPYU cHIARnCnZutUvAwMqNRFVpS2Dai+GPHhLuK79Ok6CM6xSLATi1tmWK6ZQ/2AJqZAhZCz mGb9sssei98GXuVqpT5sVer8vN9BaLomAfi7+yvsncORHFmI9kQctLF9mBRe1iyWM2XV QP+bnTM4cnnx0uFe8e0IzuGPjA1jJ+QrOwDZIDm+zfNEJaP2f8y8Z9J8FYIpP6sqz19U WWZehVGi0ghV04z0y08brBf62QV8G0LnY6DStU5lJWOSSxcr2ykwF+p6aVAq6dkOFsPw PgwA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=lNGI07dQr3wVIQYn46PTvyLn5ZY/iBSwHM9SNDKjdl8=; b=aZ1NWVfJKEWafz21gdoy8YZ4uPz+V2D7/o+GUqScLDGijQr6Try/K97cQfnNkdJjGp SDV2wBneaarYKXBAVQlYzNibFWZYrvIK1ct0rtCG8O3dV+KPVLMo3HqtfuO8wZCyHCKf SeRV7oSdpUqmeEJS7StWzBQZvKRMqpnlXkFI+Gh1vHcvOd3T81yKYhAe3awofSWh+uzG lZ5/e8dUeu2eywV/CDXWUeAhARmlDb46F8u5Jmi1upIs53jsKlhAOujH/NRqlkBzwvZV eNahKQGMDeU7hcT7ebsWCHDM0w3N2e+IlzjYlEGbcZF6C2GQRe8hguf/yGRwc/A71Ket Qbtg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=SN2s3Rpj; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s8si63522388plq.345.2019.01.08.12.01.20; Tue, 08 Jan 2019 12:01:37 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=SN2s3Rpj; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730467AbfAHT3n (ORCPT + 99 others); Tue, 8 Jan 2019 14:29:43 -0500 Received: from mail.kernel.org ([198.145.29.99]:37126 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730449AbfAHT3j (ORCPT ); Tue, 8 Jan 2019 14:29:39 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 95D0720827; Tue, 8 Jan 2019 19:29:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1546975778; bh=+V65MindRhoSnsW+P21tyvTfAWRlw7ukVetCcTGzEGk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=SN2s3RpjuZ57kYUQVim8imxYV3WgoFUyVYjnajkwNitZ8/swHlvuIBNyXOpwMj+3g iZgxZXO1z6jU5LxHkiJfL5/RdDBkX0kTuLulOYvTk7pVW7oTdEfe+w7JhprgkjOORd p2rJdq12aEHAFVHU/dhh0EcqvtYfBlR+K6HQHGBY= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Peter Xu , Andrea Arcangeli , Mike Rapoport , "Kirill A . Shutemov" , Hugh Dickins , Pavel Emelyanov , Pravin Shedge , Andrew Morton , Linus Torvalds , Sasha Levin , linux-fsdevel@vger.kernel.org Subject: [PATCH AUTOSEL 4.20 115/117] userfaultfd: clear flag if remap event not enabled Date: Tue, 8 Jan 2019 14:26:23 -0500 Message-Id: <20190108192628.121270-115-sashal@kernel.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190108192628.121270-1-sashal@kernel.org> References: <20190108192628.121270-1-sashal@kernel.org> MIME-Version: 1.0 X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peter Xu [ Upstream commit 3cfd22be0ad663248fadfc8f6ffa3e255c394552 ] 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 Reviewed-by: Andrea Arcangeli Acked-by: Mike Rapoport Reviewed-by: William Kucharski Cc: Andrea Arcangeli Cc: Mike Rapoport Cc: Kirill A. Shutemov Cc: Hugh Dickins Cc: Pavel Emelyanov Cc: Pravin Shedge Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin --- fs/userfaultfd.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/fs/userfaultfd.c b/fs/userfaultfd.c index 7a85e609fc27..d8b8323e80f4 100644 --- a/fs/userfaultfd.c +++ b/fs/userfaultfd.c @@ -736,10 +736,18 @@ void mremap_userfaultfd_prep(struct vm_area_struct *vma, struct userfaultfd_ctx *ctx; ctx = vma->vm_userfaultfd_ctx.ctx; - if (ctx && (ctx->features & UFFD_FEATURE_EVENT_REMAP)) { + + if (!ctx) + return; + + if (ctx->features & UFFD_FEATURE_EVENT_REMAP) { vm_ctx->ctx = ctx; userfaultfd_ctx_get(ctx); WRITE_ONCE(ctx->mmap_changing, true); + } else { + /* Drop uffd context if remap feature not enabled */ + vma->vm_userfaultfd_ctx = NULL_VM_UFFD_CTX; + vma->vm_flags &= ~(VM_UFFD_WP | VM_UFFD_MISSING); } } -- 2.19.1