Re: [PATCH V2] mm/thp: Define default pmd_pgtable()
From: Anshuman Khandual <hidden>
Date: 2021-06-10 04:15:36
Also in:
linux-mm, lkml
On 6/9/21 2:20 PM, Mike Rapoport wrote:
Hi Anshuman, On Wed, Jun 09, 2021 at 10:29:59AM +0530, Anshuman Khandual wrote:quoted
Currently most platforms define pmd_pgtable() as pmd_page() duplicating the same code all over. Instead just define a default value i.e pmd_page() for pmd_pgtable() and let platforms override when required via <asm/pgtable.h>. All the existing platform that override pmd_pgtable() have been moved into their respective <asm/pgtable.h> header in order to precede before the new generic definition. This makes it much cleaner with reduced code. Cc: Nick Hu <redacted> Cc: Richard Henderson <redacted> Cc: Vineet Gupta <redacted> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Will Deacon <will@kernel.org> Cc: Guo Ren <guoren@kernel.org> Cc: Brian Cain <redacted> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Cc: Michal Simek <monstr@monstr.eu> Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de> Cc: Ley Foon Tan <redacted> Cc: Jonas Bonn <jonas@southpole.se> Cc: Stefan Kristiansson <stefan.kristiansson@saunalahti.fi> Cc: Stafford Horne <shorne@gmail.com> Cc: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Christophe Leroy <redacted> Cc: Paul Walmsley <redacted> Cc: Palmer Dabbelt <palmer@dabbelt.com> Cc: Heiko Carstens <hca@linux.ibm.com> Cc: Yoshinori Sato <ysato@users.sourceforge.jp> Cc: "David S. Miller" <davem@davemloft.net> Cc: Jeff Dike <redacted> Cc: Thomas Gleixner <redacted> Cc: Chris Zankel <chris@zankel.net> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: linux-arch@vger.kernel.org Cc: linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org Signed-off-by: Anshuman Khandual <redacted>One nit below, otherwise Acked-by: Mike Rapoport <redacted>quoted
--- This patch applies on linux-next (20210608) as there is a merge conflict dependency on the following commit. 40762590e8be ("mm: define default value for FIRST_USER_ADDRESS"). This patch has been built tested across multiple platforms. Changes in V2: - Changed m68k per Geert Changes in V1: https://lore.kernel.org/linux-arch/1623130327-13325-1-git-send-email-anshuman.khandual@arm.com/ (local)...quoted
diff --git a/arch/m68k/include/asm/sun3_pgalloc.h b/arch/m68k/include/asm/sun3_pgalloc.h index 000f64869b91..198036aff519 100644 --- a/arch/m68k/include/asm/sun3_pgalloc.h +++ b/arch/m68k/include/asm/sun3_pgalloc.h@@ -32,7 +32,6 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd, pgtable_t page { pmd_val(*pmd) = __pa((unsigned long)page_address(page)); } -#define pmd_pgtable(pmd) pmd_page(pmd) /* * allocating and freeing a pmd is trivial: the 1-entry pmd isdiff --git a/arch/m68k/include/asm/sun3_pgtable.h b/arch/m68k/include/asm/sun3_pgtable.h index 5b24283a0a42..127282bd8b96 100644 --- a/arch/m68k/include/asm/sun3_pgtable.h +++ b/arch/m68k/include/asm/sun3_pgtable.h@@ -96,6 +96,8 @@ #ifndef __ASSEMBLY__ +#define pmd_pgtable(pmd) pmd_page(pmd) +Is this one really needed? Won't the generic definition work instead?
It should, sun3_defconfig builds without problem. Will drop pmd_pgtable() here.