Re: [PATCH 4/7] net: stmmac: Parse FIFO sizes from feature registers

From: Thierry Reding
Date: Thu Mar 09 2017 - 14:42:11 EST


On Thu, Mar 02, 2017 at 03:09:11PM +0000, Joao Pinto wrote:
> Hi Thierry,
>
> Ãs 5:24 PM de 2/23/2017, Thierry Reding escreveu:
> > From: Thierry Reding <treding@xxxxxxxxxx>
> >
> > New version of this core encode the FIFO sizes in one of the feature
> > registers. Use these sizes as default, but still allow device tree to
> > override them for backwards compatibility.
> >
> > Signed-off-by: Thierry Reding <treding@xxxxxxxxxx>
> > ---
> > drivers/net/ethernet/stmicro/stmmac/common.h | 3 +++
> > drivers/net/ethernet/stmicro/stmmac/dwmac4_dma.c | 2 ++
> > drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 3 +++
> > 3 files changed, 8 insertions(+)
> >
> > diff --git a/drivers/net/ethernet/stmicro/stmmac/common.h b/drivers/net/ethernet/stmicro/stmmac/common.h
> > index 144fe84e8a53..6ac653845d82 100644
> > --- a/drivers/net/ethernet/stmicro/stmmac/common.h
> > +++ b/drivers/net/ethernet/stmicro/stmmac/common.h
> > @@ -324,6 +324,9 @@ struct dma_features {
> > unsigned int number_tx_queues;
> > /* Alternate (enhanced) DESC mode */
> > unsigned int enh_desc;
> > + /* TX and RX FIFO sizes */
> > + unsigned int tx_fifo_size;
> > + unsigned int rx_fifo_size;
> > };
> >
> > /* GMAC TX FIFO is 8K, Rx FIFO is 16K */
> > diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac4_dma.c b/drivers/net/ethernet/stmicro/stmmac/dwmac4_dma.c
> > index 377d1b44d4f2..8d249f3b34c8 100644
> > --- a/drivers/net/ethernet/stmicro/stmmac/dwmac4_dma.c
> > +++ b/drivers/net/ethernet/stmicro/stmmac/dwmac4_dma.c
> > @@ -296,6 +296,8 @@ static void dwmac4_get_hw_feature(void __iomem *ioaddr,
> > hw_cap = readl(ioaddr + GMAC_HW_FEATURE1);
> > dma_cap->av = (hw_cap & GMAC_HW_FEAT_AVSEL) >> 20;
> > dma_cap->tsoen = (hw_cap & GMAC_HW_TSOEN) >> 18;
> > + dma_cap->tx_fifo_size = 128 << ((hw_cap >> 6) & 0x1f);
> > + dma_cap->rx_fifo_size = 128 << ((hw_cap >> 0) & 0x1f);
>
> I suggest you follow the way that has been done for other parameters:
>
> dma_cap->rx_fifo_size = (hw_cap & GMAC_HW_RXFIFOSIZE) >> 0; where
> GMAC_HW_RXFIFOSIZE is GENMASK(4, 0)
> dma_cap->tx_fifo_size = (hw_cap & GMAC_HW_TXFIFOSIZE) >> 6; where
> GMAC_HW_TXFIFOSIZE is GENMASK(10, 6)

Okay, can do.

> > /* MAC HW feature2 */
> > hw_cap = readl(ioaddr + GMAC_HW_FEATURE2);
> > /* TX and RX number of channels */
> > diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
> > index d7387919bdb6..291e34f0ca94 100644
> > --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
> > +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
> > @@ -1281,6 +1281,9 @@ static void stmmac_dma_operation_mode(struct stmmac_priv *priv)
> > {
> > int rxfifosz = priv->plat->rx_fifo_size;
> >
> > + if (rxfifosz == 0)
> > + rxfifosz = priv->dma_cap.rx_fifo_size;
> > +
> > if (priv->plat->force_thresh_dma_mode)
> > priv->hw->dma->dma_mode(priv->ioaddr, tc, tc, rxfifosz);
> > else if (priv->plat->force_sf_dma_mode || priv->plat->tx_coe) {
> >
>
> In my current patch for adding support for MTL in stmmac, I also had this
> approach (sizes comming from feature register and platform data) so nice to see
> it here, because I will be able to reutilize it in my future versions.
>
> There is only a slight twist that we have to pay attention to it. The RX and TX
> queue size configuration needs to be one the following values:
>
> FIFO_256 = 0x0,
> FIFO_512 = 0x1,
> FIFO_1k = 0x3,
> FIFO_2k = 0x7,
> FIFO_4k = 0xf,
> FIFO_8k = 0x1f,
> FIFO_16k = 0x3f,
> FIFO_32k = 0x7f
>
> These are the values you get from the features register, but are these the
> values that users will configure in "plat->rx_fifo_size"? From a quick grep you
> can see that users use real units:
>
> arch/arm/boot/dts/socfpga.dtsi: rx-fifo-depth = <4096>;
> arch/arm/boot/dts/socfpga.dtsi: rx-fifo-depth = <4096>;
> arch/arm/boot/dts/socfpga_arria10.dtsi: rx-fifo-depth = <16384>;
> arch/arm/boot/dts/socfpga_arria10.dtsi: rx-fifo-depth = <16384>;
> arch/arm/boot/dts/socfpga_arria10.dtsi: rx-fifo-depth = <16384>;
> arch/arm/boot/dts/lpc18xx.dtsi: rx-fifo-depth = <256>;
> arch/nios2/boot/dts/3c120_devboard.dts: rx-fifo-depth = <8192>;
> arch/nios2/boot/dts/10m50_devboard.dts: rx-fifo-depth = <8192>;
>
> So in order to have it configurable from platform and features register you need
> to convert the features values to "real" units and then in the end when you
> write to the DMA Op Mode you need to convert it back to the required values.

That's what the "128 << " part in dwmac4_get_hw_feature() does. As far
as I can tell, that's equivalent to dwmac4_get_real_fifo_sz() function
from your patch, but it's more compact.

> You can check my patch here that already has this done:
> http://patchwork.ozlabs.org/patch/728566/

I see that there's a bit of overlap between that patch and this series.
How do you want to handle this? Do you want me to rebase on top of your
patch, or would you prefer this series to get merged first and rework
your patch on top of it?

Thanks,
Thierry

Attachment: signature.asc
Description: PGP signature