Commit 310887f6 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Martin K. Petersen

scsi: mpi3mr: Switch to using ->device_configure

Switch to the ->device_configure method instead of ->slave_configure and
update the block limits on the passed in queue_limits instead of using the
per-limit accessors.

Note that mpi3mr also updates the limits from an event handler that
iterates all SCSI devices.  This is also updated to use the queue_limits,
but the complete locking of this path probably means it already is
completely broken and needs a proper audit.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/20240410042759.GA2637@lst.deReviewed-by: default avatarDamien Le Moal <dlemoal@kernel.org>
Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent a25a9c85
...@@ -986,6 +986,25 @@ static int mpi3mr_change_queue_depth(struct scsi_device *sdev, ...@@ -986,6 +986,25 @@ static int mpi3mr_change_queue_depth(struct scsi_device *sdev,
return retval; return retval;
} }
static void mpi3mr_configure_nvme_dev(struct mpi3mr_tgt_dev *tgt_dev,
struct queue_limits *lim)
{
u8 pgsz = tgt_dev->dev_spec.pcie_inf.pgsz ? : MPI3MR_DEFAULT_PGSZEXP;
lim->max_hw_sectors = tgt_dev->dev_spec.pcie_inf.mdts / 512;
lim->virt_boundary_mask = (1 << pgsz) - 1;
}
static void mpi3mr_configure_tgt_dev(struct mpi3mr_tgt_dev *tgt_dev,
struct queue_limits *lim)
{
if (tgt_dev->dev_type == MPI3_DEVICE_DEVFORM_PCIE &&
(tgt_dev->dev_spec.pcie_inf.dev_info &
MPI3_DEVICE0_PCIE_DEVICE_INFO_TYPE_MASK) ==
MPI3_DEVICE0_PCIE_DEVICE_INFO_TYPE_NVME_DEVICE)
mpi3mr_configure_nvme_dev(tgt_dev, lim);
}
/** /**
* mpi3mr_update_sdev - Update SCSI device information * mpi3mr_update_sdev - Update SCSI device information
* @sdev: SCSI device reference * @sdev: SCSI device reference
...@@ -1001,31 +1020,17 @@ static void ...@@ -1001,31 +1020,17 @@ static void
mpi3mr_update_sdev(struct scsi_device *sdev, void *data) mpi3mr_update_sdev(struct scsi_device *sdev, void *data)
{ {
struct mpi3mr_tgt_dev *tgtdev; struct mpi3mr_tgt_dev *tgtdev;
struct queue_limits lim;
tgtdev = (struct mpi3mr_tgt_dev *)data; tgtdev = (struct mpi3mr_tgt_dev *)data;
if (!tgtdev) if (!tgtdev)
return; return;
mpi3mr_change_queue_depth(sdev, tgtdev->q_depth); mpi3mr_change_queue_depth(sdev, tgtdev->q_depth);
switch (tgtdev->dev_type) {
case MPI3_DEVICE_DEVFORM_PCIE: lim = queue_limits_start_update(sdev->request_queue);
/*The block layer hw sector size = 512*/ mpi3mr_configure_tgt_dev(tgtdev, &lim);
if ((tgtdev->dev_spec.pcie_inf.dev_info & WARN_ON_ONCE(queue_limits_commit_update(sdev->request_queue, &lim));
MPI3_DEVICE0_PCIE_DEVICE_INFO_TYPE_MASK) ==
MPI3_DEVICE0_PCIE_DEVICE_INFO_TYPE_NVME_DEVICE) {
blk_queue_max_hw_sectors(sdev->request_queue,
tgtdev->dev_spec.pcie_inf.mdts / 512);
if (tgtdev->dev_spec.pcie_inf.pgsz == 0)
blk_queue_virt_boundary(sdev->request_queue,
((1 << MPI3MR_DEFAULT_PGSZEXP) - 1));
else
blk_queue_virt_boundary(sdev->request_queue,
((1 << tgtdev->dev_spec.pcie_inf.pgsz) - 1));
}
break;
default:
break;
}
} }
/** /**
...@@ -4393,15 +4398,17 @@ static void mpi3mr_target_destroy(struct scsi_target *starget) ...@@ -4393,15 +4398,17 @@ static void mpi3mr_target_destroy(struct scsi_target *starget)
} }
/** /**
* mpi3mr_slave_configure - Slave configure callback handler * mpi3mr_device_configure - Slave configure callback handler
* @sdev: SCSI device reference * @sdev: SCSI device reference
* @lim: queue limits
* *
* Configure queue depth, max hardware sectors and virt boundary * Configure queue depth, max hardware sectors and virt boundary
* as required * as required
* *
* Return: 0 always. * Return: 0 always.
*/ */
static int mpi3mr_slave_configure(struct scsi_device *sdev) static int mpi3mr_device_configure(struct scsi_device *sdev,
struct queue_limits *lim)
{ {
struct scsi_target *starget; struct scsi_target *starget;
struct Scsi_Host *shost; struct Scsi_Host *shost;
...@@ -4432,28 +4439,8 @@ static int mpi3mr_slave_configure(struct scsi_device *sdev) ...@@ -4432,28 +4439,8 @@ static int mpi3mr_slave_configure(struct scsi_device *sdev)
sdev->eh_timeout = MPI3MR_EH_SCMD_TIMEOUT; sdev->eh_timeout = MPI3MR_EH_SCMD_TIMEOUT;
blk_queue_rq_timeout(sdev->request_queue, MPI3MR_SCMD_TIMEOUT); blk_queue_rq_timeout(sdev->request_queue, MPI3MR_SCMD_TIMEOUT);
switch (tgt_dev->dev_type) { mpi3mr_configure_tgt_dev(tgt_dev, lim);
case MPI3_DEVICE_DEVFORM_PCIE:
/*The block layer hw sector size = 512*/
if ((tgt_dev->dev_spec.pcie_inf.dev_info &
MPI3_DEVICE0_PCIE_DEVICE_INFO_TYPE_MASK) ==
MPI3_DEVICE0_PCIE_DEVICE_INFO_TYPE_NVME_DEVICE) {
blk_queue_max_hw_sectors(sdev->request_queue,
tgt_dev->dev_spec.pcie_inf.mdts / 512);
if (tgt_dev->dev_spec.pcie_inf.pgsz == 0)
blk_queue_virt_boundary(sdev->request_queue,
((1 << MPI3MR_DEFAULT_PGSZEXP) - 1));
else
blk_queue_virt_boundary(sdev->request_queue,
((1 << tgt_dev->dev_spec.pcie_inf.pgsz) - 1));
}
break;
default:
break;
}
mpi3mr_tgtdev_put(tgt_dev); mpi3mr_tgtdev_put(tgt_dev);
return retval; return retval;
} }
...@@ -4921,7 +4908,7 @@ static const struct scsi_host_template mpi3mr_driver_template = { ...@@ -4921,7 +4908,7 @@ static const struct scsi_host_template mpi3mr_driver_template = {
.queuecommand = mpi3mr_qcmd, .queuecommand = mpi3mr_qcmd,
.target_alloc = mpi3mr_target_alloc, .target_alloc = mpi3mr_target_alloc,
.slave_alloc = mpi3mr_slave_alloc, .slave_alloc = mpi3mr_slave_alloc,
.slave_configure = mpi3mr_slave_configure, .device_configure = mpi3mr_device_configure,
.target_destroy = mpi3mr_target_destroy, .target_destroy = mpi3mr_target_destroy,
.slave_destroy = mpi3mr_slave_destroy, .slave_destroy = mpi3mr_slave_destroy,
.scan_finished = mpi3mr_scan_finished, .scan_finished = mpi3mr_scan_finished,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment