On Wed, 2009-07-01 at 20:37 +0800, jack wang wrote: > >From 24abd7f05d2293e03aacbdd9d620d6378ea5e2aa Mon Sep 17 00:00:00 2001 > From: Tom Peng <tom_peng@xxxxxxxxx> > Date: Wed, 1 Jul 2009 19:04:01 +0800 > Subject: [PATCH 3/5] reuse the original port when reenable the phy in a port > > Signed-off-by: Tom Peng <tom_peng@xxxxxxxxx> > Signed-off-by: Jack Wang <jack_wang@xxxxxxxxx> > Signed-off-by: Lindar Liu <lindar_liu@xxxxxxxxx> > --- > drivers/scsi/libsas/sas_port.c | 19 +++++++++++++++---- > 1 files changed, 15 insertions(+), 4 deletions(-) > > diff --git a/drivers/scsi/libsas/sas_port.c b/drivers/scsi/libsas/sas_port.c > index e6ac59c..5aad165 100644 > --- a/drivers/scsi/libsas/sas_port.c > +++ b/drivers/scsi/libsas/sas_port.c > @@ -69,16 +69,27 @@ static void sas_form_port(struct asd_sas_phy *phy) > SAS_DPRINTK("phy%d matched wide port%d\n", phy->id, > port->id); > break; > - } else if (*(u64 *) port->sas_addr == 0 && > port->num_phys==0) { > - memcpy(port->sas_addr, phy->sas_addr, > SAS_ADDR_SIZE); > - break; > } > spin_unlock(&port->phy_list_lock); > } > + /* The phy does not match any port currently existed, create new one > */ > + if (i == sas_ha->num_phys) { > + for (i = 0; i < sas_ha->num_phys; i++) { > + port = sas_ha->sas_port[i]; > + spin_lock(&port->phy_list_lock); > + if (*(u64 *)port->sas_addr == 0 > + && port->num_phys == 0) { > + memcpy(port->sas_addr, phy->sas_addr, > + SAS_ADDR_SIZE); > + break; > + } > + spin_unlock(&port->phy_list_lock); > + } > + } I don't understand why you need this. It seems identical to the else leg of the if in the for loop above it, so it wouldn't seem to add anything to the code. James -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html