The flow director API is deprecated and will be removed in 26.11. Remove it from testpmd now since testpmd CLI is not a stable API.
Signed-off-by: Stephen Hemminger <[email protected]> --- app/test-pmd/cmdline.c | 21 +-- app/test-pmd/config.c | 163 -------------------- app/test-pmd/testpmd.h | 3 - doc/guides/testpmd_app_ug/testpmd_funcs.rst | 36 ----- 4 files changed, 6 insertions(+), 217 deletions(-) diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c index cc9c462498..a5022bde04 100644 --- a/app/test-pmd/cmdline.c +++ b/app/test-pmd/cmdline.c @@ -163,7 +163,7 @@ static void cmd_help_long_parsed(void *parsed_result, "Display:\n" "--------\n\n" - "show port (info|stats|summary|xstats|fdir|dcb_tc) (port_id|all)\n" + "show port (info|stats|summary|xstats|dcb_tc) (port_id|all)\n" " Display information for port_id, or all.\n\n" "show port info (port_id) representor\n" @@ -189,7 +189,7 @@ static void cmd_help_long_parsed(void *parsed_result, "show port (port_id) rss-hash [key | algorithm]\n" " Display the RSS hash functions, RSS hash key and RSS hash algorithms of port\n\n" - "clear port (info|stats|xstats|fdir) (port_id|all)\n" + "clear port (info|stats|xstats) (port_id|all)\n" " Clear information for port_id, or all.\n\n" "show (rxq|txq) info (port_id) (queue_id)\n" @@ -7510,11 +7510,6 @@ static void cmd_showportall_parsed(void *parsed_result, else if (!strcmp(res->what, "xstats")) RTE_ETH_FOREACH_DEV(i) nic_xstats_display(i); -#if defined(RTE_NET_I40E) || defined(RTE_NET_IXGBE) - else if (!strcmp(res->what, "fdir")) - RTE_ETH_FOREACH_DEV(i) - fdir_get_infos(i); -#endif else if (!strcmp(res->what, "dcb_tc")) RTE_ETH_FOREACH_DEV(i) port_dcb_info_display(i); @@ -7527,14 +7522,14 @@ static cmdline_parse_token_string_t cmd_showportall_port = TOKEN_STRING_INITIALIZER(struct cmd_showportall_result, port, "port"); static cmdline_parse_token_string_t cmd_showportall_what = TOKEN_STRING_INITIALIZER(struct cmd_showportall_result, what, - "info#summary#stats#xstats#fdir#dcb_tc"); + "info#summary#stats#xstats#dcb_tc"); static cmdline_parse_token_string_t cmd_showportall_all = TOKEN_STRING_INITIALIZER(struct cmd_showportall_result, all, "all"); static cmdline_parse_inst_t cmd_showportall = { .f = cmd_showportall_parsed, .data = NULL, .help_str = "show|clear port " - "info|summary|stats|xstats|fdir|dcb_tc all", + "info|summary|stats|xstats|dcb_tc all", .tokens = { (void *)&cmd_showportall_show, (void *)&cmd_showportall_port, @@ -7572,10 +7567,6 @@ static void cmd_showport_parsed(void *parsed_result, nic_stats_display(res->portnum); else if (!strcmp(res->what, "xstats")) nic_xstats_display(res->portnum); -#if defined(RTE_NET_I40E) || defined(RTE_NET_IXGBE) - else if (!strcmp(res->what, "fdir")) - fdir_get_infos(res->portnum); -#endif else if (!strcmp(res->what, "dcb_tc")) port_dcb_info_display(res->portnum); } @@ -7587,7 +7578,7 @@ static cmdline_parse_token_string_t cmd_showport_port = TOKEN_STRING_INITIALIZER(struct cmd_showport_result, port, "port"); static cmdline_parse_token_string_t cmd_showport_what = TOKEN_STRING_INITIALIZER(struct cmd_showport_result, what, - "info#summary#stats#xstats#fdir#dcb_tc"); + "info#summary#stats#xstats#dcb_tc"); static cmdline_parse_token_num_t cmd_showport_portnum = TOKEN_NUM_INITIALIZER(struct cmd_showport_result, portnum, RTE_UINT16); @@ -7595,7 +7586,7 @@ static cmdline_parse_inst_t cmd_showport = { .f = cmd_showport_parsed, .data = NULL, .help_str = "show|clear port " - "info|summary|stats|xstats|fdir|dcb_tc " + "info|summary|stats|xstats|dcb_tc " "<port_id>", .tokens = { (void *)&cmd_showport_show, diff --git a/app/test-pmd/config.c b/app/test-pmd/config.c index c950793aaf..12fc679250 100644 --- a/app/test-pmd/config.c +++ b/app/test-pmd/config.c @@ -7041,169 +7041,6 @@ flowtype_to_str(uint16_t flow_type) return NULL; } -#if defined(RTE_NET_I40E) || defined(RTE_NET_IXGBE) - -static inline void -print_fdir_flex_payload(struct rte_eth_fdir_flex_conf *flex_conf, uint32_t num) -{ - struct rte_eth_flex_payload_cfg *cfg; - uint32_t i, j; - - for (i = 0; i < flex_conf->nb_payloads; i++) { - cfg = &flex_conf->flex_set[i]; - if (cfg->type == RTE_ETH_RAW_PAYLOAD) - printf("\n RAW: "); - else if (cfg->type == RTE_ETH_L2_PAYLOAD) - printf("\n L2_PAYLOAD: "); - else if (cfg->type == RTE_ETH_L3_PAYLOAD) - printf("\n L3_PAYLOAD: "); - else if (cfg->type == RTE_ETH_L4_PAYLOAD) - printf("\n L4_PAYLOAD: "); - else - printf("\n UNKNOWN PAYLOAD(%u): ", cfg->type); - for (j = 0; j < num; j++) - printf(" %-5u", cfg->src_offset[j]); - } - printf("\n"); -} - -static inline void -print_fdir_flex_mask(struct rte_eth_fdir_flex_conf *flex_conf, uint32_t num) -{ - struct rte_eth_fdir_flex_mask *mask; - uint32_t i, j; - const char *p; - - for (i = 0; i < flex_conf->nb_flexmasks; i++) { - mask = &flex_conf->flex_mask[i]; - p = flowtype_to_str(mask->flow_type); - printf("\n %s:\t", p ? p : "unknown"); - for (j = 0; j < num; j++) - printf(" %02x", mask->mask[j]); - } - printf("\n"); -} - -static inline void -print_fdir_flow_type(uint32_t flow_types_mask) -{ - int i; - const char *p; - - for (i = RTE_ETH_FLOW_UNKNOWN; i < RTE_ETH_FLOW_MAX; i++) { - if (!(flow_types_mask & (1 << i))) - continue; - p = flowtype_to_str(i); - if (p) - printf(" %s", p); - else - printf(" unknown"); - } - printf("\n"); -} - -static int -get_fdir_info(portid_t port_id, struct rte_eth_fdir_info *fdir_info, - struct rte_eth_fdir_stats *fdir_stat) -{ - int ret = -ENOTSUP; - -#ifdef RTE_NET_I40E - if (ret == -ENOTSUP) { - ret = rte_pmd_i40e_get_fdir_info(port_id, fdir_info); - if (!ret) - ret = rte_pmd_i40e_get_fdir_stats(port_id, fdir_stat); - } -#endif -#ifdef RTE_NET_IXGBE - if (ret == -ENOTSUP) { - ret = rte_pmd_ixgbe_get_fdir_info(port_id, fdir_info); - if (!ret) - ret = rte_pmd_ixgbe_get_fdir_stats(port_id, fdir_stat); - } -#endif - switch (ret) { - case 0: - break; - case -ENOTSUP: - fprintf(stderr, "\n FDIR is not supported on port %-2d\n", - port_id); - break; - default: - fprintf(stderr, "programming error: (%s)\n", strerror(-ret)); - break; - } - return ret; -} - -void -fdir_get_infos(portid_t port_id) -{ - struct rte_eth_fdir_stats fdir_stat; - struct rte_eth_fdir_info fdir_info; - - static const char *fdir_stats_border = "########################"; - - if (port_id_is_invalid(port_id, ENABLED_WARN)) - return; - - memset(&fdir_info, 0, sizeof(fdir_info)); - memset(&fdir_stat, 0, sizeof(fdir_stat)); - if (get_fdir_info(port_id, &fdir_info, &fdir_stat)) - return; - - printf("\n %s FDIR infos for port %-2d %s\n", - fdir_stats_border, port_id, fdir_stats_border); - printf(" MODE: "); - if (fdir_info.mode == RTE_FDIR_MODE_PERFECT) - printf(" PERFECT\n"); - else if (fdir_info.mode == RTE_FDIR_MODE_PERFECT_MAC_VLAN) - printf(" PERFECT-MAC-VLAN\n"); - else if (fdir_info.mode == RTE_FDIR_MODE_PERFECT_TUNNEL) - printf(" PERFECT-TUNNEL\n"); - else if (fdir_info.mode == RTE_FDIR_MODE_SIGNATURE) - printf(" SIGNATURE\n"); - else - printf(" DISABLE\n"); - if (fdir_info.mode != RTE_FDIR_MODE_PERFECT_MAC_VLAN - && fdir_info.mode != RTE_FDIR_MODE_PERFECT_TUNNEL) { - printf(" SUPPORTED FLOW TYPE: "); - print_fdir_flow_type(fdir_info.flow_types_mask[0]); - } - printf(" FLEX PAYLOAD INFO:\n"); - printf(" max_len: %-10"PRIu32" payload_limit: %-10"PRIu32"\n" - " payload_unit: %-10"PRIu32" payload_seg: %-10"PRIu32"\n" - " bitmask_unit: %-10"PRIu32" bitmask_num: %-10"PRIu32"\n", - fdir_info.max_flexpayload, fdir_info.flex_payload_limit, - fdir_info.flex_payload_unit, - fdir_info.max_flex_payload_segment_num, - fdir_info.flex_bitmask_unit, fdir_info.max_flex_bitmask_num); - if (fdir_info.flex_conf.nb_payloads > 0) { - printf(" FLEX PAYLOAD SRC OFFSET:"); - print_fdir_flex_payload(&fdir_info.flex_conf, fdir_info.max_flexpayload); - } - if (fdir_info.flex_conf.nb_flexmasks > 0) { - printf(" FLEX MASK CFG:"); - print_fdir_flex_mask(&fdir_info.flex_conf, fdir_info.max_flexpayload); - } - printf(" guarant_count: %-10"PRIu32" best_count: %"PRIu32"\n", - fdir_stat.guarant_cnt, fdir_stat.best_cnt); - printf(" guarant_space: %-10"PRIu32" best_space: %"PRIu32"\n", - fdir_info.guarant_spc, fdir_info.best_spc); - printf(" collision: %-10"PRIu32" free: %"PRIu32"\n" - " maxhash: %-10"PRIu32" maxlen: %"PRIu32"\n" - " add: %-10"PRIu64" remove: %"PRIu64"\n" - " f_add: %-10"PRIu64" f_remove: %"PRIu64"\n", - fdir_stat.collision, fdir_stat.free, - fdir_stat.maxhash, fdir_stat.maxlen, - fdir_stat.add, fdir_stat.remove, - fdir_stat.f_add, fdir_stat.f_remove); - printf(" %s############################%s\n", - fdir_stats_border, fdir_stats_border); -} - -#endif /* RTE_NET_I40E || RTE_NET_IXGBE */ - void set_vf_traffic(portid_t port_id, uint8_t is_rx, uint16_t vf, uint8_t on) { diff --git a/app/test-pmd/testpmd.h b/app/test-pmd/testpmd.h index 1a54535470..0a4ab188bb 100644 --- a/app/test-pmd/testpmd.h +++ b/app/test-pmd/testpmd.h @@ -1185,9 +1185,6 @@ int all_ports_stopped(void); int port_is_stopped(portid_t port_id); int port_is_started(portid_t port_id); void pmd_test_exit(void); -#if defined(RTE_NET_I40E) || defined(RTE_NET_IXGBE) -void fdir_get_infos(portid_t port_id); -#endif void port_rss_reta_info(portid_t port_id, struct rte_eth_rss_reta_entry64 *reta_conf, uint16_t nb_entries); diff --git a/doc/guides/testpmd_app_ug/testpmd_funcs.rst b/doc/guides/testpmd_app_ug/testpmd_funcs.rst index f99b29b423..1d079f521a 100644 --- a/doc/guides/testpmd_app_ug/testpmd_funcs.rst +++ b/doc/guides/testpmd_app_ug/testpmd_funcs.rst @@ -2266,42 +2266,6 @@ Where the threshold type can be: These threshold options are also available from the command-line. -port config pctype mapping -~~~~~~~~~~~~~~~~~~~~~~~~~~ - -Reset pctype mapping table:: - - testpmd> port config (port_id) pctype mapping reset - -Update hardware defined pctype to software defined flow type mapping table:: - - testpmd> port config (port_id) pctype mapping update (pctype_id_0[,pctype_id_1]*) (flow_type_id) - -where: - -* ``pctype_id_x``: hardware pctype id as index of bit in bitmask value of the pctype mapping table. - -* ``flow_type_id``: software flow type id as the index of the pctype mapping table. - -port config input set -~~~~~~~~~~~~~~~~~~~~~ - -Config RSS/FDIR/FDIR flexible payload input set for some pctype:: - - testpmd> port config (port_id) pctype (pctype_id) \ - (hash_inset|fdir_inset|fdir_flx_inset) \ - (get|set|clear) field (field_idx) - -Clear RSS/FDIR/FDIR flexible payload input set for some pctype:: - - testpmd> port config (port_id) pctype (pctype_id) \ - (hash_inset|fdir_inset|fdir_flx_inset) clear all - -where: - -* ``pctype_id``: hardware packet classification types. -* ``field_idx``: hardware field index. - port config udp_tunnel_port ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -- 2.53.0

