Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3535362pxb; Mon, 24 Jan 2022 11:38:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJwEnWam2GaNcSL+mMHS8dRz90DhxoprY6NmD2DYCi5xMiiTuIjBtJkmiEieao/XK1az04ty X-Received: by 2002:a17:90b:3892:: with SMTP id mu18mr3404350pjb.107.1643053112332; Mon, 24 Jan 2022 11:38:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643053112; cv=none; d=google.com; s=arc-20160816; b=pJByIuZPQ0ktZsLlbt8Q7/5Cut+GjCHpZepp94f3OBAGsXQgA9yx1DpWkO5CIrYZ0t vfT7UqV5sXKrnUMq736vyab4s4wchSQVp6CrxzZ+JRq7qJosdSApTV+O9YA2yEpYUz6y kwkNmyAMjkODrkI8Fw+Phv0lPMrm7RSJitKgT7NCbO5sCVyK1eWBrSBazZHNX1oA5en6 TXYwQwD2WUpt6q6PsKXucW4r2+bbGJLUTiJKH6A+1xy0X6D97YPYCF9FQTyLmbdw77lA 7OHrl+wVh2VOp59djoNDWjYIpof7q2cpksWTkqYoTYje0EqvkEJD20lJdadjRtHQuvud WfMg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=f8r4YHtc7J3QmIdVmwsPSNX1yPV501OuwrQz7l7iC9M=; b=y3X9tp8xdL63DW/PEaiB9YmMM49/FHNDGbwLVggudtwqu3P3BNKMCcbNilT+gLNYif zg6jIbKzkuVTWptpMOfr+c9H/uQ3LAWkIuYqyBX9iU0467N6mrZYYdG7VgpmqbITCssx ceh8yAKz6pVc4uNmxlNWNjN9Pe6nngtLTi70CQ+M44LaAUc13tWt319qZUFyjyTpYz9O cROYXV3fWMXE/cuIVBbqKqGhFRq1EICh5eUzB9QK9nedBXHXr7aJSshbRvnzTifD3e2i 63bJk0u9rbgKwG1e25C16fbtRdU4+shbZHOjU8d62tnaHYtklC+hIVc+t9QsbgmQ6++X BzCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=E826E8eJ; 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=armlinux.org.uk Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 12si14282675pga.691.2022.01.24.11.38.20; Mon, 24 Jan 2022 11:38:32 -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; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=E826E8eJ; 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=armlinux.org.uk Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244126AbiAXRHX (ORCPT + 99 others); Mon, 24 Jan 2022 12:07:23 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46232 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231633AbiAXRHW (ORCPT ); Mon, 24 Jan 2022 12:07:22 -0500 Received: from pandora.armlinux.org.uk (unknown [IPv6:2001:4d48:ad52:32c8:5054:ff:fe00:142]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 56851C06173B for ; Mon, 24 Jan 2022 09:07:21 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=armlinux.org.uk; s=pandora-2019; h=Sender:In-Reply-To:Content-Type: MIME-Version:References:Message-ID:Subject:Cc:To:From:Date:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=f8r4YHtc7J3QmIdVmwsPSNX1yPV501OuwrQz7l7iC9M=; b=E826E8eJ4DAPUjKxSWUyFzUdfG CGnLDrthBvnTqbddOWDqltsR9uIXM/UhVOfd3fGy0wiKabRnmjPgeZ89znBAZOjs29OwIQK58SCBx T/MtfBCB4G/Ax2c0AUtyK2PcKoewXYQ1a4rUvcS2DgucNo7n1qDM4Fj8vElsB032HM8GRjepVFi9f fiNdKESKNXz9MYzNXCMXh+xeherGvGG/2tCq9T2DylFIZj6YFmFIBXtuWROPVOIVBFGvIkCMsaqxt e2Q7zAIdg7pzkeTmbMrVOvLY9zTuUn2vrYyxmdfdfk108qhdhpFFGF0f68mP/+wIK44XT3LH2EiW+ EOU/zekw==; Received: from shell.armlinux.org.uk ([fd8f:7570:feb6:1:5054:ff:fe00:4ec]:56840) by pandora.armlinux.org.uk with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1nC2o2-0000cg-VJ; Mon, 24 Jan 2022 17:07:02 +0000 Received: from linux by shell.armlinux.org.uk with local (Exim 4.94.2) (envelope-from ) id 1nC2nz-0001mU-V0; Mon, 24 Jan 2022 17:06:59 +0000 Date: Mon, 24 Jan 2022 17:06:59 +0000 From: "Russell King (Oracle)" To: Anshuman Khandual Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, hch@infradead.org, akpm@linux-foundation.org, Arnd Bergmann , linux-arm-kernel@lists.infradead.org Subject: Re: [RFC V1 09/31] arm/mm: Enable ARCH_HAS_VM_GET_PAGE_PROT Message-ID: References: <1643029028-12710-1-git-send-email-anshuman.khandual@arm.com> <1643029028-12710-10-git-send-email-anshuman.khandual@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1643029028-12710-10-git-send-email-anshuman.khandual@arm.com> Sender: Russell King (Oracle) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jan 24, 2022 at 06:26:46PM +0530, Anshuman Khandual wrote: > 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. What is the fundamental advantage of this approach? > > Cc: Russell King > Cc: Arnd Bergmann > Cc: linux-arm-kernel@lists.infradead.org > Cc: linux-kernel@vger.kernel.org > Signed-off-by: Anshuman Khandual > --- > arch/arm/Kconfig | 1 + > arch/arm/include/asm/pgtable.h | 18 ------------ > arch/arm/mm/mmu.c | 50 ++++++++++++++++++++++++++++++---- > 3 files changed, 45 insertions(+), 24 deletions(-) > > diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig > index fabe39169b12..c12362d20c44 100644 > --- a/arch/arm/Kconfig > +++ b/arch/arm/Kconfig > @@ -23,6 +23,7 @@ config ARM > select ARCH_HAS_SYNC_DMA_FOR_CPU if SWIOTLB || !MMU > select ARCH_HAS_TEARDOWN_DMA_OPS if MMU > select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST > + select ARCH_HAS_VM_GET_PAGE_PROT > select ARCH_HAVE_CUSTOM_GPIO_H > select ARCH_HAVE_NMI_SAFE_CMPXCHG if CPU_V7 || CPU_V7M || CPU_V6K > select ARCH_HAS_GCOV_PROFILE_ALL > diff --git a/arch/arm/include/asm/pgtable.h b/arch/arm/include/asm/pgtable.h > index cd1f84bb40ae..ec062dd6082a 100644 > --- a/arch/arm/include/asm/pgtable.h > +++ b/arch/arm/include/asm/pgtable.h > @@ -137,24 +137,6 @@ extern pgprot_t phys_mem_access_prot(struct file *file, unsigned long pfn, > * 2) If we could do execute protection, then read is implied > * 3) write implies read permissions > */ > -#define __P000 __PAGE_NONE > -#define __P001 __PAGE_READONLY > -#define __P010 __PAGE_COPY > -#define __P011 __PAGE_COPY > -#define __P100 __PAGE_READONLY_EXEC > -#define __P101 __PAGE_READONLY_EXEC > -#define __P110 __PAGE_COPY_EXEC > -#define __P111 __PAGE_COPY_EXEC > - > -#define __S000 __PAGE_NONE > -#define __S001 __PAGE_READONLY > -#define __S010 __PAGE_SHARED > -#define __S011 __PAGE_SHARED > -#define __S100 __PAGE_READONLY_EXEC > -#define __S101 __PAGE_READONLY_EXEC > -#define __S110 __PAGE_SHARED_EXEC > -#define __S111 __PAGE_SHARED_EXEC > - > #ifndef __ASSEMBLY__ > /* > * ZERO_PAGE is a global shared page that is always zero: used > diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c > index 274e4f73fd33..3007d07bc0e7 100644 > --- a/arch/arm/mm/mmu.c > +++ b/arch/arm/mm/mmu.c > @@ -403,6 +403,8 @@ void __set_fixmap(enum fixed_addresses idx, phys_addr_t phys, pgprot_t prot) > local_flush_tlb_kernel_range(vaddr, vaddr + PAGE_SIZE); > } > > +static pteval_t user_pgprot; > + > /* > * Adjust the PMD section entries according to the CPU in use. > */ > @@ -410,7 +412,7 @@ static void __init build_mem_type_table(void) > { > struct cachepolicy *cp; > unsigned int cr = get_cr(); > - pteval_t user_pgprot, kern_pgprot, vecs_pgprot; > + pteval_t kern_pgprot, vecs_pgprot; > int cpu_arch = cpu_architecture(); > int i; > > @@ -627,11 +629,6 @@ static void __init build_mem_type_table(void) > user_pgprot |= PTE_EXT_PXN; > #endif > > - for (i = 0; i < 16; i++) { > - pteval_t v = pgprot_val(protection_map[i]); > - protection_map[i] = __pgprot(v | user_pgprot); > - } > - > mem_types[MT_LOW_VECTORS].prot_pte |= vecs_pgprot; > mem_types[MT_HIGH_VECTORS].prot_pte |= vecs_pgprot; > > @@ -670,6 +667,47 @@ static void __init build_mem_type_table(void) > } > } > > +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 __pgprot(pgprot_val(__PAGE_NONE) | user_pgprot); > + case VM_READ: > + return __pgprot(pgprot_val(__PAGE_READONLY) | user_pgprot); > + case VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_COPY) | user_pgprot); > + case VM_READ | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_COPY) | user_pgprot); > + case VM_EXEC: > + return __pgprot(pgprot_val(__PAGE_READONLY_EXEC) | user_pgprot); > + case VM_EXEC | VM_READ: > + return __pgprot(pgprot_val(__PAGE_READONLY_EXEC) | user_pgprot); > + case VM_EXEC | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_COPY_EXEC) | user_pgprot); > + case VM_EXEC | VM_READ | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_COPY_EXEC) | user_pgprot); > + case VM_SHARED: > + return __pgprot(pgprot_val(__PAGE_NONE) | user_pgprot); > + case VM_SHARED | VM_READ: > + return __pgprot(pgprot_val(__PAGE_READONLY) | user_pgprot); > + case VM_SHARED | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_SHARED) | user_pgprot); > + case VM_SHARED | VM_READ | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_SHARED) | user_pgprot); > + case VM_SHARED | VM_EXEC: > + return __pgprot(pgprot_val(__PAGE_READONLY_EXEC) | user_pgprot); > + case VM_SHARED | VM_EXEC | VM_READ: > + return __pgprot(pgprot_val(__PAGE_READONLY_EXEC) | user_pgprot); > + case VM_SHARED | VM_EXEC | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_SHARED_EXEC) | user_pgprot); > + case VM_SHARED | VM_EXEC | VM_READ | VM_WRITE: > + return __pgprot(pgprot_val(__PAGE_SHARED_EXEC) | user_pgprot); > + default: > + BUILD_BUG(); > + } > +} > +EXPORT_SYMBOL(vm_get_page_prot); > + > #ifdef CONFIG_ARM_DMA_MEM_BUFFERABLE > pgprot_t phys_mem_access_prot(struct file *file, unsigned long pfn, > unsigned long size, pgprot_t vma_prot) > -- > 2.25.1 > > -- RMK's Patch system: https://www.armlinux.org.uk/developer/patches/ FTTP is here! 40Mbps down 10Mbps up. Decent connectivity at last!