linux-scsi.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 2/2] bnx2i : Fix "cid #n not valid" issue
@ 2009-07-30  4:50 Anil Veerabhadrappa
  2009-08-18 17:48 ` Mike Christie
  0 siblings, 1 reply; 2+ messages in thread
From: Anil Veerabhadrappa @ 2009-07-30  4:50 UTC (permalink / raw)
  To: James.Bottomley; +Cc: linux-scsi, open-iscsi, michaelc, mchan


    * when bnx2i_adapter_ready() fails, connection handle(cid) = 0 is
      wrongly freed because 'cid' is not yet allocated for the endpoint
    * Fix is to initialize bnx2i_ep->ep_iscsi_cid to '-1' in bnx2i_alloc_ep()
      and not in bnx2i_ep_connect() to avoid releasing invalid 'cid'
    * There is already a check in bnx2i_free_iscsi_cid() not to free
      invalid iscsi connection handle (-1)

Signed-off-by: Anil Veerabhadrappa <anilgv@broadcom.com>
---
 drivers/scsi/bnx2i/bnx2i_iscsi.c |    3 +--
 1 files changed, 1 insertions(+), 2 deletions(-)

diff --git a/drivers/scsi/bnx2i/bnx2i_iscsi.c b/drivers/scsi/bnx2i/bnx2i_iscsi.c
index 9535bb6..08d0bfc 100644
--- a/drivers/scsi/bnx2i/bnx2i_iscsi.c
+++ b/drivers/scsi/bnx2i/bnx2i_iscsi.c
@@ -387,6 +387,7 @@ static struct iscsi_endpoint *bnx2i_alloc_ep(struct bnx2i_hba *hba)
 	bnx2i_ep = ep->dd_data;
 	INIT_LIST_HEAD(&bnx2i_ep->link);
 	bnx2i_ep->state = EP_STATE_IDLE;
+	bnx2i_ep->ep_iscsi_cid = (u16) -1;
 	bnx2i_ep->hba = hba;
 	bnx2i_ep->hba_age = hba->age;
 	hba->ofld_conns_active++;
@@ -1678,8 +1679,6 @@ static struct iscsi_endpoint *bnx2i_ep_connect(struct Scsi_Host *shost,
 		goto net_if_down;
 	}
 
-	bnx2i_ep->state = EP_STATE_IDLE;
-	bnx2i_ep->ep_iscsi_cid = (u16) -1;
 	bnx2i_ep->num_active_cmds = 0;
 	iscsi_cid = bnx2i_alloc_iscsi_cid(hba);
 	if (iscsi_cid == -1) {
-- 
1.5.4.3





^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH 2/2] bnx2i : Fix "cid #n not valid" issue
  2009-07-30  4:50 [PATCH 2/2] bnx2i : Fix "cid #n not valid" issue Anil Veerabhadrappa
@ 2009-08-18 17:48 ` Mike Christie
  0 siblings, 0 replies; 2+ messages in thread
From: Mike Christie @ 2009-08-18 17:48 UTC (permalink / raw)
  To: open-iscsi; +Cc: James.Bottomley, linux-scsi, mchan

On 07/29/2009 11:50 PM, Anil Veerabhadrappa wrote:
>
>      * when bnx2i_adapter_ready() fails, connection handle(cid) = 0 is
>        wrongly freed because 'cid' is not yet allocated for the endpoint
>      * Fix is to initialize bnx2i_ep->ep_iscsi_cid to '-1' in bnx2i_alloc_ep()
>        and not in bnx2i_ep_connect() to avoid releasing invalid 'cid'
>      * There is already a check in bnx2i_free_iscsi_cid() not to free
>        invalid iscsi connection handle (-1)
>
> Signed-off-by: Anil Veerabhadrappa<anilgv@broadcom.com>

This looks ok, but I think I got a review comment to change some of my 
code to use the definitions in kernel.h. So below you would want to use 
USHORT_MAX.

I am not sure if it will prevent the patch from getting merged or not 
since it will work either way.

Reviewed-by: Mike Christie <michaelc@cs.wisc.edu>



> ---
>   drivers/scsi/bnx2i/bnx2i_iscsi.c |    3 +--
>   1 files changed, 1 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/scsi/bnx2i/bnx2i_iscsi.c b/drivers/scsi/bnx2i/bnx2i_iscsi.c
> index 9535bb6..08d0bfc 100644
> --- a/drivers/scsi/bnx2i/bnx2i_iscsi.c
> +++ b/drivers/scsi/bnx2i/bnx2i_iscsi.c
> @@ -387,6 +387,7 @@ static struct iscsi_endpoint *bnx2i_alloc_ep(struct bnx2i_hba *hba)
>   	bnx2i_ep = ep->dd_data;
>   	INIT_LIST_HEAD(&bnx2i_ep->link);
>   	bnx2i_ep->state = EP_STATE_IDLE;
> +	bnx2i_ep->ep_iscsi_cid = (u16) -1;
>   	bnx2i_ep->hba = hba;
>   	bnx2i_ep->hba_age = hba->age;
>   	hba->ofld_conns_active++;
> @@ -1678,8 +1679,6 @@ static struct iscsi_endpoint *bnx2i_ep_connect(struct Scsi_Host *shost,
>   		goto net_if_down;
>   	}
>
> -	bnx2i_ep->state = EP_STATE_IDLE;
> -	bnx2i_ep->ep_iscsi_cid = (u16) -1;
>   	bnx2i_ep->num_active_cmds = 0;
>   	iscsi_cid = bnx2i_alloc_iscsi_cid(hba);
>   	if (iscsi_cid == -1) {


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2009-08-18 17:48 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-07-30  4:50 [PATCH 2/2] bnx2i : Fix "cid #n not valid" issue Anil Veerabhadrappa
2009-08-18 17:48 ` Mike Christie

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).