bonding: handle link transition from FAIL to UP correctly
authorMahesh Bandewar <maheshb@google.com>
Wed, 12 Apr 2017 05:36:00 +0000 (22:36 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 13 Apr 2017 17:48:59 +0000 (13:48 -0400)
When link transitions from LINK_FAIL to LINK_UP, the commit phase is
not called. This leads to an erroneous state causing slave-link state to
get stuck in "going down" state while its speed and duplex are perfectly
fine. This issue is a side-effect of splitting link-set into propose and
commit phases introduced by de77ecd4ef02 ("bonding: improve link-status
update in mii-monitoring")

This patch fixes these issues by calling commit phase whenever link
state change is proposed.

Fixes: de77ecd4ef02 ("bonding: improve link-status update in mii-monitoring")
Signed-off-by: Mahesh Bandewar <maheshb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/bonding/bond_main.c

index aba7352906a5a3744cd96337cd3c391cc722177c..01e4a69af421319953dad2d8f88f714b8b1a2f69 100644 (file)
@@ -2064,6 +2064,7 @@ static int bond_miimon_inspect(struct bonding *bond)
                                            (bond->params.downdelay - slave->delay) *
                                            bond->params.miimon,
                                            slave->dev->name);
+                               commit++;
                                continue;
                        }
 
@@ -2098,7 +2099,7 @@ static int bond_miimon_inspect(struct bonding *bond)
                                            (bond->params.updelay - slave->delay) *
                                            bond->params.miimon,
                                            slave->dev->name);
-
+                               commit++;
                                continue;
                        }