diff options
author | Steffen Maier <maier@linux.vnet.ibm.com> | 2013-04-26 11:33:45 -0400 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2013-05-31 19:32:37 -0400 |
commit | 5fea4291deacd80188b996d2f555fc6a1940e5d4 (patch) | |
tree | dc0832afacaf4e1830214af3e427630e93434b11 /drivers/s390 | |
parent | f76ccaac4f82c463a037aa4a1e4ccb85c7011814 (diff) |
[SCSI] zfcp: block queue limits with data router
Commit 86a9668a8d29ea711613e1cb37efa68e7c4db564
"[SCSI] zfcp: support for hardware data router"
reduced the initial block queue limits in the scsi_host_template to the
absolute minimum and adjusted them later on. However, the adjustment was
too late for the BSG devices of Scsi_Host and fc_host.
Therefore, ioctl(..., SG_IO, ...) with request or response size > 4kB to a
BSG device of an fc_host or a Scsi_Host fails with EINVAL. As a result,
users of such ioctl such as HBA_SendCTPassThru() in libzfcphbaapi return
with error HBA_STATUS_ERROR.
Initialize the block queue limits in zfcp_scsi_host_template to the
greatest common denominator (GCD).
While we cannot exploit the slightly enlarged maximum request size with
data router, this should be neglectible. Doing so also avoids running into
trouble after live guest relocation (LGR) / migration from a data router
FCP device to an FCP device that does not support data router. In that
case, zfcp would figure out the new limits on adapter recovery, but the
fc_host and Scsi_Host (plus in fact all sdevs) still exist with the old and
now too large queue limits.
It should also OK, not to use half the size as in the DIX case, because
fc_host and Scsi_Host do not transport FCP requests including SCSI commands
using protection data.
Signed-off-by: Steffen Maier <maier@linux.vnet.ibm.com>
Reviewed-by: Martin Peschke <mpeschke@linux.vnet.ibm.com>
Cc: <stable@vger.kernel.org> #3.2+
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/s390')
-rw-r--r-- | drivers/s390/scsi/zfcp_scsi.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/drivers/s390/scsi/zfcp_scsi.c b/drivers/s390/scsi/zfcp_scsi.c index 7b31e3f403f9..7b353647cb90 100644 --- a/drivers/s390/scsi/zfcp_scsi.c +++ b/drivers/s390/scsi/zfcp_scsi.c | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * Interface to Linux SCSI midlayer. | 4 | * Interface to Linux SCSI midlayer. |
5 | * | 5 | * |
6 | * Copyright IBM Corp. 2002, 2010 | 6 | * Copyright IBM Corp. 2002, 2013 |
7 | */ | 7 | */ |
8 | 8 | ||
9 | #define KMSG_COMPONENT "zfcp" | 9 | #define KMSG_COMPONENT "zfcp" |
@@ -311,8 +311,12 @@ static struct scsi_host_template zfcp_scsi_host_template = { | |||
311 | .proc_name = "zfcp", | 311 | .proc_name = "zfcp", |
312 | .can_queue = 4096, | 312 | .can_queue = 4096, |
313 | .this_id = -1, | 313 | .this_id = -1, |
314 | .sg_tablesize = 1, /* adjusted later */ | 314 | .sg_tablesize = (((QDIO_MAX_ELEMENTS_PER_BUFFER - 1) |
315 | .max_sectors = 8, /* adjusted later */ | 315 | * ZFCP_QDIO_MAX_SBALS_PER_REQ) - 2), |
316 | /* GCD, adjusted later */ | ||
317 | .max_sectors = (((QDIO_MAX_ELEMENTS_PER_BUFFER - 1) | ||
318 | * ZFCP_QDIO_MAX_SBALS_PER_REQ) - 2) * 8, | ||
319 | /* GCD, adjusted later */ | ||
316 | .dma_boundary = ZFCP_QDIO_SBALE_LEN - 1, | 320 | .dma_boundary = ZFCP_QDIO_SBALE_LEN - 1, |
317 | .cmd_per_lun = 1, | 321 | .cmd_per_lun = 1, |
318 | .use_clustering = 1, | 322 | .use_clustering = 1, |