sd: also set max_user_sectors when setting max_sectors
authorChristoph Hellwig <hch@lst.de>
Thu, 23 May 2024 18:26:13 +0000 (20:26 +0200)
committerJens Axboe <axboe@kernel.dk>
Tue, 28 May 2024 12:54:36 +0000 (06:54 -0600)
commitbafea1c58b24be594d97841ced1b7ae0347bf6e3
treea64b3232ae15d764b608624dd2f17683ce09d8ec
parent233e27b4d21c3e44eb863f03e566d3a22e81a7ae
sd: also set max_user_sectors when setting max_sectors

sd can set a max_sectors value that is lower than the max_hw_sectors
limit based on the block limits VPD page.   While this is rather unusual,
it used to work until the max_user_sectors field was split out to cleanly
deal with conflicting hardware and user limits when the hardware limit
changes.  Also set max_user_sectors to ensure the limit can properly be
stacked.

Fixes: 4f563a64732d ("block: add a max_user_discard_sectors queue limit")
Reported-by: Mike Snitzer <snitzer@kernel.org>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Mike Snitzer <snitzer@kernel.org>
Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com>
Link: https://lore.kernel.org/r/20240523182618.602003-2-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/scsi/sd.c