linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v7 0/6] block/md/dm: set chunk_sectors from stacked dev stripe size
@ 2025-07-11 10:52 John Garry
  2025-07-11 10:52 ` [PATCH v7 1/6] ilog2: add max_pow_of_two_factor() John Garry
                   ` (8 more replies)
  0 siblings, 9 replies; 10+ messages in thread
From: John Garry @ 2025-07-11 10:52 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, dlemoal, 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 8b428f42f3edf nbd: fix lockdep deadlock warning

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

Difference to v6:
- do comparison in sectors in 2/6

Differences to v5:
- Neaten code in blk_validate_atomic_write_limits() (Jens)

Differences to v4:
- Use check_shl_overflow() (Nilay)
- Use long long in for chunk bytes in 2/6
- Add tags from Nilay (thanks!)

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   | 62 ++++++++++++++++++++++++++----------------
 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, 56 insertions(+), 28 deletions(-)

-- 
2.43.5


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

end of thread, other threads:[~2025-07-17 12:01 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-07-11 10:52 [PATCH v7 0/6] block/md/dm: set chunk_sectors from stacked dev stripe size John Garry
2025-07-11 10:52 ` [PATCH v7 1/6] ilog2: add max_pow_of_two_factor() John Garry
2025-07-11 10:52 ` [PATCH v7 2/6] block: sanitize chunk_sectors for atomic write limits John Garry
2025-07-11 10:52 ` [PATCH v7 3/6] md/raid0: set chunk_sectors limit John Garry
2025-07-11 10:52 ` [PATCH v7 4/6] md/raid10: " John Garry
2025-07-11 10:52 ` [PATCH v7 5/6] dm-stripe: limit chunk_sectors to the stripe size John Garry
2025-07-11 10:52 ` [PATCH v7 6/6] block: use chunk_sectors when evaluating stacked atomic write limits John Garry
2025-07-11 11:43 ` [PATCH v7 0/6] block/md/dm: set chunk_sectors from stacked dev stripe size Martin K. Petersen
2025-07-17  8:00 ` John Garry
2025-07-17 12:01 ` Jens Axboe

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).