aboutsummaryrefslogtreecommitdiff
path: root/drivers/net/ethernet/intel/igb/igb_main.c
diff options
context:
space:
mode:
authorBenjamin Poirier <[email protected]>2017-07-21 11:36:26 -0700
committerJeff Kirsher <[email protected]>2017-10-10 08:35:01 -0700
commit19110cfbb34d4af0cdfe14cd243f3b09dc95b013 (patch)
treed3e23b6c58c955bc6e38c0a31d3a0d1f7ad8de99 /drivers/net/ethernet/intel/igb/igb_main.c
parentd3509f8bc7b0560044c15f0e3ecfde1d9af757a6 (diff)
e1000e: Separate signaling for link check/link up
Lennart reported the following race condition: \ e1000_watchdog_task \ e1000e_has_link \ hw->mac.ops.check_for_link() === e1000e_check_for_copper_link /* link is up */ mac->get_link_status = false; /* interrupt */ \ e1000_msix_other hw->mac.get_link_status = true; link_active = !hw->mac.get_link_status /* link_active is false, wrongly */ This problem arises because the single flag get_link_status is used to signal two different states: link status needs checking and link status is down. Avoid the problem by using the return value of .check_for_link to signal the link status to e1000e_has_link(). Reported-by: Lennart Sorensen <[email protected]> Signed-off-by: Benjamin Poirier <[email protected]> Tested-by: Aaron Brown <[email protected]> Signed-off-by: Jeff Kirsher <[email protected]>
Diffstat (limited to 'drivers/net/ethernet/intel/igb/igb_main.c')
0 files changed, 0 insertions, 0 deletions