scsi: scsi_transport_fc: Add a max_bsg_segments field to struct fc_function_template
authorChristoph Hellwig <hch@lst.de>
Tue, 9 Apr 2024 14:37:30 +0000 (16:37 +0200)
committerMartin K. Petersen <martin.petersen@oracle.com>
Fri, 12 Apr 2024 01:37:48 +0000 (21:37 -0400)
ibmvfc only supports a single segment for BSG FC passthrough.  Instead of
having it set a queue limits after creating the BSG queues, add a field so
that the FC transport can set it before allocating the queue.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/20240409143748.980206-6-hch@lst.de
Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
Reviewed-by: Hannes Reinecke <hare@suse.de>
Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/ibmvscsi/ibmvfc.c
drivers/scsi/scsi_transport_fc.c
include/scsi/scsi_transport_fc.h

index 05b126bfd18b5524870de3d8845f16a515e84e3f..a3d1013c83075c6314179464b13d1ccbbd98a867 100644 (file)
@@ -5541,8 +5541,6 @@ static void ibmvfc_tgt_add_rport(struct ibmvfc_target *tgt)
                        rport->supported_classes |= FC_COS_CLASS2;
                if (be32_to_cpu(tgt->service_parms.class3_parms[0]) & 0x80000000)
                        rport->supported_classes |= FC_COS_CLASS3;
-               if (rport->rqst_q)
-                       blk_queue_max_segments(rport->rqst_q, 1);
        } else
                tgt_dbg(tgt, "rport add failed\n");
        spin_unlock_irqrestore(vhost->host->host_lock, flags);
@@ -6391,8 +6389,6 @@ static int ibmvfc_probe(struct vio_dev *vdev, const struct vio_device_id *id)
 
        ibmvfc_init_sub_crqs(vhost);
 
-       if (shost_to_fc_host(shost)->rqst_q)
-               blk_queue_max_segments(shost_to_fc_host(shost)->rqst_q, 1);
        dev_set_drvdata(dev, vhost);
        spin_lock(&ibmvfc_driver_lock);
        list_add_tail(&vhost->queue, &ibmvfc_head);
@@ -6547,6 +6543,7 @@ static struct fc_function_template ibmvfc_transport_functions = {
        .get_starget_port_id = ibmvfc_get_starget_port_id,
        .show_starget_port_id = 1,
 
+       .max_bsg_segments = 1,
        .bsg_request = ibmvfc_bsg_request,
        .bsg_timeout = ibmvfc_bsg_timeout,
 };
index 0799700b0fca770612a5fa475fd45a53048d82bc..7d088b8da075788e4b42536746599b498ea615e2 100644 (file)
@@ -4288,6 +4288,7 @@ fc_bsg_hostadd(struct Scsi_Host *shost, struct fc_host_attrs *fc_host)
        snprintf(bsg_name, sizeof(bsg_name),
                 "fc_host%d", shost->host_no);
        scsi_init_limits(shost, &lim);
+       lim.max_segments = min_not_zero(lim.max_segments, i->f->max_bsg_segments);
        q = bsg_setup_queue(dev, bsg_name, &lim, fc_bsg_dispatch,
                        fc_bsg_job_timeout, i->f->dd_bsg_size);
        if (IS_ERR(q)) {
@@ -4320,6 +4321,7 @@ fc_bsg_rportadd(struct Scsi_Host *shost, struct fc_rport *rport)
                return -ENOTSUPP;
 
        scsi_init_limits(shost, &lim);
+       lim.max_segments = min_not_zero(lim.max_segments, i->f->max_bsg_segments);
        q = bsg_setup_queue(dev, dev_name(dev), &lim, fc_bsg_dispatch_prep,
                                fc_bsg_job_timeout, i->f->dd_bsg_size);
        if (IS_ERR(q)) {
index 483513c575976c48e9b89a4f6eac67c9c8e10827..fd039306ffbb202d3e926ec4187e4d579cad9406 100644 (file)
@@ -709,6 +709,7 @@ struct fc_function_template {
        int     (*vport_delete)(struct fc_vport *);
 
        /* bsg support */
+       u32                             max_bsg_segments;
        int     (*bsg_request)(struct bsg_job *);
        int     (*bsg_timeout)(struct bsg_job *);