summaryrefslogtreecommitdiffstats
path: root/drivers/hwmon/lm78.c
diff options
context:
space:
mode:
authorAlexander Duyck <alexander.h.duyck@intel.com>2014-07-26 02:42:44 +0000
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>2014-09-12 00:40:10 -0700
commitadc810900a703ee78fe88fd65e086d359fec04b2 (patch)
tree630c23311b79427ddc0f57d1755df43b6412ddc5 /drivers/hwmon/lm78.c
parent15be71c92f10169600b5980ee06836614836057b (diff)
downloadlinux-adc810900a703ee78fe88fd65e086d359fec04b2.tar.gz
linux-adc810900a703ee78fe88fd65e086d359fec04b2.tar.bz2
linux-adc810900a703ee78fe88fd65e086d359fec04b2.zip
ixgbe: Refactor busy poll socket code to address multiple issues
This change addresses several issues in the current ixgbe implementation of busy poll sockets. First was the fact that it was possible for frames to be delivered out of order if they were held in GRO. This is addressed by flushing the GRO buffers before releasing the q_vector back to the idle state. The other issue was the fact that we were having to take a spinlock on changing the state to and from idle. To resolve this I have replaced the state value with an atomic and use atomic_cmpxchg to change the value from idle, and a simple atomic set to restore it back to idle after we have acquired it. This allows us to only use a locked operation on acquiring the vector without a need for a locked operation to release it. Signed-off-by: Alexander Duyck <alexander.h.duyck@intel.com> Tested-by: Phil Schmitt <phillip.j.schmitt@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'drivers/hwmon/lm78.c')
0 files changed, 0 insertions, 0 deletions