dm-integrity: set max_integrity_segments in dm_integrity_io_hints
authorChristoph Hellwig <hch@lst.de>
Wed, 6 Mar 2024 14:27:39 +0000 (07:27 -0700)
committerMike Snitzer <snitzer@kernel.org>
Wed, 6 Mar 2024 17:21:27 +0000 (12:21 -0500)
Set max_integrity_segments with the other queue limits instead
of updating it later.  This also uncovered that the driver is trying
to set the limit to UINT_MAX while max_integrity_segments is an
unsigned short, so fix it up to use USHRT_MAX instead.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Mike Snitzer <snitzer@kernel.org>
drivers/md/dm-integrity.c

index c3c6669..bb3486b 100644 (file)
@@ -3487,6 +3487,7 @@ static void dm_integrity_io_hints(struct dm_target *ti, struct queue_limits *lim
                blk_limits_io_min(limits, ic->sectors_per_block << SECTOR_SHIFT);
                limits->dma_alignment = limits->logical_block_size - 1;
        }
+       limits->max_integrity_segments = USHRT_MAX;
 }
 
 static void calculate_journal_section_size(struct dm_integrity_c *ic)
@@ -3654,7 +3655,6 @@ static void dm_integrity_set(struct dm_target *ti, struct dm_integrity_c *ic)
        bi.interval_exp = ic->sb->log2_sectors_per_block + SECTOR_SHIFT;
 
        blk_integrity_register(disk, &bi);
-       blk_queue_max_integrity_segments(disk->queue, UINT_MAX);
 }
 
 static void dm_integrity_free_page_list(struct page_list *pl)