* [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).