Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp1340586pxy; Sun, 1 Aug 2021 21:56:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw0LEIMzSEGq988gQjl7Njri+mZWvOW0vve+beN7ZHXnyjHnB0atPjQ5ax+PwajkQ/wU7wu X-Received: by 2002:a17:906:2d51:: with SMTP id e17mr13670789eji.500.1627880176953; Sun, 01 Aug 2021 21:56:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627880176; cv=none; d=google.com; s=arc-20160816; b=kJiYq1G8ZNRAcZfZr9KGjl6i/sMi6r+Iq0/iuD86/82PAA9VKCM+6eGmGAI48nm6Kc ZGO8wYMeSAlDFlvsvasB1II32Na9MJlbQFVMr19/gAgtP0+Tv5hN07ng49uu1iuVRhXF 2IOTil9xAVVXHFvenapI+LPa5iLJyLPnPiercagOhg1KSbUkboW0DcYQLHe5TphOMJx0 s12NDfUSKxWdVy9QYU8KalPH9nuKPSgxqFpP0G1/o4gdVy3LRJPnPfrfA1NuDdX63whT yD1SIU/NQv1lUzch704QFkTZmePf108qudmcsxOtjTb993fd1iXuGTX4zRXGh8nvLA6/ xImA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=4q2q7n64xO96owvxAIn9yanYNWPf/MCI9p//iVxSe8A=; b=hxXae+eIBZiQ8B38/vTkvjffyF5ZlFyhcxcf0eyFiKdzGP2j7tH6Izp+P5qaHhRlCG s66H06Gw8oHsvrAu7tyZjxGXENVkPWVn8QPLDEvSqlF2A/Mjxb9hGjL4FL65tfe7LFh+ awROyq34/dqEmYxh/7O3csfWgFDFRz397VtT/b0L/hGmdibY2rbWhe68AWwJBDQXkZ0h DkMG/va+JUaWnrRU/g5wXwmYk8ymTsOH0iPzSQKWZXiIfVeqSYdwtZx8gEA5A0rozvLR j4t7cbVKSlB9dQSGnR7WtNVaB07ohFEBunCHOF4CEdCGM4u05uky3LbvM+Q0B3jOwC1w tjqw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d12si11147958ejj.130.2021.08.01.21.55.46; Sun, 01 Aug 2021 21:56:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229500AbhHBEwu (ORCPT + 99 others); Mon, 2 Aug 2021 00:52:50 -0400 Received: from foss.arm.com ([217.140.110.172]:58620 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229457AbhHBEwt (ORCPT ); Mon, 2 Aug 2021 00:52:49 -0400 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 5DED9106F; Sun, 1 Aug 2021 21:52:40 -0700 (PDT) Received: from [10.163.66.153] (unknown [10.163.66.153]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id C9B563F719; Sun, 1 Aug 2021 21:52:36 -0700 (PDT) Subject: Re: [PATCH v4 00/12] mm/debug_vm_pgtable: Enhancements To: Gavin Shan , linux-mm@kvack.org Cc: linux-kernel@vger.kernel.org, gerald.schaefer@linux.ibm.com, aneesh.kumar@linux.ibm.com, christophe.leroy@csgroup.eu, cai@lca.pw, catalin.marinas@arm.com, will@kernel.org, akpm@linux-foundation.org, chuhu@redhat.com, shan.gavin@gmail.com, Vineet Gupta References: <20210727061401.592616-1-gshan@redhat.com> <8b969a2a-a883-3ce2-fac4-70ac2e3fd157@arm.com> <05736d94-3bd1-3193-69b1-3c71aa22d0a7@redhat.com> From: Anshuman Khandual Message-ID: <5ef150b0-60dc-3cf6-da6e-34fe0734ee2e@arm.com> Date: Mon, 2 Aug 2021 10:23:27 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <05736d94-3bd1-3193-69b1-3c71aa22d0a7@redhat.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/2/21 5:39 AM, Gavin Shan wrote: > Hi Anshuman, > > On 7/29/21 5:14 PM, Anshuman Khandual wrote: >> On 7/27/21 11:43 AM, Gavin Shan wrote: >>> There are couple of issues with current implementations and this series >>> tries to resolve the issues: >>> >>>    (a) All needed information are scattered in variables, passed to various >>>        test functions. The code is organized in pretty much relaxed fashion. >>> >>>    (b) The page isn't allocated from buddy during page table entry modifying >>>        tests. The page can be invalid, conflicting to the implementations >>>        of set_xxx_at() on ARM64. The target page is accessed so that the iCache >>>        can be flushed when execution permission is given on ARM64. Besides, >>>        the target page can be unmapped and access to it causes kernel crash. >>> >>> "struct pgtable_debug_args" is introduced to address issue (a). For issue >>> (b), the used page is allocated from buddy in page table entry modifying >>> tests. The corresponding tets will be skipped if we fail to allocate the >>> (huge) page. For other test cases, the original page around to kernel >>> symbol (@start_kernel) is still used. >>> >>> The patches are organized as below. PATCH[2-10] could be combined to one >>> patch, but it will make the review harder: >>> >>>    PATCH[1] introduces "struct pgtable_debug_args" as place holder of all >>>             needed information. With it, the old and new implementation >>>             can coexist. >>>    PATCH[2-10] uses "struct pgtable_debug_args" in various test functions. >>>    PATCH[11] removes the unused code for old implementation. >>>    PATCH[12] fixes the issue of corrupted page flag for ARM64 >>> >>> Changelog >>> ========= >>> v4: >>>     * Determine the page allocation method according to >>>       MAX_ORDER                                                   (Anshuman) >>>     * Move existing comments to init_args()                       (Anshuman) >>>     * Code refactoring as suggested by Anshuman                   (Anshuman) >>>     * Improved commit log and add comments for flush_dcache_page() >>>       in PATCH[v4 12/12]                                          (Anshuman) >>>     * Address misc comments                                       (Anshuman >> >> This series builds ok on all supported platforms but should also be tested >> on them as well i.e s390, ppc, arc and riscv. I was able to do some tests >> on arm64 and x86 platforms. >> > > I had tests on the platforms except arc as it's not supported by QEMU yet. > The test is pretty simple to boot the kernel and see if there is any warning > raised from mm/debug_vm_pgtable. Everything looks good. Sure, that should be enough. > > The test was done on v5, which will be posted pretty soon. Thanks again for > your continuous review. Please also do copy Vineet Gupta for ARC in the next version. - Anshuman