linux-xfs.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v4 0/6] block/md/dm: set chunk_sectors from stacked dev stripe size
@ 2025-07-07 13:11 John Garry
  2025-07-07 13:11 ` [PATCH v4 1/6] ilog2: add max_pow_of_two_factor() John Garry
                   ` (5 more replies)
  0 siblings, 6 replies; 11+ messages in thread
From: John Garry @ 2025-07-07 13:11 UTC (permalink / raw)
  To: agk, snitzer, mpatocka, song, yukuai3, hch, nilay, axboe, cem
  Cc: dm-devel, linux-kernel, linux-raid, linux-block, ojaswin,
	martin.petersen, akpm, linux-xfs, djwong, John Garry

This value in io_min is used to configure any atomic write limit for the
stacked device. The idea is that the atomic write unit max is a
power-of-2 factor of the stripe size, and the stripe size is available
in io_min.

Using io_min causes issues, as:
a. it may be mutated
b. the check for io_min being set for determining if we are dealing with
a striped device is hard to get right, as reported in [0].

This series now sets chunk_sectors limit to share stripe size.

[0] https://lore.kernel.org/linux-block/888f3b1d-7817-4007-b3b3-1a2ea04df771@linux.ibm.com/T/#mecca17129f72811137d3c2f1e477634e77f06781

Based on 73d9cb37478f (block/for-6.17/block) block: remove pktcdvd driver

This series fixes issues for v6.16, but it's prob better to have this in
v6.17 at this stage.

Differences to v3:
- relocate max_pow_of_two_factor() to common header and rework (Mikulas)
- cater for overflow from chunk sectors (Mikulas)

Differences to v2:
- Add RB tags (thanks!)

Differences to RFC:
- sanitize chunk_sectors for atomic write limits
- set chunk_sectors in stripe_io_hints()

John Garry (6):
  ilog2: add max_pow_of_two_factor()
  block: sanitize chunk_sectors for atomic write limits
  md/raid0: set chunk_sectors limit
  md/raid10: set chunk_sectors limit
  dm-stripe: limit chunk_sectors to the stripe size
  block: use chunk_sectors when evaluating stacked atomic write limits

 block/blk-settings.c   | 66 +++++++++++++++++++++++++++---------------
 drivers/md/dm-stripe.c |  1 +
 drivers/md/raid0.c     |  1 +
 drivers/md/raid10.c    |  1 +
 fs/xfs/xfs_mount.c     |  5 ----
 include/linux/log2.h   | 14 +++++++++
 6 files changed, 60 insertions(+), 28 deletions(-)

-- 
2.43.5


^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2025-07-08 18:00 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-07-07 13:11 [PATCH v4 0/6] block/md/dm: set chunk_sectors from stacked dev stripe size John Garry
2025-07-07 13:11 ` [PATCH v4 1/6] ilog2: add max_pow_of_two_factor() John Garry
2025-07-07 13:11 ` [PATCH v4 2/6] block: sanitize chunk_sectors for atomic write limits John Garry
2025-07-07 13:11 ` [PATCH v4 3/6] md/raid0: set chunk_sectors limit John Garry
2025-07-07 13:11 ` [PATCH v4 4/6] md/raid10: " John Garry
2025-07-07 13:11 ` [PATCH v4 5/6] dm-stripe: limit chunk_sectors to the stripe size John Garry
2025-07-07 13:11 ` [PATCH v4 6/6] block: use chunk_sectors when evaluating stacked atomic write limits John Garry
2025-07-08 12:27   ` Nilay Shroff
2025-07-08 12:36     ` John Garry
2025-07-08 16:59     ` Mikulas Patocka
2025-07-08 18:00       ` John Garry

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).