From b9242a7b5b1a00686e57d8012bd19a530cdc8dd8 Mon Sep 17 00:00:00 2001 From: Shyam Sundar Date: Thu, 19 Jul 2007 15:05:59 -0700 Subject: [PATCH] --- yaml --- r: 62729 b: refs/heads/master c: 8084fe168a5252548cdddf2ed181c337fecd0523 h: refs/heads/master i: 62727: c761fc9034d056c6c9981e3b6e3d7eebc88f6454 v: v3 --- [refs] | 2 +- trunk/drivers/scsi/qla2xxx/qla_isr.c | 19 +++++++++++++++++++ 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 81dbdb6a1f10..3b0e6504a5d1 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 5881569bb33cdb0d4cdcd44d9ca2551ab04fb811 +refs/heads/master: 8084fe168a5252548cdddf2ed181c337fecd0523 diff --git a/trunk/drivers/scsi/qla2xxx/qla_isr.c b/trunk/drivers/scsi/qla2xxx/qla_isr.c index fa21cd86e9e2..4a50b931ca6f 100644 --- a/trunk/drivers/scsi/qla2xxx/qla_isr.c +++ b/trunk/drivers/scsi/qla2xxx/qla_isr.c @@ -1062,6 +1062,25 @@ qla2x00_status_entry(scsi_qla_host_t *ha, void *pkt) cp->device->id, cp->device->lun, cp, cp->serial_number)); + /* + * In case of a Underrun condition, set both the lscsi + * status and the completion status to appropriate + * values. + */ + if (resid && + ((unsigned)(cp->request_bufflen - resid) < + cp->underflow)) { + DEBUG2(qla_printk(KERN_INFO, ha, + "scsi(%ld:%d:%d:%d): Mid-layer underflow " + "detected (%x of %x bytes)...returning " + "error status.\n", ha->host_no, + cp->device->channel, cp->device->id, + cp->device->lun, resid, + cp->request_bufflen)); + + cp->result = DID_ERROR << 16 | lscsi_status; + } + if (sense_len) DEBUG5(qla2x00_dump_buffer(cp->sense_buffer, CMD_ACTUAL_SNSLEN(cp)));