Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1428127imu; Wed, 16 Jan 2019 19:43:45 -0800 (PST) X-Google-Smtp-Source: ALg8bN5IxxTV416NvD0cXP50d/nbJMYThMdNI+s5xCx71dfDNPDL6+TtYeG2iqyDbelAxCNBuwYD X-Received: by 2002:a17:902:9a98:: with SMTP id w24mr13281911plp.213.1547696625157; Wed, 16 Jan 2019 19:43:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547696625; cv=none; d=google.com; s=arc-20160816; b=aNLez0/RAK7M88P9+e30IhpiZ40cg1Ig8PPl8vAw5UG0hRz852Pz2pb5/XFll6MUzA YW2wVF+sRk5G8CFVHoMSqVtWGF6ti2TPB2xGym1TTQXjrIotbKNdpKOz6S28rS77m2UD 9LeOYaooZScsYp9ZNQL+ii18JwzZL5pI46Yjyi8CtvKffw+tn3FY2MNsPEOsFHGLzWTL ciQzbe9Gtzb85KfGYbRn4hC65nvB17+IixTUhzSkfioh6l9na1GIKdbhNWe84W0/PItj oyOI1ShQ0zsS+eYkfhF9+opZcobSvb9s4aMWNnTSP+f3ksNY8XllIn9QxWOaN++bfyo6 PKbQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=2If1P32ECdcwHjCbloHaSR2cEtyOU07J+HMy2qkDkTg=; b=ZyGmBrO+UImD5Y8bKD93eV0jz8JrembUndGFDXfOS4Sqkrp98JXfFlNERqkLuS36hE iqrGRm+OE/CvTRodTuw2cuFn/jEknadorwJFk44nni4qnmT71L0oSyRNcKsVyMwozUzx O8dlheoSXnvPNv+CSo5xG81KjxcW2BPg5Ol0KKPrwmyGQj+TDLEuNcaOG+Opn3h2jcmS ckPfMNzZiNWkfM8o0oW5qzsVL62G1RZlc2LB1/aMQbWVBKYHjtIQxrvM3kW4mBPLpbGz oosiy/4ibxDE/EEt9LK5N9X2y2P75w2WXFFldtlf83soSFuvl8Q8ca/kWqor0izNkBO1 AeNw== 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 t74si407850pgc.150.2019.01.16.19.43.28; Wed, 16 Jan 2019 19:43:45 -0800 (PST) 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 S2392889AbfAPMxy (ORCPT + 99 others); Wed, 16 Jan 2019 07:53:54 -0500 Received: from foss.arm.com ([217.140.101.70]:47630 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390091AbfAPMxx (ORCPT ); Wed, 16 Jan 2019 07:53:53 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id D548780D; Wed, 16 Jan 2019 04:53:52 -0800 (PST) Received: from [10.162.42.129] (p8cg001049571a15.blr.arm.com [10.162.42.129]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id DD8B93F5AF; Wed, 16 Jan 2019 04:53:42 -0800 (PST) Subject: Re: [PATCH V2] mm: Introduce GFP_PGTABLE To: Mike Rapoport Cc: linux-mm@kvack.org, akpm@linux-foundation.org, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, linux-sh@vger.kernel.org, kvmarm@lists.cs.columbia.edu, linux-riscv@lists.infradead.org, linux@armlinux.org.uk, catalin.marinas@arm.com, will.deacon@arm.com, mpe@ellerman.id.au, tglx@linutronix.de, mingo@redhat.com, dave.hansen@linux.intel.com, peterz@infradead.org, christoffer.dall@arm.com, marc.zyngier@arm.com, kirill@shutemov.name, rppt@linux.vnet.ibm.com, mhocko@suse.com, ard.biesheuvel@linaro.org, mark.rutland@arm.com, steve.capper@arm.com, james.morse@arm.com, robin.murphy@arm.com, aneesh.kumar@linux.ibm.com, vbabka@suse.cz, shakeelb@google.com, rientjes@google.com, palmer@sifive.com, greentime@andestech.com References: <1547619692-7946-1-git-send-email-anshuman.khandual@arm.com> <20190116065521.GC6643@rapoport-lnx> From: Anshuman Khandual Message-ID: Date: Wed, 16 Jan 2019 18:23:42 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20190116065521.GC6643@rapoport-lnx> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/16/2019 12:25 PM, Mike Rapoport wrote: > On Wed, Jan 16, 2019 at 11:51:32AM +0530, Anshuman Khandual wrote: >> All architectures have been defining their own PGALLOC_GFP as (GFP_KERNEL | >> __GFP_ZERO) and using it for allocating page table pages. This causes some >> code duplication which can be easily avoided. GFP_KERNEL allocated and >> cleared out pages (__GFP_ZERO) are required for page tables on any given >> architecture. This creates a new generic GFP flag flag which can be used >> for any page table page allocation. Does not cause any functional change. >> >> GFP_PGTABLE is being added into include/asm-generic/pgtable.h which is the >> generic page tabe header just to prevent it's potential misuse as a general >> allocation flag if included in include/linux/gfp.h. >> >> Signed-off-by: Anshuman Khandual >> --- >> Build tested on arm, arm64, powerpc, powerpc64le and x86. >> Boot tested on arm64 and x86. >> >> Changes in V2: >> >> - Moved GFP_PGTABLE into include/asm-generic/pgtable.h >> - On X86 added __GFP_ACCOUNT into GFP_PGTABLE at various places >> - Replaced possible flags on riscv and nds32 with GFP_PGTABLE >> >> Original V1: https://lkml.org/lkml/2019/1/12/54 >> >> arch/arm/include/asm/pgalloc.h | 8 +++----- >> arch/arm/mm/mmu.c | 2 +- >> arch/arm64/include/asm/pgalloc.h | 9 ++++----- >> arch/arm64/mm/mmu.c | 2 +- >> arch/arm64/mm/pgd.c | 4 ++-- >> arch/nds32/include/asm/pgalloc.h | 3 +-- >> arch/powerpc/include/asm/book3s/64/pgalloc.h | 6 +++--- >> arch/powerpc/include/asm/pgalloc.h | 2 -- >> arch/powerpc/kvm/book3s_64_mmu_hv.c | 2 +- >> arch/powerpc/mm/pgtable-frag.c | 4 ++-- >> arch/riscv/include/asm/pgalloc.h | 8 +++----- >> arch/sh/mm/pgtable.c | 6 ++---- >> arch/unicore32/include/asm/pgalloc.h | 6 ++---- >> arch/x86/kernel/espfix_64.c | 6 ++---- >> arch/x86/mm/pgtable.c | 15 +++++++-------- >> include/asm-generic/pgtable.h | 2 ++ >> virt/kvm/arm/mmu.c | 2 +- >> 17 files changed, 37 insertions(+), 50 deletions(-) > I wonder, what about the other arches? Do they use different GFP flags? > Some of them as listed below use (GFP_KERNEL | __GFP_ZERO) which I will fix next time around. Some how was focused on removing PGALLOC_GFP that missed the other ones. arch/powerpc/include/asm/nohash/64/pgalloc.h arch/alpha/include/asm/pgalloc.h arch/alpha/mm/init.c arch/csky/include/asm/pgalloc.h arch/arc/include/asm/pgalloc.h ........ ........ But then there are those which use GFP_KERNEL alone without __GFP_ZERO like pmd_alloc_one() in arch/sparc/include/asm/pgalloc_64.h cannot be replaced with this patch as it does not intend to change functionality.