diff options
author | Boaz Harrosh <bharrosh@panasas.com> | 2007-12-13 13:43:22 -0500 |
---|---|---|
committer | James Bottomley <James.Bottomley@HansenPartnership.com> | 2008-01-11 19:28:22 -0500 |
commit | 7207fea452cfdd2d4e2f4419e2c31f570edbade3 (patch) | |
tree | d240295f67ad9286295516dabc9949d5d3739700 /drivers/scsi/iscsi_tcp.c | |
parent | da32dd681f7a1a17073c42b375fc23cf73c92155 (diff) |
[SCSI] iscsi: Prettify resid handling and some extra checks
- Check to see that OVERFLOW is not negative indicating
a bug.
- Unify handling of UNDERFLOW and OVERFLOW to the same
code.
- Also handle BIDI_OVERFLOW.
Signed-off-by: Boaz Harrosh <bharrosh@panasas.com>
Signed-off-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/scsi/iscsi_tcp.c')
-rw-r--r-- | drivers/scsi/iscsi_tcp.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/drivers/scsi/iscsi_tcp.c b/drivers/scsi/iscsi_tcp.c index 1b540e03f5bf..fd88777df28b 100644 --- a/drivers/scsi/iscsi_tcp.c +++ b/drivers/scsi/iscsi_tcp.c | |||
@@ -507,22 +507,20 @@ iscsi_data_rsp(struct iscsi_conn *conn, struct iscsi_cmd_task *ctask) | |||
507 | } | 507 | } |
508 | 508 | ||
509 | if (rhdr->flags & ISCSI_FLAG_DATA_STATUS) { | 509 | if (rhdr->flags & ISCSI_FLAG_DATA_STATUS) { |
510 | sc->result = (DID_OK << 16) | rhdr->cmd_status; | ||
510 | conn->exp_statsn = be32_to_cpu(rhdr->statsn) + 1; | 511 | conn->exp_statsn = be32_to_cpu(rhdr->statsn) + 1; |
511 | if (rhdr->flags & ISCSI_FLAG_DATA_UNDERFLOW) { | 512 | if (rhdr->flags & (ISCSI_FLAG_DATA_UNDERFLOW | |
513 | ISCSI_FLAG_DATA_OVERFLOW)) { | ||
512 | int res_count = be32_to_cpu(rhdr->residual_count); | 514 | int res_count = be32_to_cpu(rhdr->residual_count); |
513 | 515 | ||
514 | if (res_count > 0 && | 516 | if (res_count > 0 && |
515 | res_count <= scsi_bufflen(sc)) { | 517 | (rhdr->flags & ISCSI_FLAG_CMD_OVERFLOW || |
518 | res_count <= scsi_bufflen(sc))) | ||
516 | scsi_set_resid(sc, res_count); | 519 | scsi_set_resid(sc, res_count); |
517 | sc->result = (DID_OK << 16) | rhdr->cmd_status; | 520 | else |
518 | } else | ||
519 | sc->result = (DID_BAD_TARGET << 16) | | 521 | sc->result = (DID_BAD_TARGET << 16) | |
520 | rhdr->cmd_status; | 522 | rhdr->cmd_status; |
521 | } else if (rhdr->flags & ISCSI_FLAG_DATA_OVERFLOW) { | 523 | } |
522 | scsi_set_resid(sc, be32_to_cpu(rhdr->residual_count)); | ||
523 | sc->result = (DID_OK << 16) | rhdr->cmd_status; | ||
524 | } else | ||
525 | sc->result = (DID_OK << 16) | rhdr->cmd_status; | ||
526 | } | 524 | } |
527 | 525 | ||
528 | conn->datain_pdus_cnt++; | 526 | conn->datain_pdus_cnt++; |