Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp699295ybx; Wed, 6 Nov 2019 07:09:21 -0800 (PST) X-Google-Smtp-Source: APXvYqztnqzpHS/TZDrjf2CzZlcotnfwQ0Ls0AbPgHyhroHJY94YhioVZpq3vVRvE5lxGzbMr/aY X-Received: by 2002:a17:906:1542:: with SMTP id c2mr34710773ejd.80.1573052961050; Wed, 06 Nov 2019 07:09:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573052961; cv=none; d=google.com; s=arc-20160816; b=h5mRoQC/ypHydzV1kskRnV8Ak0yF4WJsPFIKLnXH3Ak4RRd7js/9ijitxcqNz5bX49 nd1FEcUXLE9iFlz776bXY/zLErWUNIbgyiLiQ2FmWesvlOvk5KKt/FXNNqWarrlx6rd7 dDJn/D2f73vVLkBqckFy6D6REr8XECEyGbDDjvQwpn4eTi7uQqiEHiQqsp+OVNrlfQSF KMgI4VR9AGPK4MeKLV/BGuDZhkgwLz8baM9MQhUqD5lXtHq/+zxM8xoVrm9JkZLmt7q9 tghbwkPxelOKaogz5QlQxra5sBucq7o3GDqy0V0ulOxIKcicmUVKWbc/2AcxQgcCNDYs W/kA== 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:references:cc:to:subject:from; bh=Ua4mD+6UhXYDDXj5FwYVr+W32xVFAMLY44DGzvaRaeI=; b=eb3VIqOkbtS8+8jyZZbq/XZuKBux+bQjqrkyPZY9W0s1WyDhVH/EBQzrHAaAH3Yg3r DexEIRDk/9M115NgWrR95f0AcOii79oWICe798U+RafBWYytQJop8Y/drQs8MMmfzy87 CCF7to2Crsb+yrVnLKIoqogkINh+kAvpO1RXrTSfLLfKjtKmxUPJoBFMLua/kJs93/0B CywtwjFVdwVaxiR0vRROsd2nffS+VOfKrCs9lc6qJo1zJwRDVlBdV2t1xBdhUMUwOBpm +CTmXJo2/hVl0cmD/dP181emBQenh6zPwLNpc/+9RJ4lMe+T5C1zr0SODOfoFaVqgLvX 2dgw== 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 m16si17133964ejd.306.2019.11.06.07.08.53; Wed, 06 Nov 2019 07:09:21 -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 S1731944AbfKFPFw (ORCPT + 99 others); Wed, 6 Nov 2019 10:05:52 -0500 Received: from foss.arm.com ([217.140.110.172]:41486 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727361AbfKFPFw (ORCPT ); Wed, 6 Nov 2019 10:05:52 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id BD1D07CD; Wed, 6 Nov 2019 07:05:51 -0800 (PST) Received: from [10.1.32.101] (e122027.cambridge.arm.com [10.1.32.101]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id EEA113F71A; Wed, 6 Nov 2019 07:05:48 -0800 (PST) From: Steven Price Subject: Re: [PATCH v15 00/23] Generic page walk and ptdump To: Qian Cai , Andrew Morton , linux-mm@kvack.org Cc: Mark Rutland , x86@kernel.org, Arnd Bergmann , Ard Biesheuvel , Peter Zijlstra , Catalin Marinas , Dave Hansen , linux-kernel@vger.kernel.org, =?UTF-8?B?SsOpcsO0bWUgR2xpc3Nl?= , Ingo Molnar , Borislav Petkov , Andy Lutomirski , "H. Peter Anvin" , James Morse , Thomas Gleixner , Will Deacon , linux-arm-kernel@lists.infradead.org, "Liang, Kan" References: <20191101140942.51554-1-steven.price@arm.com> <1572896147.5937.116.camel@lca.pw> <7B040741-EC8A-4CC0-964B-4046AE2E617A@lca.pw> Message-ID: <16da6118-ac4d-a165-6202-0731a776ac72@arm.com> Date: Wed, 6 Nov 2019 15:05:29 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <7B040741-EC8A-4CC0-964B-4046AE2E617A@lca.pw> Content-Type: text/plain; charset=utf-8; format=flowed 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 06/11/2019 13:31, Qian Cai wrote: > > >> On Nov 4, 2019, at 2:35 PM, Qian Cai wrote: >> >> On Fri, 2019-11-01 at 14:09 +0000, Steven Price wrote: [...] >>> Changes since v14: >>> https://lore.kernel.org/lkml/20191028135910.33253-1-steven.price@arm.com/ >>> * Switch walk_page_range() into two functions, the existing >>> walk_page_range() now still requires VMAs (and treats areas without a >>> VMA as a 'hole'). The new walk_page_range_novma() ignores VMAs and >>> will report the actual page table layout. This fixes the previous >>> breakage of /proc//pagemap >>> * New patch at the end of the series which reduces the 'level' numbers >>> by 1 to simplify the code slightly >>> * Added tags >> >> Does this new version also take care of this boot crash seen with v14? Suppose >> it is now breaking CONFIG_EFI_PGT_DUMP=y? The full config is, >> >> https://raw.githubusercontent.com/cailca/linux-mm/master/x86.config >> > > V15 is indeed DOA here. Thanks for finding this, it looks like EFI causes issues here. The below fixes this for me (booting in QEMU). Andrew: do you want me to send out the entire series again for this fix, or can you squash this into mm-pagewalk-allow-walking-without-vma.patch? Thanks, Steve ---8<--- diff --git a/mm/pagewalk.c b/mm/pagewalk.c index c7529dc4f82b..70dcaa23598f 100644 --- a/mm/pagewalk.c +++ b/mm/pagewalk.c @@ -90,7 +90,7 @@ static int walk_pmd_range(pud_t *pud, unsigned long addr, unsigned long end, split_huge_pmd(walk->vma, pmd, addr); if (pmd_trans_unstable(pmd)) goto again; - } else if (pmd_leaf(*pmd)) { + } else if (pmd_leaf(*pmd) || !pmd_present(*pmd)) { continue; } @@ -141,7 +141,7 @@ static int walk_pud_range(p4d_t *p4d, unsigned long addr, unsigned long end, split_huge_pud(walk->vma, pud, addr); if (pud_none(*pud)) goto again; - } else if (pud_leaf(*pud)) { + } else if (pud_leaf(*pud) || !pud_present(*pud)) { continue; }