]> git.baikalelectronics.ru Git - kernel.git/commit
ixgbe: fix EICR write in ixgbe_msix_other
authorJacob Keller <jacob.e.keller@intel.com>
Sat, 2 Mar 2013 07:51:42 +0000 (07:51 +0000)
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>
Fri, 26 Apr 2013 01:59:07 +0000 (18:59 -0700)
commitcb64bdf4acac9905730e9f63f302d9ff89ae6dcd
tree39d746a48f81b828705380a27c32165a658f3712
parent18a1a3ca292cdb584effaeb266d5b2f7edd70db0
ixgbe: fix EICR write in ixgbe_msix_other

Previously, the ixgbe_msix_other was writing the full 32bits of the set
interrupts, instead of only the ones which the ixgbe_msix_other is
handling. This resulted in a loss of performance when the X540's PPS feature is
enabled due to sometimes clearing queue interrupts which resulted in the driver
not getting the interrupt for cleaning the q_vector rings often enough. The fix
is to simply mask the lower 16bits off so that this handler does not write them
in the EICR, which causes them to remain high and be properly handled by the
clean_rings interrupt routine as normal.

Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
Cc: stable <stable@vger.kernel.org>
Tested-by: Phil Schmitt <phillip.j.schmitt@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
drivers/net/ethernet/intel/ixgbe/ixgbe_main.c