Message ID | 20210106144208.1935-1-liew.s.piaw@gmail.com |
---|---|
Headers | show |
Series | bcm63xx_enet: major makeover of driver | expand |
On 1/6/21 6:42 AM, Sieng Piaw Liew wrote: > This patch series aim to improve the bcm63xx_enet driver by integrating the > latest networking features, i.e. batched rx processing, BQL, build_skb, > etc. > > The newer enetsw SoCs are found to be able to do unaligned rx DMA by adding > NET_IP_ALIGN padding which, combined with these patches, improved packet > processing performance by ~50% on BCM6328. > > Older non-enetsw SoCs still benefit mainly from rx batching. Performance > improvement of ~30% is observed on BCM6333. > > The BCM63xx SoCs are designed for routers. As such, having BQL is > beneficial as well as trivial to add. > > v3: > * Simplify xmit_more patch by not moving around the code needlessly. > * Fix indentation in xmit_more patch. > * Fix indentation in build_skb patch. > * Split rx ring cleanup patch from build_skb patch and precede build_skb > patch for better understanding, as suggested by Florian Fainelli. Thanks for addressing the feedback given, for patches that have not changed, please carry forward any tag you have been given (Reviewed-by, Acked-by, etc.) such that we don't have to reply to those patches again.
On 1/6/21 6:42 AM, Sieng Piaw Liew wrote: > Add Byte Queue Limits support to reduce/remove bufferbloat in > bcm63xx_enet. > > Signed-off-by: Sieng Piaw Liew <liew.s.piaw@gmail.com> Acked-by: Florian Fainelli <f.fainelli@gmail.com>
On 1/6/21 6:42 AM, Sieng Piaw Liew wrote: > Use netdev_alloc_skb_ip_align on newer SoCs with integrated switch > (enetsw) when refilling RX. Increases packet processing performance > by 30% (with netif_receive_skb_list). > > Non-enetsw SoCs cannot function with the extra pad so continue to use > the regular netdev_alloc_skb. > > Tested on BCM6328 320 MHz and iperf3 -M 512 to measure packet/sec > performance. > > Before: > [ ID] Interval Transfer Bandwidth Retr > [ 4] 0.00-30.00 sec 120 MBytes 33.7 Mbits/sec 277 sender > [ 4] 0.00-30.00 sec 120 MBytes 33.5 Mbits/sec receiver > > After (+netif_receive_skb_list): > [ 4] 0.00-30.00 sec 155 MBytes 43.3 Mbits/sec 354 sender > [ 4] 0.00-30.00 sec 154 MBytes 43.1 Mbits/sec receiver > > Signed-off-by: Sieng Piaw Liew <liew.s.piaw@gmail.com> Acked-by: Florian Fainelli <f.fainelli@gmail.com>
On Wed, 6 Jan 2021 22:42:01 +0800 Sieng Piaw Liew wrote: > This patch series aim to improve the bcm63xx_enet driver by integrating the > latest networking features, i.e. batched rx processing, BQL, build_skb, > etc. > > The newer enetsw SoCs are found to be able to do unaligned rx DMA by adding > NET_IP_ALIGN padding which, combined with these patches, improved packet > processing performance by ~50% on BCM6328. > > Older non-enetsw SoCs still benefit mainly from rx batching. Performance > improvement of ~30% is observed on BCM6333. > > The BCM63xx SoCs are designed for routers. As such, having BQL is > beneficial as well as trivial to add. > > v3: > * Simplify xmit_more patch by not moving around the code needlessly. > * Fix indentation in xmit_more patch. > * Fix indentation in build_skb patch. > * Split rx ring cleanup patch from build_skb patch and precede build_skb > patch for better understanding, as suggested by Florian Fainelli. > > v2: > * Add xmit_more support and rx loop improvisation patches. > * Moved BQL netdev_reset_queue() to bcm_enet_stop()/bcm_enetsw_stop() > functions as suggested by Florian Fainelli. > * Improved commit messages. Applied, thanks!