Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1306260imm; Wed, 10 Oct 2018 12:21:11 -0700 (PDT) X-Google-Smtp-Source: ACcGV633ezvWYrTh8/rK8O9hQZ7vojXwghmXHZHBltW82QiWL5sCG6R9AqDhhjo0S/ziwQY3Fhqu X-Received: by 2002:a63:d444:: with SMTP id i4-v6mr30608576pgj.194.1539199271427; Wed, 10 Oct 2018 12:21:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539199271; cv=none; d=google.com; s=arc-20160816; b=qEkv5N3DbbBwFWxGXtMveG7VRTtDK5SYcBSA4iBpReDsaSef1SviWNDCwSJloP43qK EHRLtXzAOQYfoXPdfbBNiedJUSEwYRiuS7GvxJIBzzCgowYgocTOUu4uxb1UTPtI1vBe cpQZYrqeMzhG//DiSG+MR/eP0a+NqGpFB18zPyIPu0PkC+cka+lVGl7vyJmzF8mY0dDe Hb7l1RjLrXa68/VXiWpvE4pCMt8NYbc4ITdJy5qUwzuNxNXm7pFue5O0QZQxnXlQ9V9O +BoCzW8mG3KAFWIZ+iUwqR9V+30eUWJE5jUTJErazkqfLDkaBYgcc4+UJwIpepTmz+BO Lw+w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:dkim-filter; bh=N3v2LzU7/zfxpIewN1Lf4Ei0VdWx18Nl2AhIPWVI0IE=; b=k5K7bFZQ6NunSXGxLXFjQe/7AwlLd6oM7k8qZYuJHi/CndArmcgzvzizw8tMtmfEd1 WOe7XJVphgGUKhPijdWZHPmP5wz52iqwqwWBZqrdcj4mP/JdZ/OBq5IXCk3c62+Aozpc nRqhCfAtCr3LZzqevcCJXWdi89MmLeC97yfZOR+ALGxzvRl6uhTMiCA2jg8j8ovrasni g1Y0PK0Zmo8V4bCzxylO6LJHJ1EZDCTEkaT2fO8+eWFApPxs2nSGXDPr1+j037p3OPuL nQBFEhRV6Z1xJBywPvCw3jxsVebOOuCxtUZoEL2Xqa/0NebgdcolkaOfkJ0+oY9+rDqf kaWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@efficios.com header.s=default header.b=pojuf1kk; 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=efficios.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id cc10-v6si29758220plb.97.2018.10.10.12.20.56; Wed, 10 Oct 2018 12:21:11 -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=@efficios.com header.s=default header.b=pojuf1kk; 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=efficios.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727757AbeJKCnn (ORCPT + 99 others); Wed, 10 Oct 2018 22:43:43 -0400 Received: from mail.efficios.com ([167.114.142.138]:32914 "EHLO mail.efficios.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727579AbeJKCnm (ORCPT ); Wed, 10 Oct 2018 22:43:42 -0400 Received: from localhost (ip6-localhost [IPv6:::1]) by mail.efficios.com (Postfix) with ESMTP id 68508183B8F; Wed, 10 Oct 2018 15:20:09 -0400 (EDT) Received: from mail.efficios.com ([IPv6:::1]) by localhost (mail02.efficios.com [IPv6:::1]) (amavisd-new, port 10032) with ESMTP id Cc-RHBPAIvn7; Wed, 10 Oct 2018 15:20:08 -0400 (EDT) Received: from localhost (ip6-localhost [IPv6:::1]) by mail.efficios.com (Postfix) with ESMTP id D9714183B8C; Wed, 10 Oct 2018 15:20:08 -0400 (EDT) DKIM-Filter: OpenDKIM Filter v2.10.3 mail.efficios.com D9714183B8C DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=efficios.com; s=default; t=1539199208; bh=N3v2LzU7/zfxpIewN1Lf4Ei0VdWx18Nl2AhIPWVI0IE=; h=From:To:Date:Message-Id; b=pojuf1kk6MRO/Lc3GGHNBSlUm1oXl0KHEDFzI70c+3NmZTyRvFmBSWtRkJyDPkerP 3RS7Kw6yS/PRMkyWpvXNRGCYiHv0glP/ms4u/yjTYdsbXHU9WL2ycoA8ac8cGbmoK/ g8GwLiZ0cKNOJHXjH0WXQdQ7VwZvjF9LbqsO0dselL4l3lZnC8h3nY3e3wY1QjKBq0 WvLJK2sDLpZM3tjBa+STMCbBi1lXAt3WnHunTvQvBu8xfG/8ZhaW5SjXKZ5hkSL71G NUbqWFAMSLHdlgTBT8595h6zRLFX/fFzo9LFTZuOV3xmZ6EwL7WsLmyZWoIWC2FDZX Xqz/RePjhyXeQ== X-Virus-Scanned: amavisd-new at efficios.com Received: from mail.efficios.com ([IPv6:::1]) by localhost (mail02.efficios.com [IPv6:::1]) (amavisd-new, port 10026) with ESMTP id ZosSI9PQcR26; Wed, 10 Oct 2018 15:20:08 -0400 (EDT) Received: from thinkos.internal.efficios.com (192-222-157-41.qc.cable.ebox.net [192.222.157.41]) by mail.efficios.com (Postfix) with ESMTPSA id 59062183B7F; Wed, 10 Oct 2018 15:20:07 -0400 (EDT) From: Mathieu Desnoyers To: Peter Zijlstra , "Paul E . McKenney" , Boqun Feng Cc: linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, Thomas Gleixner , Andy Lutomirski , Dave Watson , Paul Turner , Andrew Morton , Russell King , Ingo Molnar , "H . Peter Anvin" , Andi Kleen , Chris Lameter , Ben Maurer , Steven Rostedt , Josh Triplett , Linus Torvalds , Catalin Marinas , Will Deacon , Michael Kerrisk , Joel Fernandes , Mathieu Desnoyers , linux-mm@kvack.org Subject: [RFC PATCH for 4.21 05/16] mm: Provide is_vma_noncached Date: Wed, 10 Oct 2018 15:19:25 -0400 Message-Id: <20181010191936.7495-6-mathieu.desnoyers@efficios.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20181010191936.7495-1-mathieu.desnoyers@efficios.com> References: <20181010191936.7495-1-mathieu.desnoyers@efficios.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Provide is_vma_noncached() static inline to allow generic code to check whether the given vma consists of noncached memory. Signed-off-by: Mathieu Desnoyers CC: "Paul E. McKenney" CC: Peter Zijlstra CC: Paul Turner CC: Thomas Gleixner CC: Andy Lutomirski CC: Andi Kleen CC: Dave Watson CC: Chris Lameter CC: Ingo Molnar CC: "H. Peter Anvin" CC: Ben Maurer CC: Steven Rostedt CC: Josh Triplett CC: Linus Torvalds CC: Andrew Morton CC: Russell King CC: Catalin Marinas CC: Will Deacon CC: Michael Kerrisk CC: Boqun Feng CC: linux-mm@kvack.org --- include/linux/mm.h | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/include/linux/mm.h b/include/linux/mm.h index 0416a7204be3..18acf4f339f8 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -2551,6 +2551,30 @@ static inline struct page *follow_page(struct vm_area_struct *vma, return follow_page_mask(vma, address, foll_flags, &unused_page_mask); } +static inline bool pgprot_same(pgprot_t a, pgprot_t b) +{ + return pgprot_val(a) == pgprot_val(b); +} + +#ifdef pgprot_noncached +static inline bool is_vma_noncached(struct vm_area_struct *vma) +{ + pgprot_t pgprot = vma->vm_page_prot; + + /* Check whether architecture implements noncached pages. */ + if (pgprot_same(pgprot_noncached(PAGE_KERNEL), PAGE_KERNEL)) + return false; + if (!pgprot_same(pgprot, pgprot_noncached(pgprot))) + return false; + return true; +} +#else +static inline bool is_vma_noncached(struct vm_area_struct *vma) +{ + return false; +} +#endif + #define FOLL_WRITE 0x01 /* check pte is writable */ #define FOLL_TOUCH 0x02 /* mark page accessed */ #define FOLL_GET 0x04 /* do get_page on page */ -- 2.11.0