Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp286657rdb; Tue, 5 Dec 2023 05:37:46 -0800 (PST) X-Google-Smtp-Source: AGHT+IEndmg0PQ79YyPlfJVSfj9K849M6dhH18BEQEHGKeG8xDZzwrNDFy+rFFFM5AGtsZKxXJel X-Received: by 2002:a05:6e02:219c:b0:35d:6242:ee04 with SMTP id j28-20020a056e02219c00b0035d6242ee04mr3824856ila.91.1701783465438; Tue, 05 Dec 2023 05:37:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701783465; cv=none; d=google.com; s=arc-20160816; b=O5qHEVHboqkZ8ex9dnp0HEHy8BHIrGBX2Tw+eGFHA5zoY9m8W82nyuixa1OmlbHK6v 7BFeApqn9JfiUqVXAE/QeSGGcGsaY78WRildIJ/mdTheq3nZBdlNLQYd6TWfP1fqJbgL VzeRp3LnpfId3Sw7z/tSCBbwiPwjvEGHppf+s5BoECC+sssfyL7OQb6FHT4F6sp3R7pc iE9eefN8VMNTLhNSaWbD1P6rnm0Tf7bmxYapkQZrnob6Zux41fjSG6YkQwatMXcQJi7u B/LVS/X2sv9pHsZiOi4sWWbYk1q2paUtA6LF0QzpNx336sUmZ5QX31BXxV+F/sK2LAK2 0gSg== 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:content-language:subject:user-agent:mime-version :date:message-id; bh=iOxbSXuDkpV+5m06Kd035rSHpv9DDMwq+YaO4ofXapQ=; fh=GlLzLBhqF07GE0FJUf82nnkBDPyXS9iIZ0BDzvPX32s=; b=ceG3SD/tgG7Xw/tVNlRBs4YWZ19aLyfelSaqOKXOW+Y5MvBNSI3utYRLVrqrUC6vaq E0rBGpxvl+8c6IHCO9VqkW8F24b7JzSYjX5daX8oeSZpHxOBpEA6e/Jox5TkkZSlcI/A U5ZBKUS1VihYwZmxy8LzhN8l1KOIcWpcSdPdMsEPUUbNBZv7TJ26vFm/Wf18TWBQbgFV GOCUY+xIhPBTD3mbiKuAP4SIcSr32d6Z3c8briAIKDW3neEwMpjKTpYut1IylcYMRXcQ G5O0GVVIRANNkeYAvNAtx4c7BEa7ctW88tfQDiT7PuulN+ErZTlhUYTjQXnpeOoqFoc/ 8yUw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 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 morse.vger.email (morse.vger.email. [23.128.96.31]) by mx.google.com with ESMTPS id s20-20020a634514000000b005b8f298110csi9631414pga.6.2023.12.05.05.37.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 05 Dec 2023 05:37:45 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) client-ip=23.128.96.31; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 0FC0881112CA; Tue, 5 Dec 2023 05:37:43 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345471AbjLENha (ORCPT + 99 others); Tue, 5 Dec 2023 08:37:30 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35514 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345466AbjLENh3 (ORCPT ); Tue, 5 Dec 2023 08:37:29 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 67778A8 for ; Tue, 5 Dec 2023 05:37:35 -0800 (PST) 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 AB4FC139F; Tue, 5 Dec 2023 05:38:21 -0800 (PST) Received: from [10.57.73.130] (unknown [10.57.73.130]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 7BD353F5A1; Tue, 5 Dec 2023 05:37:33 -0800 (PST) Message-ID: <17d64bc7-3a84-4562-821c-439950e1da91@arm.com> Date: Tue, 5 Dec 2023 13:37:31 +0000 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH RFC 23/39] mm/rmap: introduce folio_remove_rmap_[pte|ptes|pmd]() Content-Language: en-GB To: David Hildenbrand , linux-kernel@vger.kernel.org Cc: linux-mm@kvack.org, Andrew Morton , "Matthew Wilcox (Oracle)" , Hugh Dickins , Yin Fengwei , Mike Kravetz , Muchun Song , Peter Xu References: <20231204142146.91437-1-david@redhat.com> <20231204142146.91437-24-david@redhat.com> <58be47c1-c34e-46a2-a32b-a993f7dee664@redhat.com> From: Ryan Roberts In-Reply-To: <58be47c1-c34e-46a2-a32b-a993f7dee664@redhat.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Tue, 05 Dec 2023 05:37:43 -0800 (PST) On 05/12/2023 13:09, David Hildenbrand wrote: >>> +static __always_inline void __folio_remove_rmap(struct folio *folio, >>> +        struct page *page, unsigned int nr_pages, >>> +        struct vm_area_struct *vma, enum rmap_mode mode) >>> +{ >>>       atomic_t *mapped = &folio->_nr_pages_mapped; >>> -    int nr = 0, nr_pmdmapped = 0; >>> -    bool last; >>> +    int last, nr = 0, nr_pmdmapped = 0; >> >> nit: you're being inconsistent across the functions with signed vs unsigned for >> page counts (e.g. nr, nr_pmdmapped) - see __folio_add_rmap(), >> __folio_add_file_rmap(), __folio_add_anon_rmap(). >> > > Definitely. > >> I suggest pick one and stick to it. Personally I'd go with signed int (since >> that's what all the counters in struct folio that we are manipulating are, >> underneath the atomic_t) then check that nr_pages > 0 in >> __folio_rmap_sanity_checks(). > > Can do, but note that the counters are signed to detect udnerflows. It doesn't > make sense here to pass a negative number. I agree it doesn't make sense to pass negative - hence the check. These 2 functions are inconsistent on size, but agree on signed: long folio_nr_pages(struct folio *folio) int folio_nr_pages_mapped(struct folio *folio) I don't have a strong opinon. > >> >>>       enum node_stat_item idx; >>>   -    VM_WARN_ON_FOLIO(folio_test_hugetlb(folio), folio); >>> -    VM_BUG_ON_PAGE(compound && !PageHead(page), page); >>> +    __folio_rmap_sanity_checks(folio, page, nr_pages, mode); >>>         /* Is page being unmapped by PTE? Is this its last map to be removed? */ >>> -    if (likely(!compound)) { >>> -        last = atomic_add_negative(-1, &page->_mapcount); >>> -        nr = last; >>> -        if (last && folio_test_large(folio)) { >>> -            nr = atomic_dec_return_relaxed(mapped); >>> -            nr = (nr < COMPOUND_MAPPED); >>> -        } >>> -    } else if (folio_test_pmd_mappable(folio)) { >>> -        /* That test is redundant: it's for safety or to optimize out */ >>> +    if (likely(mode == RMAP_MODE_PTE)) { >>> +        do { >>> +            last = atomic_add_negative(-1, &page->_mapcount); >>> +            if (last && folio_test_large(folio)) { >>> +                last = atomic_dec_return_relaxed(mapped); >>> +                last = (last < COMPOUND_MAPPED); >>> +            } >>>   +            if (last) >>> +                nr++; >>> +        } while (page++, --nr_pages > 0); >>> +    } else if (mode == RMAP_MODE_PMD) { >>>           last = atomic_add_negative(-1, &folio->_entire_mapcount); >>>           if (last) { >>>               nr = atomic_sub_return_relaxed(COMPOUND_MAPPED, mapped); >>> @@ -1517,7 +1528,7 @@ void page_remove_rmap(struct page *page, struct >>> vm_area_struct *vma, >>>            * is still mapped. >>>            */ >>>           if (folio_test_pmd_mappable(folio) && folio_test_anon(folio)) >> >> folio_test_pmd_mappable() -> folio_test_large() >> >> Since you're converting this to support batch PTE removal, it might as well also >> support smaller-than-pmd too? > > I remember that you have a patch for that, right? :) > >> >> I currently have a patch to do this same change in the multi-size THP series. >> > > Ah, yes, and that should go in first. > >