Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp2831914imm; Thu, 18 Oct 2018 23:56:42 -0700 (PDT) X-Google-Smtp-Source: ACcGV62Rci2QDx7IsGRrL1op+sCz9y9gPM+KEUdI1IkKTMuUPZm86a+Ue67W8DLDuIwOwhZzTHWl X-Received: by 2002:a17:902:bd08:: with SMTP id p8-v6mr3680663pls.29.1539932202541; Thu, 18 Oct 2018 23:56:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539932202; cv=none; d=google.com; s=arc-20160816; b=fKZo5FC6ODz7BQdCCR3eiOigzpm5TeiQZi3XzyIWC2j3kLPXDwed7PaOgBfHQNas6j 0oxcOo5cF3EUgCNmu1M6wiCSNewE25DVTBmkJcX0nYOxCJC+Fq5lU5VqnRCIq3DjMgv0 ln/ugTdbwx53/6oa4JRO59aJLi4NLfUBKWQMZTYZwV+42o8B0dF1eLqN7PjvIJ+BzS40 wKfeXZ+HRyYOjzuANZI3RmGiIMdqALcRYC/0F4Q7+j8Mo87VHTOCfNyK87X+wSNNPL7W ajP86xY/hF0pQ5StFtzN+Ued6Q12HKUlEAIx0/0OGV1DHqbsPYTt+m2JSEgTr8UnSDKG dLkQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:cc:to:subject:from:references :in-reply-to:message-id; bh=98zTeetLXKyhkn07gfjDukCEcXVHf+WNrgUzLGr3APw=; b=dVhvT2bKqKD/wVRRwly4qzY8N92/SqdpKoAXVVIaDzjUDiU/uCs2OzQGzBfmfxFoiC 9pHvNF4py9g6GEEg352XOSRwww2WYEE1r3tHUHqv/2NYOGldJTkvVgjn18nppeOvYuuK Y5Y8bE11rWPnK16K1JAiWEwU1MREs7HNQ892RK96SLrPAI9u/0VwsOIfxcsfYdTLTboH BgSu6c1jkGu9D5KxCUAGQvE+wqO7n/e1Ch/9peFyWqT7i1igIvrQ5YDvwdpsSnTB53RD hK84tcFsZVzZUSv6ck8k///iEigmjC6NZ2CnBCY95srZ5fZamzfi6btfdWLIdQ/vbluB 5jsg== ARC-Authentication-Results: i=1; mx.google.com; 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 u135-v6si26504945pfc.79.2018.10.18.23.56.27; Thu, 18 Oct 2018 23:56:42 -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; 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 S1727552AbeJSPAL (ORCPT + 99 others); Fri, 19 Oct 2018 11:00:11 -0400 Received: from pegase1.c-s.fr ([93.17.236.30]:14896 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727444AbeJSPAJ (ORCPT ); Fri, 19 Oct 2018 11:00:09 -0400 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 42bxWH6MvXz9ttFp; Fri, 19 Oct 2018 08:55:23 +0200 (CEST) X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id M_KTX_SHIwsD; Fri, 19 Oct 2018 08:55:23 +0200 (CEST) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 42bxWH5tVZz9ttFM; Fri, 19 Oct 2018 08:55:23 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 02F6C8B8DF; Fri, 19 Oct 2018 08:55:25 +0200 (CEST) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id SD0IOLaud1y6; Fri, 19 Oct 2018 08:55:24 +0200 (CEST) Received: from pc13168vm.idsi0.si.c-s.fr (po15451.idsi0.si.c-s.fr [172.25.231.2]) by messagerie.si.c-s.fr (Postfix) with ESMTP id D424E8B75B; Fri, 19 Oct 2018 08:55:24 +0200 (CEST) Received: by pc13168vm.idsi0.si.c-s.fr (Postfix, from userid 0) id 9CAA46F496; Fri, 19 Oct 2018 06:55:24 +0000 (UTC) Message-Id: In-Reply-To: References: From: Christophe Leroy Subject: [PATCH v6 16/20] powerpc/mm: inline pte_alloc_one() and pte_alloc_one_kernel() in PPC32 To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Date: Fri, 19 Oct 2018 06:55:24 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As in PPC64, inline pte_alloc_one() and pte_alloc_one_kernel() in PPC32. This will allow to switch nohash/32 to pte_fragment without impacting hash/32. Signed-off-by: Christophe Leroy --- arch/powerpc/include/asm/book3s/32/pgalloc.h | 22 ++++++++++++++++++++-- arch/powerpc/include/asm/nohash/32/pgalloc.h | 22 ++++++++++++++++++++-- arch/powerpc/mm/pgtable_32.c | 21 --------------------- 3 files changed, 40 insertions(+), 25 deletions(-) diff --git a/arch/powerpc/include/asm/book3s/32/pgalloc.h b/arch/powerpc/include/asm/book3s/32/pgalloc.h index 4ddc7df20381..a4cf0de10931 100644 --- a/arch/powerpc/include/asm/book3s/32/pgalloc.h +++ b/arch/powerpc/include/asm/book3s/32/pgalloc.h @@ -80,8 +80,26 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmdp, #define pmd_pgtable(pmd) pmd_page(pmd) #endif -extern pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long addr); -extern pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long addr); +static inline pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long address) +{ + return (pte_t *)__get_free_page(GFP_KERNEL | __GFP_ZERO); +} + +static inline pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long address) +{ + struct page *ptepage; + + gfp_t flags = GFP_KERNEL | __GFP_ZERO | __GFP_ACCOUNT; + + ptepage = alloc_pages(flags, 0); + if (!ptepage) + return NULL; + if (!pgtable_page_ctor(ptepage)) { + __free_page(ptepage); + return NULL; + } + return ptepage; +} static inline void pte_free_kernel(struct mm_struct *mm, pte_t *pte) { diff --git a/arch/powerpc/include/asm/nohash/32/pgalloc.h b/arch/powerpc/include/asm/nohash/32/pgalloc.h index da8fdfc76418..78367855a4f3 100644 --- a/arch/powerpc/include/asm/nohash/32/pgalloc.h +++ b/arch/powerpc/include/asm/nohash/32/pgalloc.h @@ -81,8 +81,26 @@ static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmdp, #define pmd_pgtable(pmd) pmd_page(pmd) #endif -extern pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long addr); -extern pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long addr); +static inline pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long address) +{ + return (pte_t *)__get_free_page(GFP_KERNEL | __GFP_ZERO); +} + +static inline pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long address) +{ + struct page *ptepage; + + gfp_t flags = GFP_KERNEL | __GFP_ZERO | __GFP_ACCOUNT; + + ptepage = alloc_pages(flags, 0); + if (!ptepage) + return NULL; + if (!pgtable_page_ctor(ptepage)) { + __free_page(ptepage); + return NULL; + } + return ptepage; +} static inline void pte_free_kernel(struct mm_struct *mm, pte_t *pte) { diff --git a/arch/powerpc/mm/pgtable_32.c b/arch/powerpc/mm/pgtable_32.c index ea4442dde0d5..745f2f30d4e9 100644 --- a/arch/powerpc/mm/pgtable_32.c +++ b/arch/powerpc/mm/pgtable_32.c @@ -43,27 +43,6 @@ EXPORT_SYMBOL(ioremap_bot); /* aka VMALLOC_END */ extern char etext[], _stext[], _sinittext[], _einittext[]; -pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long address) -{ - return (pte_t *)__get_free_page(GFP_KERNEL | __GFP_ZERO); -} - -pgtable_t pte_alloc_one(struct mm_struct *mm, unsigned long address) -{ - struct page *ptepage; - - gfp_t flags = GFP_KERNEL | __GFP_ZERO | __GFP_ACCOUNT; - - ptepage = alloc_pages(flags, 0); - if (!ptepage) - return NULL; - if (!pgtable_page_ctor(ptepage)) { - __free_page(ptepage); - return NULL; - } - return ptepage; -} - void __iomem * ioremap(phys_addr_t addr, unsigned long size) { -- 2.13.3