Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp2255328imm; Thu, 18 Oct 2018 11:29:31 -0700 (PDT) X-Google-Smtp-Source: ACcGV62TKcHLbprrI+L10MmjQ4jjbEJ/+8tenmW1MLZ0pajgYYL5+LVYGxKx18AjghzRBGv/APkg X-Received: by 2002:a17:902:aa48:: with SMTP id c8-v6mr31617333plr.100.1539887371086; Thu, 18 Oct 2018 11:29:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539887371; cv=none; d=google.com; s=arc-20160816; b=dcBg4C9UtBaFgW9GPBGxsar7RSfEVZscN+5sgBICYXNlRT4jKw/N6ct9HUqtqfYlM/ get+c5u23cUl7bGRkIfAF5lqmyR/uEmevzNd4/k8ZkIMs0d4UJTOVQYczyq8c8u8yJqw 66g17IfDlMAgGtwVaQIEwWjiQgygEeeeS/i3jFPjnRBVxDtQrMGwRCxo9VbM8WdY1fWc XZWLC+6zcJSCfgmGhU5t6uG1A4cwCELS2Ug2m1BHKS8u8UTZZZVuSAPC60vCxUex17DE yBVI5ulfu7/xmbZY72ZZfKoqExBCWyyPPmsJiNoW6pP9c7ZkSZ3XZXN9jijTSy4bGq9j SXlA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=NZFr1mHo0tvE50r+iVw9/YWtVFGgtJD4K3HtIJuFJaM=; b=wAhbVKrQtYbwa4DEpKO2Ie/usA4d3u2F+6aIpK/h4Z4Npt7ijZtkbvDnvqfGcJ8CiI FUeMiF/FCuS9V79BzuI/CHY4CO/AjRj8zmE5Oi1exZiO3ivWcZ8/NaPFyO6KzV2mzPmd sr6II2qMmD/fCOKv8didUHPaBknr+3zOKEq31zqpN/in+0mXmeM1IZI07ivqBO6tjwSj HfBIfPbgImhOUUp8kAbPbAf+jCKeWtS4roLLBS4LmK/ni99B1iuEKkrSTxtXSdfMMUaE HrfehzcGgb6vsyfYtjQXZJi1bCo4AHX7MLmQrW9KKvVT30ephiIfLF1sdov5sxlDSzsJ ixzA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=H7SmXmKG; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 34-v6si23532488pgy.249.2018.10.18.11.29.15; Thu, 18 Oct 2018 11:29:31 -0700 (PDT) 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=H7SmXmKG; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729936AbeJSCFf (ORCPT + 99 others); Thu, 18 Oct 2018 22:05:35 -0400 Received: from mail.kernel.org ([198.145.29.99]:53772 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729248AbeJSCFe (ORCPT ); Thu, 18 Oct 2018 22:05:34 -0400 Received: from localhost (ip-213-127-77-176.ip.prioritytelecom.net [213.127.77.176]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 1BD1221476; Thu, 18 Oct 2018 18:03:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539885807; bh=AbQTNjlCf3/q830bP7e4asbv0dbelBN8DpGKnRgAp64=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=H7SmXmKGsQLwSm8SpoagZKCKw/fL/LV/kdLKFVJIOq2QDZ3wif7SfgN0LozidFbiy jTGuf93UHErmEUAPWyqHxHqaH3Qbv/1A5b3CwbMhosKurqv7Cb6tZQNH1s42nf6QY9 Q/yysNNrifwEbqYzYsGEdlf0nY1bzofoozAhRmgw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jan Kara , Michal Hocko , Johannes Thumshirn , Dan Williams Subject: [PATCH 4.9 24/35] mm: Preserve _PAGE_DEVMAP across mprotect() calls Date: Thu, 18 Oct 2018 19:54:53 +0200 Message-Id: <20181018175426.208544492@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181018175422.506152522@linuxfoundation.org> References: <20181018175422.506152522@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Jan Kara commit 4628a64591e6cee181237060961e98c615c33966 upstream. Currently _PAGE_DEVMAP bit is not preserved in mprotect(2) calls. As a result we will see warnings such as: BUG: Bad page map in process JobWrk0013 pte:800001803875ea25 pmd:7624381067 addr:00007f0930720000 vm_flags:280000f9 anon_vma: (null) mapping:ffff97f2384056f0 index:0 file:457-000000fe00000030-00000009-000000ca-00000001_2001.fileblock fault:xfs_filemap_fault [xfs] mmap:xfs_file_mmap [xfs] readpage: (null) CPU: 3 PID: 15848 Comm: JobWrk0013 Tainted: G W 4.12.14-2.g7573215-default #1 SLE12-SP4 (unreleased) Hardware name: Intel Corporation S2600WFD/S2600WFD, BIOS SE5C620.86B.01.00.0833.051120182255 05/11/2018 Call Trace: dump_stack+0x5a/0x75 print_bad_pte+0x217/0x2c0 ? enqueue_task_fair+0x76/0x9f0 _vm_normal_page+0xe5/0x100 zap_pte_range+0x148/0x740 unmap_page_range+0x39a/0x4b0 unmap_vmas+0x42/0x90 unmap_region+0x99/0xf0 ? vma_gap_callbacks_rotate+0x1a/0x20 do_munmap+0x255/0x3a0 vm_munmap+0x54/0x80 SyS_munmap+0x1d/0x30 do_syscall_64+0x74/0x150 entry_SYSCALL_64_after_hwframe+0x3d/0xa2 ... when mprotect(2) gets used on DAX mappings. Also there is a wide variety of other failures that can result from the missing _PAGE_DEVMAP flag when the area gets used by get_user_pages() later. Fix the problem by including _PAGE_DEVMAP in a set of flags that get preserved by mprotect(2). Fixes: 69660fd797c3 ("x86, mm: introduce _PAGE_DEVMAP") Fixes: ebd31197931d ("powerpc/mm: Add devmap support for ppc64") Cc: Signed-off-by: Jan Kara Acked-by: Michal Hocko Reviewed-by: Johannes Thumshirn Signed-off-by: Dan Williams Signed-off-by: Greg Kroah-Hartman --- arch/x86/include/asm/pgtable_types.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/arch/x86/include/asm/pgtable_types.h +++ b/arch/x86/include/asm/pgtable_types.h @@ -134,7 +134,7 @@ */ #define _PAGE_CHG_MASK (PTE_PFN_MASK | _PAGE_PCD | _PAGE_PWT | \ _PAGE_SPECIAL | _PAGE_ACCESSED | _PAGE_DIRTY | \ - _PAGE_SOFT_DIRTY) + _PAGE_SOFT_DIRTY | _PAGE_DEVMAP) #define _HPAGE_CHG_MASK (_PAGE_CHG_MASK | _PAGE_PSE) /* The ASID is the lower 12 bits of CR3 */