Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/136984/?format=api
http://patchwork.dpdk.org/api/patches/136984/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/patch/20240221212044.27209-8-ajit.khaparde@broadcom.com/", "project": { "id": 1, "url": "http://patchwork.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": "<20240221212044.27209-8-ajit.khaparde@broadcom.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20240221212044.27209-8-ajit.khaparde@broadcom.com", "date": "2024-02-21T21:20:42", "name": "[07/10] net/bnxt: add IPv6 flow label based RSS support", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": true, "hash": "899161bab73c4ed6c34d40997ea910ec10d33a82", "submitter": { "id": 501, "url": "http://patchwork.dpdk.org/api/people/501/?format=api", "name": "Ajit Khaparde", "email": "ajit.khaparde@broadcom.com" }, "delegate": { "id": 1766, "url": "http://patchwork.dpdk.org/api/users/1766/?format=api", "username": "ajitkhaparde", "first_name": "Ajit", "last_name": "Khaparde", "email": "ajit.khaparde@broadcom.com" }, "mbox": "http://patchwork.dpdk.org/project/dpdk/patch/20240221212044.27209-8-ajit.khaparde@broadcom.com/mbox/", "series": [ { "id": 31173, "url": "http://patchwork.dpdk.org/api/series/31173/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/list/?series=31173", "date": "2024-02-21T21:20:35", "name": "patchset for bnxt", "version": 1, "mbox": "http://patchwork.dpdk.org/series/31173/mbox/" } ], "comments": "http://patchwork.dpdk.org/api/patches/136984/comments/", "check": "success", "checks": "http://patchwork.dpdk.org/api/patches/136984/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 0965343B67;\n\tWed, 21 Feb 2024 22:21:59 +0100 (CET)", "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id DDBCA40E28;\n\tWed, 21 Feb 2024 22:21:15 +0100 (CET)", "from mail-qt1-f176.google.com (mail-qt1-f176.google.com\n [209.85.160.176])\n by mails.dpdk.org (Postfix) with ESMTP id 323A440DCB\n for <dev@dpdk.org>; Wed, 21 Feb 2024 22:21:13 +0100 (CET)", "by mail-qt1-f176.google.com with SMTP id\n d75a77b69052e-42c7c1cb2e9so41331031cf.3\n for <dev@dpdk.org>; Wed, 21 Feb 2024 13:21:13 -0800 (PST)", "from C02GC2QQMD6T.wifi.broadcom.net ([192.19.223.252])\n by smtp.gmail.com with ESMTPSA id\n 20-20020ac84e94000000b0042bff97d9a3sm4743467qtp.40.2024.02.21.13.21.10\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Wed, 21 Feb 2024 13:21:11 -0800 (PST)" ], "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=broadcom.com; s=google; t=1708550472; x=1709155272; darn=dpdk.org;\n h=mime-version:references:in-reply-to:message-id:date:subject:cc:to\n :from:from:to:cc:subject:date:message-id:reply-to;\n bh=neb84x1GKXUlAcqC5AYj/hMESukNk2NoxtJ+/bFkU3w=;\n b=hXjdBGFCLfJJYma0qz4/UehPcpaoUz7f226/hld6JfK4sAmhEeT9v1VXUA3TWjD+rV\n 6jpRD8RNbyO7kWs36RYYvPBhbllXMbyLpgKAlENUa+iVy+vcd4PpnqyRb4RRbEBbDwDU\n ikn6o16+5RH6kzkAoxa32fZxiUQ1Fbe9azFyY=", "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20230601; t=1708550472; x=1709155272;\n h=mime-version:references:in-reply-to:message-id:date:subject:cc:to\n :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to;\n bh=neb84x1GKXUlAcqC5AYj/hMESukNk2NoxtJ+/bFkU3w=;\n b=udh9bEU8I69vPzasrxerVPU+zCOYAqK/pM5AXKPlBcaitFUCYs2UX85krntqBEjjoC\n IiG3F9VCcd0ONOhxeLgO4woG2sRYoe3JsNFx9k3A2uMkutvXzV9tl/mb+Ygwt9UQHxUE\n rU9/vN7/RdDuzWUQWmcw5mIKbYAuvrqGxLYD1g3wJI5m822hw0AuGKekmoWTo30vcIHX\n VNZkcmX2aTj8txYU6nVqQewTMd2M6JGccbjFFRUgTXM1ewoR/b2Y+ghYrMd/1xfVWJCa\n qvs4MEVqNKNcvCbhL5mF1ArDxriRVF69m38SMzStqfbvASBZbuPHWOXKTkCg7FO+MXj6\n 1cmg==", "X-Gm-Message-State": "AOJu0Yx98cOEOoRJ/fMa8/iOGWGXKaxLUSwRqnZsEygPpKqzeur176MM\n LAEDqviimw6YMoXxRowCbnbsYXhRJ7oPEiETFornv1ro0JG5BMmepWp2ytsulObIDecz7aB9h2u\n NmwFsNAdkfWRTrsNBXu/VvioKbyA2k5dEcDXTP66iq80VxVX9k1lEJu50BaYBl3LnaoT+80fdus\n hklMXDylzCgyr/r/L01DovQFoeHWc6", "X-Google-Smtp-Source": "\n AGHT+IFLthHQWem0K+F7UdAIcC2hE92vucmH3GzZKylVWXcQ390E9+HwmFFduXnlCD9AjpS1kkQDNw==", "X-Received": "by 2002:ac8:7f05:0:b0:42c:7bb1:20f8 with SMTP id\n f5-20020ac87f05000000b0042c7bb120f8mr23915011qtk.59.1708550472002;\n Wed, 21 Feb 2024 13:21:12 -0800 (PST)", "From": "Ajit Khaparde <ajit.khaparde@broadcom.com>", "To": "dev@dpdk.org", "Cc": "ferruh.yigit@amd.com,\n\tthomas@monjalon.net", "Subject": "[PATCH 07/10] net/bnxt: add IPv6 flow label based RSS support", "Date": "Wed, 21 Feb 2024 13:20:42 -0800", "Message-Id": "<20240221212044.27209-8-ajit.khaparde@broadcom.com>", "X-Mailer": "git-send-email 2.39.2 (Apple Git-143)", "In-Reply-To": "<20240221212044.27209-1-ajit.khaparde@broadcom.com>", "References": "<20240221212044.27209-1-ajit.khaparde@broadcom.com>", "MIME-Version": "1.0", "Content-Type": "multipart/signed; protocol=\"application/pkcs7-signature\";\n micalg=sha-256; boundary=\"000000000000fd09690611eae7c5\"", "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" }, "content": "P7 hardware family can support IPv6 flow label based RSS.\nCheck if the firmware indicates capability bit to support\nIPv6 flow label based RSS and parse the RSS hash types\nappropriately.\n\nSigned-off-by: Ajit Khaparde <ajit.khaparde@broadcom.com>\n---\n drivers/net/bnxt/bnxt.h | 1 +\n drivers/net/bnxt/bnxt_ethdev.c | 2 ++\n drivers/net/bnxt/bnxt_hwrm.c | 7 +++++++\n drivers/net/bnxt/bnxt_vnic.c | 9 +++++++--\n 4 files changed, 17 insertions(+), 2 deletions(-)", "diff": "diff --git a/drivers/net/bnxt/bnxt.h b/drivers/net/bnxt/bnxt.h\nindex fcf2b8be97..4203e6a055 100644\n--- a/drivers/net/bnxt/bnxt.h\n+++ b/drivers/net/bnxt/bnxt.h\n@@ -868,6 +868,7 @@ struct bnxt {\n #define BNXT_VNIC_CAP_OUTER_RSS_TRUSTED_VF\tBIT(4)\n #define BNXT_VNIC_CAP_XOR_MODE\t\tBIT(5)\n #define BNXT_VNIC_CAP_CHKSM_MODE\tBIT(6)\n+#define BNXT_VNIC_CAP_IPV6_FLOW_LABEL_MODE\tBIT(7)\n #define BNXT_VNIC_CAP_L2_CQE_MODE\tBIT(8)\n #define BNXT_VNIC_CAP_AH_SPI4_CAP\tBIT(9)\n #define BNXT_VNIC_CAP_AH_SPI6_CAP\tBIT(10)\ndiff --git a/drivers/net/bnxt/bnxt_ethdev.c b/drivers/net/bnxt/bnxt_ethdev.c\nindex f8d83662f4..d5a4312c5b 100644\n--- a/drivers/net/bnxt/bnxt_ethdev.c\n+++ b/drivers/net/bnxt/bnxt_ethdev.c\n@@ -1087,6 +1087,8 @@ uint64_t bnxt_eth_rss_support(struct bnxt *bp)\n \tif (bp->vnic_cap_flags & BNXT_VNIC_CAP_CHKSM_MODE)\n \t\tsupport |= RTE_ETH_RSS_IPV4_CHKSUM |\n \t\t\t RTE_ETH_RSS_L4_CHKSUM;\n+\tif (bp->vnic_cap_flags & BNXT_VNIC_CAP_IPV6_FLOW_LABEL_MODE)\n+\t\tsupport |= RTE_ETH_RSS_IPV6_FLOW_LABEL;\n \tif (bp->vnic_cap_flags & BNXT_VNIC_CAP_AH_SPI_CAP)\n \t\tsupport |= RTE_ETH_RSS_AH;\n \tif (bp->vnic_cap_flags & BNXT_VNIC_CAP_ESP_SPI_CAP)\ndiff --git a/drivers/net/bnxt/bnxt_hwrm.c b/drivers/net/bnxt/bnxt_hwrm.c\nindex 7f49b4b40e..6ea7089a3f 100644\n--- a/drivers/net/bnxt/bnxt_hwrm.c\n+++ b/drivers/net/bnxt/bnxt_hwrm.c\n@@ -1308,6 +1308,9 @@ int bnxt_hwrm_vnic_qcaps(struct bnxt *bp)\n \tif (flags & HWRM_VNIC_QCAPS_OUTPUT_FLAGS_RING_SELECT_MODE_TOEPLITZ_CHKSM_CAP)\n \t\tbp->vnic_cap_flags |= BNXT_VNIC_CAP_CHKSM_MODE;\n \n+\tif (flags & HWRM_VNIC_QCAPS_OUTPUT_FLAGS_RSS_IPV6_FLOW_LABEL_CAP)\n+\t\tbp->vnic_cap_flags |= BNXT_VNIC_CAP_IPV6_FLOW_LABEL_MODE;\n+\n \tif (flags & HWRM_VNIC_QCAPS_OUTPUT_FLAGS_L2_CQE_MODE_CAP)\n \t\tbp->vnic_cap_flags |= BNXT_VNIC_CAP_L2_CQE_MODE;\n \n@@ -2773,6 +2776,10 @@ static uint32_t bnxt_sanitize_rss_type(struct bnxt *bp, uint32_t types)\n {\n \tuint32_t hwrm_type = types;\n \n+\tif (types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_IPV6_FLOW_LABEL &&\n+\t !(bp->vnic_cap_flags & BNXT_VNIC_CAP_IPV6_FLOW_LABEL_MODE))\n+\t\thwrm_type &= ~HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_IPV6_FLOW_LABEL;\n+\n \tif (types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_ESP_SPI_IPV4 &&\n \t !(bp->vnic_cap_flags & BNXT_VNIC_CAP_ESP_SPI4_CAP))\n \t\thwrm_type &= ~HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_ESP_SPI_IPV4;\ndiff --git a/drivers/net/bnxt/bnxt_vnic.c b/drivers/net/bnxt/bnxt_vnic.c\nindex 5092a7d774..76905ebdd1 100644\n--- a/drivers/net/bnxt/bnxt_vnic.c\n+++ b/drivers/net/bnxt/bnxt_vnic.c\n@@ -280,6 +280,8 @@ uint32_t bnxt_rte_to_hwrm_hash_types(uint64_t rte_type)\n \t\thwrm_type |= HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_TCP_IPV6;\n \tif (rte_type & RTE_ETH_RSS_NONFRAG_IPV6_UDP)\n \t\thwrm_type |= HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_UDP_IPV6;\n+\tif (rte_type & RTE_ETH_RSS_IPV6_FLOW_LABEL)\n+\t\thwrm_type |= HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_IPV6_FLOW_LABEL;\n \tif (rte_type & RTE_ETH_RSS_ESP)\n \t\thwrm_type |= HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_ESP_SPI_IPV4 |\n \t\t\t HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_ESP_SPI_IPV6;\n@@ -302,6 +304,7 @@ int bnxt_rte_to_hwrm_hash_level(struct bnxt *bp, uint64_t hash_f, uint32_t lvl)\n \tbool l3_and_l4 = l3 && l4;\n \tbool cksum = !!(hash_f &\n \t\t\t(RTE_ETH_RSS_IPV4_CHKSUM | RTE_ETH_RSS_L4_CHKSUM));\n+\tbool fl = !!(hash_f & RTE_ETH_RSS_IPV6_FLOW_LABEL);\n \n \t/* If FW has not advertised capability to configure outer/inner\n \t * RSS hashing , just log a message. HW will work in default RSS mode.\n@@ -317,12 +320,12 @@ int bnxt_rte_to_hwrm_hash_level(struct bnxt *bp, uint64_t hash_f, uint32_t lvl)\n \tswitch (lvl) {\n \tcase BNXT_RSS_LEVEL_INNERMOST:\n \t\t/* Irrespective of what RTE says, FW always does 4 tuple */\n-\t\tif (l3_and_l4 || l4 || l3_only || cksum)\n+\t\tif (l3_and_l4 || l4 || l3_only || cksum || fl)\n \t\t\tmode = BNXT_HASH_MODE_INNERMOST;\n \t\tbreak;\n \tcase BNXT_RSS_LEVEL_OUTERMOST:\n \t\t/* Irrespective of what RTE says, FW always does 4 tuple */\n-\t\tif (l3_and_l4 || l4 || l3_only || cksum)\n+\t\tif (l3_and_l4 || l4 || l3_only || cksum || fl)\n \t\t\tmode = BNXT_HASH_MODE_OUTERMOST;\n \t\tbreak;\n \tdefault:\n@@ -1415,6 +1418,8 @@ void bnxt_hwrm_rss_to_rte_hash_conf(struct bnxt_vnic_info *vnic,\n \t\t*rss_conf |= RTE_ETH_RSS_NONFRAG_IPV6_TCP;\n \tif (hash_types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_UDP_IPV6)\n \t\t*rss_conf |= RTE_ETH_RSS_NONFRAG_IPV6_UDP;\n+\tif (hash_types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_IPV6_FLOW_LABEL)\n+\t\t*rss_conf |= RTE_ETH_RSS_IPV6_FLOW_LABEL;\n \tif (hash_types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_AH_SPI_IPV6 ||\n \t hash_types & HWRM_VNIC_RSS_CFG_INPUT_HASH_TYPE_AH_SPI_IPV4)\n \t\t*rss_conf |= RTE_ETH_RSS_AH;\n", "prefixes": [ "07/10" ] }{ "id": 136984, "url": "