]> git.baikalelectronics.ru Git - kernel.git/commitdiff
igbvf: avoid reset storms due to mailbox issues
authorAlexander Duyck <alexander.h.duyck@intel.com>
Sat, 12 Dec 2009 06:58:14 +0000 (22:58 -0800)
committerDavid S. Miller <davem@davemloft.net>
Sat, 12 Dec 2009 06:58:14 +0000 (22:58 -0800)
From: Alexander Duyck <alexander.h.duyck@intel.com>

This change makes it so that reset/interrupt storms can be avoided when
there are mailbox issues.  The new behavior is to only allow the device to
trigger mailbox related resets only once every 10 seconds.

Signed-off-by: Alexander Duyck <alexander.h.duyck@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/igbvf/igbvf.h
drivers/net/igbvf/netdev.c

index 3d1ee7a8478e77a0723dc3f1b25ff169fe020067..a1774b29d222093851ce46e29d5871d9cc69e286 100644 (file)
@@ -276,6 +276,7 @@ struct igbvf_adapter {
        unsigned long led_status;
 
        unsigned int flags;
+       unsigned long last_reset;
 };
 
 struct igbvf_info {
index a127620dc6531689d11d479d8eddf3701307da30..e9dd95f136aa8432d1542fc344a19cd0acdf3abb 100644 (file)
@@ -1469,6 +1469,8 @@ static void igbvf_reset(struct igbvf_adapter *adapter)
                memcpy(netdev->perm_addr, adapter->hw.mac.addr,
                       netdev->addr_len);
        }
+
+       adapter->last_reset = jiffies;
 }
 
 int igbvf_up(struct igbvf_adapter *adapter)
@@ -1812,11 +1814,15 @@ static bool igbvf_has_link(struct igbvf_adapter *adapter)
        s32 ret_val = E1000_SUCCESS;
        bool link_active;
 
+       /* If interface is down, stay link down */
+       if (test_bit(__IGBVF_DOWN, &adapter->state))
+               return false;
+
        ret_val = hw->mac.ops.check_for_link(hw);
        link_active = !hw->mac.get_link_status;
 
        /* if check for link returns error we will need to reset */
-       if (ret_val)
+       if (ret_val && time_after(jiffies, adapter->last_reset + (10 * HZ)))
                schedule_work(&adapter->reset_task);
 
        return link_active;