From: Su Yue <l@damenly.org>
To: Yu Kuai <yukuai@kernel.org>
Cc: Song Liu <song@kernel.org>, Yu Kuai <yukuai@fygo.io>,
Li Nan <magiclinan@didiglobal.com>, Xiao Ni <xiao@kernel.org>,
linux-raid@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH] md/md-llbitmap: track bitmap sync_size explicitly
Date: Mon, 15 Jun 2026 18:48:25 +0800 [thread overview]
Message-ID: <pl1saxl2.fsf@damenly.org> (raw)
In-Reply-To: <20260605091527.2463539-5-yukuai@kernel.org> (Yu Kuai's message of "Fri, 5 Jun 2026 17:15:11 +0800")
On Fri 05 Jun 2026 at 17:15, Yu Kuai <yukuai@kernel.org> wrote:
> From: Yu Kuai <yukuai@fygo.io>
>
> Track llbitmap's own sync_size instead of always using
> mddev->resync_max_sectors directly.
>
> This is the minimal bookkeeping needed before llbitmap can track
> old
> and new reshape geometry independently.
>
> Signed-off-by: Yu Kuai <yukuai@fygo.io>
>
Reviewed-by: Su Yue <glass.su@suse.com>
> ---
> drivers/md/md-llbitmap.c | 14 ++++++++++++--
> 1 file changed, 12 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/md/md-llbitmap.c b/drivers/md/md-llbitmap.c
> index bcf34f0c9af6..ecf3ed712315 100644
> --- a/drivers/md/md-llbitmap.c
> +++ b/drivers/md/md-llbitmap.c
> @@ -285,10 +285,12 @@ struct llbitmap {
> unsigned long chunkshift;
> /* size of one chunk in sector */
> unsigned long chunksize;
> /* total number of chunks */
> unsigned long chunks;
> + /* total number of sectors tracked by current bitmap geometry
> */
> + sector_t sync_size;
> unsigned long last_end_sync;
> /*
> * time in seconds that dirty bits will be cleared if the page
> is not
> * accessed.
> */
> @@ -916,10 +918,11 @@ static int llbitmap_init(struct llbitmap
> *llbitmap)
>
> llbitmap->barrier_idle = DEFAULT_BARRIER_IDLE;
> llbitmap->chunkshift = ffz(~chunksize);
> llbitmap->chunksize = chunksize;
> llbitmap->chunks = chunks;
> + llbitmap->sync_size = blocks;
> mddev->bitmap_info.daemon_sleep = DEFAULT_DAEMON_SLEEP;
>
> ret = llbitmap_cache_pages(llbitmap);
> if (ret)
> return ret;
> @@ -936,10 +939,11 @@ static int llbitmap_read_sb(struct
> llbitmap *llbitmap)
> {
> struct mddev *mddev = llbitmap->mddev;
> unsigned long daemon_sleep;
> unsigned long chunksize;
> unsigned long events;
> + sector_t sync_size;
> struct page *sb_page;
> bitmap_super_t *sb;
> int ret = -EINVAL;
>
> if (!mddev->bitmap_info.offset) {
> @@ -985,10 +989,13 @@ static int llbitmap_read_sb(struct
> llbitmap *llbitmap)
> if (test_and_clear_bit(BITMAP_FIRST_USE, &llbitmap->flags)) {
> ret = llbitmap_init(llbitmap);
> goto out_put_page;
> }
>
> + sync_size = le64_to_cpu(sb->sync_size);
> + if (!sync_size)
> + sync_size = mddev->resync_max_sectors;
> chunksize = le32_to_cpu(sb->chunksize);
> if (!is_power_of_2(chunksize)) {
> pr_err("md/llbitmap: %s: chunksize not a power of 2",
> mdname(mddev));
> goto out_put_page;
> @@ -1020,12 +1027,13 @@ static int llbitmap_read_sb(struct
> llbitmap *llbitmap)
> mddev->bitmap_info.chunksize = chunksize;
> mddev->bitmap_info.daemon_sleep = daemon_sleep;
>
> llbitmap->barrier_idle = DEFAULT_BARRIER_IDLE;
> llbitmap->chunksize = chunksize;
> - llbitmap->chunks =
> DIV_ROUND_UP_SECTOR_T(mddev->resync_max_sectors, chunksize);
> + llbitmap->chunks = DIV_ROUND_UP_SECTOR_T(sync_size,
> chunksize);
> llbitmap->chunkshift = ffz(~chunksize);
> + llbitmap->sync_size = sync_size;
> ret = llbitmap_cache_pages(llbitmap);
>
> out_put_page:
> __free_page(sb_page);
> kunmap_local(sb);
> @@ -1151,10 +1159,11 @@ static int llbitmap_resize(struct mddev
> *mddev, sector_t blocks, int chunksize)
> }
>
> llbitmap->chunkshift = ffz(~chunksize);
> llbitmap->chunksize = chunksize;
> llbitmap->chunks = chunks;
> + llbitmap->sync_size = blocks;
>
> return 0;
> }
>
> static int llbitmap_load(struct mddev *mddev)
> @@ -1524,11 +1533,11 @@ static void llbitmap_update_sb(void
> *data)
>
> sb = kmap_local_page(sb_page);
> sb->events = cpu_to_le64(mddev->events);
> sb->state = cpu_to_le32(llbitmap->flags);
> sb->chunksize = cpu_to_le32(llbitmap->chunksize);
> - sb->sync_size = cpu_to_le64(mddev->resync_max_sectors);
> + sb->sync_size = cpu_to_le64(llbitmap->sync_size);
> sb->events_cleared = cpu_to_le64(llbitmap->events_cleared);
> sb->sectors_reserved = cpu_to_le32(mddev->bitmap_info.space);
> sb->daemon_sleep =
> cpu_to_le32(mddev->bitmap_info.daemon_sleep);
>
> kunmap_local(sb);
> @@ -1542,10 +1551,11 @@ static int llbitmap_get_stats(void
> *data, struct md_bitmap_stats *stats)
> memset(stats, 0, sizeof(*stats));
>
> stats->missing_pages = 0;
> stats->pages = llbitmap->nr_pages;
> stats->file_pages = llbitmap->nr_pages;
> + stats->sync_size = llbitmap->sync_size;
>
> stats->behind_writes = atomic_read(&llbitmap->behind_writes);
> stats->behind_wait = wq_has_sleeper(&llbitmap->behind_wait);
> stats->events_cleared = llbitmap->events_cleared;
next prev parent reply other threads:[~2026-06-15 10:53 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-06-05 9:15 [PATCH 00/20] md/md-llbitmap: support reshape for RAID10 and RAID5 Yu Kuai
2026-06-05 9:15 ` [PATCH] md: add exact bitmap mapping and reshape hooks Yu Kuai
2026-06-05 9:15 ` [PATCH] md: skip bitmap accounting for empty write ranges Yu Kuai
2026-06-05 9:15 ` [PATCH] md: add helper to split bios at reshape offset Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: track bitmap sync_size explicitly Yu Kuai
2026-06-15 10:48 ` Su Yue [this message]
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: allocate page controls independently Yu Kuai
2026-06-15 11:06 ` Su Yue
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: grow the page cache in place for reshape Yu Kuai
2026-06-15 11:16 ` Su Yue
2026-06-15 16:19 ` yu kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: track target reshape geometry fields Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: finish reshape geometry Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: refuse reshape while llbitmap still needs sync Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: add reshape range mapping helpers Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: don't skip reshape ranges from bitmap state Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: remap checkpointed bits as reshape progresses Yu Kuai
2026-06-05 9:15 ` [PATCH] md/md-llbitmap: clamp state-machine walks to tracked bits Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid10: reject llbitmap reshape when md chunk shrinks Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid10: wire llbitmap reshape lifecycle Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid10: split reshape bios before bitmap accounting Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid5: add exact old and new llbitmap mapping helpers Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid5: reject llbitmap reshape when md chunk shrinks Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid5: wire llbitmap reshape lifecycle Yu Kuai
2026-06-05 9:15 ` [PATCH] md/raid5: split reshape bios before bitmap accounting Yu Kuai
2026-06-05 17:27 ` kernel test robot
2026-06-06 2:15 ` kernel test robot
-- strict thread matches above, loose matches on Subject: below --
2026-04-19 3:09 [PATCH 00/19] md: support llbitmap reshape for raid10 and raid5 Yu Kuai
2026-04-19 3:09 ` [PATCH] md/md-llbitmap: track bitmap sync_size explicitly Yu Kuai
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pl1saxl2.fsf@damenly.org \
--to=l@damenly.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-raid@vger.kernel.org \
--cc=magiclinan@didiglobal.com \
--cc=song@kernel.org \
--cc=xiao@kernel.org \
--cc=yukuai@fygo.io \
--cc=yukuai@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.