Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp5443291imm; Tue, 16 Oct 2018 10:17:49 -0700 (PDT) X-Google-Smtp-Source: ACcGV61rh49KSymQg6Ft0JXnSua/+RHpaMZ/zoVbzgxnh8d9y8/9tL02Bhu9AByswQFZBGDAn5rm X-Received: by 2002:a17:902:62:: with SMTP id 89-v6mr22279109pla.298.1539710268946; Tue, 16 Oct 2018 10:17:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539710268; cv=none; d=google.com; s=arc-20160816; b=WQQmejgCbkd7ZERU56G3EZMFO1uQAQiIgXcCAc2MlfoxYsg1nLZz+VhVBBgtrx/sVT 00X27yGUaUmM4LXzAaV+Dd3Nvl8pxokqoRhjjQwLmNMtrr1nB0hsCLHJLyNhwoKgWI26 zq4F++aC8IesRGFUm40ZvKlYwv9tkNF/GOb1HVclVHe4gA5dfg+gZpbMwAI7Fw3hKtMR jPtFwM0V/OUNsRgGmsJGKjt1eVuCYZAfvG/rRPLOU0BJJmuhU2L9rEGLomySDGj5HVd3 45MpjNtSdX4Ms8Cg1vQ1ZcrZhDdUAAwC1ykoUvSljTK/IlhhQAwLDE++P83E7zzBS5BW BoJQ== 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=1VoRLngdWqmyK5PGtdRCaWCbuvtzlUM/VYFPLWCwCrE=; b=n59ouVig94smNCYbE4ItZoiA62t5YzvfGAcOmBEY9xyEVcAofj8rzgPwKpT4v2ifIx RwK0ZIGQ5WSAjLuDCtQCf4p6jQiJw8na1ZdnGQhV5n0kh89cYv2RJ+sJWpqe1gWr4ule +qr3qqMABYinyXKr7f8f0XaysEWoOivt3nz/N7daVGIO+RW9lQeqvr7JjaNJDA7EFg28 tmpbRX0qCUibXb+ChT4adU+EKrKK0jrZWXDWn8LDBK4A55mADaT7MiNdUu3wGhECbUZN 5NJGYGpfXBZMY7KXzX6ZbBsN6WdBada1mCL6F7FBktbCu6v3XkpKvxtweqxd1bzPcUE8 LNWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=IuAQMajp; 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 v67-v6si15238876pfk.264.2018.10.16.10.17.32; Tue, 16 Oct 2018 10:17:48 -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=IuAQMajp; 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 S1729690AbeJQBHy (ORCPT + 99 others); Tue, 16 Oct 2018 21:07:54 -0400 Received: from mail.kernel.org ([198.145.29.99]:52430 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728606AbeJQBHy (ORCPT ); Tue, 16 Oct 2018 21:07:54 -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 6D2A02089E; Tue, 16 Oct 2018 17:16:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539710190; bh=HVs2Gc+4o1Dgpsbdx4B5TGKeBpvHBWbtOn9KmjGjxkU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=IuAQMajpthL9ka0JxUlB1MzA5F3vtYPOpgXh90Z0GOhHzwlmKXc8bDodKNCY97VzP npGLqaP3m8Ml+0XUwwgkLFi8bsw71wyloA+tZ/MQbpXiqKgJIb0HkLmhaIKgEi1RDI noFoeSxmQLwkZH5SnR3EIyuo6h44dyKjbJn2WpX0= 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.18 134/135] mm: Preserve _PAGE_DEVMAP across mprotect() calls Date: Tue, 16 Oct 2018 19:06:04 +0200 Message-Id: <20181016170524.520134936@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181016170515.447235311@linuxfoundation.org> References: <20181016170515.447235311@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.18-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/powerpc/include/asm/book3s/64/pgtable.h | 4 ++-- arch/x86/include/asm/pgtable_types.h | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) --- a/arch/powerpc/include/asm/book3s/64/pgtable.h +++ b/arch/powerpc/include/asm/book3s/64/pgtable.h @@ -104,7 +104,7 @@ */ #define _HPAGE_CHG_MASK (PTE_RPN_MASK | _PAGE_HPTEFLAGS | _PAGE_DIRTY | \ _PAGE_ACCESSED | H_PAGE_THP_HUGE | _PAGE_PTE | \ - _PAGE_SOFT_DIRTY) + _PAGE_SOFT_DIRTY | _PAGE_DEVMAP) /* * user access blocked by key */ @@ -122,7 +122,7 @@ */ #define _PAGE_CHG_MASK (PTE_RPN_MASK | _PAGE_HPTEFLAGS | _PAGE_DIRTY | \ _PAGE_ACCESSED | _PAGE_SPECIAL | _PAGE_PTE | \ - _PAGE_SOFT_DIRTY) + _PAGE_SOFT_DIRTY | _PAGE_DEVMAP) #define H_PTE_PKEY (H_PTE_PKEY_BIT0 | H_PTE_PKEY_BIT1 | H_PTE_PKEY_BIT2 | \ H_PTE_PKEY_BIT3 | H_PTE_PKEY_BIT4) --- a/arch/x86/include/asm/pgtable_types.h +++ b/arch/x86/include/asm/pgtable_types.h @@ -123,7 +123,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) /*