From: Dan Carpenter Date: Mon, 30 Jul 2012 08:16:35 +0000 (+0300) Subject: [SCSI] ipr: missing unlock before a return X-Git-Tag: v3.7-rc1~136^2^2~170 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d995e1b7c0e92af038d9ac322e35b3caaf905b10;p=profile%2Fivi%2Fkernel-x86-ivi.git [SCSI] ipr: missing unlock before a return We recently changed the locking in this function, but this return was missed. It needs an unlock and the IRQs need to be restored. Signed-off-by: Dan Carpenter Acked-by: Brian King Signed-off-by: James Bottomley --- diff --git a/drivers/scsi/ipr.c b/drivers/scsi/ipr.c index 07b14ba..7a5ccb2c 100644 --- a/drivers/scsi/ipr.c +++ b/drivers/scsi/ipr.c @@ -5874,8 +5874,11 @@ static int ipr_queuecommand(struct Scsi_Host *shost, goto err_nodev; } - if (ipr_is_gata(res) && res->sata_port) - return ata_sas_queuecmd(scsi_cmd, res->sata_port->ap); + if (ipr_is_gata(res) && res->sata_port) { + rc = ata_sas_queuecmd(scsi_cmd, res->sata_port->ap); + spin_unlock_irqrestore(shost->host_lock, lock_flags); + return rc; + } ipr_cmd = __ipr_get_free_ipr_cmnd(ioa_cfg); spin_unlock_irqrestore(shost->host_lock, lock_flags);