Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 788ce43a authored by James Bottomley's avatar James Bottomley Committed by James Bottomley
Browse files

[SCSI] SCSI core: fix leakage of scsi_cmnd's



Actually, just one problem and one cosmetic fix:

1) We need to dequeue for the loop and kill case (it seems easiest
simply to dequeue in the scsi_kill_request() routine)
2) There's no real need to drop the queue lock.  __scsi_done() is lock
agnostic, so since there's no requirement, let's just leave it in to
avoid any locking issues.

Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent e91442b6
Loading
Loading
Loading
Loading
+2 −3
Original line number Diff line number Diff line
@@ -1370,7 +1370,8 @@ static void scsi_kill_request(struct request *req, request_queue_t *q)
{
	struct scsi_cmnd *cmd = req->special;

	spin_unlock(q->queue_lock);
	blkdev_dequeue_request(req);

	if (unlikely(cmd == NULL)) {
		printk(KERN_CRIT "impossible request in %s.\n",
				 __FUNCTION__);
@@ -1381,7 +1382,6 @@ static void scsi_kill_request(struct request *req, request_queue_t *q)
	cmd->result = DID_NO_CONNECT << 16;
	atomic_inc(&cmd->device->iorequest_cnt);
	__scsi_done(cmd);
	spin_lock(q->queue_lock);
}

/*
@@ -1432,7 +1432,6 @@ static void scsi_request_fn(struct request_queue *q)
		if (unlikely(!scsi_device_online(sdev))) {
			printk(KERN_ERR "scsi%d (%d:%d): rejecting I/O to offline device\n",
			       sdev->host->host_no, sdev->id, sdev->lun);
			blkdev_dequeue_request(req);
			scsi_kill_request(req, q);
			continue;
		}