From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 2E538C83F1B for ; Mon, 14 Jul 2025 13:17:33 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id B99886B009B; Mon, 14 Jul 2025 09:17:27 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id B4A176B009C; Mon, 14 Jul 2025 09:17:27 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 9ECD96B009D; Mon, 14 Jul 2025 09:17:27 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 834D46B009B for ; Mon, 14 Jul 2025 09:17:27 -0400 (EDT) Received: from smtpin05.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay02.hostedemail.com (Postfix) with ESMTP id 4913E12AD97 for ; Mon, 14 Jul 2025 13:17:27 +0000 (UTC) X-FDA: 83662921734.05.FC17B64 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by imf10.hostedemail.com (Postfix) with ESMTP id 81722C0003 for ; Mon, 14 Jul 2025 13:17:25 +0000 (UTC) Authentication-Results: imf10.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=IIb9pEla; dmarc=pass (policy=quarantine) header.from=redhat.com; spf=pass (imf10.hostedemail.com: domain of bfoster@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=bfoster@redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1752499045; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=IQLoIIUl1KOqZesupQQ4c+B4UPtB3wlhSz47MOveC10=; b=wiB9lP8fAMwd2g6ts2/eZfFSKF5zL2QROGAM47YINOj8OUKeqrcyJGrboZgYNyuQnc+Grr t+BNThwNqYKDHcuTmVSX7tfaKPcWY7Ib79Uz0vJ+fGj5EwIEOAuyW1nOxnTCFcp+wpCxba sWJFNMJLTd+TqDVE6B/XOsDkTyrSvw4= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1752499045; a=rsa-sha256; cv=none; b=F9fG6N4B2i2P6XBWf/6C6kcv4YSvupO8FXZXuD8LuUiCR/VTuoAZDKbYvfzb4DFI4H9hoA 0iohzR+tII34eye+ZxrDdkHTxpq5uVwn5arcN9o/eDhVmHbvWVOhW1At0Kzsq0ZpUfcB+j U1OfOfUsHU5BHiS80CstWHeraZxvvmM= ARC-Authentication-Results: i=1; imf10.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=IIb9pEla; dmarc=pass (policy=quarantine) header.from=redhat.com; spf=pass (imf10.hostedemail.com: domain of bfoster@redhat.com designates 170.10.133.124 as permitted sender) smtp.mailfrom=bfoster@redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1752499044; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=IQLoIIUl1KOqZesupQQ4c+B4UPtB3wlhSz47MOveC10=; b=IIb9pEla1610tZDsFv7bu4ZI0TFl37ZOZ6SWz5X2iyYAX0hy2pEfRbN5H8hJh0mAVDClvu XOVvbhdTv2GRGC/dYldN2HRrX5iCFgbYGhEcXgAKYlrd9TP0+w4Ccm/1v5Ts5TxKjItP1I N9AHGTaW4GcR3YduhDcIxF3KlJuhr5U= Received: from mx-prod-mc-06.mail-002.prod.us-west-2.aws.redhat.com (ec2-35-165-154-97.us-west-2.compute.amazonaws.com [35.165.154.97]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-564-8jJVicwzOe6HzqPwbq4aBA-1; Mon, 14 Jul 2025 09:17:20 -0400 X-MC-Unique: 8jJVicwzOe6HzqPwbq4aBA-1 X-Mimecast-MFC-AGG-ID: 8jJVicwzOe6HzqPwbq4aBA_1752499039 Received: from mx-prod-int-06.mail-002.prod.us-west-2.aws.redhat.com (mx-prod-int-06.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.93]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mx-prod-mc-06.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id 4181B1801215; Mon, 14 Jul 2025 13:17:19 +0000 (UTC) Received: from bfoster.redhat.com (unknown [10.22.64.43]) by mx-prod-int-06.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTP id 082451800285; Mon, 14 Jul 2025 13:17:17 +0000 (UTC) From: Brian Foster To: linux-fsdevel@vger.kernel.org Cc: linux-xfs@vger.kernel.org, linux-mm@kvack.org, hch@infradead.org, djwong@kernel.org, willy@infradead.org Subject: [PATCH v2 1/7] filemap: add helper to look up dirty folios in a range Date: Mon, 14 Jul 2025 09:20:53 -0400 Message-ID: <20250714132059.288129-2-bfoster@redhat.com> In-Reply-To: <20250714132059.288129-1-bfoster@redhat.com> References: <20250714132059.288129-1-bfoster@redhat.com> MIME-Version: 1.0 Content-Type: text/plain Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.4.1 on 10.30.177.93 X-Rspamd-Queue-Id: 81722C0003 X-Stat-Signature: 9rmha94z8r3imdb65pcc573ztt6jgyfn X-Rspam-User: X-Rspamd-Server: rspam11 X-HE-Tag: 1752499045-670543 X-HE-Meta: U2FsdGVkX18JH4aXM/LrRvu7+9b+HGzdtsm6ixFcdrCOvGYErUjeA9YdgLQUk73xzXhbfTTi1EMm3lUmhRwnlhT72ZIKXnqkKHtNo+dLM6ZqG59umkCCL5cXPjmJeu2NAcxA9JqWjvxpBqfRPSqCX8IEzASBgPH6r7chHs3VuW/1UcAqOQZnVqSHqLCfWLmsKSVcjgJzw2sO7v0cSrzeGkJL/rbezozuHDdvTFyOakxvnZODimngTRxe3Zso6V74Mgd7P4mXR/VJpzGB/8HLhY2m5cGXZ84TVobKufscU8snZFs7nal0q+VKBvPFbjpVZSBGrmU7SXyuO1ANcErX9OTh9V1ChmlIyXlUO2kZp9RauoSUeiZgfN5AZUwLTeBqCwgQwcrQ9LbjoQXbdl/4pJ/16A8BfExThWVlkFUU8BLZsrj7WieJ5/uydK7N9xzRRNSgswgnBYQDImgmnyvZiiO8Xi1SwWP2OX/pfl7qUkYqaGPyW2Y1pHZYe7zoou7scK8/ehm0QRo0/3rFrffPevxCdviexSRTTi/lRu8rm99Fx/9lDCIJSHrjYY5cMBr54juSDnTiVOi3GTqQuS1tUMrmJ4CCcqtR9NHTnd0+K6gb1ws5NdHxIDqVVKeHN3EKSzMAxhp7yvS90mYRGvk+ouFqe6CRuS8Mx9CH/uQU6xPyLt6gsMsOJ3natf8nbjKsn2HvzlLFrasilPXPvj1WZ0J/eqEny4iD8BLLCXf9bUkx0LJ/lPMTezwaOXHocPMjFukGeEkvEGJZY08bVCKK5vICiB2KFcUS4xiZSePrXSX3dtKCLj8iPjXklNsGzd03mowqRTxHPfIx7dI+iBVVkEXj7kzaClh93e0OiFph/B7VCoSHmO59johhSTaGc9Cq48qqkL6LWZVVaVRUQ1ao/Pbe47eo+ZuZHkoQg27GJ9zGTqD/RZg/qrh1ii2QKPsWOLDPylDTJGX7rytC/Ab 73ND0A9g +hRE4UfG5oisRzpQQbIjx0UJtAKRHC+FdS6rVM/rRgxvf5NZ4g84y2h6xrqhYertv0HHc3khICBKg003S0+DFeulK5D7snuf6toPQWJQvA8s9HPqktI6vqAbv2rYOW2sIfzUgRTjKiCgwjtXK41s57VA8MGLcALdXcyPjp1+pJ73vEvSpyLhA6AsaBZ4eisj6Gs417o6+cXuSQeAtIfBFH/5FXZLyOr1/aBosRMCyJIO6otBM+3Xu88mrVT4yZPzTEgdxxRWbmNEIE0l2D8brQ8+Cob1kGNaH/7JFKC8UsG2CPZZtcdy6LyqLdsCugJRmV6UHaD2nOKr/n/Q= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Add a new filemap_get_folios_dirty() helper to look up existing dirty folios in a range and add them to a folio_batch. This is to support optimization of certain iomap operations that only care about dirty folios in a target range. For example, zero range only zeroes the subset of dirty pages over unwritten mappings, seek hole/data may use similar logic in the future, etc. Note that the helper is intended for use under internal fs locks. Therefore it trylocks folios in order to filter out clean folios. This loosely follows the logic from filemap_range_has_writeback(). Signed-off-by: Brian Foster --- include/linux/pagemap.h | 2 ++ mm/filemap.c | 58 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+) diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h index e63fbfbd5b0f..fb83ddf26621 100644 --- a/include/linux/pagemap.h +++ b/include/linux/pagemap.h @@ -941,6 +941,8 @@ unsigned filemap_get_folios_contig(struct address_space *mapping, pgoff_t *start, pgoff_t end, struct folio_batch *fbatch); unsigned filemap_get_folios_tag(struct address_space *mapping, pgoff_t *start, pgoff_t end, xa_mark_t tag, struct folio_batch *fbatch); +unsigned filemap_get_folios_dirty(struct address_space *mapping, + pgoff_t *start, pgoff_t end, struct folio_batch *fbatch); /* * Returns locked page at given index in given cache, creating it if needed. diff --git a/mm/filemap.c b/mm/filemap.c index bada249b9fb7..2171b7f689b0 100644 --- a/mm/filemap.c +++ b/mm/filemap.c @@ -2334,6 +2334,64 @@ unsigned filemap_get_folios_tag(struct address_space *mapping, pgoff_t *start, } EXPORT_SYMBOL(filemap_get_folios_tag); +/** + * filemap_get_folios_dirty - Get a batch of dirty folios + * @mapping: The address_space to search + * @start: The starting folio index + * @end: The final folio index (inclusive) + * @fbatch: The batch to fill + * + * filemap_get_folios_dirty() works exactly like filemap_get_folios(), except + * the returned folios are presumed to be dirty or undergoing writeback. Dirty + * state is presumed because we don't block on folio lock nor want to miss + * folios. Callers that need to can recheck state upon locking the folio. + * + * This may not return all dirty folios if the batch gets filled up. + * + * Return: The number of folios found. + * Also update @start to be positioned for traversal of the next folio. + */ +unsigned filemap_get_folios_dirty(struct address_space *mapping, pgoff_t *start, + pgoff_t end, struct folio_batch *fbatch) +{ + XA_STATE(xas, &mapping->i_pages, *start); + struct folio *folio; + + rcu_read_lock(); + while ((folio = find_get_entry(&xas, end, XA_PRESENT)) != NULL) { + if (xa_is_value(folio)) + continue; + if (folio_trylock(folio)) { + bool clean = !folio_test_dirty(folio) && + !folio_test_writeback(folio); + folio_unlock(folio); + if (clean) { + folio_put(folio); + continue; + } + } + if (!folio_batch_add(fbatch, folio)) { + unsigned long nr = folio_nr_pages(folio); + *start = folio->index + nr; + goto out; + } + } + /* + * We come here when there is no folio beyond @end. We take care to not + * overflow the index @start as it confuses some of the callers. This + * breaks the iteration when there is a folio at index -1 but that is + * already broke anyway. + */ + if (end == (pgoff_t)-1) + *start = (pgoff_t)-1; + else + *start = end + 1; +out: + rcu_read_unlock(); + + return folio_batch_count(fbatch); +} + /* * CD/DVDs are error prone. When a medium error occurs, the driver may fail * a _large_ part of the i/o request. Imagine the worst scenario: -- 2.50.0