Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp288621rdb; Tue, 5 Dec 2023 05:41:15 -0800 (PST) X-Google-Smtp-Source: AGHT+IEsJQJI78eW/Hwo6AIv80pqFdNFU0h71et2pfujfl8kbNb5Jp1upUVnLcacZKipoPexhhbU X-Received: by 2002:a05:6a20:160a:b0:18f:97c:9778 with SMTP id l10-20020a056a20160a00b0018f097c9778mr7786117pzj.96.1701783674814; Tue, 05 Dec 2023 05:41:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701783674; cv=none; d=google.com; s=arc-20160816; b=d7M58L+b2TeG/e72q+ABdY46fWkmp8z1a+7+KscK60Xg1M8d+t9hpVESrb76SyX2Du WjgAvnXhPmIKttC3DnmOlWUiThlc+d+ZP0wx4vTfpJ33zZ1hdwF3IScKjoIR/Rm+FJqf 2sk5xf5GY5+PrZqj9eTqIhivhEu4pCAOj17b55RzUGUfQ15/vrUdlZ4FKQ9CWin3ft94 PPo5D8sqPwOyDqjWotJa3G/r+OG9/nvsGuQ1Cp1ODmKnW+TI6mIGewWQZ0sojhrnhB4i QU7DuVjbhthR5VsLVstneEmv49CRcfJbSBRXLs6jkNA3CS3xp1h1td2kDaWupCahUiEo CWOg== 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=dynIkdHN+Emasb5kQcs7SfUmgfOjTkWT0O52R12xz58=; fh=GlLzLBhqF07GE0FJUf82nnkBDPyXS9iIZ0BDzvPX32s=; b=fc13qjvV6MAmKo9tofa5b0cgqtp8YiH/hTCAZDvUOm6FbHcc0iT18crWhFDxtpzjbr I2dk0/BE6ll+ZQRRmO4SJ+eE3hNvlpX1uRCJ2gcjM2SY2XjqqhgNs+Q0qa1BR3xbxrBl mhA2zJ9JI/CU/1W1QXQU69/XRN1L35SXu+csK4SVGo16UHM03MRx9yjyxNm6ZNhFGaFu VmIHuvK3d9EnjFMoiyxAu1U1GkNwiFW6v5rNfAKWhqosVVHvyI8FMyJg1LFJSX5EGN0s GJ8qbo06Y5Vgxi34mbqHZL1OqVZjXicDTk6iZHz6u2jXuWNpH53CJfcqPSZI7IObcIDT Ftpw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 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 snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id y8-20020a1709027c8800b001bdd0d0530dsi9241194pll.129.2023.12.05.05.41.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 05 Dec 2023 05:41:14 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 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 snail.vger.email (Postfix) with ESMTP id C842680781DA; Tue, 5 Dec 2023 05:40:33 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345517AbjLENkV (ORCPT + 99 others); Tue, 5 Dec 2023 08:40:21 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44448 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345471AbjLENkT (ORCPT ); Tue, 5 Dec 2023 08:40:19 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id E0D1C19B for ; Tue, 5 Dec 2023 05:40:23 -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 2DCD42F4; Tue, 5 Dec 2023 05:41:10 -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 2DBA93F5A1; Tue, 5 Dec 2023 05:40:22 -0800 (PST) Message-ID: <181a1623-9285-415e-9ec6-6b6548ca7487@arm.com> Date: Tue, 5 Dec 2023 13:40:20 +0000 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH RFC 34/39] mm/rmap: introduce folio_try_dup_anon_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-35-david@redhat.com> <88a341bf-0b6a-454a-aeb1-0699233eb37c@redhat.com> From: Ryan Roberts In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Tue, 05 Dec 2023 05:40:33 -0800 (PST) On 05/12/2023 13:18, David Hildenbrand wrote: > On 05.12.23 14:17, David Hildenbrand wrote: >> On 05.12.23 14:12, Ryan Roberts wrote: >>> On 04/12/2023 14:21, David Hildenbrand wrote: >>>> The last user of page_needs_cow_for_dma() and __page_dup_rmap() are gone, >>>> remove them. >>>> >>>> Add folio_try_dup_anon_rmap_ptes() right away, we want to perform rmap >>>> baching during fork() soon. >>>> >>>> Signed-off-by: David Hildenbrand >>>> --- >>>>    include/linux/mm.h   |   6 -- >>>>    include/linux/rmap.h | 145 +++++++++++++++++++++++++++++-------------- >>>>    2 files changed, 100 insertions(+), 51 deletions(-) >>>> >>>> diff --git a/include/linux/mm.h b/include/linux/mm.h >>>> index 24c1c7c5a99c0..f7565b35ae931 100644 >>>> --- a/include/linux/mm.h >>>> +++ b/include/linux/mm.h >>>> @@ -1964,12 +1964,6 @@ static inline bool folio_needs_cow_for_dma(struct >>>> vm_area_struct *vma, >>>>        return folio_maybe_dma_pinned(folio); >>>>    } >>>>    -static inline bool page_needs_cow_for_dma(struct vm_area_struct *vma, >>>> -                      struct page *page) >>>> -{ >>>> -    return folio_needs_cow_for_dma(vma, page_folio(page)); >>>> -} >>>> - >>>>    /** >>>>     * is_zero_page - Query if a page is a zero page >>>>     * @page: The page to query >>>> diff --git a/include/linux/rmap.h b/include/linux/rmap.h >>>> index 21d72cc602adc..84439f7720c62 100644 >>>> --- a/include/linux/rmap.h >>>> +++ b/include/linux/rmap.h >>>> @@ -354,68 +354,123 @@ static inline void folio_dup_file_rmap_pmd(struct >>>> folio *folio, >>>>    #endif >>>>    } >>>>    -static inline void __page_dup_rmap(struct page *page, bool compound) >>>> +static inline int __folio_try_dup_anon_rmap(struct folio *folio, >>> >>> __always_inline? >> >> Yes. > > Ah, no, I did this for a reason. This function lives in a header, so it will > always be inlined. > Really? It will certainly be duplicated across every compilation unit, but that's separate from being inlined - if the optimizer is off, won't it just end up as an out-of-line function in every compilation unit?