Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/pci/ixgbe - ixv_enableintr(): Fix a bug that ixv_ena...



details:   https://anonhg.NetBSD.org/src/rev/74cdcf98649a
branches:  trunk
changeset: 356592:74cdcf98649a
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Wed Oct 04 11:03:20 2017 +0000

description:
- ixv_enableintr(): Fix a bug that ixv_enable_queue() is called with incorrect
  argument. This bug was added in rev. 1.68.
- Don't check neither VTEICR nor VTEICS same as Linux. It seems that both
  registers can't be used to check which MSI-X vector is triggered. A bit is
  set on very low probability and the bit location is incorrect. Is this an
  errata?

diffstat:

 sys/dev/pci/ixgbe/ixv.c |  16 +++++-----------
 1 files changed, 5 insertions(+), 11 deletions(-)

diffs (41 lines):

diff -r e15d92148c03 -r 74cdcf98649a sys/dev/pci/ixgbe/ixv.c
--- a/sys/dev/pci/ixgbe/ixv.c   Wed Oct 04 09:59:24 2017 +0000
+++ b/sys/dev/pci/ixgbe/ixv.c   Wed Oct 04 11:03:20 2017 +0000
@@ -1,4 +1,4 @@
-/*$NetBSD: ixv.c,v 1.68 2017/10/03 03:12:29 msaitoh Exp $*/
+/*$NetBSD: ixv.c,v 1.69 2017/10/04 11:03:20 msaitoh Exp $*/
 
 /******************************************************************************
 
@@ -912,20 +912,13 @@
 {
        struct adapter  *adapter = arg;
        struct ixgbe_hw *hw = &adapter->hw;
-       u32             reg;
 
        ++adapter->link_irq.ev_count;
-
-       /* First get the cause */
-       reg = IXGBE_READ_REG(hw, IXGBE_VTEICR);
-#if 0  /* NetBSD: We use auto-clear, so it's not required to write VTEICR */
-       /* Clear interrupt with write */
-       IXGBE_WRITE_REG(hw, IXGBE_VTEICR, (1 << adapter->vector));
-#endif
+       /* NetBSD: We use auto-clear, so it's not required to write VTEICR */
 
        /* Link status change */
-       if (reg & (1 << adapter->vector))
-               softint_schedule(adapter->link_si);
+       hw->mac.get_link_status = TRUE;
+       softint_schedule(adapter->link_si);
 
        IXGBE_WRITE_REG(hw, IXGBE_VTEIMS, (1 << adapter->vector));
 
@@ -1865,6 +1858,7 @@
 
        /* For VTEIMS */
        IXGBE_WRITE_REG(hw, IXGBE_VTEIMS, (1 << adapter->vector));
+       que = adapter->queues;
        for (i = 0; i < adapter->num_queues; i++, que++)
                ixv_enable_queue(adapter, que->msix);
 



Home | Main Index | Thread Index | Old Index