diff options
| author | Benjamin Poirier <bpoirier@suse.com> | 2017-07-21 21:36:26 +0300 |
|---|---|---|
| committer | Jeff Kirsher <jeffrey.t.kirsher@intel.com> | 2017-10-10 18:35:01 +0300 |
| commit | 19110cfbb34d4af0cdfe14cd243f3b09dc95b013 (patch) | |
| tree | d3e23b6c58c955bc6e38c0a31d3a0d1f7ad8de99 /scripts/const_structs.checkpatch | |
| parent | d3509f8bc7b0560044c15f0e3ecfde1d9af757a6 (diff) | |
| download | linux-19110cfbb34d4af0cdfe14cd243f3b09dc95b013.tar.xz | |
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 <lsorense@csclub.uwaterloo.ca>
Signed-off-by: Benjamin Poirier <bpoirier@suse.com>
Tested-by: Aaron Brown <aaron.f.brown@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'scripts/const_structs.checkpatch')
0 files changed, 0 insertions, 0 deletions
