In fc_disc_gpn_ft_parse(), after fc_disc_done() is called, the
disc state is changed by setting buf_len = 0.  This is wrong
since the discovery may have restarted.   Instead, return
after calling fc_disc_done.

Also, return an error on memory allocation failure.

Signed-off-by: Joe Eykholt <[email protected]>
---
 drivers/scsi/libfc/fc_disc.c |    7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)


diff --git a/drivers/scsi/libfc/fc_disc.c b/drivers/scsi/libfc/fc_disc.c
index f42e646..cda5d98 100644
--- a/drivers/scsi/libfc/fc_disc.c
+++ b/drivers/scsi/libfc/fc_disc.c
@@ -478,6 +478,7 @@ static int fc_disc_gpn_ft_parse(struct fc_disc *disc, void 
*buf, size_t len)
        plen = len;
        np = (struct fc_gpn_ft_resp *)bp;
        tlen = disc->buf_len;
+       disc->buf_len = 0;
        if (tlen) {
                WARN_ON(tlen >= sizeof(*np));
                plen = sizeof(*np) - tlen;
@@ -518,10 +519,12 @@ static int fc_disc_gpn_ft_parse(struct fc_disc *disc, 
void *buf, size_t len)
                        rdata = lport->tt.rport_create(lport, &ids);
                        if (rdata)
                                rdata->disc_id = disc->disc_id;
-                       else
+                       else {
                                printk(KERN_WARNING "libfc: Failed to allocate "
                                       "memory for the newly discovered port "
                                       "(%6x)\n", ids.port_id);
+                               error = -ENOMEM;
+                       }
                }
 
                if (np->fp_flags & FC_NS_FID_LAST) {
@@ -545,8 +548,6 @@ static int fc_disc_gpn_ft_parse(struct fc_disc *disc, void 
*buf, size_t len)
                        memcpy(&disc->partial_buf, np, len);
                }
                disc->buf_len = (unsigned char) len;
-       } else {
-               disc->buf_len = 0;
        }
        return error;
 }


_______________________________________________
devel mailing list
[email protected]
http://www.open-fcoe.org/mailman/listinfo/devel

Reply via email to