get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/94471/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 94471,
    "url": "https://patches.dpdk.org/api/patches/94471/?format=api",
    "web_url": "https://patches.dpdk.org/project/dpdk/patch/20210618103741.26526-63-ndabilpuram@marvell.com/",
    "project": {
        "id": 1,
        "url": "https://patches.dpdk.org/api/projects/1/?format=api",
        "name": "DPDK",
        "link_name": "dpdk",
        "list_id": "dev.dpdk.org",
        "list_email": "dev@dpdk.org",
        "web_url": "http://core.dpdk.org",
        "scm_url": "git://dpdk.org/dpdk",
        "webscm_url": "http://git.dpdk.org/dpdk",
        "list_archive_url": "https://inbox.dpdk.org/dev",
        "list_archive_url_format": "https://inbox.dpdk.org/dev/{}",
        "commit_url_format": ""
    },
    "msgid": "<20210618103741.26526-63-ndabilpuram@marvell.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20210618103741.26526-63-ndabilpuram@marvell.com",
    "date": "2021-06-18T10:37:41",
    "name": "[v3,62/62] net/cnxk: add marking and VLAN tagging support",
    "commit_ref": null,
    "pull_url": null,
    "state": "changes-requested",
    "archived": true,
    "hash": "772a0206f27eec4a0ae1cb2f1d8acfc8516e856a",
    "submitter": {
        "id": 1202,
        "url": "https://patches.dpdk.org/api/people/1202/?format=api",
        "name": "Nithin Dabilpuram",
        "email": "ndabilpuram@marvell.com"
    },
    "delegate": {
        "id": 310,
        "url": "https://patches.dpdk.org/api/users/310/?format=api",
        "username": "jerin",
        "first_name": "Jerin",
        "last_name": "Jacob",
        "email": "jerinj@marvell.com"
    },
    "mbox": "https://patches.dpdk.org/project/dpdk/patch/20210618103741.26526-63-ndabilpuram@marvell.com/mbox/",
    "series": [
        {
            "id": 17394,
            "url": "https://patches.dpdk.org/api/series/17394/?format=api",
            "web_url": "https://patches.dpdk.org/project/dpdk/list/?series=17394",
            "date": "2021-06-18T10:36:39",
            "name": "Marvell CNXK Ethdev Driver",
            "version": 3,
            "mbox": "https://patches.dpdk.org/series/17394/mbox/"
        }
    ],
    "comments": "https://patches.dpdk.org/api/patches/94471/comments/",
    "check": "fail",
    "checks": "https://patches.dpdk.org/api/patches/94471/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@inbox.dpdk.org",
        "Delivered-To": "patchwork@inbox.dpdk.org",
        "Received": [
            "from mails.dpdk.org (mails.dpdk.org [217.70.189.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 5F9D0A0C46;\n\tFri, 18 Jun 2021 12:46:28 +0200 (CEST)",
            "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 09FFE41235;\n\tFri, 18 Jun 2021 12:42:18 +0200 (CEST)",
            "from mx0b-0016f401.pphosted.com (mx0a-0016f401.pphosted.com\n [67.231.148.174])\n by mails.dpdk.org (Postfix) with ESMTP id 13136410F4\n for <dev@dpdk.org>; Fri, 18 Jun 2021 12:42:16 +0200 (CEST)",
            "from pps.filterd (m0045849.ppops.net [127.0.0.1])\n by mx0a-0016f401.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id\n 15IAYhNu029389 for <dev@dpdk.org>; Fri, 18 Jun 2021 03:42:16 -0700",
            "from dc5-exch02.marvell.com ([199.233.59.182])\n by mx0a-0016f401.pphosted.com with ESMTP id 398r750dat-1\n (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT)\n for <dev@dpdk.org>; Fri, 18 Jun 2021 03:42:16 -0700",
            "from DC5-EXCH02.marvell.com (10.69.176.39) by DC5-EXCH02.marvell.com\n (10.69.176.39) with Microsoft SMTP Server (TLS) id 15.0.1497.18;\n Fri, 18 Jun 2021 03:42:14 -0700",
            "from maili.marvell.com (10.69.176.80) by DC5-EXCH02.marvell.com\n (10.69.176.39) with Microsoft SMTP Server id 15.0.1497.18 via Frontend\n Transport; Fri, 18 Jun 2021 03:42:14 -0700",
            "from hyd1588t430.marvell.com (unknown [10.29.52.204])\n by maili.marvell.com (Postfix) with ESMTP id 468E25B69B8;\n Fri, 18 Jun 2021 03:41:46 -0700 (PDT)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com;\n h=from : to : cc :\n subject : date : message-id : in-reply-to : references : mime-version :\n content-type; s=pfpt0220; bh=Bw/JVXZURICslFLWddAqPEEpa2TE9xGTFvq/jj0bXhk=;\n b=S0SCB6CkKP7pAc0vCXYQFprJtyJZole338T52NHqBWQ9z+z9GrFBxXXIrQpWIvSVuLaU\n OOI/DvZN/6/PFV1rhiqVogEc8RIjzlCZC/P8C13MIX2wiz2t/C0NMhdHJkTSclgWZU8S\n /E5eCiQcpnjOUB4F5pWCQwQjqSs6AqKeIXLzBsVfjcuKzwPoT5/tgv+p8zqAGrx/gvwp\n ndrfaerBBQXHycqU3S7sRxlMxM2R5v2imIEEn4sc2/ovFPb3gHmtQBToyZpTLk/buLds\n 0yv4fJv/oSY0HEixu9jyKQNIPIUES8wOiD+ehda2KyUiNl9KD1yhm3fmo2vEczUUL+jJ 7g==",
        "From": "Nithin Dabilpuram <ndabilpuram@marvell.com>",
        "To": "<dev@dpdk.org>",
        "CC": "<jerinj@marvell.com>, <skori@marvell.com>, <skoteshwar@marvell.com>,\n <pbhagavatula@marvell.com>, <kirankumark@marvell.com>,\n <psatheesh@marvell.com>, <asekhar@marvell.com>, <hkalra@marvell.com>",
        "Date": "Fri, 18 Jun 2021 16:07:41 +0530",
        "Message-ID": "<20210618103741.26526-63-ndabilpuram@marvell.com>",
        "X-Mailer": "git-send-email 2.8.4",
        "In-Reply-To": "<20210618103741.26526-1-ndabilpuram@marvell.com>",
        "References": "<20210306153404.10781-1-ndabilpuram@marvell.com>\n <20210618103741.26526-1-ndabilpuram@marvell.com>",
        "MIME-Version": "1.0",
        "Content-Type": "text/plain",
        "X-Proofpoint-ORIG-GUID": "le59lhUd1Cx8NrE01s9sdypQsqGgpF0c",
        "X-Proofpoint-GUID": "le59lhUd1Cx8NrE01s9sdypQsqGgpF0c",
        "X-Proofpoint-Virus-Version": "vendor=fsecure engine=2.50.10434:6.0.391, 18.0.790\n definitions=2021-06-18_04:2021-06-18,\n 2021-06-18 signatures=0",
        "Subject": "[dpdk-dev] [PATCH v3 62/62] net/cnxk: add marking and VLAN tagging\n support",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.29",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://mails.dpdk.org/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "From: Satheesh Paul <psatheesh@marvell.com>\n\nThis patch adds support for mark, flag, VLAN pop and\npush flow actions.\n\nSigned-off-by: Satheesh Paul <psatheesh@marvell.com>\n---\n doc/guides/nics/features/cnxk.ini |   5 ++\n drivers/net/cnxk/cn10k_rte_flow.c |  42 +++++++++\n drivers/net/cnxk/cn10k_rx.c       |  27 +++---\n drivers/net/cnxk/cn10k_rx.h       | 175 ++++++++++++++++++++++++++++++--------\n drivers/net/cnxk/cn10k_rx_mseg.c  |   2 +-\n drivers/net/cnxk/cn10k_rx_vec.c   |   2 +-\n drivers/net/cnxk/cn9k_rte_flow.c  |  42 +++++++++\n drivers/net/cnxk/cn9k_rx.c        |  27 +++---\n drivers/net/cnxk/cn9k_rx.h        | 175 ++++++++++++++++++++++++++++++--------\n drivers/net/cnxk/cn9k_rx_mseg.c   |   2 +-\n drivers/net/cnxk/cn9k_rx_vec.c    |   2 +-\n drivers/net/cnxk/cnxk_ethdev.c    |   1 +\n drivers/net/cnxk/cnxk_ethdev.h    |   3 +-\n drivers/net/cnxk/cnxk_rte_flow.c  |  17 ++++\n 14 files changed, 423 insertions(+), 99 deletions(-)",
    "diff": "diff --git a/doc/guides/nics/features/cnxk.ini b/doc/guides/nics/features/cnxk.ini\nindex c686ceb..337ad24 100644\n--- a/doc/guides/nics/features/cnxk.ini\n+++ b/doc/guides/nics/features/cnxk.ini\n@@ -77,6 +77,11 @@ vxlan_gpe            = Y\n count                = Y\n drop                 = Y\n flag                 = Y\n+mark                 = Y\n+of_pop_vlan          = Y\n+of_push_vlan         = Y\n+of_set_vlan_pcp      = Y\n+of_set_vlan_vid      = Y\n pf                   = Y\n port_id              = Y\n queue                = Y\ndiff --git a/drivers/net/cnxk/cn10k_rte_flow.c b/drivers/net/cnxk/cn10k_rte_flow.c\nindex 65893cc..b04de6a 100644\n--- a/drivers/net/cnxk/cn10k_rte_flow.c\n+++ b/drivers/net/cnxk/cn10k_rte_flow.c\n@@ -4,6 +4,7 @@\n #include <cnxk_rte_flow.h>\n #include \"cn10k_rte_flow.h\"\n #include \"cn10k_ethdev.h\"\n+#include \"cn10k_rx.h\"\n \n struct rte_flow *\n cn10k_flow_create(struct rte_eth_dev *eth_dev, const struct rte_flow_attr *attr,\n@@ -11,12 +12,29 @@ cn10k_flow_create(struct rte_eth_dev *eth_dev, const struct rte_flow_attr *attr,\n \t\t  const struct rte_flow_action actions[],\n \t\t  struct rte_flow_error *error)\n {\n+\tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n+\tint mark_actions = 0, vtag_actions = 0;\n+\tstruct roc_npc *npc = &dev->npc;\n \tstruct roc_npc_flow *flow;\n \n \tflow = cnxk_flow_create(eth_dev, attr, pattern, actions, error);\n \tif (!flow)\n \t\treturn NULL;\n \n+\tmark_actions = roc_npc_mark_actions_get(npc);\n+\n+\tif (mark_actions) {\n+\t\tdev->rx_offload_flags |= NIX_RX_OFFLOAD_MARK_UPDATE_F;\n+\t\tcn10k_eth_set_rx_function(eth_dev);\n+\t}\n+\n+\tvtag_actions = roc_npc_vtag_actions_get(npc);\n+\n+\tif (vtag_actions) {\n+\t\tdev->rx_offload_flags |= NIX_RX_OFFLOAD_VLAN_STRIP_F;\n+\t\tcn10k_eth_set_rx_function(eth_dev);\n+\t}\n+\n \treturn (struct rte_flow *)flow;\n }\n \n@@ -25,6 +43,30 @@ cn10k_flow_destroy(struct rte_eth_dev *eth_dev, struct rte_flow *rte_flow,\n \t\t   struct rte_flow_error *error)\n {\n \tstruct roc_npc_flow *flow = (struct roc_npc_flow *)rte_flow;\n+\tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n+\tint mark_actions = 0, vtag_actions = 0;\n+\tstruct roc_npc *npc = &dev->npc;\n+\n+\tmark_actions = roc_npc_mark_actions_get(npc);\n+\tif (mark_actions) {\n+\t\tmark_actions = roc_npc_mark_actions_sub_return(npc, 1);\n+\t\tif (mark_actions == 0) {\n+\t\t\tdev->rx_offload_flags &= ~NIX_RX_OFFLOAD_MARK_UPDATE_F;\n+\t\t\tcn10k_eth_set_rx_function(eth_dev);\n+\t\t}\n+\t}\n+\n+\tvtag_actions = roc_npc_vtag_actions_get(npc);\n+\tif (vtag_actions) {\n+\t\tif (flow->nix_intf == ROC_NPC_INTF_RX) {\n+\t\t\tvtag_actions = roc_npc_vtag_actions_sub_return(npc, 1);\n+\t\t\tif (vtag_actions == 0) {\n+\t\t\t\tdev->rx_offload_flags &=\n+\t\t\t\t\t~NIX_RX_OFFLOAD_VLAN_STRIP_F;\n+\t\t\t\tcn10k_eth_set_rx_function(eth_dev);\n+\t\t\t}\n+\t\t}\n+\t}\n \n \treturn cnxk_flow_destroy(eth_dev, flow, error);\n }\ndiff --git a/drivers/net/cnxk/cn10k_rx.c b/drivers/net/cnxk/cn10k_rx.c\nindex c9744e2..5c956c0 100644\n--- a/drivers/net/cnxk/cn10k_rx.c\n+++ b/drivers/net/cnxk/cn10k_rx.c\n@@ -5,7 +5,7 @@\n #include \"cn10k_ethdev.h\"\n #include \"cn10k_rx.h\"\n \n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n \tuint16_t __rte_noinline __rte_hot cn10k_nix_recv_pkts_##name(\t       \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts)      \\\n \t{                                                                      \\\n@@ -17,12 +17,13 @@ NIX_RX_FASTPATH_MODES\n \n static inline void\n pick_rx_func(struct rte_eth_dev *eth_dev,\n-\t     const eth_rx_burst_t rx_burst[2][2][2][2][2])\n+\t     const eth_rx_burst_t rx_burst[2][2][2][2][2][2])\n {\n \tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n \n-\t/* [TSP] [MARK] [CKSUM] [PTYPE] [RSS] */\n+\t/* [VLAN] [TSP] [MARK] [CKSUM] [PTYPE] [RSS] */\n \teth_dev->rx_pkt_burst = rx_burst\n+\t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_VLAN_STRIP_F)]\n \t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_TSTAMP_F)]\n \t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_MARK_UPDATE_F)]\n \t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_CHECKSUM_F)]\n@@ -35,25 +36,25 @@ cn10k_eth_set_rx_function(struct rte_eth_dev *eth_dev)\n {\n \tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n \n-\tconst eth_rx_burst_t nix_eth_rx_burst[2][2][2][2][2] = {\n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n-\t[f4][f3][f2][f1][f0] = cn10k_nix_recv_pkts_##name,\n+\tconst eth_rx_burst_t nix_eth_rx_burst[2][2][2][2][2][2] = {\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+\t[f5][f4][f3][f2][f1][f0] = cn10k_nix_recv_pkts_##name,\n \n \t\tNIX_RX_FASTPATH_MODES\n #undef R\n \t};\n \n-\tconst eth_rx_burst_t nix_eth_rx_burst_mseg[2][2][2][2][2] = {\n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n-\t[f4][f3][f2][f1][f0] = cn10k_nix_recv_pkts_mseg_##name,\n+\tconst eth_rx_burst_t nix_eth_rx_burst_mseg[2][2][2][2][2][2] = {\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+\t[f5][f4][f3][f2][f1][f0] = cn10k_nix_recv_pkts_mseg_##name,\n \n \t\tNIX_RX_FASTPATH_MODES\n #undef R\n \t};\n \n-\tconst eth_rx_burst_t nix_eth_rx_vec_burst[2][2][2][2][2] = {\n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n-\t[f4][f3][f2][f1][f0] = cn10k_nix_recv_pkts_vec_##name,\n+\tconst eth_rx_burst_t nix_eth_rx_vec_burst[2][2][2][2][2][2] = {\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+\t[f5][f4][f3][f2][f1][f0] = cn10k_nix_recv_pkts_vec_##name,\n \n \t\tNIX_RX_FASTPATH_MODES\n #undef R\n@@ -73,6 +74,6 @@ cn10k_eth_set_rx_function(struct rte_eth_dev *eth_dev)\n \t/* Copy multi seg version with no offload for tear down sequence */\n \tif (rte_eal_process_type() == RTE_PROC_PRIMARY)\n \t\tdev->rx_pkt_burst_no_offload =\n-\t\t\tnix_eth_rx_burst_mseg[0][0][0][0][0];\n+\t\t\tnix_eth_rx_burst_mseg[0][0][0][0][0][0];\n \trte_mb();\n }\ndiff --git a/drivers/net/cnxk/cn10k_rx.h b/drivers/net/cnxk/cn10k_rx.h\nindex c09ccdf..1cc37cb 100644\n--- a/drivers/net/cnxk/cn10k_rx.h\n+++ b/drivers/net/cnxk/cn10k_rx.h\n@@ -15,6 +15,7 @@\n #define NIX_RX_OFFLOAD_CHECKSUM_F    BIT(2)\n #define NIX_RX_OFFLOAD_MARK_UPDATE_F BIT(3)\n #define NIX_RX_OFFLOAD_TSTAMP_F\t     BIT(4)\n+#define NIX_RX_OFFLOAD_VLAN_STRIP_F  BIT(5)\n \n /* Flags to control cqe_to_mbuf conversion function.\n  * Defining it from backwards to denote its been\n@@ -179,6 +180,17 @@ cn10k_nix_cqe_to_mbuf(const struct nix_cqe_hdr_s *cq, const uint32_t tag,\n \tif (flag & NIX_RX_OFFLOAD_CHECKSUM_F)\n \t\tol_flags |= nix_rx_olflags_get(lookup_mem, w1);\n \n+\tif (flag & NIX_RX_OFFLOAD_VLAN_STRIP_F) {\n+\t\tif (rx->vtag0_gone) {\n+\t\t\tol_flags |= PKT_RX_VLAN | PKT_RX_VLAN_STRIPPED;\n+\t\t\tmbuf->vlan_tci = rx->vtag0_tci;\n+\t\t}\n+\t\tif (rx->vtag1_gone) {\n+\t\t\tol_flags |= PKT_RX_QINQ | PKT_RX_QINQ_STRIPPED;\n+\t\t\tmbuf->vlan_tci_outer = rx->vtag1_tci;\n+\t\t}\n+\t}\n+\n \tif (flag & NIX_RX_OFFLOAD_MARK_UPDATE_F)\n \t\tol_flags = nix_update_match_id(rx->match_id, ol_flags, mbuf);\n \n@@ -273,6 +285,28 @@ cn10k_nix_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts,\n \n #if defined(RTE_ARCH_ARM64)\n \n+static __rte_always_inline uint64_t\n+nix_vlan_update(const uint64_t w2, uint64_t ol_flags, uint8x16_t *f)\n+{\n+\tif (w2 & BIT_ULL(21) /* vtag0_gone */) {\n+\t\tol_flags |= PKT_RX_VLAN | PKT_RX_VLAN_STRIPPED;\n+\t\t*f = vsetq_lane_u16((uint16_t)(w2 >> 32), *f, 5);\n+\t}\n+\n+\treturn ol_flags;\n+}\n+\n+static __rte_always_inline uint64_t\n+nix_qinq_update(const uint64_t w2, uint64_t ol_flags, struct rte_mbuf *mbuf)\n+{\n+\tif (w2 & BIT_ULL(23) /* vtag1_gone */) {\n+\t\tol_flags |= PKT_RX_QINQ | PKT_RX_QINQ_STRIPPED;\n+\t\tmbuf->vlan_tci_outer = (uint16_t)(w2 >> 48);\n+\t}\n+\n+\treturn ol_flags;\n+}\n+\n static __rte_always_inline uint16_t\n cn10k_nix_recv_pkts_vector(void *rx_queue, struct rte_mbuf **rx_pkts,\n \t\t\t   uint16_t pkts, const uint16_t flags)\n@@ -397,6 +431,23 @@ cn10k_nix_recv_pkts_vector(void *rx_queue, struct rte_mbuf **rx_pkts,\n \t\t\tol_flags3 |= nix_rx_olflags_get(lookup_mem, cq3_w1);\n \t\t}\n \n+\t\tif (flags & NIX_RX_OFFLOAD_VLAN_STRIP_F) {\n+\t\t\tuint64_t cq0_w2 = *(uint64_t *)(cq0 + CQE_SZ(0) + 16);\n+\t\t\tuint64_t cq1_w2 = *(uint64_t *)(cq0 + CQE_SZ(1) + 16);\n+\t\t\tuint64_t cq2_w2 = *(uint64_t *)(cq0 + CQE_SZ(2) + 16);\n+\t\t\tuint64_t cq3_w2 = *(uint64_t *)(cq0 + CQE_SZ(3) + 16);\n+\n+\t\t\tol_flags0 = nix_vlan_update(cq0_w2, ol_flags0, &f0);\n+\t\t\tol_flags1 = nix_vlan_update(cq1_w2, ol_flags1, &f1);\n+\t\t\tol_flags2 = nix_vlan_update(cq2_w2, ol_flags2, &f2);\n+\t\t\tol_flags3 = nix_vlan_update(cq3_w2, ol_flags3, &f3);\n+\n+\t\t\tol_flags0 = nix_qinq_update(cq0_w2, ol_flags0, mbuf0);\n+\t\t\tol_flags1 = nix_qinq_update(cq1_w2, ol_flags1, mbuf1);\n+\t\t\tol_flags2 = nix_qinq_update(cq2_w2, ol_flags2, mbuf2);\n+\t\t\tol_flags3 = nix_qinq_update(cq3_w2, ol_flags3, mbuf3);\n+\t\t}\n+\n \t\tif (flags & NIX_RX_OFFLOAD_MARK_UPDATE_F) {\n \t\t\tol_flags0 = nix_update_match_id(\n \t\t\t\t*(uint16_t *)(cq0 + CQE_SZ(0) + 38), ol_flags0,\n@@ -494,43 +545,99 @@ cn10k_nix_recv_pkts_vector(void *rx_queue, struct rte_mbuf **rx_pkts,\n #define CKSUM_F\t  NIX_RX_OFFLOAD_CHECKSUM_F\n #define MARK_F\t  NIX_RX_OFFLOAD_MARK_UPDATE_F\n #define TS_F      NIX_RX_OFFLOAD_TSTAMP_F\n+#define RX_VLAN_F NIX_RX_OFFLOAD_VLAN_STRIP_F\n \n-/* [TS] [MARK] [CKSUM] [PTYPE] [RSS] */\n+/* [RX_VLAN_F] [TS] [MARK] [CKSUM] [PTYPE] [RSS] */\n #define NIX_RX_FASTPATH_MODES\t\t\t\t\t\t       \\\n-R(no_offload,\t\t\t0, 0, 0, 0, 0, NIX_RX_OFFLOAD_NONE)\t       \\\n-R(rss,\t\t\t\t0, 0, 0, 0, 1, RSS_F)\t\t\t       \\\n-R(ptype,\t\t\t0, 0, 0, 1, 0, PTYPE_F)\t\t\t       \\\n-R(ptype_rss,\t\t\t0, 0, 0, 1, 1, PTYPE_F | RSS_F)\t\t       \\\n-R(cksum,\t\t\t0, 0, 1, 0, 0, CKSUM_F)\t\t\t       \\\n-R(cksum_rss,\t\t\t0, 0, 1, 0, 1, CKSUM_F | RSS_F)\t\t       \\\n-R(cksum_ptype,\t\t\t0, 0, 1, 1, 0, CKSUM_F | PTYPE_F)\t       \\\n-R(cksum_ptype_rss,\t\t0, 0, 1, 1, 1, CKSUM_F | PTYPE_F | RSS_F)      \\\n-R(mark,\t\t\t\t0, 1, 0, 0, 0, MARK_F)\t\t\t       \\\n-R(mark_rss,\t\t\t0, 1, 0, 0, 1, MARK_F | RSS_F)\t\t       \\\n-R(mark_ptype,\t\t\t0, 1, 0, 1, 0, MARK_F | PTYPE_F)\t       \\\n-R(mark_ptype_rss,\t\t0, 1, 0, 1, 1, MARK_F | PTYPE_F | RSS_F)       \\\n-R(mark_cksum,\t\t\t0, 1, 1, 0, 0, MARK_F | CKSUM_F)\t       \\\n-R(mark_cksum_rss,\t\t0, 1, 1, 0, 1, MARK_F | CKSUM_F | RSS_F)       \\\n-R(mark_cksum_ptype,\t\t0, 1, 1, 1, 0, MARK_F | CKSUM_F | PTYPE_F)     \\\n-R(mark_cksum_ptype_rss,\t\t0, 1, 1, 1, 1, MARK_F | CKSUM_F | PTYPE_F | RSS_F)\\\n-R(ts,\t\t\t\t1, 0, 0, 0, 0, TS_F)\t\t\t       \\\n-R(ts_rss,\t\t\t1, 0, 0, 0, 1, TS_F | RSS_F)\t\t       \\\n-R(ts_ptype,\t\t\t1, 0, 0, 1, 0, TS_F | PTYPE_F)\t\t       \\\n-R(ts_ptype_rss,\t\t\t1, 0, 0, 1, 1, TS_F | PTYPE_F | RSS_F)\t       \\\n-R(ts_cksum,\t\t\t1, 0, 1, 0, 0, TS_F | CKSUM_F)\t\t       \\\n-R(ts_cksum_rss,\t\t\t1, 0, 1, 0, 1, TS_F | CKSUM_F | RSS_F)\t       \\\n-R(ts_cksum_ptype,\t\t1, 0, 1, 1, 0, TS_F | CKSUM_F | PTYPE_F)       \\\n-R(ts_cksum_ptype_rss,\t\t1, 0, 1, 1, 1, TS_F | CKSUM_F | PTYPE_F | RSS_F)\\\n-R(ts_mark,\t\t\t1, 1, 0, 0, 0, TS_F | MARK_F)\t\t       \\\n-R(ts_mark_rss,\t\t\t1, 1, 0, 0, 1, TS_F | MARK_F | RSS_F)\t       \\\n-R(ts_mark_ptype,\t\t1, 1, 0, 1, 0, TS_F | MARK_F | PTYPE_F)\t       \\\n-R(ts_mark_ptype_rss,\t\t1, 1, 0, 1, 1, TS_F | MARK_F | PTYPE_F | RSS_F)\\\n-R(ts_mark_cksum,\t\t1, 1, 1, 0, 0, TS_F | MARK_F | CKSUM_F)\t       \\\n-R(ts_mark_cksum_rss,\t\t1, 1, 1, 0, 1, TS_F | MARK_F | CKSUM_F | RSS_F)\\\n-R(ts_mark_cksum_ptype,\t\t1, 1, 1, 1, 0, TS_F | MARK_F | CKSUM_F | PTYPE_F)\\\n-R(ts_mark_cksum_ptype_rss,\t1, 1, 1, 1, 1, TS_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\n+R(no_offload,\t\t\t0, 0, 0, 0, 0, 0, NIX_RX_OFFLOAD_NONE)\t       \\\n+R(rss,\t\t\t\t0, 0, 0, 0, 0, 1, RSS_F)\t\t       \\\n+R(ptype,\t\t\t0, 0, 0, 0, 1, 0, PTYPE_F)\t\t       \\\n+R(ptype_rss,\t\t\t0, 0, 0, 0, 1, 1, PTYPE_F | RSS_F)\t       \\\n+R(cksum,\t\t\t0, 0, 0, 1, 0, 0, CKSUM_F)\t\t       \\\n+R(cksum_rss,\t\t\t0, 0, 0, 1, 0, 1, CKSUM_F | RSS_F)\t       \\\n+R(cksum_ptype,\t\t\t0, 0, 0, 1, 1, 0, CKSUM_F | PTYPE_F)\t       \\\n+R(cksum_ptype_rss,\t\t0, 0, 0, 1, 1, 1, CKSUM_F | PTYPE_F | RSS_F)   \\\n+R(mark,\t\t\t\t0, 0, 1, 0, 0, 0, MARK_F)\t\t       \\\n+R(mark_rss,\t\t\t0, 0, 1, 0, 0, 1, MARK_F | RSS_F)\t       \\\n+R(mark_ptype,\t\t\t0, 0, 1, 0, 1, 0, MARK_F | PTYPE_F)\t       \\\n+R(mark_ptype_rss,\t\t0, 0, 1, 0, 1, 1, MARK_F | PTYPE_F | RSS_F)    \\\n+R(mark_cksum,\t\t\t0, 0, 1, 1, 0, 0, MARK_F | CKSUM_F)\t       \\\n+R(mark_cksum_rss,\t\t0, 0, 1, 1, 0, 1, MARK_F | CKSUM_F | RSS_F)    \\\n+R(mark_cksum_ptype,\t\t0, 0, 1, 1, 1, 0, MARK_F | CKSUM_F | PTYPE_F)  \\\n+R(mark_cksum_ptype_rss,\t\t0, 0, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tMARK_F | CKSUM_F | PTYPE_F | RSS_F)\t\t       \\\n+R(ts,\t\t\t\t0, 1, 0, 0, 0, 0, TS_F)\t\t\t       \\\n+R(ts_rss,\t\t\t0, 1, 0, 0, 0, 1, TS_F | RSS_F)\t\t       \\\n+R(ts_ptype,\t\t\t0, 1, 0, 0, 1, 0, TS_F | PTYPE_F)\t       \\\n+R(ts_ptype_rss,\t\t\t0, 1, 0, 0, 1, 1, TS_F | PTYPE_F | RSS_F)      \\\n+R(ts_cksum,\t\t\t0, 1, 0, 1, 0, 0, TS_F | CKSUM_F)\t       \\\n+R(ts_cksum_rss,\t\t\t0, 1, 0, 1, 0, 1, TS_F | CKSUM_F | RSS_F)      \\\n+R(ts_cksum_ptype,\t\t0, 1, 0, 1, 1, 0, TS_F | CKSUM_F | PTYPE_F)    \\\n+R(ts_cksum_ptype_rss,\t\t0, 1, 0, 1, 1, 1,\t\t\t       \\\n+\t\t\tTS_F | CKSUM_F | PTYPE_F | RSS_F)\t\t       \\\n+R(ts_mark,\t\t\t0, 1, 1, 0, 0, 0, TS_F | MARK_F)\t       \\\n+R(ts_mark_rss,\t\t\t0, 1, 1, 0, 0, 1, TS_F | MARK_F | RSS_F)       \\\n+R(ts_mark_ptype,\t\t0, 1, 1, 0, 1, 0, TS_F | MARK_F | PTYPE_F)     \\\n+R(ts_mark_ptype_rss,\t\t0, 1, 1, 0, 1, 1,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | PTYPE_F | RSS_F)\t\t       \\\n+R(ts_mark_cksum,\t\t0, 1, 1, 1, 0, 0, TS_F | MARK_F | CKSUM_F)     \\\n+R(ts_mark_cksum_rss,\t\t0, 1, 1, 1, 0, 1,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | CKSUM_F | RSS_F)\t\t       \\\n+R(ts_mark_cksum_ptype,\t\t0, 1, 1, 1, 1, 0,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | CKSUM_F | PTYPE_F)\t\t       \\\n+R(ts_mark_cksum_ptype_rss,\t0, 1, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan,\t\t\t\t1, 0, 0, 0, 0, 0, RX_VLAN_F)\t\t       \\\n+R(vlan_rss,\t\t\t1, 0, 0, 0, 0, 1, RX_VLAN_F | RSS_F)\t       \\\n+R(vlan_ptype,\t\t\t1, 0, 0, 0, 1, 0, RX_VLAN_F | PTYPE_F)\t       \\\n+R(vlan_ptype_rss,\t\t1, 0, 0, 0, 1, 1, RX_VLAN_F | PTYPE_F | RSS_F) \\\n+R(vlan_cksum,\t\t\t1, 0, 0, 1, 0, 0, RX_VLAN_F | CKSUM_F)\t       \\\n+R(vlan_cksum_rss,\t\t1, 0, 0, 1, 0, 1, RX_VLAN_F | CKSUM_F | RSS_F) \\\n+R(vlan_cksum_ptype,\t\t1, 0, 0, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | CKSUM_F | PTYPE_F)\t\t\t       \\\n+R(vlan_cksum_ptype_rss,\t\t1, 0, 0, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | CKSUM_F | PTYPE_F | RSS_F)\t\t       \\\n+R(vlan_mark,\t\t\t1, 0, 1, 0, 0, 0, RX_VLAN_F | MARK_F)\t       \\\n+R(vlan_mark_rss,\t\t1, 0, 1, 0, 0, 1, RX_VLAN_F | MARK_F | RSS_F)  \\\n+R(vlan_mark_ptype,\t\t1, 0, 1, 0, 1, 0, RX_VLAN_F | MARK_F | PTYPE_F)\\\n+R(vlan_mark_ptype_rss,\t\t1, 0, 1, 0, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | PTYPE_F | RSS_F)\t\t       \\\n+R(vlan_mark_cksum,\t\t1, 0, 1, 1, 0, 0, RX_VLAN_F | MARK_F | CKSUM_F)\\\n+R(vlan_mark_cksum_rss,\t\t1, 0, 1, 1, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | CKSUM_F | RSS_F)\t\t       \\\n+R(vlan_mark_cksum_ptype,\t1, 0, 1, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | CKSUM_F | PTYPE_F)\t\t       \\\n+R(vlan_mark_cksum_ptype_rss,\t1, 0, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan_ts,\t\t\t1, 1, 0, 0, 0, 0, RX_VLAN_F | TS_F)\t       \\\n+R(vlan_ts_rss,\t\t\t1, 1, 0, 0, 0, 1, RX_VLAN_F | TS_F | RSS_F)    \\\n+R(vlan_ts_ptype,\t\t1, 1, 0, 0, 1, 0, RX_VLAN_F | TS_F | PTYPE_F)  \\\n+R(vlan_ts_ptype_rss,\t\t1, 1, 0, 0, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | PTYPE_F | RSS_F)\t\t       \\\n+R(vlan_ts_cksum,\t\t1, 1, 0, 1, 0, 0, RX_VLAN_F | TS_F | CKSUM_F)  \\\n+R(vlan_ts_cksum_rss,\t\t1, 1, 0, 1, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | CKSUM_F | RSS_F)\t\t       \\\n+R(vlan_ts_cksum_ptype,\t\t1, 1, 0, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | CKSUM_F | PTYPE_F)\t\t       \\\n+R(vlan_ts_cksum_ptype_rss,\t1, 1, 0, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | CKSUM_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan_ts_mark,\t\t\t1, 1, 1, 0, 0, 0, RX_VLAN_F | TS_F | MARK_F)   \\\n+R(vlan_ts_mark_rss,\t\t1, 1, 1, 0, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | RSS_F)\t\t       \\\n+R(vlan_ts_mark_ptype,\t\t1, 1, 1, 0, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | PTYPE_F)\t\t       \\\n+R(vlan_ts_mark_ptype_rss,\t1, 1, 1, 0, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan_ts_mark_cksum,\t\t1, 1, 1, 1, 0, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F)\t\t       \\\n+R(vlan_ts_mark_cksum_rss,\t1, 1, 1, 1, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F | RSS_F)\t       \\\n+R(vlan_ts_mark_cksum_ptype,\t1, 1, 1, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F | PTYPE_F)\t       \\\n+R(vlan_ts_mark_cksum_ptype_rss,\t1, 1, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\n \n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n \tuint16_t __rte_noinline __rte_hot cn10k_nix_recv_pkts_##name(          \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts);     \\\n \t\t\t\t\t\t\t\t\t       \\\ndiff --git a/drivers/net/cnxk/cn10k_rx_mseg.c b/drivers/net/cnxk/cn10k_rx_mseg.c\nindex b67d21f..3340771 100644\n--- a/drivers/net/cnxk/cn10k_rx_mseg.c\n+++ b/drivers/net/cnxk/cn10k_rx_mseg.c\n@@ -5,7 +5,7 @@\n #include \"cn10k_ethdev.h\"\n #include \"cn10k_rx.h\"\n \n-#define R(name, f4, f3, f2, f1, f0, flags)                                     \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)                                 \\\n \tuint16_t __rte_noinline __rte_hot cn10k_nix_recv_pkts_mseg_##name(     \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts)      \\\n \t{                                                                      \\\ndiff --git a/drivers/net/cnxk/cn10k_rx_vec.c b/drivers/net/cnxk/cn10k_rx_vec.c\nindex 1330235..65ffa97 100644\n--- a/drivers/net/cnxk/cn10k_rx_vec.c\n+++ b/drivers/net/cnxk/cn10k_rx_vec.c\n@@ -5,7 +5,7 @@\n #include \"cn10k_ethdev.h\"\n #include \"cn10k_rx.h\"\n \n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n \tuint16_t __rte_noinline __rte_hot\t\t\t\t       \\\n \t\tcn10k_nix_recv_pkts_vec_##name(void *rx_queue,                 \\\n \t\t\t\t\t       struct rte_mbuf **rx_pkts,      \\\ndiff --git a/drivers/net/cnxk/cn9k_rte_flow.c b/drivers/net/cnxk/cn9k_rte_flow.c\nindex 24e1b92..b94d29e 100644\n--- a/drivers/net/cnxk/cn9k_rte_flow.c\n+++ b/drivers/net/cnxk/cn9k_rte_flow.c\n@@ -4,6 +4,7 @@\n #include <cnxk_rte_flow.h>\n #include \"cn9k_ethdev.h\"\n #include \"cn9k_rte_flow.h\"\n+#include \"cn9k_rx.h\"\n \n struct rte_flow *\n cn9k_flow_create(struct rte_eth_dev *eth_dev, const struct rte_flow_attr *attr,\n@@ -11,12 +12,29 @@ cn9k_flow_create(struct rte_eth_dev *eth_dev, const struct rte_flow_attr *attr,\n \t\t const struct rte_flow_action actions[],\n \t\t struct rte_flow_error *error)\n {\n+\tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n+\tint mark_actions = 0, vtag_actions = 0;\n+\tstruct roc_npc *npc = &dev->npc;\n \tstruct roc_npc_flow *flow;\n \n \tflow = cnxk_flow_create(eth_dev, attr, pattern, actions, error);\n \tif (!flow)\n \t\treturn NULL;\n \n+\tmark_actions = roc_npc_mark_actions_get(npc);\n+\n+\tif (mark_actions) {\n+\t\tdev->rx_offload_flags |= NIX_RX_OFFLOAD_MARK_UPDATE_F;\n+\t\tcn9k_eth_set_rx_function(eth_dev);\n+\t}\n+\n+\tvtag_actions = roc_npc_vtag_actions_get(npc);\n+\n+\tif (vtag_actions) {\n+\t\tdev->rx_offload_flags |= NIX_RX_OFFLOAD_VLAN_STRIP_F;\n+\t\tcn9k_eth_set_rx_function(eth_dev);\n+\t}\n+\n \treturn (struct rte_flow *)flow;\n }\n \n@@ -25,6 +43,30 @@ cn9k_flow_destroy(struct rte_eth_dev *eth_dev, struct rte_flow *rte_flow,\n \t\t  struct rte_flow_error *error)\n {\n \tstruct roc_npc_flow *flow = (struct roc_npc_flow *)rte_flow;\n+\tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n+\tint mark_actions = 0, vtag_actions = 0;\n+\tstruct roc_npc *npc = &dev->npc;\n+\n+\tmark_actions = roc_npc_mark_actions_get(npc);\n+\tif (mark_actions) {\n+\t\tmark_actions = roc_npc_mark_actions_sub_return(npc, 1);\n+\t\tif (mark_actions == 0) {\n+\t\t\tdev->rx_offload_flags &= ~NIX_RX_OFFLOAD_MARK_UPDATE_F;\n+\t\t\tcn9k_eth_set_rx_function(eth_dev);\n+\t\t}\n+\t}\n+\n+\tvtag_actions = roc_npc_vtag_actions_get(npc);\n+\tif (vtag_actions) {\n+\t\tif (flow->nix_intf == ROC_NPC_INTF_RX) {\n+\t\t\tvtag_actions = roc_npc_vtag_actions_sub_return(npc, 1);\n+\t\t\tif (vtag_actions == 0) {\n+\t\t\t\tdev->rx_offload_flags &=\n+\t\t\t\t\t~NIX_RX_OFFLOAD_VLAN_STRIP_F;\n+\t\t\t\tcn9k_eth_set_rx_function(eth_dev);\n+\t\t\t}\n+\t\t}\n+\t}\n \n \treturn cnxk_flow_destroy(eth_dev, flow, error);\n }\ndiff --git a/drivers/net/cnxk/cn9k_rx.c b/drivers/net/cnxk/cn9k_rx.c\nindex a15428d..0acedd0 100644\n--- a/drivers/net/cnxk/cn9k_rx.c\n+++ b/drivers/net/cnxk/cn9k_rx.c\n@@ -5,7 +5,7 @@\n #include \"cn9k_ethdev.h\"\n #include \"cn9k_rx.h\"\n \n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n \tuint16_t __rte_noinline __rte_hot cn9k_nix_recv_pkts_##name(\t       \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts)      \\\n \t{                                                                      \\\n@@ -17,12 +17,13 @@ NIX_RX_FASTPATH_MODES\n \n static inline void\n pick_rx_func(struct rte_eth_dev *eth_dev,\n-\t     const eth_rx_burst_t rx_burst[2][2][2][2][2])\n+\t     const eth_rx_burst_t rx_burst[2][2][2][2][2][2])\n {\n \tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n \n-\t/* [TSP] [MARK] [CKSUM] [PTYPE] [RSS] */\n+\t/* [TSP] [MARK] [VLAN] [CKSUM] [PTYPE] [RSS] */\n \teth_dev->rx_pkt_burst = rx_burst\n+\t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_VLAN_STRIP_F)]\n \t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_TSTAMP_F)]\n \t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_MARK_UPDATE_F)]\n \t\t[!!(dev->rx_offload_flags & NIX_RX_OFFLOAD_CHECKSUM_F)]\n@@ -35,25 +36,25 @@ cn9k_eth_set_rx_function(struct rte_eth_dev *eth_dev)\n {\n \tstruct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);\n \n-\tconst eth_rx_burst_t nix_eth_rx_burst[2][2][2][2][2] = {\n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n-\t[f4][f3][f2][f1][f0] = cn9k_nix_recv_pkts_##name,\n+\tconst eth_rx_burst_t nix_eth_rx_burst[2][2][2][2][2][2] = {\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+\t[f5][f4][f3][f2][f1][f0] = cn9k_nix_recv_pkts_##name,\n \n \t\tNIX_RX_FASTPATH_MODES\n #undef R\n \t};\n \n-\tconst eth_rx_burst_t nix_eth_rx_burst_mseg[2][2][2][2][2] = {\n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n-\t[f4][f3][f2][f1][f0] = cn9k_nix_recv_pkts_mseg_##name,\n+\tconst eth_rx_burst_t nix_eth_rx_burst_mseg[2][2][2][2][2][2] = {\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+\t[f5][f4][f3][f2][f1][f0] = cn9k_nix_recv_pkts_mseg_##name,\n \n \t\tNIX_RX_FASTPATH_MODES\n #undef R\n \t};\n \n-\tconst eth_rx_burst_t nix_eth_rx_vec_burst[2][2][2][2][2] = {\n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n-\t[f4][f3][f2][f1][f0] = cn9k_nix_recv_pkts_vec_##name,\n+\tconst eth_rx_burst_t nix_eth_rx_vec_burst[2][2][2][2][2][2] = {\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+\t[f5][f4][f3][f2][f1][f0] = cn9k_nix_recv_pkts_vec_##name,\n \n \t\tNIX_RX_FASTPATH_MODES\n #undef R\n@@ -73,6 +74,6 @@ cn9k_eth_set_rx_function(struct rte_eth_dev *eth_dev)\n \t/* Copy multi seg version with no offload for tear down sequence */\n \tif (rte_eal_process_type() == RTE_PROC_PRIMARY)\n \t\tdev->rx_pkt_burst_no_offload =\n-\t\t\tnix_eth_rx_burst_mseg[0][0][0][0][0];\n+\t\t\tnix_eth_rx_burst_mseg[0][0][0][0][0][0];\n \trte_mb();\n }\ndiff --git a/drivers/net/cnxk/cn9k_rx.h b/drivers/net/cnxk/cn9k_rx.h\nindex c5ad5db..10ef5c6 100644\n--- a/drivers/net/cnxk/cn9k_rx.h\n+++ b/drivers/net/cnxk/cn9k_rx.h\n@@ -16,6 +16,7 @@\n #define NIX_RX_OFFLOAD_CHECKSUM_F    BIT(2)\n #define NIX_RX_OFFLOAD_MARK_UPDATE_F BIT(3)\n #define NIX_RX_OFFLOAD_TSTAMP_F\t     BIT(4)\n+#define NIX_RX_OFFLOAD_VLAN_STRIP_F  BIT(5)\n \n /* Flags to control cqe_to_mbuf conversion function.\n  * Defining it from backwards to denote its been\n@@ -181,6 +182,17 @@ cn9k_nix_cqe_to_mbuf(const struct nix_cqe_hdr_s *cq, const uint32_t tag,\n \tif (flag & NIX_RX_OFFLOAD_CHECKSUM_F)\n \t\tol_flags |= nix_rx_olflags_get(lookup_mem, w1);\n \n+\tif (flag & NIX_RX_OFFLOAD_VLAN_STRIP_F) {\n+\t\tif (rx->cn9k.vtag0_gone) {\n+\t\t\tol_flags |= PKT_RX_VLAN | PKT_RX_VLAN_STRIPPED;\n+\t\t\tmbuf->vlan_tci = rx->cn9k.vtag0_tci;\n+\t\t}\n+\t\tif (rx->cn9k.vtag1_gone) {\n+\t\t\tol_flags |= PKT_RX_QINQ | PKT_RX_QINQ_STRIPPED;\n+\t\t\tmbuf->vlan_tci_outer = rx->cn9k.vtag1_tci;\n+\t\t}\n+\t}\n+\n \tif (flag & NIX_RX_OFFLOAD_MARK_UPDATE_F)\n \t\tol_flags =\n \t\t\tnix_update_match_id(rx->cn9k.match_id, ol_flags, mbuf);\n@@ -276,6 +288,28 @@ cn9k_nix_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts,\n \n #if defined(RTE_ARCH_ARM64)\n \n+static __rte_always_inline uint64_t\n+nix_vlan_update(const uint64_t w2, uint64_t ol_flags, uint8x16_t *f)\n+{\n+\tif (w2 & BIT_ULL(21) /* vtag0_gone */) {\n+\t\tol_flags |= PKT_RX_VLAN | PKT_RX_VLAN_STRIPPED;\n+\t\t*f = vsetq_lane_u16((uint16_t)(w2 >> 32), *f, 5);\n+\t}\n+\n+\treturn ol_flags;\n+}\n+\n+static __rte_always_inline uint64_t\n+nix_qinq_update(const uint64_t w2, uint64_t ol_flags, struct rte_mbuf *mbuf)\n+{\n+\tif (w2 & BIT_ULL(23) /* vtag1_gone */) {\n+\t\tol_flags |= PKT_RX_QINQ | PKT_RX_QINQ_STRIPPED;\n+\t\tmbuf->vlan_tci_outer = (uint16_t)(w2 >> 48);\n+\t}\n+\n+\treturn ol_flags;\n+}\n+\n static __rte_always_inline uint16_t\n cn9k_nix_recv_pkts_vector(void *rx_queue, struct rte_mbuf **rx_pkts,\n \t\t\t  uint16_t pkts, const uint16_t flags)\n@@ -400,6 +434,23 @@ cn9k_nix_recv_pkts_vector(void *rx_queue, struct rte_mbuf **rx_pkts,\n \t\t\tol_flags3 |= nix_rx_olflags_get(lookup_mem, cq3_w1);\n \t\t}\n \n+\t\tif (flags & NIX_RX_OFFLOAD_VLAN_STRIP_F) {\n+\t\t\tuint64_t cq0_w2 = *(uint64_t *)(cq0 + CQE_SZ(0) + 16);\n+\t\t\tuint64_t cq1_w2 = *(uint64_t *)(cq0 + CQE_SZ(1) + 16);\n+\t\t\tuint64_t cq2_w2 = *(uint64_t *)(cq0 + CQE_SZ(2) + 16);\n+\t\t\tuint64_t cq3_w2 = *(uint64_t *)(cq0 + CQE_SZ(3) + 16);\n+\n+\t\t\tol_flags0 = nix_vlan_update(cq0_w2, ol_flags0, &f0);\n+\t\t\tol_flags1 = nix_vlan_update(cq1_w2, ol_flags1, &f1);\n+\t\t\tol_flags2 = nix_vlan_update(cq2_w2, ol_flags2, &f2);\n+\t\t\tol_flags3 = nix_vlan_update(cq3_w2, ol_flags3, &f3);\n+\n+\t\t\tol_flags0 = nix_qinq_update(cq0_w2, ol_flags0, mbuf0);\n+\t\t\tol_flags1 = nix_qinq_update(cq1_w2, ol_flags1, mbuf1);\n+\t\t\tol_flags2 = nix_qinq_update(cq2_w2, ol_flags2, mbuf2);\n+\t\t\tol_flags3 = nix_qinq_update(cq3_w2, ol_flags3, mbuf3);\n+\t\t}\n+\n \t\tif (flags & NIX_RX_OFFLOAD_MARK_UPDATE_F) {\n \t\t\tol_flags0 = nix_update_match_id(\n \t\t\t\t*(uint16_t *)(cq0 + CQE_SZ(0) + 38), ol_flags0,\n@@ -496,43 +547,99 @@ cn9k_nix_recv_pkts_vector(void *rx_queue, struct rte_mbuf **rx_pkts,\n #define CKSUM_F\t  NIX_RX_OFFLOAD_CHECKSUM_F\n #define MARK_F\t  NIX_RX_OFFLOAD_MARK_UPDATE_F\n #define TS_F\t  NIX_RX_OFFLOAD_TSTAMP_F\n+#define RX_VLAN_F NIX_RX_OFFLOAD_VLAN_STRIP_F\n \n-/* [TS] [MARK] [CKSUM] [PTYPE] [RSS] */\n+/* [RX_VLAN_F] [TS] [MARK] [CKSUM] [PTYPE] [RSS] */\n #define NIX_RX_FASTPATH_MODES\t\t\t\t\t\t       \\\n-R(no_offload,\t\t\t0, 0, 0, 0, 0, NIX_RX_OFFLOAD_NONE)\t       \\\n-R(rss,\t\t\t\t0, 0, 0, 0, 1, RSS_F)\t\t\t       \\\n-R(ptype,\t\t\t0, 0, 0, 1, 0, PTYPE_F)\t\t\t       \\\n-R(ptype_rss,\t\t\t0, 0, 0, 1, 1, PTYPE_F | RSS_F)\t\t       \\\n-R(cksum,\t\t\t0, 0, 1, 0, 0, CKSUM_F)\t\t\t       \\\n-R(cksum_rss,\t\t\t0, 0, 1, 0, 1, CKSUM_F | RSS_F)\t\t       \\\n-R(cksum_ptype,\t\t\t0, 0, 1, 1, 0, CKSUM_F | PTYPE_F)\t       \\\n-R(cksum_ptype_rss,\t\t0, 0, 1, 1, 1, CKSUM_F | PTYPE_F | RSS_F)      \\\n-R(mark,\t\t\t\t0, 1, 0, 0, 0, MARK_F)\t\t\t       \\\n-R(mark_rss,\t\t\t0, 1, 0, 0, 1, MARK_F | RSS_F)\t\t       \\\n-R(mark_ptype,\t\t\t0, 1, 0, 1, 0, MARK_F | PTYPE_F)\t       \\\n-R(mark_ptype_rss,\t\t0, 1, 0, 1, 1, MARK_F | PTYPE_F | RSS_F)       \\\n-R(mark_cksum,\t\t\t0, 1, 1, 0, 0, MARK_F | CKSUM_F)\t       \\\n-R(mark_cksum_rss,\t\t0, 1, 1, 0, 1, MARK_F | CKSUM_F | RSS_F)       \\\n-R(mark_cksum_ptype,\t\t0, 1, 1, 1, 0, MARK_F | CKSUM_F | PTYPE_F)     \\\n-R(mark_cksum_ptype_rss,\t\t0, 1, 1, 1, 1, MARK_F | CKSUM_F | PTYPE_F | RSS_F)\\\n-R(ts,\t\t\t\t1, 0, 0, 0, 0, TS_F)\t\t\t       \\\n-R(ts_rss,\t\t\t1, 0, 0, 0, 1, TS_F | RSS_F)\t\t       \\\n-R(ts_ptype,\t\t\t1, 0, 0, 1, 0, TS_F | PTYPE_F)\t\t       \\\n-R(ts_ptype_rss,\t\t\t1, 0, 0, 1, 1, TS_F | PTYPE_F | RSS_F)\t       \\\n-R(ts_cksum,\t\t\t1, 0, 1, 0, 0, TS_F | CKSUM_F)\t\t       \\\n-R(ts_cksum_rss,\t\t\t1, 0, 1, 0, 1, TS_F | CKSUM_F | RSS_F)\t       \\\n-R(ts_cksum_ptype,\t\t1, 0, 1, 1, 0, TS_F | CKSUM_F | PTYPE_F)       \\\n-R(ts_cksum_ptype_rss,\t\t1, 0, 1, 1, 1, TS_F | CKSUM_F | PTYPE_F | RSS_F)\\\n-R(ts_mark,\t\t\t1, 1, 0, 0, 0, TS_F | MARK_F)\t\t       \\\n-R(ts_mark_rss,\t\t\t1, 1, 0, 0, 1, TS_F | MARK_F | RSS_F)\t       \\\n-R(ts_mark_ptype,\t\t1, 1, 0, 1, 0, TS_F | MARK_F | PTYPE_F)\t       \\\n-R(ts_mark_ptype_rss,\t\t1, 1, 0, 1, 1, TS_F | MARK_F | PTYPE_F | RSS_F)\\\n-R(ts_mark_cksum,\t\t1, 1, 1, 0, 0, TS_F | MARK_F | CKSUM_F)\t       \\\n-R(ts_mark_cksum_rss,\t\t1, 1, 1, 0, 1, TS_F | MARK_F | CKSUM_F | RSS_F)\\\n-R(ts_mark_cksum_ptype,\t\t1, 1, 1, 1, 0, TS_F | MARK_F | CKSUM_F | PTYPE_F)\\\n-R(ts_mark_cksum_ptype_rss,\t1, 1, 1, 1, 1, TS_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\n+R(no_offload,\t\t\t0, 0, 0, 0, 0, 0, NIX_RX_OFFLOAD_NONE)\t       \\\n+R(rss,\t\t\t\t0, 0, 0, 0, 0, 1, RSS_F)\t\t       \\\n+R(ptype,\t\t\t0, 0, 0, 0, 1, 0, PTYPE_F)\t\t       \\\n+R(ptype_rss,\t\t\t0, 0, 0, 0, 1, 1, PTYPE_F | RSS_F)\t       \\\n+R(cksum,\t\t\t0, 0, 0, 1, 0, 0, CKSUM_F)\t\t       \\\n+R(cksum_rss,\t\t\t0, 0, 0, 1, 0, 1, CKSUM_F | RSS_F)\t       \\\n+R(cksum_ptype,\t\t\t0, 0, 0, 1, 1, 0, CKSUM_F | PTYPE_F)\t       \\\n+R(cksum_ptype_rss,\t\t0, 0, 0, 1, 1, 1, CKSUM_F | PTYPE_F | RSS_F)   \\\n+R(mark,\t\t\t\t0, 0, 1, 0, 0, 0, MARK_F)\t\t       \\\n+R(mark_rss,\t\t\t0, 0, 1, 0, 0, 1, MARK_F | RSS_F)\t       \\\n+R(mark_ptype,\t\t\t0, 0, 1, 0, 1, 0, MARK_F | PTYPE_F)\t       \\\n+R(mark_ptype_rss,\t\t0, 0, 1, 0, 1, 1, MARK_F | PTYPE_F | RSS_F)    \\\n+R(mark_cksum,\t\t\t0, 0, 1, 1, 0, 0, MARK_F | CKSUM_F)\t       \\\n+R(mark_cksum_rss,\t\t0, 0, 1, 1, 0, 1, MARK_F | CKSUM_F | RSS_F)    \\\n+R(mark_cksum_ptype,\t\t0, 0, 1, 1, 1, 0, MARK_F | CKSUM_F | PTYPE_F)  \\\n+R(mark_cksum_ptype_rss,\t\t0, 0, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tMARK_F | CKSUM_F | PTYPE_F | RSS_F)\t\t       \\\n+R(ts,\t\t\t\t0, 1, 0, 0, 0, 0, TS_F)\t\t\t       \\\n+R(ts_rss,\t\t\t0, 1, 0, 0, 0, 1, TS_F | RSS_F)\t\t       \\\n+R(ts_ptype,\t\t\t0, 1, 0, 0, 1, 0, TS_F | PTYPE_F)\t       \\\n+R(ts_ptype_rss,\t\t\t0, 1, 0, 0, 1, 1, TS_F | PTYPE_F | RSS_F)      \\\n+R(ts_cksum,\t\t\t0, 1, 0, 1, 0, 0, TS_F | CKSUM_F)\t       \\\n+R(ts_cksum_rss,\t\t\t0, 1, 0, 1, 0, 1, TS_F | CKSUM_F | RSS_F)      \\\n+R(ts_cksum_ptype,\t\t0, 1, 0, 1, 1, 0, TS_F | CKSUM_F | PTYPE_F)    \\\n+R(ts_cksum_ptype_rss,\t\t0, 1, 0, 1, 1, 1,\t\t\t       \\\n+\t\t\tTS_F | CKSUM_F | PTYPE_F | RSS_F)\t\t       \\\n+R(ts_mark,\t\t\t0, 1, 1, 0, 0, 0, TS_F | MARK_F)\t       \\\n+R(ts_mark_rss,\t\t\t0, 1, 1, 0, 0, 1, TS_F | MARK_F | RSS_F)       \\\n+R(ts_mark_ptype,\t\t0, 1, 1, 0, 1, 0, TS_F | MARK_F | PTYPE_F)     \\\n+R(ts_mark_ptype_rss,\t\t0, 1, 1, 0, 1, 1,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | PTYPE_F | RSS_F)\t\t       \\\n+R(ts_mark_cksum,\t\t0, 1, 1, 1, 0, 0, TS_F | MARK_F | CKSUM_F)     \\\n+R(ts_mark_cksum_rss,\t\t0, 1, 1, 1, 0, 1,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | CKSUM_F | RSS_F)\t\t       \\\n+R(ts_mark_cksum_ptype,\t\t0, 1, 1, 1, 1, 0,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | CKSUM_F | PTYPE_F)\t\t       \\\n+R(ts_mark_cksum_ptype_rss,\t0, 1, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tTS_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan,\t\t\t\t1, 0, 0, 0, 0, 0, RX_VLAN_F)\t\t       \\\n+R(vlan_rss,\t\t\t1, 0, 0, 0, 0, 1, RX_VLAN_F | RSS_F)\t       \\\n+R(vlan_ptype,\t\t\t1, 0, 0, 0, 1, 0, RX_VLAN_F | PTYPE_F)\t       \\\n+R(vlan_ptype_rss,\t\t1, 0, 0, 0, 1, 1, RX_VLAN_F | PTYPE_F | RSS_F) \\\n+R(vlan_cksum,\t\t\t1, 0, 0, 1, 0, 0, RX_VLAN_F | CKSUM_F)\t       \\\n+R(vlan_cksum_rss,\t\t1, 0, 0, 1, 0, 1, RX_VLAN_F | CKSUM_F | RSS_F) \\\n+R(vlan_cksum_ptype,\t\t1, 0, 0, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | CKSUM_F | PTYPE_F)\t\t\t       \\\n+R(vlan_cksum_ptype_rss,\t\t1, 0, 0, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | CKSUM_F | PTYPE_F | RSS_F)\t\t       \\\n+R(vlan_mark,\t\t\t1, 0, 1, 0, 0, 0, RX_VLAN_F | MARK_F)\t       \\\n+R(vlan_mark_rss,\t\t1, 0, 1, 0, 0, 1, RX_VLAN_F | MARK_F | RSS_F)  \\\n+R(vlan_mark_ptype,\t\t1, 0, 1, 0, 1, 0, RX_VLAN_F | MARK_F | PTYPE_F)\\\n+R(vlan_mark_ptype_rss,\t\t1, 0, 1, 0, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | PTYPE_F | RSS_F)\t\t       \\\n+R(vlan_mark_cksum,\t\t1, 0, 1, 1, 0, 0, RX_VLAN_F | MARK_F | CKSUM_F)\\\n+R(vlan_mark_cksum_rss,\t\t1, 0, 1, 1, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | CKSUM_F | RSS_F)\t\t       \\\n+R(vlan_mark_cksum_ptype,\t1, 0, 1, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | CKSUM_F | PTYPE_F)\t\t       \\\n+R(vlan_mark_cksum_ptype_rss,\t1, 0, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan_ts,\t\t\t1, 1, 0, 0, 0, 0, RX_VLAN_F | TS_F)\t       \\\n+R(vlan_ts_rss,\t\t\t1, 1, 0, 0, 0, 1, RX_VLAN_F | TS_F | RSS_F)    \\\n+R(vlan_ts_ptype,\t\t1, 1, 0, 0, 1, 0, RX_VLAN_F | TS_F | PTYPE_F)  \\\n+R(vlan_ts_ptype_rss,\t\t1, 1, 0, 0, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | PTYPE_F | RSS_F)\t\t       \\\n+R(vlan_ts_cksum,\t\t1, 1, 0, 1, 0, 0, RX_VLAN_F | TS_F | CKSUM_F)  \\\n+R(vlan_ts_cksum_rss,\t\t1, 1, 0, 1, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | CKSUM_F | RSS_F)\t\t       \\\n+R(vlan_ts_cksum_ptype,\t\t1, 1, 0, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | CKSUM_F | PTYPE_F)\t\t       \\\n+R(vlan_ts_cksum_ptype_rss,\t1, 1, 0, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | CKSUM_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan_ts_mark,\t\t\t1, 1, 1, 0, 0, 0, RX_VLAN_F | TS_F | MARK_F)   \\\n+R(vlan_ts_mark_rss,\t\t1, 1, 1, 0, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | RSS_F)\t\t       \\\n+R(vlan_ts_mark_ptype,\t\t1, 1, 1, 0, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | PTYPE_F)\t\t       \\\n+R(vlan_ts_mark_ptype_rss,\t1, 1, 1, 0, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | PTYPE_F | RSS_F)\t       \\\n+R(vlan_ts_mark_cksum,\t\t1, 1, 1, 1, 0, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F)\t\t       \\\n+R(vlan_ts_mark_cksum_rss,\t1, 1, 1, 1, 0, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F | RSS_F)\t       \\\n+R(vlan_ts_mark_cksum_ptype,\t1, 1, 1, 1, 1, 0,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F | PTYPE_F)\t       \\\n+R(vlan_ts_mark_cksum_ptype_rss,\t1, 1, 1, 1, 1, 1,\t\t\t       \\\n+\t\t\tRX_VLAN_F | TS_F | MARK_F | CKSUM_F | PTYPE_F | RSS_F)\n \n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n \tuint16_t __rte_noinline __rte_hot cn9k_nix_recv_pkts_##name(           \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts);     \\\n \t\t\t\t\t\t\t\t\t       \\\ndiff --git a/drivers/net/cnxk/cn9k_rx_mseg.c b/drivers/net/cnxk/cn9k_rx_mseg.c\nindex 3b26962..d7e19b1 100644\n--- a/drivers/net/cnxk/cn9k_rx_mseg.c\n+++ b/drivers/net/cnxk/cn9k_rx_mseg.c\n@@ -5,7 +5,7 @@\n #include \"cn9k_ethdev.h\"\n #include \"cn9k_rx.h\"\n \n-#define R(name, f4, f3, f2, f1, f0, flags)                                     \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)                                 \\\n \tuint16_t __rte_noinline __rte_hot cn9k_nix_recv_pkts_mseg_##name(      \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts)      \\\n \t{                                                                      \\\ndiff --git a/drivers/net/cnxk/cn9k_rx_vec.c b/drivers/net/cnxk/cn9k_rx_vec.c\nindex b19c7f3..e61c222 100644\n--- a/drivers/net/cnxk/cn9k_rx_vec.c\n+++ b/drivers/net/cnxk/cn9k_rx_vec.c\n@@ -5,7 +5,7 @@\n #include \"cn9k_ethdev.h\"\n #include \"cn9k_rx.h\"\n \n-#define R(name, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n+#define R(name, f5, f4, f3, f2, f1, f0, flags)\t\t\t\t       \\\n \tuint16_t __rte_noinline __rte_hot cn9k_nix_recv_pkts_vec_##name(       \\\n \t\tvoid *rx_queue, struct rte_mbuf **rx_pkts, uint16_t pkts)      \\\n \t{                                                                      \\\ndiff --git a/drivers/net/cnxk/cnxk_ethdev.c b/drivers/net/cnxk/cnxk_ethdev.c\nindex 1edea35..93d7ec7 100644\n--- a/drivers/net/cnxk/cnxk_ethdev.c\n+++ b/drivers/net/cnxk/cnxk_ethdev.c\n@@ -1287,6 +1287,7 @@ cnxk_eth_dev_init(struct rte_eth_dev *eth_dev)\n \n \t/* Initialize base roc nix */\n \tnix->pci_dev = pci_dev;\n+\tnix->hw_vlan_ins = true;\n \trc = roc_nix_dev_init(nix);\n \tif (rc) {\n \t\tplt_err(\"Failed to initialize roc nix rc=%d\", rc);\ndiff --git a/drivers/net/cnxk/cnxk_ethdev.h b/drivers/net/cnxk/cnxk_ethdev.h\nindex c07e988..67b1f42 100644\n--- a/drivers/net/cnxk/cnxk_ethdev.h\n+++ b/drivers/net/cnxk/cnxk_ethdev.h\n@@ -76,7 +76,8 @@\n \t(DEV_RX_OFFLOAD_CHECKSUM | DEV_RX_OFFLOAD_SCTP_CKSUM |                 \\\n \t DEV_RX_OFFLOAD_OUTER_IPV4_CKSUM | DEV_RX_OFFLOAD_SCATTER |            \\\n \t DEV_RX_OFFLOAD_JUMBO_FRAME | DEV_RX_OFFLOAD_OUTER_UDP_CKSUM |         \\\n-\t DEV_RX_OFFLOAD_RSS_HASH | DEV_RX_OFFLOAD_TIMESTAMP)\n+\t DEV_RX_OFFLOAD_RSS_HASH | DEV_RX_OFFLOAD_TIMESTAMP |                  \\\n+\t DEV_RX_OFFLOAD_VLAN_STRIP)\n \n #define RSS_IPV4_ENABLE                                                        \\\n \t(ETH_RSS_IPV4 | ETH_RSS_FRAG_IPV4 | ETH_RSS_NONFRAG_IPV4_UDP |         \\\ndiff --git a/drivers/net/cnxk/cnxk_rte_flow.c b/drivers/net/cnxk/cnxk_rte_flow.c\nindex c61618a..213125b 100644\n--- a/drivers/net/cnxk/cnxk_rte_flow.c\n+++ b/drivers/net/cnxk/cnxk_rte_flow.c\n@@ -178,6 +178,23 @@ cnxk_map_actions(struct rte_eth_dev *eth_dev, const struct rte_flow_attr *attr,\n \t\tcase RTE_FLOW_ACTION_TYPE_SECURITY:\n \t\t\tin_actions[i].type = ROC_NPC_ACTION_TYPE_SEC;\n \t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_OF_POP_VLAN:\n+\t\t\tin_actions[i].type = ROC_NPC_ACTION_TYPE_VLAN_STRIP;\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_OF_SET_VLAN_VID:\n+\t\t\tin_actions[i].type = ROC_NPC_ACTION_TYPE_VLAN_INSERT;\n+\t\t\tin_actions[i].conf = actions->conf;\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_OF_PUSH_VLAN:\n+\t\t\tin_actions[i].type =\n+\t\t\t\tROC_NPC_ACTION_TYPE_VLAN_ETHTYPE_INSERT;\n+\t\t\tin_actions[i].conf = actions->conf;\n+\t\t\tbreak;\n+\t\tcase RTE_FLOW_ACTION_TYPE_OF_SET_VLAN_PCP:\n+\t\t\tin_actions[i].type =\n+\t\t\t\tROC_NPC_ACTION_TYPE_VLAN_PCP_INSERT;\n+\t\t\tin_actions[i].conf = actions->conf;\n+\t\t\tbreak;\n \t\tdefault:\n \t\t\tplt_npc_dbg(\"Action is not supported = %d\",\n \t\t\t\t    actions->type);\n",
    "prefixes": [
        "v3",
        "62/62"
    ]
}