Call ixgbe_ifstop() instead of ixgbe_stop_locked() in

ixgbe_setup_low_power_mode() to stop the timer workqueue.
This commit is contained in:
msaitoh 2020-09-01 04:06:56 +00:00
parent 4895509f32
commit b600995833

View File

@ -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 */