scsi: fix host max depth checking for the 'queue_depth' sysfs interface
Commit1e6f241604
changed the scsi sysfs 'queue_depth' code to rejects depths higher than the scsi host template setting. But lots of hosts set this to 1, and update the settings in the scsi host when the controller/devices probing happens. This breaks (at least) mpt2sas and mpt3sas runtime setting of queue depth, returning EINVAL for all settings but '1'. And once it's set to 1, there's no way to go back up. Cc: stable@vger.kernel.org Fixes:1e6f241604
"scsi: don't allow setting of queue_depth bigger than can_queue" Signed-off-by: Jens Axboe <axboe@fb.com> Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: James Bottomley <JBottomley@Odin.com>
This commit is contained in:
parent
e7ac6c6666
commit
1278dd6809
|
@ -859,7 +859,7 @@ sdev_store_queue_depth(struct device *dev, struct device_attribute *attr,
|
||||||
|
|
||||||
depth = simple_strtoul(buf, NULL, 0);
|
depth = simple_strtoul(buf, NULL, 0);
|
||||||
|
|
||||||
if (depth < 1 || depth > sht->can_queue)
|
if (depth < 1 || depth > sdev->host->can_queue)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
retval = sht->change_queue_depth(sdev, depth);
|
retval = sht->change_queue_depth(sdev, depth);
|
||||||
|
|
Loading…
Reference in New Issue