drivers/net/{e1000|igc}: fix reinit for RX/TX rings

Descriptor head is managed by HW and should not be modified by SW unless:
1. device is after a reset
2. device is before enabling TX or RX

Also set correct tail for RX which should point at the end of ring
(descriptor ring is zero-indexed).

Signed-off-by: p-szafonimateusz <p-szafonimateusz@xiaomi.com>
This commit is contained in:
p-szafonimateusz 2025-06-03 14:07:56 +02:00 committed by Xiang Xiao
parent bdde180d7a
commit 0f537dcb97
2 changed files with 26 additions and 10 deletions

View file

@ -484,6 +484,9 @@ static void e1000_dump_mem(FAR struct e1000_driver_s *priv,
* Returned Value:
* None
*
* Assumption:
* This function can be called only after card reset and when TX is disabled
*
*****************************************************************************/
static void e1000_txclean(FAR struct e1000_driver_s *priv)
@ -524,6 +527,9 @@ static void e1000_txclean(FAR struct e1000_driver_s *priv)
* Returned Value:
* None
*
* Assumption:
* This function can be called only after card reset and when RX is disabled
*
*****************************************************************************/
static void e1000_rxclean(FAR struct e1000_driver_s *priv)
@ -531,7 +537,7 @@ static void e1000_rxclean(FAR struct e1000_driver_s *priv)
priv->rx_now = 0;
e1000_putreg_mem(priv, E1000_RDH, 0);
e1000_putreg_mem(priv, E1000_RDT, 0);
e1000_putreg_mem(priv, E1000_RDT, E1000_RX_DESC - 1);
}
/*****************************************************************************
@ -1179,6 +1185,12 @@ static void e1000_disable(FAR struct e1000_driver_s *priv)
e1000_putreg_mem(priv, E1000_RCTL, 0);
/* We have to reset device, otherwise writing to RDH and THD corrupts
* the device state.
*/
e1000_putreg_mem(priv, E1000_CTRL, E1000_CTRL_RST);
/* Reset Tx tail */
e1000_txclean(priv);
@ -1287,10 +1299,6 @@ static void e1000_enable(FAR struct e1000_driver_s *priv)
e1000_rxclean(priv);
/* All RX descriptors available */
e1000_putreg_mem(priv, E1000_RDT, E1000_RX_DESC);
/* Enable interrupts */
e1000_putreg_mem(priv, E1000_IMS, priv->irqs);

View file

@ -438,6 +438,9 @@ static void igc_dump_mem(FAR struct igc_driver_s *priv, FAR const char *msg)
* Returned Value:
* None
*
* Assumption:
* This function can be called only after card reset and when TX is disabled
*
*****************************************************************************/
static void igc_txclean(FAR struct igc_driver_s *priv)
@ -478,6 +481,9 @@ static void igc_txclean(FAR struct igc_driver_s *priv)
* Returned Value:
* None
*
* Assumption:
* This function can be called only after card reset and when RX is disabled
*
*****************************************************************************/
static void igc_rxclean(FAR struct igc_driver_s *priv)
@ -485,7 +491,7 @@ static void igc_rxclean(FAR struct igc_driver_s *priv)
priv->rx_now = 0;
igc_putreg_mem(priv, IGC_RDH0, 0);
igc_putreg_mem(priv, IGC_RDT0, 0);
igc_putreg_mem(priv, IGC_RDT0, IGC_RX_DESC - 1);
}
/*****************************************************************************
@ -1061,6 +1067,12 @@ static void igc_disable(FAR struct igc_driver_s *priv)
igc_putreg_mem(priv, IGC_RCTL, 0);
/* We have to reset device, otherwise writing to RDH and THD corrupts
* the device state.
*/
igc_putreg_mem(priv, IGC_CTRL, IGC_CTRL_DEVRST);
/* Reset Tx tail */
igc_txclean(priv);
@ -1214,10 +1226,6 @@ static void igc_enable(FAR struct igc_driver_s *priv)
igc_rxclean(priv);
/* All RX descriptors available */
igc_putreg_mem(priv, IGC_RDT0, IGC_RX_DESC);
#ifdef CONFIG_DEBUG_NET_INFO
/* Dump memory */