mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-18 10:46:41 +00:00
87b03d9961
Add the required changes for kernel 6.1 support. Signed-off-by: Robert Marko <robimarko@gmail.com>
57 lines
1.8 KiB
Diff
57 lines
1.8 KiB
Diff
From ae4fe8fb79b68f4cf4a887434ab6a8a9a1c65bfc Mon Sep 17 00:00:00 2001
|
|
From: Robert Marko <robimarko@gmail.com>
|
|
Date: Thu, 23 Jun 2022 14:18:50 +0200
|
|
Subject: [PATCH] nss-dp: edma-v1: use NAPI GRO by default
|
|
|
|
Utilize napi_gro_receive instead of plain netif_receive_skb on EDMA v1.
|
|
|
|
Usually it provides quite a lot of RX speed improvements, however in some
|
|
cases it may lead to decreased performance as there is no checksum
|
|
offloading implemented.
|
|
|
|
In cases where reduced performance is experienced its possible to disable
|
|
GRO by using ethtool.
|
|
|
|
Signed-off-by: Robert Marko <robimarko@gmail.com>
|
|
---
|
|
hal/dp_ops/edma_dp/edma_v1/edma_data_plane.c | 10 ++++++----
|
|
hal/dp_ops/edma_dp/edma_v1/edma_tx_rx.c | 8 ++++++--
|
|
2 files changed, 12 insertions(+), 6 deletions(-)
|
|
|
|
--- a/hal/dp_ops/edma_dp/edma_v1/edma_data_plane.c
|
|
+++ b/hal/dp_ops/edma_dp/edma_v1/edma_data_plane.c
|
|
@@ -589,10 +589,12 @@ drop:
|
|
*/
|
|
static void edma_if_set_features(struct nss_dp_data_plane_ctx *dpc)
|
|
{
|
|
- /*
|
|
- * TODO - add flags to support HIGHMEM/cksum offload VLAN
|
|
- * the features are enabled.
|
|
- */
|
|
+ struct net_device *netdev = dpc->dev;
|
|
+
|
|
+ netdev->features |= NETIF_F_GRO;
|
|
+ netdev->hw_features |= NETIF_F_GRO;
|
|
+ netdev->vlan_features |= NETIF_F_GRO;
|
|
+ netdev->wanted_features |= NETIF_F_GRO;
|
|
}
|
|
|
|
/* TODO - check if this is needed */
|
|
--- a/hal/dp_ops/edma_dp/edma_v1/edma_tx_rx.c
|
|
+++ b/hal/dp_ops/edma_dp/edma_v1/edma_tx_rx.c
|
|
@@ -410,8 +410,12 @@ static uint32_t edma_clean_rx(struct edm
|
|
if (unlikely(EDMA_RXPH_SERVICE_CODE_GET(rxph) ==
|
|
NSS_PTP_EVENT_SERVICE_CODE))
|
|
nss_phy_tstamp_rx_buf(ndev, skb);
|
|
- else
|
|
- netif_receive_skb(skb);
|
|
+ else {
|
|
+ if (likely(ndev->features & NETIF_F_GRO))
|
|
+ napi_gro_receive(&ehw->napi, skb);
|
|
+ else
|
|
+ netif_receive_skb(skb);
|
|
+ }
|
|
|
|
next_rx_desc:
|
|
/*
|