mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
[SCSI] qla2xxx: Check for empty slot in request queue before posting Command type 6 request.
For ISP82xx, the check for empty slot in request queue before posting command type 6 request was missing. This could lead to request queue entry corruptions causing IO timeouts. Signed-off-by: Giridhar Malavali <giridhar.malavali@qlogic.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
This commit is contained in:
parent
0374f55ed8
commit
1bd58b89e8
1 changed files with 13 additions and 0 deletions
|
@ -2672,6 +2672,19 @@ qla82xx_start_scsi(srb_t *sp)
|
||||||
sufficient_dsds:
|
sufficient_dsds:
|
||||||
req_cnt = 1;
|
req_cnt = 1;
|
||||||
|
|
||||||
|
if (req->cnt < (req_cnt + 2)) {
|
||||||
|
cnt = (uint16_t)RD_REG_DWORD_RELAXED(
|
||||||
|
®->req_q_out[0]);
|
||||||
|
if (req->ring_index < cnt)
|
||||||
|
req->cnt = cnt - req->ring_index;
|
||||||
|
else
|
||||||
|
req->cnt = req->length -
|
||||||
|
(req->ring_index - cnt);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (req->cnt < (req_cnt + 2))
|
||||||
|
goto queuing_error;
|
||||||
|
|
||||||
ctx = sp->ctx = mempool_alloc(ha->ctx_mempool, GFP_ATOMIC);
|
ctx = sp->ctx = mempool_alloc(ha->ctx_mempool, GFP_ATOMIC);
|
||||||
if (!sp->ctx) {
|
if (!sp->ctx) {
|
||||||
DEBUG(printk(KERN_INFO
|
DEBUG(printk(KERN_INFO
|
||||||
|
|
Loading…
Reference in a new issue