Call ixgbe_ifstop() instead of ixgbe_stop_locked() in
ixgbe_setup_low_power_mode() to stop the timer workqueue.
This commit is contained in:
parent
4895509f32
commit
b600995833
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: ixgbe.c,v 1.252 2020/08/31 14:12:50 msaitoh Exp $ */
|
/* $NetBSD: ixgbe.c,v 1.253 2020/09/01 04:06:56 msaitoh Exp $ */
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
|
|
||||||
@ -3600,12 +3600,10 @@ ixgbe_detach(device_t dev, int flags)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Stop the interface. ixgbe_setup_low_power_mode() calls
|
* Stop the interface. ixgbe_setup_low_power_mode() calls
|
||||||
* ixgbe_stop_locked(), so it's not required to call ixgbe_stop_locked()
|
* ixgbe_ifstop(), so it's not required to call ixgbe_ifstop()
|
||||||
* directly.
|
* directly.
|
||||||
*/
|
*/
|
||||||
IXGBE_CORE_LOCK(adapter);
|
|
||||||
ixgbe_setup_low_power_mode(adapter);
|
ixgbe_setup_low_power_mode(adapter);
|
||||||
IXGBE_CORE_UNLOCK(adapter);
|
|
||||||
|
|
||||||
callout_halt(&adapter->timer, NULL);
|
callout_halt(&adapter->timer, NULL);
|
||||||
if (adapter->feat_en & IXGBE_FEATURE_RECOVERY_MODE) {
|
if (adapter->feat_en & IXGBE_FEATURE_RECOVERY_MODE) {
|
||||||
@ -3773,16 +3771,15 @@ ixgbe_setup_low_power_mode(struct adapter *adapter)
|
|||||||
{
|
{
|
||||||
struct ixgbe_hw *hw = &adapter->hw;
|
struct ixgbe_hw *hw = &adapter->hw;
|
||||||
device_t dev = adapter->dev;
|
device_t dev = adapter->dev;
|
||||||
|
struct ifnet *ifp = adapter->ifp;
|
||||||
s32 error = 0;
|
s32 error = 0;
|
||||||
|
|
||||||
KASSERT(mutex_owned(&adapter->core_mtx));
|
|
||||||
|
|
||||||
/* Limit power management flow to X550EM baseT */
|
/* Limit power management flow to X550EM baseT */
|
||||||
if (hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T &&
|
if (hw->device_id == IXGBE_DEV_ID_X550EM_X_10G_T &&
|
||||||
hw->phy.ops.enter_lplu) {
|
hw->phy.ops.enter_lplu) {
|
||||||
/* X550EM baseT adapters need a special LPLU flow */
|
/* X550EM baseT adapters need a special LPLU flow */
|
||||||
hw->phy.reset_disable = true;
|
hw->phy.reset_disable = true;
|
||||||
ixgbe_stop_locked(adapter);
|
ixgbe_ifstop(ifp, 1);
|
||||||
error = hw->phy.ops.enter_lplu(hw);
|
error = hw->phy.ops.enter_lplu(hw);
|
||||||
if (error)
|
if (error)
|
||||||
device_printf(dev,
|
device_printf(dev,
|
||||||
@ -3790,9 +3787,11 @@ ixgbe_setup_low_power_mode(struct adapter *adapter)
|
|||||||
hw->phy.reset_disable = false;
|
hw->phy.reset_disable = false;
|
||||||
} else {
|
} else {
|
||||||
/* Just stop for other adapters */
|
/* Just stop for other adapters */
|
||||||
ixgbe_stop_locked(adapter);
|
ixgbe_ifstop(ifp, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IXGBE_CORE_LOCK(adapter);
|
||||||
|
|
||||||
if (!hw->wol_enabled) {
|
if (!hw->wol_enabled) {
|
||||||
ixgbe_set_phy_power(hw, FALSE);
|
ixgbe_set_phy_power(hw, FALSE);
|
||||||
IXGBE_WRITE_REG(hw, IXGBE_WUFC, 0);
|
IXGBE_WRITE_REG(hw, IXGBE_WUFC, 0);
|
||||||
@ -3820,6 +3819,8 @@ ixgbe_setup_low_power_mode(struct adapter *adapter)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IXGBE_CORE_UNLOCK(adapter);
|
||||||
|
|
||||||
return error;
|
return error;
|
||||||
} /* ixgbe_setup_low_power_mode */
|
} /* ixgbe_setup_low_power_mode */
|
||||||
|
|
||||||
@ -3835,9 +3836,7 @@ ixgbe_shutdown(device_t dev)
|
|||||||
|
|
||||||
INIT_DEBUGOUT("ixgbe_shutdown: begin");
|
INIT_DEBUGOUT("ixgbe_shutdown: begin");
|
||||||
|
|
||||||
IXGBE_CORE_LOCK(adapter);
|
|
||||||
error = ixgbe_setup_low_power_mode(adapter);
|
error = ixgbe_setup_low_power_mode(adapter);
|
||||||
IXGBE_CORE_UNLOCK(adapter);
|
|
||||||
|
|
||||||
return (error);
|
return (error);
|
||||||
} /* ixgbe_shutdown */
|
} /* ixgbe_shutdown */
|
||||||
@ -3856,12 +3855,8 @@ ixgbe_suspend(device_t dev, const pmf_qual_t *qual)
|
|||||||
|
|
||||||
INIT_DEBUGOUT("ixgbe_suspend: begin");
|
INIT_DEBUGOUT("ixgbe_suspend: begin");
|
||||||
|
|
||||||
IXGBE_CORE_LOCK(adapter);
|
|
||||||
|
|
||||||
error = ixgbe_setup_low_power_mode(adapter);
|
error = ixgbe_setup_low_power_mode(adapter);
|
||||||
|
|
||||||
IXGBE_CORE_UNLOCK(adapter);
|
|
||||||
|
|
||||||
return (error);
|
return (error);
|
||||||
} /* ixgbe_suspend */
|
} /* ixgbe_suspend */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user