Commit 5759a565 authored by Mike Christie's avatar Mike Christie Committed by Martin K. Petersen

scsi: hp_sw: Fix sshdr use

If scsi_execute_cmd returns < 0, it doesn't initialize the sshdr, so we
shouldn't access the sshdr. If it returns 0, then the cmd executed
successfully, so there is no need to check the sshdr. This has us access
the sshdr when we get a return value > 0.
Signed-off-by: default avatarMike Christie <michael.christie@oracle.com>
Link: https://lore.kernel.org/r/20231004210013.5601-4-michael.christie@oracle.comReviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarJohn Garry <john.g.garry@oracle.com>
Reviewed-by: default avatarMartin Wilck <mwilck@suse.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent b4d0c33a
...@@ -82,7 +82,7 @@ static int hp_sw_tur(struct scsi_device *sdev, struct hp_sw_dh_data *h) ...@@ -82,7 +82,7 @@ static int hp_sw_tur(struct scsi_device *sdev, struct hp_sw_dh_data *h)
{ {
unsigned char cmd[6] = { TEST_UNIT_READY }; unsigned char cmd[6] = { TEST_UNIT_READY };
struct scsi_sense_hdr sshdr; struct scsi_sense_hdr sshdr;
int ret = SCSI_DH_OK, res; int ret, res;
blk_opf_t opf = REQ_OP_DRV_IN | REQ_FAILFAST_DEV | blk_opf_t opf = REQ_OP_DRV_IN | REQ_FAILFAST_DEV |
REQ_FAILFAST_TRANSPORT | REQ_FAILFAST_DRIVER; REQ_FAILFAST_TRANSPORT | REQ_FAILFAST_DRIVER;
const struct scsi_exec_args exec_args = { const struct scsi_exec_args exec_args = {
...@@ -92,19 +92,18 @@ static int hp_sw_tur(struct scsi_device *sdev, struct hp_sw_dh_data *h) ...@@ -92,19 +92,18 @@ static int hp_sw_tur(struct scsi_device *sdev, struct hp_sw_dh_data *h)
retry: retry:
res = scsi_execute_cmd(sdev, cmd, opf, NULL, 0, HP_SW_TIMEOUT, res = scsi_execute_cmd(sdev, cmd, opf, NULL, 0, HP_SW_TIMEOUT,
HP_SW_RETRIES, &exec_args); HP_SW_RETRIES, &exec_args);
if (res) { if (res > 0 && scsi_sense_valid(&sshdr)) {
if (scsi_sense_valid(&sshdr))
ret = tur_done(sdev, h, &sshdr); ret = tur_done(sdev, h, &sshdr);
else { } else if (res == 0) {
h->path_state = HP_SW_PATH_ACTIVE;
ret = SCSI_DH_OK;
} else {
sdev_printk(KERN_WARNING, sdev, sdev_printk(KERN_WARNING, sdev,
"%s: sending tur failed with %x\n", "%s: sending tur failed with %x\n",
HP_SW_NAME, res); HP_SW_NAME, res);
ret = SCSI_DH_IO; ret = SCSI_DH_IO;
} }
} else {
h->path_state = HP_SW_PATH_ACTIVE;
ret = SCSI_DH_OK;
}
if (ret == SCSI_DH_IMM_RETRY) if (ret == SCSI_DH_IMM_RETRY)
goto retry; goto retry;
...@@ -122,7 +121,7 @@ static int hp_sw_start_stop(struct hp_sw_dh_data *h) ...@@ -122,7 +121,7 @@ static int hp_sw_start_stop(struct hp_sw_dh_data *h)
unsigned char cmd[6] = { START_STOP, 0, 0, 0, 1, 0 }; unsigned char cmd[6] = { START_STOP, 0, 0, 0, 1, 0 };
struct scsi_sense_hdr sshdr; struct scsi_sense_hdr sshdr;
struct scsi_device *sdev = h->sdev; struct scsi_device *sdev = h->sdev;
int res, rc = SCSI_DH_OK; int res, rc;
int retry_cnt = HP_SW_RETRIES; int retry_cnt = HP_SW_RETRIES;
blk_opf_t opf = REQ_OP_DRV_IN | REQ_FAILFAST_DEV | blk_opf_t opf = REQ_OP_DRV_IN | REQ_FAILFAST_DEV |
REQ_FAILFAST_TRANSPORT | REQ_FAILFAST_DRIVER; REQ_FAILFAST_TRANSPORT | REQ_FAILFAST_DRIVER;
...@@ -133,13 +132,15 @@ static int hp_sw_start_stop(struct hp_sw_dh_data *h) ...@@ -133,13 +132,15 @@ static int hp_sw_start_stop(struct hp_sw_dh_data *h)
retry: retry:
res = scsi_execute_cmd(sdev, cmd, opf, NULL, 0, HP_SW_TIMEOUT, res = scsi_execute_cmd(sdev, cmd, opf, NULL, 0, HP_SW_TIMEOUT,
HP_SW_RETRIES, &exec_args); HP_SW_RETRIES, &exec_args);
if (res) { if (!res) {
if (!scsi_sense_valid(&sshdr)) { return SCSI_DH_OK;
} else if (res < 0 || !scsi_sense_valid(&sshdr)) {
sdev_printk(KERN_WARNING, sdev, sdev_printk(KERN_WARNING, sdev,
"%s: sending start_stop_unit failed, " "%s: sending start_stop_unit failed, "
"no sense available\n", HP_SW_NAME); "no sense available\n", HP_SW_NAME);
return SCSI_DH_IO; return SCSI_DH_IO;
} }
switch (sshdr.sense_key) { switch (sshdr.sense_key) {
case NOT_READY: case NOT_READY:
if (sshdr.asc == 0x04 && sshdr.ascq == 3) { if (sshdr.asc == 0x04 && sshdr.ascq == 3) {
...@@ -161,7 +162,7 @@ static int hp_sw_start_stop(struct hp_sw_dh_data *h) ...@@ -161,7 +162,7 @@ static int hp_sw_start_stop(struct hp_sw_dh_data *h)
sshdr.sense_key, sshdr.asc, sshdr.ascq); sshdr.sense_key, sshdr.asc, sshdr.ascq);
rc = SCSI_DH_IO; rc = SCSI_DH_IO;
} }
}
return rc; return rc;
} }
......
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