You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.6 KiB
75 lines
2.6 KiB
5 years ago
|
From 7d47d61e11444426ad0d5493de4194224d693606 Mon Sep 17 00:00:00 2001
|
||
|
From: Jonathan Toppins <jtoppins@redhat.com>
|
||
|
Date: Wed, 2 Oct 2019 18:22:59 -0400
|
||
|
Subject: [PATCH 44/96] [netdrv] bnxt_en: Handle standalone RX_AGG completions
|
||
|
|
||
|
Message-id: <a156f3cbca063eab1a76e155863749b563b042af.1570027456.git.jtoppins@redhat.com>
|
||
|
Patchwork-id: 276463
|
||
|
O-Subject: [RHEL-8.2 PATCH 37/78] bnxt_en: Handle standalone RX_AGG completions.
|
||
|
Bugzilla: 1724766
|
||
|
RH-Acked-by: John Linville <linville@redhat.com>
|
||
|
RH-Acked-by: Jarod Wilson <jarod@redhat.com>
|
||
|
|
||
|
On the new 57500 chips, these new RX_AGG completions are not coalesced
|
||
|
at the TPA_END completion. Handle these by storing them in the
|
||
|
array in the bnxt_tpa_info struct, as they are seen when processing
|
||
|
the CMPL ring.
|
||
|
|
||
|
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
|
||
|
Signed-off-by: David S. Miller <davem@davemloft.net>
|
||
|
(cherry picked from commit 8fe88ce7ab3181a11989eb7a8bb00c42a2b7b3b0)
|
||
|
Bugzilla: 1724766
|
||
|
Build Info: https://brewweb.engineering.redhat.com/brew/taskinfo?taskID=23809532
|
||
|
Tested: build, boot, basic ping
|
||
|
Signed-off-by: Jonathan Toppins <jtoppins@redhat.com>
|
||
|
Signed-off-by: Bruno Meneguele <bmeneg@redhat.com>
|
||
|
---
|
||
|
drivers/net/ethernet/broadcom/bnxt/bnxt.c | 20 ++++++++++++++++++--
|
||
|
1 file changed, 18 insertions(+), 2 deletions(-)
|
||
|
|
||
|
Index: src/drivers/net/ethernet/broadcom/bnxt/bnxt.c
|
||
|
===================================================================
|
||
|
--- src.orig/drivers/net/ethernet/broadcom/bnxt/bnxt.c 2020-02-06 16:23:16.115509434 +0100
|
||
|
+++ src/drivers/net/ethernet/broadcom/bnxt/bnxt.c 2020-02-06 16:23:16.250508195 +0100
|
||
|
@@ -1519,6 +1519,17 @@
|
||
|
return skb;
|
||
|
}
|
||
|
|
||
|
+static void bnxt_tpa_agg(struct bnxt *bp, struct bnxt_rx_ring_info *rxr,
|
||
|
+ struct rx_agg_cmp *rx_agg)
|
||
|
+{
|
||
|
+ u16 agg_id = TPA_AGG_AGG_ID(rx_agg);
|
||
|
+ struct bnxt_tpa_info *tpa_info;
|
||
|
+
|
||
|
+ tpa_info = &rxr->rx_tpa[agg_id];
|
||
|
+ BUG_ON(tpa_info->agg_count >= MAX_SKB_FRAGS);
|
||
|
+ tpa_info->agg_arr[tpa_info->agg_count++] = *rx_agg;
|
||
|
+}
|
||
|
+
|
||
|
static void bnxt_deliver_skb(struct bnxt *bp, struct bnxt_napi *bnapi,
|
||
|
struct sk_buff *skb)
|
||
|
{
|
||
|
@@ -1560,6 +1571,13 @@
|
||
|
rxcmp = (struct rx_cmp *)
|
||
|
&cpr->cp_desc_ring[CP_RING(cp_cons)][CP_IDX(cp_cons)];
|
||
|
|
||
|
+ cmp_type = RX_CMP_TYPE(rxcmp);
|
||
|
+
|
||
|
+ if (cmp_type == CMP_TYPE_RX_TPA_AGG_CMP) {
|
||
|
+ bnxt_tpa_agg(bp, rxr, (struct rx_agg_cmp *)rxcmp);
|
||
|
+ goto next_rx_no_prod_no_len;
|
||
|
+ }
|
||
|
+
|
||
|
tmp_raw_cons = NEXT_RAW_CMP(tmp_raw_cons);
|
||
|
cp_cons = RING_CMP(tmp_raw_cons);
|
||
|
rxcmp1 = (struct rx_cmp_ext *)
|
||
|
@@ -1568,8 +1586,6 @@
|
||
|
if (!RX_CMP_VALID(rxcmp1, tmp_raw_cons))
|
||
|
return -EBUSY;
|
||
|
|
||
|
- cmp_type = RX_CMP_TYPE(rxcmp);
|
||
|
-
|
||
|
prod = rxr->rx_prod;
|
||
|
|
||
|
if (cmp_type == CMP_TYPE_RX_L2_TPA_START_CMP) {
|