net: marvell: return csum computation result from mvneta_rx_csum/mvpp2_rx_csum
authorLorenzo Bianconi <lorenzo@kernel.org>
Tue, 22 Jun 2021 17:18:31 +0000 (19:18 +0200)
committerDavid S. Miller <davem@davemloft.net>
Tue, 22 Jun 2021 17:55:05 +0000 (10:55 -0700)
This is a preliminary patch to add hw csum hint support to
mvneta/mvpp2 xdp implementation

Tested-by: Matteo Croce <mcroce@linux.microsoft.com>
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/marvell/mvneta.c
drivers/net/ethernet/marvell/mvpp2/mvpp2_main.c

index c15ce06427d0fd032c955cf758eb1f5a80087de1..88a755034c398b995273498247de9f0885bebc9a 100644 (file)
@@ -1805,18 +1805,14 @@ static void mvneta_rx_error(struct mvneta_port *pp,
 }
 
 /* Handle RX checksum offload based on the descriptor's status */
-static void mvneta_rx_csum(struct mvneta_port *pp, u32 status,
-                          struct sk_buff *skb)
+static int mvneta_rx_csum(struct mvneta_port *pp, u32 status)
 {
        if ((pp->dev->features & NETIF_F_RXCSUM) &&
            (status & MVNETA_RXD_L3_IP4) &&
-           (status & MVNETA_RXD_L4_CSUM_OK)) {
-               skb->csum = 0;
-               skb->ip_summed = CHECKSUM_UNNECESSARY;
-               return;
-       }
+           (status & MVNETA_RXD_L4_CSUM_OK))
+               return CHECKSUM_UNNECESSARY;
 
-       skb->ip_summed = CHECKSUM_NONE;
+       return CHECKSUM_NONE;
 }
 
 /* Return tx queue pointer (find last set bit) according to <cause> returned
@@ -2335,7 +2331,7 @@ mvneta_swbm_build_skb(struct mvneta_port *pp, struct page_pool *pool,
 
        skb_reserve(skb, xdp->data - xdp->data_hard_start);
        skb_put(skb, xdp->data_end - xdp->data);
-       mvneta_rx_csum(pp, desc_status, skb);
+       skb->ip_summed = mvneta_rx_csum(pp, desc_status);
 
        for (i = 0; i < num_frags; i++) {
                skb_frag_t *frag = &sinfo->frags[i];
@@ -2535,7 +2531,7 @@ err_drop_frame:
                                     rx_bytes);
 
                        skb->protocol = eth_type_trans(skb, dev);
-                       mvneta_rx_csum(pp, rx_status, skb);
+                       skb->ip_summed = mvneta_rx_csum(pp, rx_status);
                        napi_gro_receive(napi, skb);
 
                        rcvd_pkts++;
@@ -2584,8 +2580,7 @@ err_drop_frame:
                skb_put(skb, rx_bytes);
 
                skb->protocol = eth_type_trans(skb, dev);
-
-               mvneta_rx_csum(pp, rx_status, skb);
+               skb->ip_summed = mvneta_rx_csum(pp, rx_status);
 
                napi_gro_receive(napi, skb);
        }
index 8362e64a3b2846d559423e4a798c7c9cf0bdaee6..3135220a8942d0c1be988dfba98703ff4ede6710 100644 (file)
@@ -3543,21 +3543,17 @@ static void mvpp2_rx_error(struct mvpp2_port *port,
 }
 
 /* Handle RX checksum offload */
-static void mvpp2_rx_csum(struct mvpp2_port *port, u32 status,
-                         struct sk_buff *skb)
+static int mvpp2_rx_csum(struct mvpp2_port *port, u32 status)
 {
        if (((status & MVPP2_RXD_L3_IP4) &&
             !(status & MVPP2_RXD_IP4_HEADER_ERR)) ||
            (status & MVPP2_RXD_L3_IP6))
                if (((status & MVPP2_RXD_L4_UDP) ||
                     (status & MVPP2_RXD_L4_TCP)) &&
-                    (status & MVPP2_RXD_L4_CSUM_OK)) {
-                       skb->csum = 0;
-                       skb->ip_summed = CHECKSUM_UNNECESSARY;
-                       return;
-               }
+                    (status & MVPP2_RXD_L4_CSUM_OK))
+                       return CHECKSUM_UNNECESSARY;
 
-       skb->ip_summed = CHECKSUM_NONE;
+       return CHECKSUM_NONE;
 }
 
 /* Allocate a new skb and add it to BM pool */
@@ -4012,7 +4008,7 @@ static int mvpp2_rx(struct mvpp2_port *port, struct napi_struct *napi,
 
                skb_reserve(skb, MVPP2_MH_SIZE + MVPP2_SKB_HEADROOM);
                skb_put(skb, rx_bytes);
-               mvpp2_rx_csum(port, rx_status, skb);
+               skb->ip_summed = mvpp2_rx_csum(port, rx_status);
                skb->protocol = eth_type_trans(skb, dev);
 
                napi_gro_receive(napi, skb);