aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390
diff options
context:
space:
mode:
authorMartin Petermann <martin@linux.vnet.ibm.com>2009-04-17 09:08:01 -0400
committerJames Bottomley <James.Bottomley@HansenPartnership.com>2009-04-27 11:07:15 -0400
commit135ea137e3c2872448c12d3a8890389fa64990c6 (patch)
tree017f0ca49ddf8a0e02d5aeaef1e6e9db924b8495 /drivers/s390
parentb4efdd586bc08cdf5977cad0a90091f44546a930 (diff)
[SCSI] zfcp: Avoid referencing freed memory in req send
Avoid referencing a fsf request after sending it in fcp_fsf_req_send, it might have already completed and deallocated. Signed-off-by: Martin Petermann <martin@linux.vnet.ibm.com> Signed-off-by: Christof Schmitt <christof.schmitt@de.ibm.com> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/s390')
-rw-r--r--drivers/s390/scsi/zfcp_fsf.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/s390/scsi/zfcp_fsf.c b/drivers/s390/scsi/zfcp_fsf.c
index b29f3121b66..fa896dc600b 100644
--- a/drivers/s390/scsi/zfcp_fsf.c
+++ b/drivers/s390/scsi/zfcp_fsf.c
@@ -766,8 +766,9 @@ static struct zfcp_fsf_req *zfcp_fsf_req_create(struct zfcp_adapter *adapter,
766static int zfcp_fsf_req_send(struct zfcp_fsf_req *req) 766static int zfcp_fsf_req_send(struct zfcp_fsf_req *req)
767{ 767{
768 struct zfcp_adapter *adapter = req->adapter; 768 struct zfcp_adapter *adapter = req->adapter;
769 unsigned long flags; 769 unsigned long flags;
770 int idx; 770 int idx;
771 int with_qtcb = (req->qtcb != NULL);
771 772
772 /* put allocated FSF request into hash table */ 773 /* put allocated FSF request into hash table */
773 spin_lock_irqsave(&adapter->req_list_lock, flags); 774 spin_lock_irqsave(&adapter->req_list_lock, flags);
@@ -789,7 +790,7 @@ static int zfcp_fsf_req_send(struct zfcp_fsf_req *req)
789 } 790 }
790 791
791 /* Don't increase for unsolicited status */ 792 /* Don't increase for unsolicited status */
792 if (req->qtcb) 793 if (with_qtcb)
793 adapter->fsf_req_seq_no++; 794 adapter->fsf_req_seq_no++;
794 adapter->req_no++; 795 adapter->req_no++;
795 796