>-----Original Message-----
>From: Vladimir Oltean <olte...@gmail.com>
>Sent: Saturday, April 17, 2021 2:42 AM
>To: Jakub Kicinski <k...@kernel.org>; David S. Miller
><da...@davemloft.net>; netdev@vger.kernel.org; Po Liu
><po....@nxp.com>
>Cc: Claudiu Manoil <claudiu.man...@nxp.com>; Alexandru Marginean
><alexandru.margin...@nxp.com>; Rob Herring <robh...@kernel.org>;
>Shawn Guo <shawn...@kernel.org>; linux-arm-ker...@lists.infradead.org;
>devicet...@vger.kernel.org; Russell King - ARM Linux admin
><li...@armlinux.org.uk>; Andrew Lunn <and...@lunn.ch>; Michael Walle
><mich...@walle.cc>; Vladimir Oltean <vladimir.olt...@nxp.com>
>Subject: [PATCH net-next 5/5] net: enetc: add support for flow control
>
>From: Vladimir Oltean <vladimir.olt...@nxp.com>
>
>In the ENETC receive path, a frame received by the MAC is first stored
>in a 256KB 'FIFO' memory, then transferred to DRAM when enqueuing it to
>the RX ring. The FIFO is a shared resource for all ENETC ports, but
>every port keeps track of its own memory utilization, on RX and on TX.
>
>There is a setting for RX rings through which they can either operate in
>'lossy' mode (where the lack of a free buffer causes an immediate
>discard of the frame) or in 'lossless' mode (where the lack of a free
>buffer in the ring makes the frame stay longer in the FIFO).
>
>In turn, when the memory utilization of the FIFO exceeds a certain
>margin, the MAC can be configured to emit PAUSE frames.
>
>There is enough FIFO memory to buffer up to 3 MTU-sized frames per RX
>port while not jeopardizing the other use cases (jumbo frames), and
>also not consume bytes from the port TX allocations. Also, 3 MTU-sized
>frames worth of memory is enough to ensure zero loss for 64 byte packets
>at 1G line rate.
>
>Signed-off-by: Vladimir Oltean <vladimir.olt...@nxp.com>

Reviewed-by: Claudiu Manoil <claudiu.man...@nxp.com>

Reply via email to