Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp2385789imb; Mon, 4 Mar 2019 03:58:09 -0800 (PST) X-Google-Smtp-Source: AHgI3IZEcfAwX7pRUEqzLIkykjkNiU0FlkHYtOnneuQvn/zD51k8hHK1sWZJrqqTbOOQstETcRNb X-Received: by 2002:a62:1706:: with SMTP id 6mr19316915pfx.28.1551700689922; Mon, 04 Mar 2019 03:58:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551700689; cv=none; d=google.com; s=arc-20160816; b=S+4Y8csb8EDF/6IZGo42ff6LEA8gCLUgDUIbK8Y7JQezVlQeueJbx9YyWmFvKXbvSy O5cAf1PC81jPQxuICrtWFv6lsw9fGe0g/qd91/fMUYqMG4TCAcfbqw52ytKWTS/ONE2G yPbs7RWm5zSqXQ4l4FmTsF1bZSMoFMC/ThSpvPOrtHdKa1wdi/x8D3mHNxQ/QNlT3tCc e7SuRAzQa54WJ+L2M2N3biacw9BarHeq6YiM8hU30yWAR+mPylYSekoFbLAuHXDK3oFa tGBU/ZY3mWhYXQyuM+AJGcgv9fnQnK1lJBWMgPgNwQjxvBftXuHRdZB2VsjZRUUG9dS5 pCGA== 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=V4MHQpXWPAcCZV7QaLKDIEt71UAdXIwx9TuioGwDtoc=; b=Kp6qJS1U1LpiUfZM8+CipDbzsCzo4NcBk4MC5qHemY+AgbWbXjx42jjcBuyIRw1Ulo +6fdaJtiNlxAfN5bVGWbDOgS9sEWzW7CfyW8x+n/NbbB79Ls4gZLdqolOYlUgmLcna80 tNnsy10wYxXZYKngRupVv3g+G3vmDug/1uCeLmCp9QVfQVbRIZc7V5KUT2rKDgZUEZ7h oItZELLW0CU7V2ILL8Pc/IWQSK/CdWRnxtk36/rh+tVu32/fGAzbfG6eIiZbHrcIciXn Z/rankdKtNEYIZtr/MXeyvGn3UA5gEg65R4iKSWsLTe/riBXTX9aq8fAQt78py4grIKg 6Uzw== 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 cm8si5682345plb.47.2019.03.04.03.57.54; Mon, 04 Mar 2019 03:58:09 -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 S1726076AbfCDL4T (ORCPT + 99 others); Mon, 4 Mar 2019 06:56:19 -0500 Received: from foss.arm.com ([217.140.101.70]:60698 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725974AbfCDL4T (ORCPT ); Mon, 4 Mar 2019 06:56:19 -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 DE573A78; Mon, 4 Mar 2019 03:56:18 -0800 (PST) Received: from [10.1.196.69] (e112269-lin.cambridge.arm.com [10.1.196.69]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 9426E3F703; Mon, 4 Mar 2019 03:56:15 -0800 (PST) Subject: Re: [PATCH v3 03/34] arm: mm: Add p?d_large() definitions To: "Kirill A. Shutemov" Cc: Mark Rutland , x86@kernel.org, Arnd Bergmann , Ard Biesheuvel , Peter Zijlstra , Catalin Marinas , Dave Hansen , Will Deacon , linux-kernel@vger.kernel.org, Russell King , linux-mm@kvack.org, =?UTF-8?B?SsOpcsO0bWUgR2xpc3Nl?= , Ingo Molnar , Borislav Petkov , Andy Lutomirski , "H. Peter Anvin" , James Morse , Thomas Gleixner , linux-arm-kernel@lists.infradead.org, "Liang, Kan" References: <20190227170608.27963-1-steven.price@arm.com> <20190227170608.27963-4-steven.price@arm.com> <20190301214715.hyzy5tevvwgki4w5@kshutemo-mobl1> From: Steven Price Message-ID: <974310a0-0114-9a0c-9041-4e0394c4b9aa@arm.com> Date: Mon, 4 Mar 2019 11:56:13 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.5.0 MIME-Version: 1.0 In-Reply-To: <20190301214715.hyzy5tevvwgki4w5@kshutemo-mobl1> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB 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/03/2019 21:47, Kirill A. Shutemov wrote: > On Wed, Feb 27, 2019 at 05:05:37PM +0000, Steven Price wrote: >> walk_page_range() is going to be allowed to walk page tables other than >> those of user space. For this it needs to know when it has reached a >> 'leaf' entry in the page tables. This information will be provided by the >> p?d_large() functions/macros. >> >> For arm, we already provide most p?d_large() macros. Add a stub for PUD >> as we don't have huge pages at that level. > > We do not have PUD for 2- and 3-level paging. Macros from generic header > should cover it, shouldn't it? > I'm not sure of the reasoning behind this, but levels are folded in a slightly strange way. arm/include/asm/pgtable.h defines __ARCH_USE_5LEVEL_HACK which means: PGD has 2048 (2-level) or 4 (3-level) entries which are always considered 'present' (pgd_present() returns 1 defined in asm-generic/pgtables-nop4d-hack.h). P4D has 1 entry which is always present (see asm-generic/5level-fixup.h) PUD has 1 entry (see asm-generic/pgtable-nop4d-hack.h). This is always present for 2-level, and present only if the first level of real page table is present with a 3-level. PMD/PTE are as you might expect. So in terms of tables which are more than one entry you have PGD, (optionally) PMD, PTE. But the levels which actually read the table entries are PUD, PMD, PTE. This means that the corresponding p?d_large() macros are needed for PUD/PMD as that is where the actual entries are read. The asm-generic files provide the definitions for PGD/P4D. Steve