* [PATCH 0/2] app/testpmd: support set RSS hash algorithm
@ 2023-11-22  9:48 Jie Hai
  2023-11-22  9:48 ` [PATCH 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
                   ` (5 more replies)
  0 siblings, 6 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-22  9:48 UTC (permalink / raw)
  To: dev; +Cc: lihuisong, fengchengwen, liudongdong3, haijie1
This patch set supports setting RSS hash algorithm.
Jie Hai (2):
  ethdev: add new API to get RSS hash algorithm by name
  app/testpmd: support set RSS hash algorithm
 app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
 doc/guides/rel_notes/release_23_11.rst      |  3 +
 doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
 lib/ethdev/rte_ethdev.c                     | 15 ++++
 lib/ethdev/rte_ethdev.h                     | 20 ++++++
 lib/ethdev/version.map                      |  1 +
 6 files changed, 129 insertions(+)
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [PATCH 1/2] ethdev: add new API to get RSS hash algorithm by name
  2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
@ 2023-11-22  9:48 ` Jie Hai
  2023-11-22  9:48 ` [PATCH 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
                   ` (4 subsequent siblings)
  5 siblings, 0 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-22  9:48 UTC (permalink / raw)
  To: dev, Thomas Monjalon, Ferruh Yigit, Andrew Rybchenko
  Cc: lihuisong, fengchengwen, liudongdong3, haijie1
This patch supports conversion from names to hash algorithms(see
RTE_ETH_HASH_FUNCTION_XXX).
Signed-off-by: Jie Hai <haijie1@huawei.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
---
 doc/guides/rel_notes/release_23_11.rst |  3 +++
 lib/ethdev/rte_ethdev.c                | 15 +++++++++++++++
 lib/ethdev/rte_ethdev.h                | 20 ++++++++++++++++++++
 lib/ethdev/version.map                 |  1 +
 4 files changed, 39 insertions(+)
diff --git a/doc/guides/rel_notes/release_23_11.rst b/doc/guides/rel_notes/release_23_11.rst
index 520321c71e9c..b157fb9d307e 100644
--- a/doc/guides/rel_notes/release_23_11.rst
+++ b/doc/guides/rel_notes/release_23_11.rst
@@ -124,6 +124,9 @@ New Features
   * Added new function ``rte_eth_dev_rss_algo_name``
     to get name of RSS hash algorithm.
 
+  * Added new function ``rte_eth_find_rss_algo``
+    to get RSS hash algorithm by its name.
+
 * **Added packet type flow matching criteria.**
 
   Added ``RTE_FLOW_ITEM_TYPE_PTYPE`` to allow matching on L2/L3/L4
diff --git a/lib/ethdev/rte_ethdev.c b/lib/ethdev/rte_ethdev.c
index 3858983fcc80..c0398d945502 100644
--- a/lib/ethdev/rte_ethdev.c
+++ b/lib/ethdev/rte_ethdev.c
@@ -4826,6 +4826,21 @@ rte_eth_dev_rss_algo_name(enum rte_eth_hash_function rss_algo)
 	return name;
 }
 
+int
+rte_eth_find_rss_algo(const char *name, uint32_t *algo)
+{
+	unsigned int i;
+
+	for (i = 0; i < RTE_DIM(rte_eth_dev_rss_algo_names); i++) {
+		if (strcmp(name, rte_eth_dev_rss_algo_names[i].name) == 0) {
+			*algo = rte_eth_dev_rss_algo_names[i].algo;
+			return 0;
+		}
+	}
+
+	return -EINVAL;
+}
+
 int
 rte_eth_dev_udp_tunnel_port_add(uint16_t port_id,
 				struct rte_eth_udp_tunnel *udp_tunnel)
diff --git a/lib/ethdev/rte_ethdev.h b/lib/ethdev/rte_ethdev.h
index 77331ce6525e..3bde5c4c17a6 100644
--- a/lib/ethdev/rte_ethdev.h
+++ b/lib/ethdev/rte_ethdev.h
@@ -4667,6 +4667,26 @@ __rte_experimental
 const char *
 rte_eth_dev_rss_algo_name(enum rte_eth_hash_function rss_algo);
 
+/**
+ * @warning
+ * @b EXPERIMENTAL: this API may change, or be removed, without prior notice.
+ *
+ *  Get RSS hash algorithm by its name.
+ *
+ * @param name
+ *   RSS hash algorithm.
+ *
+ * @param algo
+ *   return the RSS hash algorithm found, @see rte_eth_hash_function.
+ *
+ * @return
+ *   - (0) if successful.
+ *   - (-EINVAL) if not found.
+ */
+__rte_experimental
+int
+rte_eth_find_rss_algo(const char *name, uint32_t *algo);
+
 /**
  * Add UDP tunneling port for a type of tunnel.
  *
diff --git a/lib/ethdev/version.map b/lib/ethdev/version.map
index 5c4917c020dc..d585c12c0110 100644
--- a/lib/ethdev/version.map
+++ b/lib/ethdev/version.map
@@ -313,6 +313,7 @@ EXPERIMENTAL {
 
 	# added in 23.11
 	rte_eth_dev_rss_algo_name;
+	rte_eth_find_rss_algo;
 	rte_eth_recycle_rx_queue_info_get;
 	rte_flow_group_set_miss_actions;
 	rte_flow_calc_table_hash;
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [PATCH 2/2] app/testpmd: support set RSS hash algorithm
  2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
  2023-11-22  9:48 ` [PATCH 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
@ 2023-11-22  9:48 ` Jie Hai
  2023-11-22 10:46 ` [PATCH 0/2] " Ferruh Yigit
                   ` (3 subsequent siblings)
  5 siblings, 0 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-22  9:48 UTC (permalink / raw)
  To: dev, Aman Singh, Yuying Zhang
  Cc: lihuisong, fengchengwen, liudongdong3, haijie1
Since API rte_eth_dev_rss_hash_update() supports setting RSS hash
algorithm, add new command to support it:
testpmd> port config 0 rss-hash-algo symmetric_toeplitz
Signed-off-by: Jie Hai <haijie1@huawei.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
---
 app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
 doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
 2 files changed, 90 insertions(+)
diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c
index 9369d3b4c526..2cd85c918a09 100644
--- a/app/test-pmd/cmdline.c
+++ b/app/test-pmd/cmdline.c
@@ -726,6 +726,10 @@ static void cmd_help_long_parsed(void *parsed_result,
 			"port config port-id rss reta (hash,queue)[,(hash,queue)]\n"
 			"    Set the RSS redirection table.\n\n"
 
+			"port config port-id rss-hash-algo (default|simple_xor|toeplitz|"
+			"symmetric_toeplitz|symmetric_toeplitz_sort)\n"
+			"    Set the RSS hash algorithm.\n\n"
+
 			"port config (port_id) dcb vt (on|off) (traffic_class)"
 			" pfc (on|off)\n"
 			"    Set the DCB mode.\n\n"
@@ -2275,6 +2279,80 @@ static cmdline_parse_inst_t cmd_config_rss_hash_key = {
 	},
 };
 
+/* *** configure rss hash algorithm *** */
+struct cmd_config_rss_hash_algo {
+	cmdline_fixed_string_t port;
+	cmdline_fixed_string_t config;
+	portid_t port_id;
+	cmdline_fixed_string_t rss_hash_algo;
+	cmdline_fixed_string_t algo;
+};
+
+static void
+cmd_config_rss_hash_algo_parsed(void *parsed_result,
+				__rte_unused struct cmdline *cl,
+				__rte_unused void *data)
+{
+	struct cmd_config_rss_hash_algo *res = parsed_result;
+	uint8_t rss_key[RSS_HASH_KEY_LENGTH];
+	struct rte_eth_rss_conf rss_conf;
+	int ret;
+
+	rss_conf.rss_key_len = RSS_HASH_KEY_LENGTH;
+	rss_conf.rss_key = rss_key;
+	ret = rte_eth_dev_rss_hash_conf_get(res->port_id, &rss_conf);
+	if (ret != 0) {
+		fprintf(stderr, "failed to get port %u RSS confinguration\n",
+			res->port_id);
+		return;
+	}
+
+	ret = rte_eth_find_rss_algo(res->algo, &rss_conf.algorithm);
+	if (ret != 0) {
+		fprintf(stderr, "port %u configured invalid RSS hash algorithm: %s\n",
+			res->port_id, res->algo);
+		return;
+	}
+
+	ret = rte_eth_dev_rss_hash_update(res->port_id, &rss_conf);
+	if (ret != 0) {
+		fprintf(stderr, "failed to set port %u RSS hash algorithm\n",
+			res->port_id);
+		return;
+	}
+}
+
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_port =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, port, "port");
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_config =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, config,
+				 "config");
+static cmdline_parse_token_num_t cmd_config_rss_hash_algo_port_id =
+	TOKEN_NUM_INITIALIZER(struct cmd_config_rss_hash_algo, port_id,
+			      RTE_UINT16);
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_rss_hash_algo =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo,
+				 rss_hash_algo, "rss-hash-algo");
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_algo =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, algo,
+				 "default#simple_xor#toeplitz#"
+				 "symmetric_toeplitz#symmetric_toeplitz_sort");
+
+static cmdline_parse_inst_t cmd_config_rss_hash_algo = {
+	.f = cmd_config_rss_hash_algo_parsed,
+	.data = NULL,
+	.help_str = "port config <port_id> rss-hash-algo "
+		"(default|simple_xor|toeplitz|symmetric_toeplitz|symmetric_toeplitz_sort)",
+	.tokens = {
+		(void *)&cmd_config_rss_hash_algo_port,
+		(void *)&cmd_config_rss_hash_algo_config,
+		(void *)&cmd_config_rss_hash_algo_port_id,
+		(void *)&cmd_config_rss_hash_algo_rss_hash_algo,
+		(void *)&cmd_config_rss_hash_algo_algo,
+		NULL,
+	},
+};
+
 /* *** cleanup txq mbufs *** */
 struct cmd_cleanup_txq_mbufs_result {
 	cmdline_fixed_string_t port;
@@ -13165,6 +13243,7 @@ static cmdline_parse_ctx_t builtin_ctx[] = {
 	(cmdline_parse_inst_t *)&cmd_showport_rss_hash_key,
 	(cmdline_parse_inst_t *)&cmd_showport_rss_hash_algo,
 	(cmdline_parse_inst_t *)&cmd_config_rss_hash_key,
+	(cmdline_parse_inst_t *)&cmd_config_rss_hash_algo,
 	(cmdline_parse_inst_t *)&cmd_cleanup_txq_mbufs,
 	(cmdline_parse_inst_t *)&cmd_dump,
 	(cmdline_parse_inst_t *)&cmd_dump_one,
diff --git a/doc/guides/testpmd_app_ug/testpmd_funcs.rst b/doc/guides/testpmd_app_ug/testpmd_funcs.rst
index 447e28e6944f..3c7d20c2db82 100644
--- a/doc/guides/testpmd_app_ug/testpmd_funcs.rst
+++ b/doc/guides/testpmd_app_ug/testpmd_funcs.rst
@@ -2263,6 +2263,17 @@ hash of input [IP] packets received on port::
                      ipv6-udp-ex <string of hex digits \
                      (variable length, NIC dependent)>)
 
+
+port config rss hash algorithm
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+To configure the RSS hash algorithm used to compute the RSS
+hash of input packets received on port::
+
+   testpmd> port config <port_id> rss-hash-algo (default|\
+                     simple_xor|toeplitz|symmetric_toeplitz|\
+                     symmetric_toeplitz_sort)
+
 port cleanup txq mbufs
 ~~~~~~~~~~~~~~~~~~~~~~
 
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [PATCH 0/2] app/testpmd: support set RSS hash algorithm
  2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
  2023-11-22  9:48 ` [PATCH 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
  2023-11-22  9:48 ` [PATCH 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
@ 2023-11-22 10:46 ` Ferruh Yigit
  2023-11-23  6:32   ` Jie Hai
  2023-11-30  9:02 ` Ferruh Yigit
                   ` (2 subsequent siblings)
  5 siblings, 1 reply; 18+ messages in thread
From: Ferruh Yigit @ 2023-11-22 10:46 UTC (permalink / raw)
  To: Jie Hai, dev; +Cc: lihuisong, fengchengwen, liudongdong3
On 11/22/2023 9:48 AM, Jie Hai wrote:
> This patch set supports setting RSS hash algorithm.
> 
> Jie Hai (2):
>   ethdev: add new API to get RSS hash algorithm by name
>   app/testpmd: support set RSS hash algorithm
> 
Hi Jie,
It is too late for the current release, can you please rebase it on
v24.03-rc0 when it is out and send again?
Thanks,
ferruh
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [PATCH 0/2] app/testpmd: support set RSS hash algorithm
  2023-11-22 10:46 ` [PATCH 0/2] " Ferruh Yigit
@ 2023-11-23  6:32   ` Jie Hai
  0 siblings, 0 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-23  6:32 UTC (permalink / raw)
  To: Ferruh Yigit, dev; +Cc: lihuisong, fengchengwen, liudongdong3
On 2023/11/22 18:46, Ferruh Yigit wrote:
> On 11/22/2023 9:48 AM, Jie Hai wrote:
>> This patch set supports setting RSS hash algorithm.
>>
>> Jie Hai (2):
>>    ethdev: add new API to get RSS hash algorithm by name
>>    app/testpmd: support set RSS hash algorithm
>>
> 
> Hi Jie,
> 
Hi, ferruh,
> It is too late for the current release, can you please rebase it on
> v24.03-rc0 when it is out and send again?
Thanks and I will wait and send again.
> 
> Thanks,
> ferruh
> 
Thanks,
Jie Hai
> .
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [PATCH 0/2] app/testpmd: support set RSS hash algorithm
  2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
                   ` (2 preceding siblings ...)
  2023-11-22 10:46 ` [PATCH 0/2] " Ferruh Yigit
@ 2023-11-30  9:02 ` Ferruh Yigit
  2023-11-30 10:01   ` Jie Hai
  2023-11-30 10:44 ` [RESEND " Jie Hai
  2023-12-01  8:52 ` [PATCH v2 0/2] " Jie Hai
  5 siblings, 1 reply; 18+ messages in thread
From: Ferruh Yigit @ 2023-11-30  9:02 UTC (permalink / raw)
  To: Jie Hai, dev; +Cc: lihuisong, fengchengwen, liudongdong3
On 11/22/2023 9:48 AM, Jie Hai wrote:
> This patch set supports setting RSS hash algorithm.
> 
> Jie Hai (2):
>   ethdev: add new API to get RSS hash algorithm by name
>   app/testpmd: support set RSS hash algorithm
> 
>  app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
>  doc/guides/rel_notes/release_23_11.rst      |  3 +
>
Hi Jie,
Can you rebase the patchset to new release please?
>  doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
>  lib/ethdev/rte_ethdev.c                     | 15 ++++
>  lib/ethdev/rte_ethdev.h                     | 20 ++++++
>  lib/ethdev/version.map                      |  1 +
>  6 files changed, 129 insertions(+)
> 
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [PATCH 0/2] app/testpmd: support set RSS hash algorithm
  2023-11-30  9:02 ` Ferruh Yigit
@ 2023-11-30 10:01   ` Jie Hai
  0 siblings, 0 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-30 10:01 UTC (permalink / raw)
  To: Ferruh Yigit, dev; +Cc: lihuisong, fengchengwen, liudongdong3
On 2023/11/30 17:02, Ferruh Yigit wrote:
> On 11/22/2023 9:48 AM, Jie Hai wrote:
>> This patch set supports setting RSS hash algorithm.
>>
>> Jie Hai (2):
>>    ethdev: add new API to get RSS hash algorithm by name
>>    app/testpmd: support set RSS hash algorithm
>>
>>   app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
>>   doc/guides/rel_notes/release_23_11.rst      |  3 +
>>
> 
> Hi Jie,
> 
> Can you rebase the patchset to new release please?
> 
Hi, Ferruh,
Thanks, I will do it as soon as possible.
Thanks,
Jie Hai
>>   doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
>>   lib/ethdev/rte_ethdev.c                     | 15 ++++
>>   lib/ethdev/rte_ethdev.h                     | 20 ++++++
>>   lib/ethdev/version.map                      |  1 +
>>   6 files changed, 129 insertions(+)
>>
> 
> .
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [RESEND 0/2] app/testpmd: support set RSS hash algorithm
  2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
                   ` (3 preceding siblings ...)
  2023-11-30  9:02 ` Ferruh Yigit
@ 2023-11-30 10:44 ` Jie Hai
  2023-11-30 10:44   ` [RESEND 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
  2023-11-30 10:44   ` [RESEND 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
  2023-12-01  8:52 ` [PATCH v2 0/2] " Jie Hai
  5 siblings, 2 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-30 10:44 UTC (permalink / raw)
  To: thomas, ferruh.yigit, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
This patch set supports setting RSS hash algorithm.
Jie Hai (2):
  ethdev: add new API to get RSS hash algorithm by name
  app/testpmd: support set RSS hash algorithm
 app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
 doc/guides/rel_notes/release_24_03.rst      |  5 ++
 doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
 lib/ethdev/rte_ethdev.c                     | 15 ++++
 lib/ethdev/rte_ethdev.h                     | 20 ++++++
 lib/ethdev/version.map                      |  3 +
 6 files changed, 133 insertions(+)
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [RESEND 1/2] ethdev: add new API to get RSS hash algorithm by name
  2023-11-30 10:44 ` [RESEND " Jie Hai
@ 2023-11-30 10:44   ` Jie Hai
  2023-11-30 11:23     ` Ferruh Yigit
  2023-11-30 10:44   ` [RESEND 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
  1 sibling, 1 reply; 18+ messages in thread
From: Jie Hai @ 2023-11-30 10:44 UTC (permalink / raw)
  To: thomas, ferruh.yigit, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
This patch supports conversion from names to hash algorithm
(see RTE_ETH_HASH_FUNCTION_XXX).
Signed-off-by: Jie Hai <haijie1@huawei.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
---
 doc/guides/rel_notes/release_24_03.rst |  5 +++++
 lib/ethdev/rte_ethdev.c                | 15 +++++++++++++++
 lib/ethdev/rte_ethdev.h                | 20 ++++++++++++++++++++
 lib/ethdev/version.map                 |  3 +++
 4 files changed, 43 insertions(+)
diff --git a/doc/guides/rel_notes/release_24_03.rst b/doc/guides/rel_notes/release_24_03.rst
index e9c9717706a0..bd84875d4f17 100644
--- a/doc/guides/rel_notes/release_24_03.rst
+++ b/doc/guides/rel_notes/release_24_03.rst
@@ -55,6 +55,11 @@ New Features
      Also, make sure to start the actual text at the margin.
      =======================================================
 
+* **Improved support of RSS hash algorithm.**
+
+  * Added new function ``rte_eth_find_rss_algo`` to get RSS hash
+    algorithm by its name.
+
 
 Removed Items
 -------------
diff --git a/lib/ethdev/rte_ethdev.c b/lib/ethdev/rte_ethdev.c
index 3858983fcc80..c0398d945502 100644
--- a/lib/ethdev/rte_ethdev.c
+++ b/lib/ethdev/rte_ethdev.c
@@ -4826,6 +4826,21 @@ rte_eth_dev_rss_algo_name(enum rte_eth_hash_function rss_algo)
 	return name;
 }
 
+int
+rte_eth_find_rss_algo(const char *name, uint32_t *algo)
+{
+	unsigned int i;
+
+	for (i = 0; i < RTE_DIM(rte_eth_dev_rss_algo_names); i++) {
+		if (strcmp(name, rte_eth_dev_rss_algo_names[i].name) == 0) {
+			*algo = rte_eth_dev_rss_algo_names[i].algo;
+			return 0;
+		}
+	}
+
+	return -EINVAL;
+}
+
 int
 rte_eth_dev_udp_tunnel_port_add(uint16_t port_id,
 				struct rte_eth_udp_tunnel *udp_tunnel)
diff --git a/lib/ethdev/rte_ethdev.h b/lib/ethdev/rte_ethdev.h
index 77331ce6525e..3bde5c4c17a6 100644
--- a/lib/ethdev/rte_ethdev.h
+++ b/lib/ethdev/rte_ethdev.h
@@ -4667,6 +4667,26 @@ __rte_experimental
 const char *
 rte_eth_dev_rss_algo_name(enum rte_eth_hash_function rss_algo);
 
+/**
+ * @warning
+ * @b EXPERIMENTAL: this API may change, or be removed, without prior notice.
+ *
+ *  Get RSS hash algorithm by its name.
+ *
+ * @param name
+ *   RSS hash algorithm.
+ *
+ * @param algo
+ *   return the RSS hash algorithm found, @see rte_eth_hash_function.
+ *
+ * @return
+ *   - (0) if successful.
+ *   - (-EINVAL) if not found.
+ */
+__rte_experimental
+int
+rte_eth_find_rss_algo(const char *name, uint32_t *algo);
+
 /**
  * Add UDP tunneling port for a type of tunnel.
  *
diff --git a/lib/ethdev/version.map b/lib/ethdev/version.map
index 5c4917c020dc..a050baab0fe7 100644
--- a/lib/ethdev/version.map
+++ b/lib/ethdev/version.map
@@ -316,6 +316,9 @@ EXPERIMENTAL {
 	rte_eth_recycle_rx_queue_info_get;
 	rte_flow_group_set_miss_actions;
 	rte_flow_calc_table_hash;
+
+	# added in 24.03
+	rte_eth_find_rss_algo;
 };
 
 INTERNAL {
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [RESEND 2/2] app/testpmd: support set RSS hash algorithm
  2023-11-30 10:44 ` [RESEND " Jie Hai
  2023-11-30 10:44   ` [RESEND 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
@ 2023-11-30 10:44   ` Jie Hai
  2023-11-30 11:37     ` Ferruh Yigit
  2023-11-30 11:38     ` Ferruh Yigit
  1 sibling, 2 replies; 18+ messages in thread
From: Jie Hai @ 2023-11-30 10:44 UTC (permalink / raw)
  To: thomas, ferruh.yigit, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
Since API rte_eth_dev_rss_hash_update() supports setting RSS hash
algorithm, add new command to support it:
testpmd> port config 0 rss-hash-algo symmetric_toeplitz
Signed-off-by: Jie Hai <haijie1@huawei.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
---
 app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
 doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
 2 files changed, 90 insertions(+)
diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c
index 9369d3b4c526..2cd85c918a09 100644
--- a/app/test-pmd/cmdline.c
+++ b/app/test-pmd/cmdline.c
@@ -726,6 +726,10 @@ static void cmd_help_long_parsed(void *parsed_result,
 			"port config port-id rss reta (hash,queue)[,(hash,queue)]\n"
 			"    Set the RSS redirection table.\n\n"
 
+			"port config port-id rss-hash-algo (default|simple_xor|toeplitz|"
+			"symmetric_toeplitz|symmetric_toeplitz_sort)\n"
+			"    Set the RSS hash algorithm.\n\n"
+
 			"port config (port_id) dcb vt (on|off) (traffic_class)"
 			" pfc (on|off)\n"
 			"    Set the DCB mode.\n\n"
@@ -2275,6 +2279,80 @@ static cmdline_parse_inst_t cmd_config_rss_hash_key = {
 	},
 };
 
+/* *** configure rss hash algorithm *** */
+struct cmd_config_rss_hash_algo {
+	cmdline_fixed_string_t port;
+	cmdline_fixed_string_t config;
+	portid_t port_id;
+	cmdline_fixed_string_t rss_hash_algo;
+	cmdline_fixed_string_t algo;
+};
+
+static void
+cmd_config_rss_hash_algo_parsed(void *parsed_result,
+				__rte_unused struct cmdline *cl,
+				__rte_unused void *data)
+{
+	struct cmd_config_rss_hash_algo *res = parsed_result;
+	uint8_t rss_key[RSS_HASH_KEY_LENGTH];
+	struct rte_eth_rss_conf rss_conf;
+	int ret;
+
+	rss_conf.rss_key_len = RSS_HASH_KEY_LENGTH;
+	rss_conf.rss_key = rss_key;
+	ret = rte_eth_dev_rss_hash_conf_get(res->port_id, &rss_conf);
+	if (ret != 0) {
+		fprintf(stderr, "failed to get port %u RSS confinguration\n",
+			res->port_id);
+		return;
+	}
+
+	ret = rte_eth_find_rss_algo(res->algo, &rss_conf.algorithm);
+	if (ret != 0) {
+		fprintf(stderr, "port %u configured invalid RSS hash algorithm: %s\n",
+			res->port_id, res->algo);
+		return;
+	}
+
+	ret = rte_eth_dev_rss_hash_update(res->port_id, &rss_conf);
+	if (ret != 0) {
+		fprintf(stderr, "failed to set port %u RSS hash algorithm\n",
+			res->port_id);
+		return;
+	}
+}
+
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_port =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, port, "port");
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_config =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, config,
+				 "config");
+static cmdline_parse_token_num_t cmd_config_rss_hash_algo_port_id =
+	TOKEN_NUM_INITIALIZER(struct cmd_config_rss_hash_algo, port_id,
+			      RTE_UINT16);
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_rss_hash_algo =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo,
+				 rss_hash_algo, "rss-hash-algo");
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_algo =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, algo,
+				 "default#simple_xor#toeplitz#"
+				 "symmetric_toeplitz#symmetric_toeplitz_sort");
+
+static cmdline_parse_inst_t cmd_config_rss_hash_algo = {
+	.f = cmd_config_rss_hash_algo_parsed,
+	.data = NULL,
+	.help_str = "port config <port_id> rss-hash-algo "
+		"(default|simple_xor|toeplitz|symmetric_toeplitz|symmetric_toeplitz_sort)",
+	.tokens = {
+		(void *)&cmd_config_rss_hash_algo_port,
+		(void *)&cmd_config_rss_hash_algo_config,
+		(void *)&cmd_config_rss_hash_algo_port_id,
+		(void *)&cmd_config_rss_hash_algo_rss_hash_algo,
+		(void *)&cmd_config_rss_hash_algo_algo,
+		NULL,
+	},
+};
+
 /* *** cleanup txq mbufs *** */
 struct cmd_cleanup_txq_mbufs_result {
 	cmdline_fixed_string_t port;
@@ -13165,6 +13243,7 @@ static cmdline_parse_ctx_t builtin_ctx[] = {
 	(cmdline_parse_inst_t *)&cmd_showport_rss_hash_key,
 	(cmdline_parse_inst_t *)&cmd_showport_rss_hash_algo,
 	(cmdline_parse_inst_t *)&cmd_config_rss_hash_key,
+	(cmdline_parse_inst_t *)&cmd_config_rss_hash_algo,
 	(cmdline_parse_inst_t *)&cmd_cleanup_txq_mbufs,
 	(cmdline_parse_inst_t *)&cmd_dump,
 	(cmdline_parse_inst_t *)&cmd_dump_one,
diff --git a/doc/guides/testpmd_app_ug/testpmd_funcs.rst b/doc/guides/testpmd_app_ug/testpmd_funcs.rst
index 447e28e6944f..3c7d20c2db82 100644
--- a/doc/guides/testpmd_app_ug/testpmd_funcs.rst
+++ b/doc/guides/testpmd_app_ug/testpmd_funcs.rst
@@ -2263,6 +2263,17 @@ hash of input [IP] packets received on port::
                      ipv6-udp-ex <string of hex digits \
                      (variable length, NIC dependent)>)
 
+
+port config rss hash algorithm
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+To configure the RSS hash algorithm used to compute the RSS
+hash of input packets received on port::
+
+   testpmd> port config <port_id> rss-hash-algo (default|\
+                     simple_xor|toeplitz|symmetric_toeplitz|\
+                     symmetric_toeplitz_sort)
+
 port cleanup txq mbufs
 ~~~~~~~~~~~~~~~~~~~~~~
 
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [RESEND 1/2] ethdev: add new API to get RSS hash algorithm by name
  2023-11-30 10:44   ` [RESEND 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
@ 2023-11-30 11:23     ` Ferruh Yigit
  0 siblings, 0 replies; 18+ messages in thread
From: Ferruh Yigit @ 2023-11-30 11:23 UTC (permalink / raw)
  To: Jie Hai, thomas, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
On 11/30/2023 10:44 AM, Jie Hai wrote:
> This patch supports conversion from names to hash algorithm
> (see RTE_ETH_HASH_FUNCTION_XXX).
> 
> Signed-off-by: Jie Hai <haijie1@huawei.com>
> Reviewed-by: Huisong Li <lihuisong@huawei.com>
> 
Reviewed-by: Ferruh Yigit <ferruh.yigit@amd.com>
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [RESEND 2/2] app/testpmd: support set RSS hash algorithm
  2023-11-30 10:44   ` [RESEND 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
@ 2023-11-30 11:37     ` Ferruh Yigit
  2023-11-30 11:38     ` Ferruh Yigit
  1 sibling, 0 replies; 18+ messages in thread
From: Ferruh Yigit @ 2023-11-30 11:37 UTC (permalink / raw)
  To: Jie Hai, thomas, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
On 11/30/2023 10:44 AM, Jie Hai wrote:
> Since API rte_eth_dev_rss_hash_update() supports setting RSS hash
> algorithm, add new command to support it:
> 
> testpmd> port config 0 rss-hash-algo symmetric_toeplitz
> 
> Signed-off-by: Jie Hai <haijie1@huawei.com>
> Reviewed-by: Huisong Li <lihuisong@huawei.com>
> ---
>  app/test-pmd/cmdline.c                      | 79 +++++++++++++++++++++
>  doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
>  2 files changed, 90 insertions(+)
> 
> diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c
> index 9369d3b4c526..2cd85c918a09 100644
> --- a/app/test-pmd/cmdline.c
> +++ b/app/test-pmd/cmdline.c
> @@ -726,6 +726,10 @@ static void cmd_help_long_parsed(void *parsed_result,
>  			"port config port-id rss reta (hash,queue)[,(hash,queue)]\n"
>  			"    Set the RSS redirection table.\n\n"
>  
> +			"port config port-id rss-hash-algo (default|simple_xor|toeplitz|"
>
Variables marked by putting them within (), so 'port-id' should be
(port_id).
<...>
> +static cmdline_parse_inst_t cmd_config_rss_hash_algo = {
> +	.f = cmd_config_rss_hash_algo_parsed,
> +	.data = NULL,
> +	.help_str = "port config <port_id> rss-hash-algo "
> +		"(default|simple_xor|toeplitz|symmetric_toeplitz|symmetric_toeplitz_sort)",
>
'simple_xor', 'toeplitz', etc.. are keywords, not name of variable, so
should not use (). Instead like:
"port config <port_id> rss-hash-algo default|simple_xor|..."
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [RESEND 2/2] app/testpmd: support set RSS hash algorithm
  2023-11-30 10:44   ` [RESEND 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
  2023-11-30 11:37     ` Ferruh Yigit
@ 2023-11-30 11:38     ` Ferruh Yigit
  1 sibling, 0 replies; 18+ messages in thread
From: Ferruh Yigit @ 2023-11-30 11:38 UTC (permalink / raw)
  To: Jie Hai, thomas, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
On 11/30/2023 10:44 AM, Jie Hai wrote:
> +static void
> +cmd_config_rss_hash_algo_parsed(void *parsed_result,
> +				__rte_unused struct cmdline *cl,
> +				__rte_unused void *data)
> +{
> +	struct cmd_config_rss_hash_algo *res = parsed_result;
> +	uint8_t rss_key[RSS_HASH_KEY_LENGTH];
> +	struct rte_eth_rss_conf rss_conf;
> +	int ret;
> +
> +	rss_conf.rss_key_len = RSS_HASH_KEY_LENGTH;
> +	rss_conf.rss_key = rss_key;
> +	ret = rte_eth_dev_rss_hash_conf_get(res->port_id, &rss_conf);
> +	if (ret != 0) {
> +		fprintf(stderr, "failed to get port %u RSS confinguration\n",
> 
s/confinguration/configuration/
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [PATCH v2 0/2] app/testpmd: support set RSS hash algorithm
  2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
                   ` (4 preceding siblings ...)
  2023-11-30 10:44 ` [RESEND " Jie Hai
@ 2023-12-01  8:52 ` Jie Hai
  2023-12-01  8:52   ` [PATCH v2 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
                     ` (2 more replies)
  5 siblings, 3 replies; 18+ messages in thread
From: Jie Hai @ 2023-12-01  8:52 UTC (permalink / raw)
  To: thomas, ferruh.yigit, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
This patch set supports setting RSS hash algorithm.
--
v2:
1. fix misspelling and format.
2. fix CI compile error.
3. add reviewed-by for patch 1.
--
Jie Hai (2):
  ethdev: add new API to get RSS hash algorithm by name
  app/testpmd: support set RSS hash algorithm
 app/test-pmd/cmdline.c                      | 81 +++++++++++++++++++++
 doc/guides/rel_notes/release_24_03.rst      |  5 ++
 doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
 lib/ethdev/rte_ethdev.c                     | 15 ++++
 lib/ethdev/rte_ethdev.h                     | 20 +++++
 lib/ethdev/version.map                      |  3 +
 6 files changed, 135 insertions(+)
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [PATCH v2 1/2] ethdev: add new API to get RSS hash algorithm by name
  2023-12-01  8:52 ` [PATCH v2 0/2] " Jie Hai
@ 2023-12-01  8:52   ` Jie Hai
  2023-12-01  8:52   ` [PATCH v2 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
  2023-12-04 13:57   ` [PATCH v2 0/2] " Ferruh Yigit
  2 siblings, 0 replies; 18+ messages in thread
From: Jie Hai @ 2023-12-01  8:52 UTC (permalink / raw)
  To: thomas, ferruh.yigit, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
This patch supports conversion from names to hash algorithm
(see RTE_ETH_HASH_FUNCTION_XXX).
Signed-off-by: Jie Hai <haijie1@huawei.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
Reviewed-by: Ferruh Yigit <ferruh.yigit@amd.com>
---
 doc/guides/rel_notes/release_24_03.rst |  5 +++++
 lib/ethdev/rte_ethdev.c                | 15 +++++++++++++++
 lib/ethdev/rte_ethdev.h                | 20 ++++++++++++++++++++
 lib/ethdev/version.map                 |  3 +++
 4 files changed, 43 insertions(+)
diff --git a/doc/guides/rel_notes/release_24_03.rst b/doc/guides/rel_notes/release_24_03.rst
index e9c9717706a0..bd84875d4f17 100644
--- a/doc/guides/rel_notes/release_24_03.rst
+++ b/doc/guides/rel_notes/release_24_03.rst
@@ -55,6 +55,11 @@ New Features
      Also, make sure to start the actual text at the margin.
      =======================================================
 
+* **Improved support of RSS hash algorithm.**
+
+  * Added new function ``rte_eth_find_rss_algo`` to get RSS hash
+    algorithm by its name.
+
 
 Removed Items
 -------------
diff --git a/lib/ethdev/rte_ethdev.c b/lib/ethdev/rte_ethdev.c
index 3858983fcc80..c0398d945502 100644
--- a/lib/ethdev/rte_ethdev.c
+++ b/lib/ethdev/rte_ethdev.c
@@ -4826,6 +4826,21 @@ rte_eth_dev_rss_algo_name(enum rte_eth_hash_function rss_algo)
 	return name;
 }
 
+int
+rte_eth_find_rss_algo(const char *name, uint32_t *algo)
+{
+	unsigned int i;
+
+	for (i = 0; i < RTE_DIM(rte_eth_dev_rss_algo_names); i++) {
+		if (strcmp(name, rte_eth_dev_rss_algo_names[i].name) == 0) {
+			*algo = rte_eth_dev_rss_algo_names[i].algo;
+			return 0;
+		}
+	}
+
+	return -EINVAL;
+}
+
 int
 rte_eth_dev_udp_tunnel_port_add(uint16_t port_id,
 				struct rte_eth_udp_tunnel *udp_tunnel)
diff --git a/lib/ethdev/rte_ethdev.h b/lib/ethdev/rte_ethdev.h
index 77331ce6525e..3bde5c4c17a6 100644
--- a/lib/ethdev/rte_ethdev.h
+++ b/lib/ethdev/rte_ethdev.h
@@ -4667,6 +4667,26 @@ __rte_experimental
 const char *
 rte_eth_dev_rss_algo_name(enum rte_eth_hash_function rss_algo);
 
+/**
+ * @warning
+ * @b EXPERIMENTAL: this API may change, or be removed, without prior notice.
+ *
+ *  Get RSS hash algorithm by its name.
+ *
+ * @param name
+ *   RSS hash algorithm.
+ *
+ * @param algo
+ *   return the RSS hash algorithm found, @see rte_eth_hash_function.
+ *
+ * @return
+ *   - (0) if successful.
+ *   - (-EINVAL) if not found.
+ */
+__rte_experimental
+int
+rte_eth_find_rss_algo(const char *name, uint32_t *algo);
+
 /**
  * Add UDP tunneling port for a type of tunnel.
  *
diff --git a/lib/ethdev/version.map b/lib/ethdev/version.map
index 5c4917c020dc..a050baab0fe7 100644
--- a/lib/ethdev/version.map
+++ b/lib/ethdev/version.map
@@ -316,6 +316,9 @@ EXPERIMENTAL {
 	rte_eth_recycle_rx_queue_info_get;
 	rte_flow_group_set_miss_actions;
 	rte_flow_calc_table_hash;
+
+	# added in 24.03
+	rte_eth_find_rss_algo;
 };
 
 INTERNAL {
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* [PATCH v2 2/2] app/testpmd: support set RSS hash algorithm
  2023-12-01  8:52 ` [PATCH v2 0/2] " Jie Hai
  2023-12-01  8:52   ` [PATCH v2 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
@ 2023-12-01  8:52   ` Jie Hai
  2023-12-01 11:26     ` Ferruh Yigit
  2023-12-04 13:57   ` [PATCH v2 0/2] " Ferruh Yigit
  2 siblings, 1 reply; 18+ messages in thread
From: Jie Hai @ 2023-12-01  8:52 UTC (permalink / raw)
  To: thomas, ferruh.yigit, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
Since API rte_eth_dev_rss_hash_update() supports setting RSS hash
algorithm, add new command to support it:
testpmd> port config 0 rss-hash-algo symmetric_toeplitz
Signed-off-by: Jie Hai <haijie1@huawei.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
---
 app/test-pmd/cmdline.c                      | 81 +++++++++++++++++++++
 doc/guides/testpmd_app_ug/testpmd_funcs.rst | 11 +++
 2 files changed, 92 insertions(+)
diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c
index 9369d3b4c526..f704319771f1 100644
--- a/app/test-pmd/cmdline.c
+++ b/app/test-pmd/cmdline.c
@@ -726,6 +726,10 @@ static void cmd_help_long_parsed(void *parsed_result,
 			"port config port-id rss reta (hash,queue)[,(hash,queue)]\n"
 			"    Set the RSS redirection table.\n\n"
 
+			"port config (port_id) rss-hash-algo (default|simple_xor|toeplitz|"
+			"symmetric_toeplitz|symmetric_toeplitz_sort)\n"
+			"    Set the RSS hash algorithm.\n\n"
+
 			"port config (port_id) dcb vt (on|off) (traffic_class)"
 			" pfc (on|off)\n"
 			"    Set the DCB mode.\n\n"
@@ -2275,6 +2279,82 @@ static cmdline_parse_inst_t cmd_config_rss_hash_key = {
 	},
 };
 
+/* *** configure rss hash algorithm *** */
+struct cmd_config_rss_hash_algo {
+	cmdline_fixed_string_t port;
+	cmdline_fixed_string_t config;
+	portid_t port_id;
+	cmdline_fixed_string_t rss_hash_algo;
+	cmdline_fixed_string_t algo;
+};
+
+static void
+cmd_config_rss_hash_algo_parsed(void *parsed_result,
+				__rte_unused struct cmdline *cl,
+				__rte_unused void *data)
+{
+	struct cmd_config_rss_hash_algo *res = parsed_result;
+	uint8_t rss_key[RSS_HASH_KEY_LENGTH];
+	struct rte_eth_rss_conf rss_conf;
+	uint32_t algorithm;
+	int ret;
+
+	rss_conf.rss_key_len = RSS_HASH_KEY_LENGTH;
+	rss_conf.rss_key = rss_key;
+	ret = rte_eth_dev_rss_hash_conf_get(res->port_id, &rss_conf);
+	if (ret != 0) {
+		fprintf(stderr, "failed to get port %u RSS configuration\n",
+			res->port_id);
+		return;
+	}
+
+	algorithm = (uint32_t)rss_conf.algorithm;
+	ret = rte_eth_find_rss_algo(res->algo, &algorithm);
+	if (ret != 0) {
+		fprintf(stderr, "port %u configured invalid RSS hash algorithm: %s\n",
+			res->port_id, res->algo);
+		return;
+	}
+
+	ret = rte_eth_dev_rss_hash_update(res->port_id, &rss_conf);
+	if (ret != 0) {
+		fprintf(stderr, "failed to set port %u RSS hash algorithm\n",
+			res->port_id);
+		return;
+	}
+}
+
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_port =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, port, "port");
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_config =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, config,
+				 "config");
+static cmdline_parse_token_num_t cmd_config_rss_hash_algo_port_id =
+	TOKEN_NUM_INITIALIZER(struct cmd_config_rss_hash_algo, port_id,
+			      RTE_UINT16);
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_rss_hash_algo =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo,
+				 rss_hash_algo, "rss-hash-algo");
+static cmdline_parse_token_string_t cmd_config_rss_hash_algo_algo =
+	TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_algo, algo,
+				 "default#simple_xor#toeplitz#"
+				 "symmetric_toeplitz#symmetric_toeplitz_sort");
+
+static cmdline_parse_inst_t cmd_config_rss_hash_algo = {
+	.f = cmd_config_rss_hash_algo_parsed,
+	.data = NULL,
+	.help_str = "port config <port_id> rss-hash-algo "
+		"default|simple_xor|toeplitz|symmetric_toeplitz|symmetric_toeplitz_sort",
+	.tokens = {
+		(void *)&cmd_config_rss_hash_algo_port,
+		(void *)&cmd_config_rss_hash_algo_config,
+		(void *)&cmd_config_rss_hash_algo_port_id,
+		(void *)&cmd_config_rss_hash_algo_rss_hash_algo,
+		(void *)&cmd_config_rss_hash_algo_algo,
+		NULL,
+	},
+};
+
 /* *** cleanup txq mbufs *** */
 struct cmd_cleanup_txq_mbufs_result {
 	cmdline_fixed_string_t port;
@@ -13165,6 +13245,7 @@ static cmdline_parse_ctx_t builtin_ctx[] = {
 	(cmdline_parse_inst_t *)&cmd_showport_rss_hash_key,
 	(cmdline_parse_inst_t *)&cmd_showport_rss_hash_algo,
 	(cmdline_parse_inst_t *)&cmd_config_rss_hash_key,
+	(cmdline_parse_inst_t *)&cmd_config_rss_hash_algo,
 	(cmdline_parse_inst_t *)&cmd_cleanup_txq_mbufs,
 	(cmdline_parse_inst_t *)&cmd_dump,
 	(cmdline_parse_inst_t *)&cmd_dump_one,
diff --git a/doc/guides/testpmd_app_ug/testpmd_funcs.rst b/doc/guides/testpmd_app_ug/testpmd_funcs.rst
index 447e28e6944f..3c7d20c2db82 100644
--- a/doc/guides/testpmd_app_ug/testpmd_funcs.rst
+++ b/doc/guides/testpmd_app_ug/testpmd_funcs.rst
@@ -2263,6 +2263,17 @@ hash of input [IP] packets received on port::
                      ipv6-udp-ex <string of hex digits \
                      (variable length, NIC dependent)>)
 
+
+port config rss hash algorithm
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+To configure the RSS hash algorithm used to compute the RSS
+hash of input packets received on port::
+
+   testpmd> port config <port_id> rss-hash-algo (default|\
+                     simple_xor|toeplitz|symmetric_toeplitz|\
+                     symmetric_toeplitz_sort)
+
 port cleanup txq mbufs
 ~~~~~~~~~~~~~~~~~~~~~~
 
-- 
2.30.0
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [PATCH v2 2/2] app/testpmd: support set RSS hash algorithm
  2023-12-01  8:52   ` [PATCH v2 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
@ 2023-12-01 11:26     ` Ferruh Yigit
  0 siblings, 0 replies; 18+ messages in thread
From: Ferruh Yigit @ 2023-12-01 11:26 UTC (permalink / raw)
  To: Jie Hai, thomas, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
On 12/1/2023 8:52 AM, Jie Hai wrote:
> Since API rte_eth_dev_rss_hash_update() supports setting RSS hash
> algorithm, add new command to support it:
> 
> testpmd> port config 0 rss-hash-algo symmetric_toeplitz
> 
> Signed-off-by: Jie Hai <haijie1@huawei.com>
> Reviewed-by: Huisong Li <lihuisong@huawei.com>
>
Reviewed-by: Ferruh Yigit <ferruh.yigit@amd.com>
^ permalink raw reply	[flat|nested] 18+ messages in thread
* Re: [PATCH v2 0/2] app/testpmd: support set RSS hash algorithm
  2023-12-01  8:52 ` [PATCH v2 0/2] " Jie Hai
  2023-12-01  8:52   ` [PATCH v2 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
  2023-12-01  8:52   ` [PATCH v2 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
@ 2023-12-04 13:57   ` Ferruh Yigit
  2 siblings, 0 replies; 18+ messages in thread
From: Ferruh Yigit @ 2023-12-04 13:57 UTC (permalink / raw)
  To: Jie Hai, thomas, dev, andrew.rybchenko; +Cc: fengchengwen, lihuisong
On 12/1/2023 8:52 AM, Jie Hai wrote:
> This patch set supports setting RSS hash algorithm.
> 
> --
> v2:
> 1. fix misspelling and format.
> 2. fix CI compile error.
> 3. add reviewed-by for patch 1.
> --
> 
> Jie Hai (2):
>   ethdev: add new API to get RSS hash algorithm by name
>   app/testpmd: support set RSS hash algorithm
>
Series applied to dpdk-next-net/main, thanks.
^ permalink raw reply	[flat|nested] 18+ messages in thread
end of thread, other threads:[~2023-12-04 13:57 UTC | newest]
Thread overview: 18+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-11-22  9:48 [PATCH 0/2] app/testpmd: support set RSS hash algorithm Jie Hai
2023-11-22  9:48 ` [PATCH 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
2023-11-22  9:48 ` [PATCH 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
2023-11-22 10:46 ` [PATCH 0/2] " Ferruh Yigit
2023-11-23  6:32   ` Jie Hai
2023-11-30  9:02 ` Ferruh Yigit
2023-11-30 10:01   ` Jie Hai
2023-11-30 10:44 ` [RESEND " Jie Hai
2023-11-30 10:44   ` [RESEND 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
2023-11-30 11:23     ` Ferruh Yigit
2023-11-30 10:44   ` [RESEND 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
2023-11-30 11:37     ` Ferruh Yigit
2023-11-30 11:38     ` Ferruh Yigit
2023-12-01  8:52 ` [PATCH v2 0/2] " Jie Hai
2023-12-01  8:52   ` [PATCH v2 1/2] ethdev: add new API to get RSS hash algorithm by name Jie Hai
2023-12-01  8:52   ` [PATCH v2 2/2] app/testpmd: support set RSS hash algorithm Jie Hai
2023-12-01 11:26     ` Ferruh Yigit
2023-12-04 13:57   ` [PATCH v2 0/2] " Ferruh Yigit
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).