Commit d075db51 authored by Vladimir Oltean's avatar Vladimir Oltean Committed by Jakub Kicinski

net: enetc: bring "bool extended" to top-level in enetc_open()

Extended RX buffer descriptors are necessary if they carry RX
timestamps, which will be true when PTP timestamping is enabled.

Right now, the rx_ring->ext_en is set from the function that allocates
ring resources (enetc_alloc_rx_resources() -> enetc_alloc_rxbdr()), and
also used later, in enetc_setup_rxbdr(). It is also used in the
enetc_rxbd() and enetc_rxbd_next() fast path helpers.

We want to decouple resource allocation from BD ring setup, but both
procedures depend on BD size (extended or not). Move the "extended"
boolean to enetc_open() and pass it both to the RX allocation procedure
as well as to the RX ring setup procedure. The latter will set
rx_ring->ext_en from now on.
Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent bbd6043f
...@@ -1829,8 +1829,6 @@ static int enetc_alloc_rxbdr(struct enetc_bdr *rxr, bool extended) ...@@ -1829,8 +1829,6 @@ static int enetc_alloc_rxbdr(struct enetc_bdr *rxr, bool extended)
return err; return err;
} }
rxr->ext_en = extended;
return 0; return 0;
} }
...@@ -1842,9 +1840,8 @@ static void enetc_free_rxbdr(struct enetc_bdr *rxr) ...@@ -1842,9 +1840,8 @@ static void enetc_free_rxbdr(struct enetc_bdr *rxr)
rxr->rx_swbd = NULL; rxr->rx_swbd = NULL;
} }
static int enetc_alloc_rx_resources(struct enetc_ndev_priv *priv) static int enetc_alloc_rx_resources(struct enetc_ndev_priv *priv, bool extended)
{ {
bool extended = !!(priv->active_offloads & ENETC_F_RX_TSTAMP);
int i, err; int i, err;
for (i = 0; i < priv->num_rx_rings; i++) { for (i = 0; i < priv->num_rx_rings; i++) {
...@@ -2022,7 +2019,8 @@ static void enetc_setup_txbdr(struct enetc_hw *hw, struct enetc_bdr *tx_ring) ...@@ -2022,7 +2019,8 @@ static void enetc_setup_txbdr(struct enetc_hw *hw, struct enetc_bdr *tx_ring)
tx_ring->idr = hw->reg + ENETC_SITXIDR; tx_ring->idr = hw->reg + ENETC_SITXIDR;
} }
static void enetc_setup_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring) static void enetc_setup_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring,
bool extended)
{ {
int idx = rx_ring->index; int idx = rx_ring->index;
u32 rbmr; u32 rbmr;
...@@ -2054,6 +2052,7 @@ static void enetc_setup_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring) ...@@ -2054,6 +2052,7 @@ static void enetc_setup_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring)
rbmr = ENETC_RBMR_EN; rbmr = ENETC_RBMR_EN;
rx_ring->ext_en = extended;
if (rx_ring->ext_en) if (rx_ring->ext_en)
rbmr |= ENETC_RBMR_BDS; rbmr |= ENETC_RBMR_BDS;
...@@ -2075,7 +2074,7 @@ static void enetc_setup_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring) ...@@ -2075,7 +2074,7 @@ static void enetc_setup_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring)
enetc_rxbdr_wr(hw, idx, ENETC_RBMR, rbmr); enetc_rxbdr_wr(hw, idx, ENETC_RBMR, rbmr);
} }
static void enetc_setup_bdrs(struct enetc_ndev_priv *priv) static void enetc_setup_bdrs(struct enetc_ndev_priv *priv, bool extended)
{ {
struct enetc_hw *hw = &priv->si->hw; struct enetc_hw *hw = &priv->si->hw;
int i; int i;
...@@ -2084,7 +2083,7 @@ static void enetc_setup_bdrs(struct enetc_ndev_priv *priv) ...@@ -2084,7 +2083,7 @@ static void enetc_setup_bdrs(struct enetc_ndev_priv *priv)
enetc_setup_txbdr(hw, priv->tx_ring[i]); enetc_setup_txbdr(hw, priv->tx_ring[i]);
for (i = 0; i < priv->num_rx_rings; i++) for (i = 0; i < priv->num_rx_rings; i++)
enetc_setup_rxbdr(hw, priv->rx_ring[i]); enetc_setup_rxbdr(hw, priv->rx_ring[i], extended);
} }
static void enetc_clear_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring) static void enetc_clear_rxbdr(struct enetc_hw *hw, struct enetc_bdr *rx_ring)
...@@ -2308,8 +2307,11 @@ int enetc_open(struct net_device *ndev) ...@@ -2308,8 +2307,11 @@ int enetc_open(struct net_device *ndev)
{ {
struct enetc_ndev_priv *priv = netdev_priv(ndev); struct enetc_ndev_priv *priv = netdev_priv(ndev);
int num_stack_tx_queues; int num_stack_tx_queues;
bool extended;
int err; int err;
extended = !!(priv->active_offloads & ENETC_F_RX_TSTAMP);
err = enetc_setup_irqs(priv); err = enetc_setup_irqs(priv);
if (err) if (err)
return err; return err;
...@@ -2322,7 +2324,7 @@ int enetc_open(struct net_device *ndev) ...@@ -2322,7 +2324,7 @@ int enetc_open(struct net_device *ndev)
if (err) if (err)
goto err_alloc_tx; goto err_alloc_tx;
err = enetc_alloc_rx_resources(priv); err = enetc_alloc_rx_resources(priv, extended);
if (err) if (err)
goto err_alloc_rx; goto err_alloc_rx;
...@@ -2337,7 +2339,7 @@ int enetc_open(struct net_device *ndev) ...@@ -2337,7 +2339,7 @@ int enetc_open(struct net_device *ndev)
goto err_set_queues; goto err_set_queues;
enetc_tx_onestep_tstamp_init(priv); enetc_tx_onestep_tstamp_init(priv);
enetc_setup_bdrs(priv); enetc_setup_bdrs(priv, extended);
enetc_start(ndev); enetc_start(ndev);
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment