Received: by 2002:a05:6358:7058:b0:131:369:b2a3 with SMTP id 24csp6611885rwp; Tue, 18 Jul 2023 03:16:07 -0700 (PDT) X-Google-Smtp-Source: APBJJlFec0JpWwtL6mTPoZbC2S0OTQ4dWVenh8YuwzDtwUi3Kml30UJZAk9+K6kbv4UxY5tMh75e X-Received: by 2002:aa7:c454:0:b0:51e:ceb:7d71 with SMTP id n20-20020aa7c454000000b0051e0ceb7d71mr11135524edr.39.1689675366954; Tue, 18 Jul 2023 03:16:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689675366; cv=none; d=google.com; s=arc-20160816; b=Ib3mAq4Mn9uSLagxR3xjmhVWiHJZ4EL7CCbMORm17e+hfeD20t4FhYBLEK6QgmUQvF epiRYdNG27lQ8fxlZoPMv7HTZ88FU/ZrhY+wD7GX8eZ/uEMPk4xPORFcwudbb3bXlBW7 0XbHYadMo73K566tuR+ePYLESOB5IUePOFwUwP/5uj0G9XNrppGX6jrboRfHwx6e5o6C 9dl6VQSry6prUXgEpLOu+WZfZEg+cjMjoaOL0H8enq9v+HK62dxe0UjkdH6nezuzrJgw 5thpnSFSHHsIG++gToX7PLcF5kYUu4iIuNPPR67hnp34jII5rBKcge7W58t84VnNqEze v8Lw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:subject:user-agent:mime-version:date:message-id; bh=cNZ3XrLafaVH+oeoOcmCL7d+TDkTJJ+59ns+VGV9YcY=; fh=KrBIZ8r2HjujMo8mNFCECHVo7ipThad731CI2NVAsf8=; b=n63+AJVWD+ADXUCWKh/zmbbACTVY6Bl7znjgzwO2O3fFkO8itq0jgiYelBM8wm/A5g 0XXy0S2wYqosmeYCfoTlk8iDsZ9W8gxPE4Sehm9MAmojKsyLPw10+MsjY7njaVwAoORf XgoD9lb04OkEf54vTp5hXbaxrzv+fuvX7Oe8EzVYGn8P43Sn3Zto14nvgQMjeIHUBaKG vXRUaraxqcxnrRBMwGbzqc4pCi9W0LOGn4CsPZ9fY0rBS0j+7MRIp+KNkg/Et7//8hVV d17i7omPW1qCciEoyDZ3xPXyEyfuHqO6RAlBoP7ck4tLhAtnD7cjqEE/X/bp1mh+vJWe bqsg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i5-20020a05640200c500b0051e52c20926si1010496edu.275.2023.07.18.03.15.29; Tue, 18 Jul 2023 03:16:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S231562AbjGRJeE (ORCPT + 99 others); Tue, 18 Jul 2023 05:34:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39364 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230479AbjGRJeD (ORCPT ); Tue, 18 Jul 2023 05:34:03 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id ED51DE60 for ; Tue, 18 Jul 2023 02:34:01 -0700 (PDT) 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 26E332F4; Tue, 18 Jul 2023 02:34:45 -0700 (PDT) Received: from [10.1.34.52] (C02Z41KALVDN.cambridge.arm.com [10.1.34.52]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 4533C3F67D; Tue, 18 Jul 2023 02:34:00 -0700 (PDT) Message-ID: <225cbb00-9759-3547-8073-3b08b458c73e@arm.com> Date: Tue, 18 Jul 2023 10:33:58 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH v1 1/3] mm: Allow deferred splitting of arbitrary large anon folios To: David Hildenbrand , Andrew Morton , Matthew Wilcox , Yin Fengwei , Yu Zhao , Yang Shi , "Huang, Ying" , Zi Yan Cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org References: <20230717143110.260162-1-ryan.roberts@arm.com> <20230717143110.260162-2-ryan.roberts@arm.com> <90b406af-9db4-b668-a7a0-e574e104c84c@redhat.com> <028c5f5b-b67c-9ccc-bc06-468f47362999@arm.com> <0250a2d7-c79b-0e0f-8161-bf475daf1c82@redhat.com> <7319a1aa-7c72-82e9-f26d-eeccb6fdf35b@arm.com> <7b0e691d-b224-20d0-a90a-bb659fbb3e1a@redhat.com> From: Ryan Roberts In-Reply-To: <7b0e691d-b224-20d0-a90a-bb659fbb3e1a@redhat.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 18/07/2023 10:08, David Hildenbrand wrote: > On 18.07.23 10:58, Ryan Roberts wrote: >> On 17/07/2023 17:48, David Hildenbrand wrote: >>> On 17.07.23 18:01, Ryan Roberts wrote: >>>> On 17/07/2023 16:42, David Hildenbrand wrote: >>>>> On 17.07.23 16:31, Ryan Roberts wrote: >>>>>> In preparation for the introduction of large folios for anonymous >>>>>> memory, we would like to be able to split them when they have unmapped >>>>>> subpages, in order to free those unused pages under memory pressure. So >>>>>> remove the artificial requirement that the large folio needed to be at >>>>>> least PMD-sized. >>>>>> >>>>>> Signed-off-by: Ryan Roberts >>>>>> Reviewed-by: Yu Zhao >>>>>> Reviewed-by: Yin Fengwei >>>>>> --- >>>>>>     mm/rmap.c | 2 +- >>>>>>     1 file changed, 1 insertion(+), 1 deletion(-) >>>>>> >>>>>> diff --git a/mm/rmap.c b/mm/rmap.c >>>>>> index 0c0d8857dfce..2baf57d65c23 100644 >>>>>> --- a/mm/rmap.c >>>>>> +++ b/mm/rmap.c >>>>>> @@ -1430,7 +1430,7 @@ void page_remove_rmap(struct page *page, struct >>>>>> vm_area_struct *vma, >>>>>>              * page of the folio is unmapped and at least one page >>>>>>              * is still mapped. >>>>>>              */ >>>>>> -        if (folio_test_pmd_mappable(folio) && folio_test_anon(folio)) >>>>>> +        if (folio_test_large(folio) && folio_test_anon(folio)) >>>>>>                 if (!compound || nr < nr_pmdmapped) >>>>>>                     deferred_split_folio(folio); >>>>> >>>>> !compound will always be true I guess, so nr_pmdmapped == 0 (which will always >>>>> be the case) will be ignored. >>>> >>>> I don't follow why !compound will always be true. This function is >>>> page_remove_rmap() (not folio_remove_rmap_range() which I add in a later >>>> patch). >>>> page_remove_rmap() can work on pmd-mapped pages where compound=true is >>>> passed in. >>> >>> I was talking about the folio_test_pmd_mappable() -> folio_test_large() change. >>> For folio_test_large() && !folio_test_pmd_mappable() I expect that we'll never >>> pass in "compound=true". >>> >> >> Sorry David, I've been staring at the code and your comment, and I still don't >> understand your point. I assumed you were trying to say that compound is always >> false and therefore "if (!compound || nr < nr_pmdmapped)" can be removed? But >> its not the case that compound is always false; it will be true when called to >> remove a pmd-mapped compound page. > > Let me try again: > > Assume, as I wrote, that we are given a folio that is "folio_test_large() && > !folio_test_pmd_mappable()". That is, a folio that is *not* pmd mappable. > > If it's not pmd-mappable, certainly, nr_pmdmapped == 0, and therefore, "nr < > nr_pmdmapped" will never ever trigger. > > The only way to have it added to the deferred split queue is, therefore "if > (!compound)". > > So *for these folios*, we will always pass "compound == false" to make that "if > (!compound)" succeed. > > > Does that make sense? Yes I agree with all of this. I thought you were pointing out an issue or proposing a change to the logic. Hence my confusion. > >> What change are you suggesting, exactly? > > Oh, I never suggested a change (I even gave you my RB). I was just thinking out > loud. >