Skip to content

Commit

Permalink
examples/ethtool: fix pause configuration
Browse files Browse the repository at this point in the history
[ upstream commit 29cb7cf999bd5b3cb44ec6937529b2b197e7e25f ]

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: bda68ab ("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>
Acked-by: Stephen Hemminger <stephen@networkplumber.org>
  • Loading branch information
LiHuiSong1 authored and bluca committed Nov 23, 2023
1 parent 00d4567 commit a6a44fd
Showing 1 changed file with 36 additions and 23 deletions.
59 changes: 36 additions & 23 deletions examples/ethtool/ethtool-app/ethapp.c
Original file line number Diff line number Diff line change
Expand Up @@ -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 =
Expand Down Expand Up @@ -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 =
Expand Down Expand Up @@ -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;

Expand All @@ -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,
Expand Down Expand Up @@ -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
},
};
Expand Down

0 comments on commit a6a44fd

Please sign in to comment.