Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3519268pxb; Mon, 24 Jan 2022 11:15:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJwgNA0nm4ZKZkCHTbiHidY9uz/lnSPZm6NX5ADVHngCYr5dhf+4YqBmL3R38+JxlYqMx6// X-Received: by 2002:a05:6a00:1681:b0:4a8:2462:ba0a with SMTP id k1-20020a056a00168100b004a82462ba0amr15124994pfc.75.1643051739007; Mon, 24 Jan 2022 11:15:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643051739; cv=none; d=google.com; s=arc-20160816; b=HXE4VCCaCdrLR4/zF7eZSTduVFAYy8KDJ+i5Ftw3B7syQrXND+dq2Y9+z4HnS9p4pN +oxqUMcSWJ8MYW55GFk7u0ftj6eJVfEXPE5KS8nbXlRp+t8R7R0xR+B/lFahWGfgD7Ix /acYk6p4KvNe5Fkoh6SishalZJeagWpOghKx8AHuYqFkynNgtUIRWuJ+TFnJkFHgMJPJ XTg+cwO77q0liLQOHTw0FOe7VdaCmM51WuJASDu4m9PEUqY1BOKBTE6/k6hIxsG3kWnx gJVOZDR8YSBlv7jLNWvvpdPP91NJs3v+joc5bTGIPkMieRRRVRzPDarlplFdDr1x64HL JuXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=J7YG7QMdG19m+JnjrkD9AYlpCCUu2IksITOO+dsGH3I=; b=vvH/c9unlc41U2b1RVLX87yV8VndyMHAzHeqLQj3cgoaZBc/NXDmLxuyyeYWru2eKZ hSz+uWMats5N9joAKhCAlkGNgpmO0dNUhetZWgFRlhDEdRO5QnhKbQP7ADgBYOUETG4M 9H4GaYy6DmbfLphE0l5PeCabdl+v5NmuuKfzCKi7582TeRY04hrqG2ueUiUL12f2NxLT VnKZtqSzNRYzM8g+74sRk5a9eTK0PsVv6zBw9CB6cO8UDkp4tXplgBZpZkl3tbIpFats Pf1hiE/tWrZ+eV2K3MoBaRW5Mf1kA1YZyiC+wRF1LPWaot/5s5uGAJnp5yFSQgafT6pm tpmg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u2si15451823plg.50.2022.01.24.11.15.26; Mon, 24 Jan 2022 11:15:38 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242775AbiAXM6p (ORCPT + 99 others); Mon, 24 Jan 2022 07:58:45 -0500 Received: from foss.arm.com ([217.140.110.172]:33152 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242855AbiAXM6g (ORCPT ); Mon, 24 Jan 2022 07:58:36 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 949A0101E; Mon, 24 Jan 2022 04:58:35 -0800 (PST) Received: from p8cg001049571a15.arm.com (unknown [10.163.43.190]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id ACC1C3F774; Mon, 24 Jan 2022 04:58:31 -0800 (PST) From: Anshuman Khandual To: linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org, hch@infradead.org, akpm@linux-foundation.org, Anshuman Khandual , "James E.J. Bottomley" , linux-parisc@vger.kernel.org Subject: [RFC V1 21/31] parisc/mm: Enable ARCH_HAS_VM_GET_PAGE_PROT Date: Mon, 24 Jan 2022 18:26:58 +0530 Message-Id: <1643029028-12710-22-git-send-email-anshuman.khandual@arm.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1643029028-12710-1-git-send-email-anshuman.khandual@arm.com> References: <1643029028-12710-1-git-send-email-anshuman.khandual@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This defines and exports a platform specific custom vm_get_page_prot() via subscribing ARCH_HAS_VM_GET_PAGE_PROT. Subsequently all __SXXX and __PXXX macros can be dropped which are no longer needed. Cc: "James E.J. Bottomley" Cc: linux-parisc@vger.kernel.org Cc: linux-kernel@vger.kernel.org Signed-off-by: Anshuman Khandual --- arch/parisc/Kconfig | 1 + arch/parisc/include/asm/pgtable.h | 20 --------------- arch/parisc/mm/init.c | 41 +++++++++++++++++++++++++++++++ 3 files changed, 42 insertions(+), 20 deletions(-) diff --git a/arch/parisc/Kconfig b/arch/parisc/Kconfig index 43c1c880def6..de512f120b50 100644 --- a/arch/parisc/Kconfig +++ b/arch/parisc/Kconfig @@ -10,6 +10,7 @@ config PARISC select ARCH_HAS_ELF_RANDOMIZE select ARCH_HAS_STRICT_KERNEL_RWX select ARCH_HAS_UBSAN_SANITIZE_ALL + select ARCH_HAS_VM_GET_PAGE_PROT select ARCH_NO_SG_CHAIN select ARCH_SUPPORTS_HUGETLBFS if PA20 select ARCH_SUPPORTS_MEMORY_FAILURE diff --git a/arch/parisc/include/asm/pgtable.h b/arch/parisc/include/asm/pgtable.h index 3e7cf882639f..80d99b2b5913 100644 --- a/arch/parisc/include/asm/pgtable.h +++ b/arch/parisc/include/asm/pgtable.h @@ -269,26 +269,6 @@ extern void __update_cache(pte_t pte); * pages. */ - /*xwr*/ -#define __P000 PAGE_NONE -#define __P001 PAGE_READONLY -#define __P010 __P000 /* copy on write */ -#define __P011 __P001 /* copy on write */ -#define __P100 PAGE_EXECREAD -#define __P101 PAGE_EXECREAD -#define __P110 __P100 /* copy on write */ -#define __P111 __P101 /* copy on write */ - -#define __S000 PAGE_NONE -#define __S001 PAGE_READONLY -#define __S010 PAGE_WRITEONLY -#define __S011 PAGE_SHARED -#define __S100 PAGE_EXECREAD -#define __S101 PAGE_EXECREAD -#define __S110 PAGE_RWX -#define __S111 PAGE_RWX - - extern pgd_t swapper_pg_dir[]; /* declared in init_task.c */ /* initial page tables for 0-8MB for kernel */ diff --git a/arch/parisc/mm/init.c b/arch/parisc/mm/init.c index 1ae31db9988f..c8316e97e1a2 100644 --- a/arch/parisc/mm/init.c +++ b/arch/parisc/mm/init.c @@ -866,3 +866,44 @@ void flush_tlb_all(void) spin_unlock(&sid_lock); } #endif + +pgprot_t vm_get_page_prot(unsigned long vm_flags) +{ + switch (vm_flags & (VM_READ | VM_WRITE | VM_EXEC | VM_SHARED)) { + case VM_NONE: + return PAGE_NONE; + case VM_READ: + return PAGE_READONLY; + case VM_WRITE: + return PAGE_NONE; + case VM_READ | VM_WRITE: + return PAGE_READONLY; + case VM_EXEC: + return PAGE_EXECREAD; + case VM_EXEC | VM_READ: + return PAGE_EXECREAD; + case VM_EXEC | VM_WRITE: + return PAGE_EXECREAD; + case VM_EXEC | VM_READ | VM_WRITE: + return PAGE_EXECREAD; + case VM_SHARED: + return PAGE_NONE; + case VM_SHARED | VM_READ: + return PAGE_READONLY; + case VM_SHARED | VM_WRITE: + return PAGE_WRITEONLY; + case VM_SHARED | VM_READ | VM_WRITE: + return PAGE_SHARED; + case VM_SHARED | VM_EXEC: + return PAGE_EXECREAD; + case VM_SHARED | VM_EXEC | VM_READ: + return PAGE_EXECREAD; + case VM_SHARED | VM_EXEC | VM_WRITE: + return PAGE_RWX; + case VM_SHARED | VM_EXEC | VM_READ | VM_WRITE: + return PAGE_RWX; + default: + BUILD_BUG(); + } +} +EXPORT_SYMBOL(vm_get_page_prot); -- 2.25.1