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 Ensure we don't call workqueue_enqueue() i...
details: https://anonhg.NetBSD.org/src/rev/71395165b462
branches: trunk
changeset: 969046:71395165b462
user: thorpej <thorpej%NetBSD.org@localhost>
date: Thu Feb 06 06:28:49 2020 +0000
description:
Ensure we don't call workqueue_enqueue() if the pluggable optics
handler is already pending.
diffstat:
sys/dev/pci/ixgbe/ixgbe.c | 31 +++++++++++++++++++------------
sys/dev/pci/ixgbe/ixgbe.h | 3 ++-
2 files changed, 21 insertions(+), 13 deletions(-)
diffs (104 lines):
diff -r 42e421e0e842 -r 71395165b462 sys/dev/pci/ixgbe/ixgbe.c
--- a/sys/dev/pci/ixgbe/ixgbe.c Thu Feb 06 02:17:24 2020 +0000
+++ b/sys/dev/pci/ixgbe/ixgbe.c Thu Feb 06 06:28:49 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ixgbe.c,v 1.225 2020/02/05 07:45:46 msaitoh Exp $ */
+/* $NetBSD: ixgbe.c,v 1.226 2020/02/06 06:28:49 thorpej Exp $ */
/******************************************************************************
@@ -1507,6 +1507,18 @@
}
} /* ixgbe_is_sfp */
+static void
+ixgbe_schedule_msf_tasklet(struct adapter *adapter)
+{
+ if (adapter->schedule_wqs_ok) {
+ if (!adapter->msf_pending) {
+ adapter->msf_pending = true;
+ workqueue_enqueue(adapter->msf_wq,
+ &adapter->msf_wc, NULL);
+ }
+ }
+}
+
/************************************************************************
* ixgbe_config_link
************************************************************************/
@@ -1523,9 +1535,7 @@
if (hw->phy.multispeed_fiber) {
ixgbe_enable_tx_laser(hw);
kpreempt_disable();
- if (adapter->schedule_wqs_ok)
- workqueue_enqueue(adapter->msf_wq,
- &adapter->msf_wc, NULL);
+ ixgbe_schedule_msf_tasklet(adapter);
kpreempt_enable();
}
kpreempt_disable();
@@ -3099,9 +3109,7 @@
(eicr & IXGBE_EICR_GPI_SDP1_BY_MAC(hw))) {
IXGBE_WRITE_REG(hw, IXGBE_EICR,
IXGBE_EICR_GPI_SDP1_BY_MAC(hw));
- if (adapter->schedule_wqs_ok)
- workqueue_enqueue(adapter->msf_wq,
- &adapter->msf_wc, NULL);
+ ixgbe_schedule_msf_tasklet(adapter);
}
}
@@ -4674,8 +4682,7 @@
goto out;
}
}
- if (adapter->schedule_wqs_ok)
- workqueue_enqueue(adapter->msf_wq, &adapter->msf_wc, NULL);
+ ixgbe_schedule_msf_tasklet(adapter);
out:
IXGBE_CORE_UNLOCK(adapter);
} /* ixgbe_handle_mod */
@@ -4703,6 +4710,7 @@
IFNET_LOCK(ifp);
IXGBE_CORE_LOCK(adapter);
+ adapter->msf_pending = false;
++adapter->msf_sicount.ev_count;
/* get_supported_phy_layer will call hw->phy.ops.identify_sfp() */
adapter->phy_layer = ixgbe_get_supported_physical_layer(hw);
@@ -4754,6 +4762,7 @@
IXGBE_CORE_UNLOCK(adapter);
workqueue_wait(adapter->msf_wq, &adapter->msf_wc);
+ adapter->msf_pending = false;
}
/************************************************************************
@@ -5122,9 +5131,7 @@
(eicr & IXGBE_EICR_GPI_SDP1_BY_MAC(hw))) {
IXGBE_WRITE_REG(hw, IXGBE_EICR,
IXGBE_EICR_GPI_SDP1_BY_MAC(hw));
- if (adapter->schedule_wqs_ok)
- workqueue_enqueue(adapter->msf_wq,
- &adapter->msf_wc, NULL);
+ ixgbe_schedule_msf_tasklet(adapter);
}
}
diff -r 42e421e0e842 -r 71395165b462 sys/dev/pci/ixgbe/ixgbe.h
--- a/sys/dev/pci/ixgbe/ixgbe.h Thu Feb 06 02:17:24 2020 +0000
+++ b/sys/dev/pci/ixgbe/ixgbe.h Thu Feb 06 06:28:49 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ixgbe.h,v 1.64 2020/02/05 07:45:46 msaitoh Exp $ */
+/* $NetBSD: ixgbe.h,v 1.65 2020/02/06 06:28:49 thorpej Exp $ */
/******************************************************************************
SPDX-License-Identifier: BSD-3-Clause
@@ -515,6 +515,7 @@
void *mod_si; /* SFP tasklet */
struct workqueue *msf_wq; /* Multispeed Fiber */
struct work msf_wc;
+ bool msf_pending;
void *mbx_si; /* VF -> PF mailbox interrupt */
/* Flow Director */
Home |
Main Index |
Thread Index |
Old Index