From: "Min Hu (Connor)" <humin29@huawei.com>
To: <dev@dpdk.org>
Cc: <ferruh.yigit@intel.com>
Subject: Re: [dpdk-dev] [PATCH] examples/ethtool: fix pause configuration
Date: Mon, 28 Jun 2021 10:17:37 +0800 [thread overview]
Message-ID: <2c9d58e1-57f1-d2ec-dc30-c12cb9ce9c67@huawei.com> (raw)
In-Reply-To: <1619599379-470-1-git-send-email-humin29@huawei.com>
Hi, all,
any comments?
在 2021/4/28 16:42, Min Hu (Connor) 写道:
> From: Huisong Li <lihuisong@huawei.com>
>
> Currently, the pause command in ethtool to enable Rx/Tx pause has the
> following problem. Namely, Assume that the device supports flow control
> auto-negotiation to set pause parameters, which will the device that does
> not support flow control auto-negotiation fails to run this command.
>
> This patch supports the configuration of flow control auto-negotiation
> and fixes the print format and style of the pause cmd to make it more
> readable.
>
> Fixes: bda68ab9d1e7 ("examples/ethtool: add user-space ethtool sample application")
>
> Signed-off-by: Huisong Li <lihuisong@huawei.com>
> Signed-off-by: Min Hu (Connor) <humin29@huawei.com>
> ---
> examples/ethtool/ethtool-app/ethapp.c | 59 +++++++++++++++++++++--------------
> 1 file changed, 36 insertions(+), 23 deletions(-)
>
> diff --git a/examples/ethtool/ethtool-app/ethapp.c b/examples/ethtool/ethtool-app/ethapp.c
> index 36a1c37..057fa97 100644
> --- a/examples/ethtool/ethtool-app/ethapp.c
> +++ b/examples/ethtool/ethtool-app/ethapp.c
> @@ -49,6 +49,13 @@ struct pcmd_intintint_params {
> uint16_t rx;
> };
>
> +struct pcmd_pause_params {
> + cmdline_fixed_string_t cmd;
> + uint16_t port;
> + cmdline_fixed_string_t mode;
> + cmdline_fixed_string_t autoneg;
> + cmdline_fixed_string_t an_status;
> +};
>
> /* Parameter-less commands */
> cmdline_parse_token_string_t pcmd_quit_token_cmd =
> @@ -116,12 +123,18 @@ cmdline_parse_token_num_t pcmd_intintint_token_rx =
>
> /* Pause commands */
> cmdline_parse_token_string_t pcmd_pause_token_cmd =
> - TOKEN_STRING_INITIALIZER(struct pcmd_intstr_params, cmd, "pause");
> + TOKEN_STRING_INITIALIZER(struct pcmd_pause_params, cmd, "pause");
> cmdline_parse_token_num_t pcmd_pause_token_port =
> - TOKEN_NUM_INITIALIZER(struct pcmd_intstr_params, port, RTE_UINT16);
> -cmdline_parse_token_string_t pcmd_pause_token_opt =
> - TOKEN_STRING_INITIALIZER(struct pcmd_intstr_params,
> - opt, "all#tx#rx#none");
> + TOKEN_NUM_INITIALIZER(struct pcmd_pause_params, port, RTE_UINT16);
> +cmdline_parse_token_string_t pcmd_pause_token_mode =
> + TOKEN_STRING_INITIALIZER(struct pcmd_pause_params,
> + mode, "full#tx#rx#none");
> +cmdline_parse_token_string_t pcmd_pause_token_autoneg =
> + TOKEN_STRING_INITIALIZER(struct pcmd_pause_params,
> + autoneg, "autoneg");
> +cmdline_parse_token_string_t pcmd_pause_token_an_status =
> + TOKEN_STRING_INITIALIZER(struct pcmd_pause_params,
> + an_status, "on#off");
>
> /* VLAN commands */
> cmdline_parse_token_string_t pcmd_vlan_token_cmd =
> @@ -348,13 +361,12 @@ pcmd_module_eeprom_callback(void *ptr_params,
> fclose(fp_eeprom);
> }
>
> -
> static void
> pcmd_pause_callback(void *ptr_params,
> __rte_unused struct cmdline *ctx,
> void *ptr_data)
> {
> - struct pcmd_intstr_params *params = ptr_params;
> + struct pcmd_pause_params *params = ptr_params;
> struct ethtool_pauseparam info;
> int stat;
>
> @@ -366,39 +378,38 @@ pcmd_pause_callback(void *ptr_params,
> stat = rte_ethtool_get_pauseparam(params->port, &info);
> } else {
> memset(&info, 0, sizeof(info));
> - if (strcasecmp("all", params->opt) == 0) {
> + if (strcasecmp("full", params->mode) == 0) {
> info.tx_pause = 1;
> info.rx_pause = 1;
> - } else if (strcasecmp("tx", params->opt) == 0) {
> + } else if (strcasecmp("tx", params->mode) == 0) {
> info.tx_pause = 1;
> info.rx_pause = 0;
> - } else if (strcasecmp("rx", params->opt) == 0) {
> + } else if (strcasecmp("rx", params->mode) == 0) {
> info.tx_pause = 0;
> info.rx_pause = 1;
> } else {
> info.tx_pause = 0;
> info.rx_pause = 0;
> }
> - /* Assume auto-negotiation wanted */
> - info.autoneg = 1;
> +
> + if (strcasecmp("on", params->an_status) == 0)
> + info.autoneg = 1;
> + else
> + info.autoneg = 0;
> +
> stat = rte_ethtool_set_pauseparam(params->port, &info);
> }
> if (stat == 0) {
> - if (info.rx_pause && info.tx_pause)
> - printf("Port %i: Tx & Rx Paused\n", params->port);
> - else if (info.rx_pause)
> - printf("Port %i: Rx Paused\n", params->port);
> - else if (info.tx_pause)
> - printf("Port %i: Tx Paused\n", params->port);
> - else
> - printf("Port %i: Tx & Rx not paused\n", params->port);
> + printf("Pause parameters for Port %i:\n", params->port);
> + printf("Rx pause: %s\n", info.rx_pause ? "on" : "off");
> + printf("Tx pause: %s\n", info.tx_pause ? "on" : "off");
> + printf("Autoneg: %s\n", info.autoneg ? "on" : "off");
> } else if (stat == -ENOTSUP)
> printf("Port %i: Operation not supported\n", params->port);
> else
> printf("Port %i: Error %i\n", params->port, stat);
> }
>
> -
> static void
> pcmd_open_callback(__rte_unused void *ptr_params,
> __rte_unused struct cmdline *ctx,
> @@ -741,11 +752,13 @@ cmdline_parse_inst_t pcmd_pause = {
> .f = pcmd_pause_callback,
> .data = NULL,
> .help_str =
> - "pause <port_id> <all|tx|rx|none>\n Pause/unpause port",
> + "pause <port_id> <full|tx|rx|none> autoneg <on|off>\n Pause/unpause port",
> .tokens = {
> (void *)&pcmd_pause_token_cmd,
> (void *)&pcmd_pause_token_port,
> - (void *)&pcmd_pause_token_opt,
> + (void *)&pcmd_pause_token_mode,
> + (void *)&pcmd_pause_token_autoneg,
> + (void *)&pcmd_pause_token_an_status,
> NULL
> },
> };
>
next prev parent reply other threads:[~2021-06-28 2:17 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-04-28 8:42 Min Hu (Connor)
2021-06-28 2:17 ` Min Hu (Connor) [this message]
2021-07-17 2:15 ` Min Hu (Connor)
2021-09-28 1:20 ` Min Hu (Connor)
2023-07-03 23:19 ` Stephen Hemminger
2023-11-10 3:30 ` [PATCH v2] " Huisong Li
2023-11-22 22:50 ` Thomas Monjalon
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=2c9d58e1-57f1-d2ec-dc30-c12cb9ce9c67@huawei.com \
--to=humin29@huawei.com \
--cc=dev@dpdk.org \
--cc=ferruh.yigit@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).