This is a note to let you know that I've just added the patch titled

    Drivers: scsi: storvsc: Change the limits to reflect the values on the host

to the 3.14-stable tree which can be found at:
    
http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     
drivers-scsi-storvsc-change-the-limits-to-reflect-the-values-on-the-host.patch
and it can be found in the queue-3.14 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <[email protected]> know about it.


>From 4cd83ecdac20d30725b4f96e5d7814a1e290bc7e Mon Sep 17 00:00:00 2001
From: "K. Y. Srinivasan" <[email protected]>
Date: Sat, 12 Jul 2014 09:48:26 -0700
Subject: Drivers: scsi: storvsc: Change the limits to reflect the values on the 
host

From: "K. Y. Srinivasan" <[email protected]>

commit 4cd83ecdac20d30725b4f96e5d7814a1e290bc7e upstream.

Hyper-V hosts can support multiple targets and multiple channels and larger 
number of
LUNs per target. Update the code to reflect this. With this patch we can 
correctly
enumerate all the paths in a multi-path storage environment.

Signed-off-by: K. Y. Srinivasan <[email protected]>
Reviewed-by: Hannes Reinecke <[email protected]>
Signed-off-by: Christoph Hellwig <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>

---
 drivers/scsi/storvsc_drv.c |   51 +++++++++++++++++++++++++++++----------------
 1 file changed, 33 insertions(+), 18 deletions(-)

--- a/drivers/scsi/storvsc_drv.c
+++ b/drivers/scsi/storvsc_drv.c
@@ -331,17 +331,17 @@ static int storvsc_timeout = 180;
 
 static void storvsc_on_channel_callback(void *context);
 
-/*
- * In Hyper-V, each port/path/target maps to 1 scsi host adapter.  In
- * reality, the path/target is not used (ie always set to 0) so our
- * scsi host adapter essentially has 1 bus with 1 target that contains
- * up to 256 luns.
- */
-#define STORVSC_MAX_LUNS_PER_TARGET                    64
-#define STORVSC_MAX_TARGETS                            1
-#define STORVSC_MAX_CHANNELS                           1
-
-
+#define STORVSC_MAX_LUNS_PER_TARGET                    255
+#define STORVSC_MAX_TARGETS                            2
+#define STORVSC_MAX_CHANNELS                           8
+
+#define STORVSC_FC_MAX_LUNS_PER_TARGET                 255
+#define STORVSC_FC_MAX_TARGETS                         128
+#define STORVSC_FC_MAX_CHANNELS                                8
+
+#define STORVSC_IDE_MAX_LUNS_PER_TARGET                        64
+#define STORVSC_IDE_MAX_TARGETS                                1
+#define STORVSC_IDE_MAX_CHANNELS                       1
 
 struct storvsc_cmd_request {
        struct list_head entry;
@@ -1713,7 +1713,6 @@ static struct scsi_host_template scsi_dr
        .slave_destroy =        storvsc_device_destroy,
        .slave_configure =      storvsc_device_configure,
        .cmd_per_lun =          1,
-       /* 64 max_queue * 1 target */
        .can_queue =            STORVSC_MAX_IO_REQUESTS*STORVSC_MAX_TARGETS,
        .this_id =              -1,
        /* no use setting to 0 since ll_blk_rw reset it to 1 */
@@ -1778,6 +1777,9 @@ static int storvsc_probe(struct hv_devic
        }
 
 
+       if (dev_id->driver_data == SFC_GUID)
+               scsi_driver.can_queue = (STORVSC_MAX_IO_REQUESTS *
+                                        STORVSC_FC_MAX_TARGETS);
        host = scsi_host_alloc(&scsi_driver,
                               sizeof(struct hv_host_device));
        if (!host)
@@ -1811,12 +1813,25 @@ static int storvsc_probe(struct hv_devic
        host_dev->path = stor_device->path_id;
        host_dev->target = stor_device->target_id;
 
-       /* max # of devices per target */
-       host->max_lun = STORVSC_MAX_LUNS_PER_TARGET;
-       /* max # of targets per channel */
-       host->max_id = STORVSC_MAX_TARGETS;
-       /* max # of channels */
-       host->max_channel = STORVSC_MAX_CHANNELS - 1;
+       switch (dev_id->driver_data) {
+       case SFC_GUID:
+               host->max_lun = STORVSC_FC_MAX_LUNS_PER_TARGET;
+               host->max_id = STORVSC_FC_MAX_TARGETS;
+               host->max_channel = STORVSC_FC_MAX_CHANNELS - 1;
+               break;
+
+       case SCSI_GUID:
+               host->max_lun = STORVSC_MAX_LUNS_PER_TARGET;
+               host->max_id = STORVSC_MAX_TARGETS;
+               host->max_channel = STORVSC_MAX_CHANNELS - 1;
+               break;
+
+       default:
+               host->max_lun = STORVSC_IDE_MAX_LUNS_PER_TARGET;
+               host->max_id = STORVSC_IDE_MAX_TARGETS;
+               host->max_channel = STORVSC_IDE_MAX_CHANNELS - 1;
+               break;
+       }
        /* max cmd length */
        host->max_cmd_len = STORVSC_MAX_CMD_LEN;
 


Patches currently in stable-queue which might be from [email protected] are

queue-3.14/drivers-scsi-storvsc-implement-a-eh_timed_out-handler.patch
queue-3.14/drivers-scsi-storvsc-correctly-handle-test_unit_ready-failure.patch
queue-3.14/drivers-scsi-storvsc-set-srb_flags-in-all-cases.patch
queue-3.14/drivers-scsi-storvsc-fix-a-bug-in-handling-vmbus-protocol-version.patch
queue-3.14/scsi-add-a-blacklist-flag-which-enables-vpd-page-inquiries.patch
queue-3.14/drivers-scsi-storvsc-change-the-limits-to-reflect-the-values-on-the-host.patch
queue-3.14/drivers-scsi-storvsc-filter-commands-based-on-the-storage-protocol-version.patch
queue-3.14/drivers-scsi-storvsc-set-cmd_per_lun-to-reflect-value-supported-by-the-host.patch
--
To unsubscribe from this list: send the line "unsubscribe stable" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to