[openib-general] [PATCH 1/2 vex branch] IB/VNIC Fix failover from secondary path back to primary path

Ramachandra K ramachandra.kuchimanchi at qlogic.com
Thu Dec 7 03:02:48 PST 2006


This fixes a bug due to which failover from secondary path back to primary path
was not working.

Signed-off-by: Ramachandra K <ramachandra.kuchimanchi at qlogic.com>
---

 drivers/infiniband/ulp/vnic/vnic_ib.c   |    4 +++-
 drivers/infiniband/ulp/vnic/vnic_main.c |    9 +++++----
 2 files changed, 8 insertions(+), 5 deletions(-)

diff --git a/drivers/infiniband/ulp/vnic/vnic_ib.c b/drivers/infiniband/ulp/vnic/vnic_ib.c
index 6196e20..56ae9f7 100644
--- a/drivers/infiniband/ulp/vnic/vnic_ib.c
+++ b/drivers/infiniband/ulp/vnic/vnic_ib.c
@@ -303,10 +303,12 @@ int vnic_ib_get_path(struct netpath *net
 			       " path record query\n",
 			       config->path_info.status);
 
-		netpath_timer(netpath, vnic->config->no_path_timeout);
 		ret = config->path_info.status;
 	}
 out:
+	if (ret)
+		netpath_timer(netpath, vnic->config->no_path_timeout);
+
 	return ret;
 }
 
diff --git a/drivers/infiniband/ulp/vnic/vnic_main.c b/drivers/infiniband/ulp/vnic/vnic_main.c
index fca2b90..e15d3f9 100644
--- a/drivers/infiniband/ulp/vnic/vnic_main.c
+++ b/drivers/infiniband/ulp/vnic/vnic_main.c
@@ -710,17 +710,18 @@ static struct vnic * vnic_handle_npevent
 	case VNIC_PRINP_TIMEREXPIRED:
 		netpath = &vnic->primary_path;
 		netpath->timer_state = NETPATH_TS_EXPIRED;
-		if (netpath->carrier)
+		if (!netpath->carrier)
 			update_path_and_reconnect(netpath, vnic);
 		break;
 	case VNIC_SECNP_TIMEREXPIRED:
 		netpath = &vnic->secondary_path;
 		netpath->timer_state = NETPATH_TS_EXPIRED;
-		if (netpath->carrier) {
+		if (!netpath->carrier)
+			update_path_and_reconnect(netpath, vnic);
+		else {
 			if (vnic->state == VNIC_UNINITIALIZED)
 				vnic_npevent_register(vnic, netpath);
-		} else
-			update_path_and_reconnect(netpath, vnic);
+		}
 		break;
 	case VNIC_PRINP_LINKUP:
 		vnic->primary_path.carrier = 1;






More information about the general mailing list