app/testpmd: fix use of indirect action after port close
[dpdk.git] / app / test-pmd / cmdline.c
index 36d50fd..1e5b294 100644 (file)
@@ -24,7 +24,6 @@
 #include <rte_eal.h>
 #include <rte_per_lcore.h>
 #include <rte_lcore.h>
-#include <rte_atomic.h>
 #include <rte_branch_prediction.h>
 #include <rte_ring.h>
 #include <rte_mempool.h>
@@ -35,7 +34,9 @@
 #include <rte_string_fns.h>
 #include <rte_devargs.h>
 #include <rte_flow.h>
+#ifdef RTE_LIB_GRO
 #include <rte_gro.h>
+#endif
 #include <rte_mbuf_dyn.h>
 
 #include <cmdline_rdline.h>
@@ -252,6 +253,9 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "show port (port_id) macs|mcast_macs"
                        "       Display list of mac addresses added to port.\n\n"
 
+                       "show port (port_id) flow transfer proxy\n"
+                       "       Display proxy port to manage transfer flows\n\n"
+
                        "show port (port_id) fec capabilities"
                        "       Show fec capabilities of a port.\n\n"
 
@@ -459,6 +463,7 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "tso show (portid)"
                        "    Display the status of TCP Segmentation Offload.\n\n"
 
+#ifdef RTE_LIB_GRO
                        "set port (port_id) gro on|off\n"
                        "    Enable or disable Generic Receive Offload in"
                        " csum forwarding engine.\n\n"
@@ -469,7 +474,9 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "set gro flush (cycles)\n"
                        "    Set the cycle to flush GROed packets from"
                        " reassembly tables.\n\n"
+#endif
 
+#ifdef RTE_LIB_GSO
                        "set port (port_id) gso (on|off)"
                        "    Enable or disable Generic Segmentation Offload in"
                        " csum forwarding engine.\n\n"
@@ -480,6 +487,7 @@ static void cmd_help_long_parsed(void *parsed_result,
 
                        "show port (port_id) gso\n"
                        "    Show GSO configuration.\n\n"
+#endif
 
                        "set fwd (%s)\n"
                        "    Set packet forwarding mode.\n\n"
@@ -536,6 +544,11 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "    Set the priority flow control parameter on a"
                        " port.\n\n"
 
+                       "set pfc_queue_ctrl (port_id) rx (on|off) (tx_qid)"
+                       " (tx_tc) tx (on|off) (rx_qid) (rx_tc) (pause_time)\n"
+                       "    Set the queue priority flow control parameter on a"
+                       " given Rx and Tx queues of a port.\n\n"
+
                        "set stat_qmap (tx|rx) (port_id) (queue_id) (qmapping)\n"
                        "    Set statistics mapping (qmapping 0..15) for RX/TX"
                        " queue on port.\n"
@@ -553,7 +566,7 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "    Set the option to enable display of RX and TX bursts.\n"
 
                        "set port (port_id) vf (vf_id) rx|tx on|off\n"
-                       "    Enable/Disable a VF receive/tranmit from a port\n\n"
+                       "    Enable/Disable a VF receive/transmit from a port\n\n"
 
                        "set port (port_id) vf (vf_id) rxmode (AUPE|ROPE|BAM"
                        "|MPE) (on|off)\n"
@@ -785,8 +798,8 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "receive buffers available.\n\n"
 
                        "port config all rss (all|default|ip|tcp|udp|sctp|"
-                       "ether|port|vxlan|geneve|nvgre|vxlan-gpe|ecpri|mpls|none|level-default|"
-                       "level-outer|level-inner|<flowtype_id>)\n"
+                       "ether|port|vxlan|geneve|nvgre|vxlan-gpe|ecpri|mpls|ipv4-chksum|l2tpv2|"
+                       "none|level-default|level-outer|level-inner|<flowtype_id>)\n"
                        "    Set the RSS mode.\n\n"
 
                        "port config port-id rss reta (hash,queue)[,(hash,queue)]\n"
@@ -1478,51 +1491,51 @@ parse_and_check_speed_duplex(char *speedstr, char *duplexstr, uint32_t *speed)
        int duplex;
 
        if (!strcmp(duplexstr, "half")) {
-               duplex = ETH_LINK_HALF_DUPLEX;
+               duplex = RTE_ETH_LINK_HALF_DUPLEX;
        } else if (!strcmp(duplexstr, "full")) {
-               duplex = ETH_LINK_FULL_DUPLEX;
+               duplex = RTE_ETH_LINK_FULL_DUPLEX;
        } else if (!strcmp(duplexstr, "auto")) {
-               duplex = ETH_LINK_FULL_DUPLEX;
+               duplex = RTE_ETH_LINK_FULL_DUPLEX;
        } else {
                fprintf(stderr, "Unknown duplex parameter\n");
                return -1;
        }
 
        if (!strcmp(speedstr, "10")) {
-               *speed = (duplex == ETH_LINK_HALF_DUPLEX) ?
-                               ETH_LINK_SPEED_10M_HD : ETH_LINK_SPEED_10M;
+               *speed = (duplex == RTE_ETH_LINK_HALF_DUPLEX) ?
+                               RTE_ETH_LINK_SPEED_10M_HD : RTE_ETH_LINK_SPEED_10M;
        } else if (!strcmp(speedstr, "100")) {
-               *speed = (duplex == ETH_LINK_HALF_DUPLEX) ?
-                               ETH_LINK_SPEED_100M_HD : ETH_LINK_SPEED_100M;
+               *speed = (duplex == RTE_ETH_LINK_HALF_DUPLEX) ?
+                               RTE_ETH_LINK_SPEED_100M_HD : RTE_ETH_LINK_SPEED_100M;
        } else {
-               if (duplex != ETH_LINK_FULL_DUPLEX) {
+               if (duplex != RTE_ETH_LINK_FULL_DUPLEX) {
                        fprintf(stderr, "Invalid speed/duplex parameters\n");
                        return -1;
                }
                if (!strcmp(speedstr, "1000")) {
-                       *speed = ETH_LINK_SPEED_1G;
+                       *speed = RTE_ETH_LINK_SPEED_1G;
                } else if (!strcmp(speedstr, "10000")) {
-                       *speed = ETH_LINK_SPEED_10G;
+                       *speed = RTE_ETH_LINK_SPEED_10G;
                } else if (!strcmp(speedstr, "25000")) {
-                       *speed = ETH_LINK_SPEED_25G;
+                       *speed = RTE_ETH_LINK_SPEED_25G;
                } else if (!strcmp(speedstr, "40000")) {
-                       *speed = ETH_LINK_SPEED_40G;
+                       *speed = RTE_ETH_LINK_SPEED_40G;
                } else if (!strcmp(speedstr, "50000")) {
-                       *speed = ETH_LINK_SPEED_50G;
+                       *speed = RTE_ETH_LINK_SPEED_50G;
                } else if (!strcmp(speedstr, "100000")) {
-                       *speed = ETH_LINK_SPEED_100G;
+                       *speed = RTE_ETH_LINK_SPEED_100G;
                } else if (!strcmp(speedstr, "200000")) {
-                       *speed = ETH_LINK_SPEED_200G;
+                       *speed = RTE_ETH_LINK_SPEED_200G;
                } else if (!strcmp(speedstr, "auto")) {
-                       *speed = ETH_LINK_SPEED_AUTONEG;
+                       *speed = RTE_ETH_LINK_SPEED_AUTONEG;
                } else {
                        fprintf(stderr, "Unknown speed parameter\n");
                        return -1;
                }
        }
 
-       if (*speed != ETH_LINK_SPEED_AUTONEG)
-               *speed |= ETH_LINK_SPEED_FIXED;
+       if (*speed != RTE_ETH_LINK_SPEED_AUTONEG)
+               *speed |= RTE_ETH_LINK_SPEED_FIXED;
 
        return 0;
 }
@@ -1880,45 +1893,38 @@ cmd_config_max_pkt_len_parsed(void *parsed_result,
                                __rte_unused void *data)
 {
        struct cmd_config_max_pkt_len_result *res = parsed_result;
-       uint32_t max_rx_pkt_len_backup = 0;
-       portid_t pid;
+       portid_t port_id;
        int ret;
 
+       if (strcmp(res->name, "max-pkt-len") != 0) {
+               printf("Unknown parameter\n");
+               return;
+       }
+
        if (!all_ports_stopped()) {
                fprintf(stderr, "Please stop all ports first\n");
                return;
        }
 
-       RTE_ETH_FOREACH_DEV(pid) {
-               struct rte_port *port = &ports[pid];
+       RTE_ETH_FOREACH_DEV(port_id) {
+               struct rte_port *port = &ports[port_id];
 
-               if (!strcmp(res->name, "max-pkt-len")) {
-                       if (res->value < RTE_ETHER_MIN_LEN) {
-                               fprintf(stderr,
-                                       "max-pkt-len can not be less than %d\n",
-                                       RTE_ETHER_MIN_LEN);
-                               return;
-                       }
-                       if (res->value == port->dev_conf.rxmode.max_rx_pkt_len)
-                               return;
-
-                       ret = eth_dev_info_get_print_err(pid, &port->dev_info);
-                       if (ret != 0) {
-                               fprintf(stderr,
-                                       "rte_eth_dev_info_get() failed for port %u\n",
-                                       pid);
-                               return;
-                       }
-
-                       max_rx_pkt_len_backup = port->dev_conf.rxmode.max_rx_pkt_len;
+               if (res->value < RTE_ETHER_MIN_LEN) {
+                       fprintf(stderr,
+                               "max-pkt-len can not be less than %d\n",
+                               RTE_ETHER_MIN_LEN);
+                       return;
+               }
 
-                       port->dev_conf.rxmode.max_rx_pkt_len = res->value;
-                       if (update_jumbo_frame_offload(pid) != 0)
-                               port->dev_conf.rxmode.max_rx_pkt_len = max_rx_pkt_len_backup;
-               } else {
-                       fprintf(stderr, "Unknown parameter\n");
+               ret = eth_dev_info_get_print_err(port_id, &port->dev_info);
+               if (ret != 0) {
+                       fprintf(stderr,
+                               "rte_eth_dev_info_get() failed for port %u\n",
+                               port_id);
                        return;
                }
+
+               update_mtu_from_frame_size(port_id, res->value);
        }
 
        init_port_config();
@@ -2044,10 +2050,6 @@ cmd_config_mtu_parsed(void *parsed_result,
 {
        struct cmd_config_mtu_result *res = parsed_result;
 
-       if (res->value < RTE_ETHER_MIN_LEN) {
-               fprintf(stderr, "mtu cannot be less than %d\n", RTE_ETHER_MIN_LEN);
-               return;
-       }
        port_mtu_set(res->port_id, res->value);
 }
 
@@ -2173,33 +2175,33 @@ cmd_config_rss_parsed(void *parsed_result,
        int ret;
 
        if (!strcmp(res->value, "all"))
-               rss_conf.rss_hf = ETH_RSS_ETH | ETH_RSS_VLAN | ETH_RSS_IP |
-                       ETH_RSS_TCP | ETH_RSS_UDP | ETH_RSS_SCTP |
-                       ETH_RSS_L2_PAYLOAD | ETH_RSS_L2TPV3 | ETH_RSS_ESP |
-                       ETH_RSS_AH | ETH_RSS_PFCP | ETH_RSS_GTPU |
-                       ETH_RSS_ECPRI;
+               rss_conf.rss_hf = RTE_ETH_RSS_ETH | RTE_ETH_RSS_VLAN | RTE_ETH_RSS_IP |
+                       RTE_ETH_RSS_TCP | RTE_ETH_RSS_UDP | RTE_ETH_RSS_SCTP |
+                       RTE_ETH_RSS_L2_PAYLOAD | RTE_ETH_RSS_L2TPV3 | RTE_ETH_RSS_ESP |
+                       RTE_ETH_RSS_AH | RTE_ETH_RSS_PFCP | RTE_ETH_RSS_GTPU |
+                       RTE_ETH_RSS_ECPRI | RTE_ETH_RSS_L2TPV2;
        else if (!strcmp(res->value, "eth"))
-               rss_conf.rss_hf = ETH_RSS_ETH;
+               rss_conf.rss_hf = RTE_ETH_RSS_ETH;
        else if (!strcmp(res->value, "vlan"))
-               rss_conf.rss_hf = ETH_RSS_VLAN;
+               rss_conf.rss_hf = RTE_ETH_RSS_VLAN;
        else if (!strcmp(res->value, "ip"))
-               rss_conf.rss_hf = ETH_RSS_IP;
+               rss_conf.rss_hf = RTE_ETH_RSS_IP;
        else if (!strcmp(res->value, "udp"))
-               rss_conf.rss_hf = ETH_RSS_UDP;
+               rss_conf.rss_hf = RTE_ETH_RSS_UDP;
        else if (!strcmp(res->value, "tcp"))
-               rss_conf.rss_hf = ETH_RSS_TCP;
+               rss_conf.rss_hf = RTE_ETH_RSS_TCP;
        else if (!strcmp(res->value, "sctp"))
-               rss_conf.rss_hf = ETH_RSS_SCTP;
+               rss_conf.rss_hf = RTE_ETH_RSS_SCTP;
        else if (!strcmp(res->value, "ether"))
-               rss_conf.rss_hf = ETH_RSS_L2_PAYLOAD;
+               rss_conf.rss_hf = RTE_ETH_RSS_L2_PAYLOAD;
        else if (!strcmp(res->value, "port"))
-               rss_conf.rss_hf = ETH_RSS_PORT;
+               rss_conf.rss_hf = RTE_ETH_RSS_PORT;
        else if (!strcmp(res->value, "vxlan"))
-               rss_conf.rss_hf = ETH_RSS_VXLAN;
+               rss_conf.rss_hf = RTE_ETH_RSS_VXLAN;
        else if (!strcmp(res->value, "geneve"))
-               rss_conf.rss_hf = ETH_RSS_GENEVE;
+               rss_conf.rss_hf = RTE_ETH_RSS_GENEVE;
        else if (!strcmp(res->value, "nvgre"))
-               rss_conf.rss_hf = ETH_RSS_NVGRE;
+               rss_conf.rss_hf = RTE_ETH_RSS_NVGRE;
        else if (!strcmp(res->value, "l3-pre32"))
                rss_conf.rss_hf = RTE_ETH_RSS_L3_PRE32;
        else if (!strcmp(res->value, "l3-pre40"))
@@ -2213,46 +2215,48 @@ cmd_config_rss_parsed(void *parsed_result,
        else if (!strcmp(res->value, "l3-pre96"))
                rss_conf.rss_hf = RTE_ETH_RSS_L3_PRE96;
        else if (!strcmp(res->value, "l3-src-only"))
-               rss_conf.rss_hf = ETH_RSS_L3_SRC_ONLY;
+               rss_conf.rss_hf = RTE_ETH_RSS_L3_SRC_ONLY;
        else if (!strcmp(res->value, "l3-dst-only"))
-               rss_conf.rss_hf = ETH_RSS_L3_DST_ONLY;
+               rss_conf.rss_hf = RTE_ETH_RSS_L3_DST_ONLY;
        else if (!strcmp(res->value, "l4-src-only"))
-               rss_conf.rss_hf = ETH_RSS_L4_SRC_ONLY;
+               rss_conf.rss_hf = RTE_ETH_RSS_L4_SRC_ONLY;
        else if (!strcmp(res->value, "l4-dst-only"))
-               rss_conf.rss_hf = ETH_RSS_L4_DST_ONLY;
+               rss_conf.rss_hf = RTE_ETH_RSS_L4_DST_ONLY;
        else if (!strcmp(res->value, "l2-src-only"))
-               rss_conf.rss_hf = ETH_RSS_L2_SRC_ONLY;
+               rss_conf.rss_hf = RTE_ETH_RSS_L2_SRC_ONLY;
        else if (!strcmp(res->value, "l2-dst-only"))
-               rss_conf.rss_hf = ETH_RSS_L2_DST_ONLY;
+               rss_conf.rss_hf = RTE_ETH_RSS_L2_DST_ONLY;
        else if (!strcmp(res->value, "l2tpv3"))
-               rss_conf.rss_hf = ETH_RSS_L2TPV3;
+               rss_conf.rss_hf = RTE_ETH_RSS_L2TPV3;
        else if (!strcmp(res->value, "esp"))
-               rss_conf.rss_hf = ETH_RSS_ESP;
+               rss_conf.rss_hf = RTE_ETH_RSS_ESP;
        else if (!strcmp(res->value, "ah"))
-               rss_conf.rss_hf = ETH_RSS_AH;
+               rss_conf.rss_hf = RTE_ETH_RSS_AH;
        else if (!strcmp(res->value, "pfcp"))
-               rss_conf.rss_hf = ETH_RSS_PFCP;
+               rss_conf.rss_hf = RTE_ETH_RSS_PFCP;
        else if (!strcmp(res->value, "pppoe"))
-               rss_conf.rss_hf = ETH_RSS_PPPOE;
+               rss_conf.rss_hf = RTE_ETH_RSS_PPPOE;
        else if (!strcmp(res->value, "gtpu"))
-               rss_conf.rss_hf = ETH_RSS_GTPU;
+               rss_conf.rss_hf = RTE_ETH_RSS_GTPU;
        else if (!strcmp(res->value, "ecpri"))
-               rss_conf.rss_hf = ETH_RSS_ECPRI;
+               rss_conf.rss_hf = RTE_ETH_RSS_ECPRI;
        else if (!strcmp(res->value, "mpls"))
-               rss_conf.rss_hf = ETH_RSS_MPLS;
+               rss_conf.rss_hf = RTE_ETH_RSS_MPLS;
        else if (!strcmp(res->value, "ipv4-chksum"))
-               rss_conf.rss_hf = ETH_RSS_IPV4_CHKSUM;
+               rss_conf.rss_hf = RTE_ETH_RSS_IPV4_CHKSUM;
+       else if (!strcmp(res->value, "l2tpv2"))
+               rss_conf.rss_hf = RTE_ETH_RSS_L2TPV2;
        else if (!strcmp(res->value, "none"))
                rss_conf.rss_hf = 0;
        else if (!strcmp(res->value, "level-default")) {
-               rss_hf &= (~ETH_RSS_LEVEL_MASK);
-               rss_conf.rss_hf = (rss_hf | ETH_RSS_LEVEL_PMD_DEFAULT);
+               rss_hf &= (~RTE_ETH_RSS_LEVEL_MASK);
+               rss_conf.rss_hf = (rss_hf | RTE_ETH_RSS_LEVEL_PMD_DEFAULT);
        } else if (!strcmp(res->value, "level-outer")) {
-               rss_hf &= (~ETH_RSS_LEVEL_MASK);
-               rss_conf.rss_hf = (rss_hf | ETH_RSS_LEVEL_OUTERMOST);
+               rss_hf &= (~RTE_ETH_RSS_LEVEL_MASK);
+               rss_conf.rss_hf = (rss_hf | RTE_ETH_RSS_LEVEL_OUTERMOST);
        } else if (!strcmp(res->value, "level-inner")) {
-               rss_hf &= (~ETH_RSS_LEVEL_MASK);
-               rss_conf.rss_hf = (rss_hf | ETH_RSS_LEVEL_INNERMOST);
+               rss_hf &= (~RTE_ETH_RSS_LEVEL_MASK);
+               rss_conf.rss_hf = (rss_hf | RTE_ETH_RSS_LEVEL_INNERMOST);
        } else if (!strcmp(res->value, "default"))
                use_default = 1;
        else if (isdigit(res->value[0]) && atoi(res->value) > 0 &&
@@ -2312,8 +2316,8 @@ cmdline_parse_inst_t cmd_config_rss = {
        .data = NULL,
        .help_str = "port config all rss "
                "all|default|eth|vlan|ip|tcp|udp|sctp|ether|port|vxlan|geneve|"
-               "nvgre|vxlan-gpe|l2tpv3|esp|ah|pfcp|ecpri|mpls|none|level-default|"
-               "level-outer|level-inner|ipv4-chksum|<flowtype_id>",
+               "nvgre|vxlan-gpe|l2tpv3|esp|ah|pfcp|ecpri|mpls|ipv4-chksum|l2tpv2|"
+               "none|level-default|level-outer|level-inner|<flowtype_id>",
        .tokens = {
                (void *)&cmd_config_rss_port,
                (void *)&cmd_config_rss_keyword,
@@ -2428,7 +2432,7 @@ cmdline_parse_token_string_t cmd_config_rss_hash_key_rss_type =
                                 "ipv6-tcp-ex#ipv6-udp-ex#"
                                 "l3-src-only#l3-dst-only#l4-src-only#l4-dst-only#"
                                 "l2-src-only#l2-dst-only#s-vlan#c-vlan#"
-                                "l2tpv3#esp#ah#pfcp#pppoe#gtpu#ecpri#mpls");
+                                "l2tpv3#esp#ah#pfcp#pppoe#gtpu#ecpri#mpls#l2tpv2");
 cmdline_parse_token_string_t cmd_config_rss_hash_key_value =
        TOKEN_STRING_INITIALIZER(struct cmd_config_rss_hash_key, key, NULL);
 
@@ -2441,7 +2445,7 @@ cmdline_parse_inst_t cmd_config_rss_hash_key = {
                "l2-payload|ipv6-ex|ipv6-tcp-ex|ipv6-udp-ex|"
                "l3-src-only|l3-dst-only|l4-src-only|l4-dst-only|"
                "l2-src-only|l2-dst-only|s-vlan|c-vlan|"
-               "l2tpv3|esp|ah|pfcp|pppoe|gtpu|ecpri|mpls "
+               "l2tpv3|esp|ah|pfcp|pppoe|gtpu|ecpri|mpls|l2tpv2 "
                "<string of hex digits (variable length, NIC dependent)>",
        .tokens = {
                (void *)&cmd_config_rss_hash_key_port,
@@ -2700,7 +2704,7 @@ cmd_config_rxtx_queue_parsed(void *parsed_result,
                ret = rte_eth_dev_tx_queue_stop(res->portid, res->qid);
 
        if (ret == -ENOTSUP)
-               fprintf(stderr, "Function not supported in PMD driver\n");
+               fprintf(stderr, "Function not supported in PMD\n");
 }
 
 cmdline_parse_token_string_t cmd_config_rxtx_queue_port =
@@ -2989,8 +2993,8 @@ parse_reta_config(const char *str,
                        return -1;
                }
 
-               idx = hash_index / RTE_RETA_GROUP_SIZE;
-               shift = hash_index % RTE_RETA_GROUP_SIZE;
+               idx = hash_index / RTE_ETH_RETA_GROUP_SIZE;
+               shift = hash_index % RTE_ETH_RETA_GROUP_SIZE;
                reta_conf[idx].mask |= (1ULL << shift);
                reta_conf[idx].reta[shift] = nb_queue;
        }
@@ -3019,10 +3023,10 @@ cmd_set_rss_reta_parsed(void *parsed_result,
        } else
                printf("The reta size of port %d is %u\n",
                        res->port_id, dev_info.reta_size);
-       if (dev_info.reta_size > ETH_RSS_RETA_SIZE_512) {
+       if (dev_info.reta_size > RTE_ETH_RSS_RETA_SIZE_512) {
                fprintf(stderr,
                        "Currently do not support more than %u entries of redirection table\n",
-                       ETH_RSS_RETA_SIZE_512);
+                       RTE_ETH_RSS_RETA_SIZE_512);
                return;
        }
 
@@ -3093,8 +3097,8 @@ showport_parse_reta_config(struct rte_eth_rss_reta_entry64 *conf,
        char *end;
        char *str_fld[8];
        uint16_t i;
-       uint16_t num = (nb_entries + RTE_RETA_GROUP_SIZE - 1) /
-                       RTE_RETA_GROUP_SIZE;
+       uint16_t num = (nb_entries + RTE_ETH_RETA_GROUP_SIZE - 1) /
+                       RTE_ETH_RETA_GROUP_SIZE;
        int ret;
 
        p = strchr(p0, '(');
@@ -3119,7 +3123,7 @@ showport_parse_reta_config(struct rte_eth_rss_reta_entry64 *conf,
                return -1;
        }
        for (i = 0; i < ret; i++)
-               conf[i].mask = (uint64_t)strtoul(str_fld[i], &end, 0);
+               conf[i].mask = (uint64_t)strtoull(str_fld[i], &end, 0);
 
        return 0;
 }
@@ -3139,7 +3143,7 @@ cmd_showport_reta_parsed(void *parsed_result,
        if (ret != 0)
                return;
 
-       max_reta_size = RTE_MIN(dev_info.reta_size, ETH_RSS_RETA_SIZE_512);
+       max_reta_size = RTE_MIN(dev_info.reta_size, RTE_ETH_RSS_RETA_SIZE_512);
        if (res->size == 0 || res->size > max_reta_size) {
                fprintf(stderr, "Invalid redirection table size: %u (1-%u)\n",
                        res->size, max_reta_size);
@@ -3279,7 +3283,7 @@ cmd_config_dcb_parsed(void *parsed_result,
                return;
        }
 
-       if ((res->num_tcs != ETH_4_TCS) && (res->num_tcs != ETH_8_TCS)) {
+       if ((res->num_tcs != RTE_ETH_4_TCS) && (res->num_tcs != RTE_ETH_8_TCS)) {
                fprintf(stderr,
                        "The invalid number of traffic class, only 4 or 8 allowed.\n");
                return;
@@ -3660,7 +3664,7 @@ parse_item_list(const char *str, const char *item_name, unsigned int max_items,
                return nb_item;
 
        /*
-        * Then, check that all values in the list are differents.
+        * Then, check that all values in the list are different.
         * No optimization here...
         */
        for (i = 0; i < nb_item; i++) {
@@ -4283,9 +4287,9 @@ cmd_vlan_tpid_parsed(void *parsed_result,
        enum rte_vlan_type vlan_type;
 
        if (!strcmp(res->vlan_type, "inner"))
-               vlan_type = ETH_VLAN_TYPE_INNER;
+               vlan_type = RTE_ETH_VLAN_TYPE_INNER;
        else if (!strcmp(res->vlan_type, "outer"))
-               vlan_type = ETH_VLAN_TYPE_OUTER;
+               vlan_type = RTE_ETH_VLAN_TYPE_OUTER;
        else {
                fprintf(stderr, "Unknown vlan type\n");
                return;
@@ -4622,55 +4626,55 @@ csum_show(int port_id)
        printf("Parse tunnel is %s\n",
                (ports[port_id].parse_tunnel) ? "on" : "off");
        printf("IP checksum offload is %s\n",
-               (tx_offloads & DEV_TX_OFFLOAD_IPV4_CKSUM) ? "hw" : "sw");
+               (tx_offloads & RTE_ETH_TX_OFFLOAD_IPV4_CKSUM) ? "hw" : "sw");
        printf("UDP checksum offload is %s\n",
-               (tx_offloads & DEV_TX_OFFLOAD_UDP_CKSUM) ? "hw" : "sw");
+               (tx_offloads & RTE_ETH_TX_OFFLOAD_UDP_CKSUM) ? "hw" : "sw");
        printf("TCP checksum offload is %s\n",
-               (tx_offloads & DEV_TX_OFFLOAD_TCP_CKSUM) ? "hw" : "sw");
+               (tx_offloads & RTE_ETH_TX_OFFLOAD_TCP_CKSUM) ? "hw" : "sw");
        printf("SCTP checksum offload is %s\n",
-               (tx_offloads & DEV_TX_OFFLOAD_SCTP_CKSUM) ? "hw" : "sw");
+               (tx_offloads & RTE_ETH_TX_OFFLOAD_SCTP_CKSUM) ? "hw" : "sw");
        printf("Outer-Ip checksum offload is %s\n",
-               (tx_offloads & DEV_TX_OFFLOAD_OUTER_IPV4_CKSUM) ? "hw" : "sw");
+               (tx_offloads & RTE_ETH_TX_OFFLOAD_OUTER_IPV4_CKSUM) ? "hw" : "sw");
        printf("Outer-Udp checksum offload is %s\n",
-               (tx_offloads & DEV_TX_OFFLOAD_OUTER_UDP_CKSUM) ? "hw" : "sw");
+               (tx_offloads & RTE_ETH_TX_OFFLOAD_OUTER_UDP_CKSUM) ? "hw" : "sw");
 
        /* display warnings if configuration is not supported by the NIC */
        ret = eth_dev_info_get_print_err(port_id, &dev_info);
        if (ret != 0)
                return;
 
-       if ((tx_offloads & DEV_TX_OFFLOAD_IPV4_CKSUM) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_IPV4_CKSUM) == 0) {
+       if ((tx_offloads & RTE_ETH_TX_OFFLOAD_IPV4_CKSUM) &&
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_IPV4_CKSUM) == 0) {
                fprintf(stderr,
                        "Warning: hardware IP checksum enabled but not supported by port %d\n",
                        port_id);
        }
-       if ((tx_offloads & DEV_TX_OFFLOAD_UDP_CKSUM) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_UDP_CKSUM) == 0) {
+       if ((tx_offloads & RTE_ETH_TX_OFFLOAD_UDP_CKSUM) &&
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_UDP_CKSUM) == 0) {
                fprintf(stderr,
                        "Warning: hardware UDP checksum enabled but not supported by port %d\n",
                        port_id);
        }
-       if ((tx_offloads & DEV_TX_OFFLOAD_TCP_CKSUM) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_TCP_CKSUM) == 0) {
+       if ((tx_offloads & RTE_ETH_TX_OFFLOAD_TCP_CKSUM) &&
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_TCP_CKSUM) == 0) {
                fprintf(stderr,
                        "Warning: hardware TCP checksum enabled but not supported by port %d\n",
                        port_id);
        }
-       if ((tx_offloads & DEV_TX_OFFLOAD_SCTP_CKSUM) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_SCTP_CKSUM) == 0) {
+       if ((tx_offloads & RTE_ETH_TX_OFFLOAD_SCTP_CKSUM) &&
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_SCTP_CKSUM) == 0) {
                fprintf(stderr,
                        "Warning: hardware SCTP checksum enabled but not supported by port %d\n",
                        port_id);
        }
-       if ((tx_offloads & DEV_TX_OFFLOAD_OUTER_IPV4_CKSUM) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_OUTER_IPV4_CKSUM) == 0) {
+       if ((tx_offloads & RTE_ETH_TX_OFFLOAD_OUTER_IPV4_CKSUM) &&
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_OUTER_IPV4_CKSUM) == 0) {
                fprintf(stderr,
                        "Warning: hardware outer IP checksum enabled but not supported by port %d\n",
                        port_id);
        }
-       if ((tx_offloads & DEV_TX_OFFLOAD_OUTER_UDP_CKSUM) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_OUTER_UDP_CKSUM)
+       if ((tx_offloads & RTE_ETH_TX_OFFLOAD_OUTER_UDP_CKSUM) &&
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_OUTER_UDP_CKSUM)
                        == 0) {
                fprintf(stderr,
                        "Warning: hardware outer UDP checksum enabled but not supported by port %d\n",
@@ -4720,8 +4724,8 @@ cmd_csum_parsed(void *parsed_result,
 
                if (!strcmp(res->proto, "ip")) {
                        if (hw == 0 || (dev_info.tx_offload_capa &
-                                               DEV_TX_OFFLOAD_IPV4_CKSUM)) {
-                               csum_offloads |= DEV_TX_OFFLOAD_IPV4_CKSUM;
+                                               RTE_ETH_TX_OFFLOAD_IPV4_CKSUM)) {
+                               csum_offloads |= RTE_ETH_TX_OFFLOAD_IPV4_CKSUM;
                        } else {
                                fprintf(stderr,
                                        "IP checksum offload is not supported by port %u\n",
@@ -4729,8 +4733,8 @@ cmd_csum_parsed(void *parsed_result,
                        }
                } else if (!strcmp(res->proto, "udp")) {
                        if (hw == 0 || (dev_info.tx_offload_capa &
-                                               DEV_TX_OFFLOAD_UDP_CKSUM)) {
-                               csum_offloads |= DEV_TX_OFFLOAD_UDP_CKSUM;
+                                               RTE_ETH_TX_OFFLOAD_UDP_CKSUM)) {
+                               csum_offloads |= RTE_ETH_TX_OFFLOAD_UDP_CKSUM;
                        } else {
                                fprintf(stderr,
                                        "UDP checksum offload is not supported by port %u\n",
@@ -4738,8 +4742,8 @@ cmd_csum_parsed(void *parsed_result,
                        }
                } else if (!strcmp(res->proto, "tcp")) {
                        if (hw == 0 || (dev_info.tx_offload_capa &
-                                               DEV_TX_OFFLOAD_TCP_CKSUM)) {
-                               csum_offloads |= DEV_TX_OFFLOAD_TCP_CKSUM;
+                                               RTE_ETH_TX_OFFLOAD_TCP_CKSUM)) {
+                               csum_offloads |= RTE_ETH_TX_OFFLOAD_TCP_CKSUM;
                        } else {
                                fprintf(stderr,
                                        "TCP checksum offload is not supported by port %u\n",
@@ -4747,8 +4751,8 @@ cmd_csum_parsed(void *parsed_result,
                        }
                } else if (!strcmp(res->proto, "sctp")) {
                        if (hw == 0 || (dev_info.tx_offload_capa &
-                                               DEV_TX_OFFLOAD_SCTP_CKSUM)) {
-                               csum_offloads |= DEV_TX_OFFLOAD_SCTP_CKSUM;
+                                               RTE_ETH_TX_OFFLOAD_SCTP_CKSUM)) {
+                               csum_offloads |= RTE_ETH_TX_OFFLOAD_SCTP_CKSUM;
                        } else {
                                fprintf(stderr,
                                        "SCTP checksum offload is not supported by port %u\n",
@@ -4756,9 +4760,9 @@ cmd_csum_parsed(void *parsed_result,
                        }
                } else if (!strcmp(res->proto, "outer-ip")) {
                        if (hw == 0 || (dev_info.tx_offload_capa &
-                                       DEV_TX_OFFLOAD_OUTER_IPV4_CKSUM)) {
+                                       RTE_ETH_TX_OFFLOAD_OUTER_IPV4_CKSUM)) {
                                csum_offloads |=
-                                               DEV_TX_OFFLOAD_OUTER_IPV4_CKSUM;
+                                               RTE_ETH_TX_OFFLOAD_OUTER_IPV4_CKSUM;
                        } else {
                                fprintf(stderr,
                                        "Outer IP checksum offload is not supported by port %u\n",
@@ -4766,9 +4770,9 @@ cmd_csum_parsed(void *parsed_result,
                        }
                } else if (!strcmp(res->proto, "outer-udp")) {
                        if (hw == 0 || (dev_info.tx_offload_capa &
-                                       DEV_TX_OFFLOAD_OUTER_UDP_CKSUM)) {
+                                       RTE_ETH_TX_OFFLOAD_OUTER_UDP_CKSUM)) {
                                csum_offloads |=
-                                               DEV_TX_OFFLOAD_OUTER_UDP_CKSUM;
+                                               RTE_ETH_TX_OFFLOAD_OUTER_UDP_CKSUM;
                        } else {
                                fprintf(stderr,
                                        "Outer UDP checksum offload is not supported by port %u\n",
@@ -4923,7 +4927,7 @@ cmd_tso_set_parsed(void *parsed_result,
                return;
 
        if ((ports[res->port_id].tso_segsz != 0) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_TCP_TSO) == 0) {
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_TCP_TSO) == 0) {
                fprintf(stderr, "Error: TSO is not supported by port %d\n",
                        res->port_id);
                return;
@@ -4931,11 +4935,11 @@ cmd_tso_set_parsed(void *parsed_result,
 
        if (ports[res->port_id].tso_segsz == 0) {
                ports[res->port_id].dev_conf.txmode.offloads &=
-                                               ~DEV_TX_OFFLOAD_TCP_TSO;
+                                               ~RTE_ETH_TX_OFFLOAD_TCP_TSO;
                printf("TSO for non-tunneled packets is disabled\n");
        } else {
                ports[res->port_id].dev_conf.txmode.offloads |=
-                                               DEV_TX_OFFLOAD_TCP_TSO;
+                                               RTE_ETH_TX_OFFLOAD_TCP_TSO;
                printf("TSO segment size for non-tunneled packets is %d\n",
                        ports[res->port_id].tso_segsz);
        }
@@ -4947,7 +4951,7 @@ cmd_tso_set_parsed(void *parsed_result,
                return;
 
        if ((ports[res->port_id].tso_segsz != 0) &&
-               (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_TCP_TSO) == 0) {
+               (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_TCP_TSO) == 0) {
                fprintf(stderr,
                        "Warning: TSO enabled but not supported by port %d\n",
                        res->port_id);
@@ -5018,27 +5022,27 @@ check_tunnel_tso_nic_support(portid_t port_id)
        if (eth_dev_info_get_print_err(port_id, &dev_info) != 0)
                return dev_info;
 
-       if (!(dev_info.tx_offload_capa & DEV_TX_OFFLOAD_VXLAN_TNL_TSO))
+       if (!(dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_VXLAN_TNL_TSO))
                fprintf(stderr,
                        "Warning: VXLAN TUNNEL TSO not supported therefore not enabled for port %d\n",
                        port_id);
-       if (!(dev_info.tx_offload_capa & DEV_TX_OFFLOAD_GRE_TNL_TSO))
+       if (!(dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_GRE_TNL_TSO))
                fprintf(stderr,
                        "Warning: GRE TUNNEL TSO not supported therefore not enabled for port %d\n",
                        port_id);
-       if (!(dev_info.tx_offload_capa & DEV_TX_OFFLOAD_IPIP_TNL_TSO))
+       if (!(dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_IPIP_TNL_TSO))
                fprintf(stderr,
                        "Warning: IPIP TUNNEL TSO not supported therefore not enabled for port %d\n",
                        port_id);
-       if (!(dev_info.tx_offload_capa & DEV_TX_OFFLOAD_GENEVE_TNL_TSO))
+       if (!(dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_GENEVE_TNL_TSO))
                fprintf(stderr,
                        "Warning: GENEVE TUNNEL TSO not supported therefore not enabled for port %d\n",
                        port_id);
-       if (!(dev_info.tx_offload_capa & DEV_TX_OFFLOAD_IP_TNL_TSO))
+       if (!(dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_IP_TNL_TSO))
                fprintf(stderr,
                        "Warning: IP TUNNEL TSO not supported therefore not enabled for port %d\n",
                        port_id);
-       if (!(dev_info.tx_offload_capa & DEV_TX_OFFLOAD_UDP_TNL_TSO))
+       if (!(dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_UDP_TNL_TSO))
                fprintf(stderr,
                        "Warning: UDP TUNNEL TSO not supported therefore not enabled for port %d\n",
                        port_id);
@@ -5066,20 +5070,20 @@ cmd_tunnel_tso_set_parsed(void *parsed_result,
        dev_info = check_tunnel_tso_nic_support(res->port_id);
        if (ports[res->port_id].tunnel_tso_segsz == 0) {
                ports[res->port_id].dev_conf.txmode.offloads &=
-                       ~(DEV_TX_OFFLOAD_VXLAN_TNL_TSO |
-                         DEV_TX_OFFLOAD_GRE_TNL_TSO |
-                         DEV_TX_OFFLOAD_IPIP_TNL_TSO |
-                         DEV_TX_OFFLOAD_GENEVE_TNL_TSO |
-                         DEV_TX_OFFLOAD_IP_TNL_TSO |
-                         DEV_TX_OFFLOAD_UDP_TNL_TSO);
+                       ~(RTE_ETH_TX_OFFLOAD_VXLAN_TNL_TSO |
+                         RTE_ETH_TX_OFFLOAD_GRE_TNL_TSO |
+                         RTE_ETH_TX_OFFLOAD_IPIP_TNL_TSO |
+                         RTE_ETH_TX_OFFLOAD_GENEVE_TNL_TSO |
+                         RTE_ETH_TX_OFFLOAD_IP_TNL_TSO |
+                         RTE_ETH_TX_OFFLOAD_UDP_TNL_TSO);
                printf("TSO for tunneled packets is disabled\n");
        } else {
-               uint64_t tso_offloads = (DEV_TX_OFFLOAD_VXLAN_TNL_TSO |
-                                        DEV_TX_OFFLOAD_GRE_TNL_TSO |
-                                        DEV_TX_OFFLOAD_IPIP_TNL_TSO |
-                                        DEV_TX_OFFLOAD_GENEVE_TNL_TSO |
-                                        DEV_TX_OFFLOAD_IP_TNL_TSO |
-                                        DEV_TX_OFFLOAD_UDP_TNL_TSO);
+               uint64_t tso_offloads = (RTE_ETH_TX_OFFLOAD_VXLAN_TNL_TSO |
+                                        RTE_ETH_TX_OFFLOAD_GRE_TNL_TSO |
+                                        RTE_ETH_TX_OFFLOAD_IPIP_TNL_TSO |
+                                        RTE_ETH_TX_OFFLOAD_GENEVE_TNL_TSO |
+                                        RTE_ETH_TX_OFFLOAD_IP_TNL_TSO |
+                                        RTE_ETH_TX_OFFLOAD_UDP_TNL_TSO);
 
                ports[res->port_id].dev_conf.txmode.offloads |=
                        (tso_offloads & dev_info.tx_offload_capa);
@@ -5102,7 +5106,7 @@ cmd_tunnel_tso_set_parsed(void *parsed_result,
                        fprintf(stderr,
                                "Warning: csum parse_tunnel must be set so that tunneled packets are recognized\n");
                if (!(ports[res->port_id].dev_conf.txmode.offloads &
-                     DEV_TX_OFFLOAD_OUTER_IPV4_CKSUM))
+                     RTE_ETH_TX_OFFLOAD_OUTER_IPV4_CKSUM))
                        fprintf(stderr,
                                "Warning: csum set outer-ip must be set to hw if outer L3 is IPv4; not necessary for IPv6\n");
        }
@@ -5157,6 +5161,7 @@ cmdline_parse_inst_t cmd_tunnel_tso_show = {
        },
 };
 
+#ifdef RTE_LIB_GRO
 /* *** SET GRO FOR A PORT *** */
 struct cmd_gro_enable_result {
        cmdline_fixed_string_t cmd_set;
@@ -5300,7 +5305,9 @@ cmdline_parse_inst_t cmd_gro_flush = {
                NULL,
        },
 };
+#endif /* RTE_LIB_GRO */
 
+#ifdef RTE_LIB_GSO
 /* *** ENABLE/DISABLE GSO *** */
 struct cmd_gso_enable_result {
        cmdline_fixed_string_t cmd_set;
@@ -5467,6 +5474,7 @@ cmdline_parse_inst_t cmd_gso_show = {
                NULL,
        },
 };
+#endif /* RTE_LIB_GSO */
 
 /* *** ENABLE/DISABLE FLUSH ON RX STREAMS *** */
 struct cmd_set_flush_rx {
@@ -5910,6 +5918,19 @@ static void cmd_set_bonding_mode_parsed(void *parsed_result,
 {
        struct cmd_set_bonding_mode_result *res = parsed_result;
        portid_t port_id = res->port_id;
+       struct rte_port *port = &ports[port_id];
+
+       /*
+        * Bonding mode changed means resources of device changed, like whether
+        * started rte timer or not. Device should be restarted when resources
+        * of device changed.
+        */
+       if (port->port_status != RTE_PORT_STOPPED) {
+               fprintf(stderr,
+                       "\t Error: Can't set bonding mode when port %d is not stopped\n",
+                       port_id);
+               return;
+       }
 
        /* Set the bonding mode for the relevant port. */
        if (0 != rte_eth_bond_mode_set(port_id, res->value))
@@ -6304,7 +6325,8 @@ static void cmd_show_bonding_config_parsed(void *parsed_result,
        } else
                printf("\tBonding mode: %d\n", bonding_mode);
 
-       if (bonding_mode == BONDING_MODE_BALANCE) {
+       if (bonding_mode == BONDING_MODE_BALANCE ||
+               bonding_mode == BONDING_MODE_8023AD) {
                int balance_xmit_policy;
 
                balance_xmit_policy = rte_eth_bond_xmit_policy_get(port_id);
@@ -6645,6 +6667,7 @@ static void cmd_create_bonded_device_parsed(void *parsed_result,
                                "Failed to enable promiscuous mode for port %u: %s - ignore\n",
                                port_id, rte_strerror(-ret));
 
+               ports[port_id].bond_flag = 1;
                ports[port_id].need_setup = 0;
                ports[port_id].port_status = RTE_PORT_STOPPED;
        }
@@ -7234,9 +7257,9 @@ cmd_link_flow_ctrl_show_parsed(void *parsed_result,
                return;
        }
 
-       if (fc_conf.mode == RTE_FC_RX_PAUSE || fc_conf.mode == RTE_FC_FULL)
+       if (fc_conf.mode == RTE_ETH_FC_RX_PAUSE || fc_conf.mode == RTE_ETH_FC_FULL)
                rx_fc_en = true;
-       if (fc_conf.mode == RTE_FC_TX_PAUSE || fc_conf.mode == RTE_FC_FULL)
+       if (fc_conf.mode == RTE_ETH_FC_TX_PAUSE || fc_conf.mode == RTE_ETH_FC_FULL)
                tx_fc_en = true;
 
        printf("\n%s Flow control infos for port %-2d %s\n",
@@ -7514,12 +7537,12 @@ cmd_link_flow_ctrl_set_parsed(void *parsed_result,
 
        /*
         * Rx on/off, flow control is enabled/disabled on RX side. This can indicate
-        * the RTE_FC_TX_PAUSE, Transmit pause frame at the Rx side.
+        * the RTE_ETH_FC_TX_PAUSE, Transmit pause frame at the Rx side.
         * Tx on/off, flow control is enabled/disabled on TX side. This can indicate
-        * the RTE_FC_RX_PAUSE, Respond to the pause frame at the Tx side.
+        * the RTE_ETH_FC_RX_PAUSE, Respond to the pause frame at the Tx side.
         */
        static enum rte_eth_fc_mode rx_tx_onoff_2_lfc_mode[2][2] = {
-                       {RTE_FC_NONE, RTE_FC_TX_PAUSE}, {RTE_FC_RX_PAUSE, RTE_FC_FULL}
+                       {RTE_ETH_FC_NONE, RTE_ETH_FC_TX_PAUSE}, {RTE_ETH_FC_RX_PAUSE, RTE_ETH_FC_FULL}
        };
 
        /* Partial command line, retrieve current configuration */
@@ -7532,11 +7555,11 @@ cmd_link_flow_ctrl_set_parsed(void *parsed_result,
                        return;
                }
 
-               if ((fc_conf.mode == RTE_FC_RX_PAUSE) ||
-                   (fc_conf.mode == RTE_FC_FULL))
+               if ((fc_conf.mode == RTE_ETH_FC_RX_PAUSE) ||
+                   (fc_conf.mode == RTE_ETH_FC_FULL))
                        rx_fc_en = 1;
-               if ((fc_conf.mode == RTE_FC_TX_PAUSE) ||
-                   (fc_conf.mode == RTE_FC_FULL))
+               if ((fc_conf.mode == RTE_ETH_FC_TX_PAUSE) ||
+                   (fc_conf.mode == RTE_ETH_FC_FULL))
                        tx_fc_en = 1;
        }
 
@@ -7604,12 +7627,12 @@ cmd_priority_flow_ctrl_set_parsed(void *parsed_result,
 
        /*
         * Rx on/off, flow control is enabled/disabled on RX side. This can indicate
-        * the RTE_FC_TX_PAUSE, Transmit pause frame at the Rx side.
+        * the RTE_ETH_FC_TX_PAUSE, Transmit pause frame at the Rx side.
         * Tx on/off, flow control is enabled/disabled on TX side. This can indicate
-        * the RTE_FC_RX_PAUSE, Respond to the pause frame at the Tx side.
+        * the RTE_ETH_FC_RX_PAUSE, Respond to the pause frame at the Tx side.
         */
        static enum rte_eth_fc_mode rx_tx_onoff_2_pfc_mode[2][2] = {
-               {RTE_FC_NONE, RTE_FC_TX_PAUSE}, {RTE_FC_RX_PAUSE, RTE_FC_FULL}
+               {RTE_ETH_FC_NONE, RTE_ETH_FC_TX_PAUSE}, {RTE_ETH_FC_RX_PAUSE, RTE_ETH_FC_FULL}
        };
 
        memset(&pfc_conf, 0, sizeof(struct rte_eth_pfc_conf));
@@ -7684,6 +7707,122 @@ cmdline_parse_inst_t cmd_priority_flow_control_set = {
        },
 };
 
+struct cmd_queue_priority_flow_ctrl_set_result {
+       cmdline_fixed_string_t set;
+       cmdline_fixed_string_t pfc_queue_ctrl;
+       portid_t port_id;
+       cmdline_fixed_string_t rx;
+       cmdline_fixed_string_t rx_pfc_mode;
+       uint16_t tx_qid;
+       uint8_t  tx_tc;
+       cmdline_fixed_string_t tx;
+       cmdline_fixed_string_t tx_pfc_mode;
+       uint16_t rx_qid;
+       uint8_t  rx_tc;
+       uint16_t pause_time;
+};
+
+static void
+cmd_queue_priority_flow_ctrl_set_parsed(void *parsed_result,
+                                       __rte_unused struct cmdline *cl,
+                                       __rte_unused void *data)
+{
+       struct cmd_queue_priority_flow_ctrl_set_result *res = parsed_result;
+       struct rte_eth_pfc_queue_conf pfc_queue_conf;
+       int rx_fc_enable, tx_fc_enable;
+       int ret;
+
+       /*
+        * Rx on/off, flow control is enabled/disabled on RX side. This can
+        * indicate the RTE_ETH_FC_TX_PAUSE, Transmit pause frame at the Rx
+        * side. Tx on/off, flow control is enabled/disabled on TX side. This
+        * can indicate the RTE_ETH_FC_RX_PAUSE, Respond to the pause frame at
+        * the Tx side.
+        */
+       static enum rte_eth_fc_mode rx_tx_onoff_2_mode[2][2] = {
+               {RTE_ETH_FC_NONE, RTE_ETH_FC_TX_PAUSE},
+               {RTE_ETH_FC_RX_PAUSE, RTE_ETH_FC_FULL}
+       };
+
+       memset(&pfc_queue_conf, 0, sizeof(struct rte_eth_pfc_queue_conf));
+       rx_fc_enable = (!strncmp(res->rx_pfc_mode, "on", 2)) ? 1 : 0;
+       tx_fc_enable = (!strncmp(res->tx_pfc_mode, "on", 2)) ? 1 : 0;
+       pfc_queue_conf.mode = rx_tx_onoff_2_mode[rx_fc_enable][tx_fc_enable];
+       pfc_queue_conf.rx_pause.tc  = res->tx_tc;
+       pfc_queue_conf.rx_pause.tx_qid = res->tx_qid;
+       pfc_queue_conf.tx_pause.tc  = res->rx_tc;
+       pfc_queue_conf.tx_pause.rx_qid  = res->rx_qid;
+       pfc_queue_conf.tx_pause.pause_time = res->pause_time;
+
+       ret = rte_eth_dev_priority_flow_ctrl_queue_configure(res->port_id,
+                                                            &pfc_queue_conf);
+       if (ret != 0) {
+               fprintf(stderr,
+                       "bad queue priority flow control parameter, rc = %d\n",
+                       ret);
+       }
+}
+
+cmdline_parse_token_string_t cmd_q_pfc_set_set =
+       TOKEN_STRING_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               set, "set");
+cmdline_parse_token_string_t cmd_q_pfc_set_flow_ctrl =
+       TOKEN_STRING_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               pfc_queue_ctrl, "pfc_queue_ctrl");
+cmdline_parse_token_num_t cmd_q_pfc_set_portid =
+       TOKEN_NUM_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               port_id, RTE_UINT16);
+cmdline_parse_token_string_t cmd_q_pfc_set_rx =
+       TOKEN_STRING_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               rx, "rx");
+cmdline_parse_token_string_t cmd_q_pfc_set_rx_mode =
+       TOKEN_STRING_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               rx_pfc_mode, "on#off");
+cmdline_parse_token_num_t cmd_q_pfc_set_tx_qid =
+       TOKEN_NUM_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               tx_qid, RTE_UINT16);
+cmdline_parse_token_num_t cmd_q_pfc_set_tx_tc =
+       TOKEN_NUM_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               tx_tc, RTE_UINT8);
+cmdline_parse_token_string_t cmd_q_pfc_set_tx =
+       TOKEN_STRING_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               tx, "tx");
+cmdline_parse_token_string_t cmd_q_pfc_set_tx_mode =
+       TOKEN_STRING_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               tx_pfc_mode, "on#off");
+cmdline_parse_token_num_t cmd_q_pfc_set_rx_qid =
+       TOKEN_NUM_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               rx_qid, RTE_UINT16);
+cmdline_parse_token_num_t cmd_q_pfc_set_rx_tc =
+       TOKEN_NUM_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               rx_tc, RTE_UINT8);
+cmdline_parse_token_num_t cmd_q_pfc_set_pause_time =
+       TOKEN_NUM_INITIALIZER(struct cmd_queue_priority_flow_ctrl_set_result,
+                               pause_time, RTE_UINT16);
+
+cmdline_parse_inst_t cmd_queue_priority_flow_control_set = {
+       .f = cmd_queue_priority_flow_ctrl_set_parsed,
+       .data = NULL,
+       .help_str = "set pfc_queue_ctrl <port_id> rx <on|off> <tx_qid> <tx_tc> "
+               "tx <on|off> <rx_qid> <rx_tc> <pause_time>: "
+               "Configure the Ethernet queue priority flow control",
+       .tokens = {
+               (void *)&cmd_q_pfc_set_set,
+               (void *)&cmd_q_pfc_set_flow_ctrl,
+               (void *)&cmd_q_pfc_set_portid,
+               (void *)&cmd_q_pfc_set_rx,
+               (void *)&cmd_q_pfc_set_rx_mode,
+               (void *)&cmd_q_pfc_set_tx_qid,
+               (void *)&cmd_q_pfc_set_tx_tc,
+               (void *)&cmd_q_pfc_set_tx,
+               (void *)&cmd_q_pfc_set_tx_mode,
+               (void *)&cmd_q_pfc_set_rx_qid,
+               (void *)&cmd_q_pfc_set_rx_tc,
+               (void *)&cmd_q_pfc_set_pause_time,
+               NULL,
+       },
+};
+
 /* *** RESET CONFIGURATION *** */
 struct cmd_reset_result {
        cmdline_fixed_string_t reset;
@@ -9257,16 +9396,17 @@ cmd_set_vf_rxmode_parsed(void *parsed_result,
        int is_on = (strcmp(res->on, "on") == 0) ? 1 : 0;
        if (!strcmp(res->what,"rxmode")) {
                if (!strcmp(res->mode, "AUPE"))
-                       vf_rxmode |= ETH_VMDQ_ACCEPT_UNTAG;
+                       vf_rxmode |= RTE_ETH_VMDQ_ACCEPT_UNTAG;
                else if (!strcmp(res->mode, "ROPE"))
-                       vf_rxmode |= ETH_VMDQ_ACCEPT_HASH_UC;
+                       vf_rxmode |= RTE_ETH_VMDQ_ACCEPT_HASH_UC;
                else if (!strcmp(res->mode, "BAM"))
-                       vf_rxmode |= ETH_VMDQ_ACCEPT_BROADCAST;
+                       vf_rxmode |= RTE_ETH_VMDQ_ACCEPT_BROADCAST;
                else if (!strncmp(res->mode, "MPE",3))
-                       vf_rxmode |= ETH_VMDQ_ACCEPT_MULTICAST;
+                       vf_rxmode |= RTE_ETH_VMDQ_ACCEPT_MULTICAST;
        }
 
        RTE_SET_USED(is_on);
+       RTE_SET_USED(vf_rxmode);
 
 #ifdef RTE_NET_IXGBE
        if (ret == -ENOTSUP)
@@ -9663,7 +9803,7 @@ cmd_tunnel_udp_config_parsed(void *parsed_result,
        int ret;
 
        tunnel_udp.udp_port = res->udp_port;
-       tunnel_udp.prot_type = RTE_TUNNEL_TYPE_VXLAN;
+       tunnel_udp.prot_type = RTE_ETH_TUNNEL_TYPE_VXLAN;
 
        if (!strcmp(res->what, "add"))
                ret = rte_eth_dev_udp_tunnel_port_add(res->port_id,
@@ -9729,13 +9869,13 @@ cmd_cfg_tunnel_udp_port_parsed(void *parsed_result,
        tunnel_udp.udp_port = res->udp_port;
 
        if (!strcmp(res->tunnel_type, "vxlan")) {
-               tunnel_udp.prot_type = RTE_TUNNEL_TYPE_VXLAN;
+               tunnel_udp.prot_type = RTE_ETH_TUNNEL_TYPE_VXLAN;
        } else if (!strcmp(res->tunnel_type, "geneve")) {
-               tunnel_udp.prot_type = RTE_TUNNEL_TYPE_GENEVE;
+               tunnel_udp.prot_type = RTE_ETH_TUNNEL_TYPE_GENEVE;
        } else if (!strcmp(res->tunnel_type, "vxlan-gpe")) {
-               tunnel_udp.prot_type = RTE_TUNNEL_TYPE_VXLAN_GPE;
+               tunnel_udp.prot_type = RTE_ETH_TUNNEL_TYPE_VXLAN_GPE;
        } else if (!strcmp(res->tunnel_type, "ecpri")) {
-               tunnel_udp.prot_type = RTE_TUNNEL_TYPE_ECPRI;
+               tunnel_udp.prot_type = RTE_ETH_TUNNEL_TYPE_ECPRI;
        } else {
                fprintf(stderr, "Invalid tunnel type\n");
                return;
@@ -10445,6 +10585,10 @@ str2flowtype(char *string)
                {"ipv6-sctp", RTE_ETH_FLOW_NONFRAG_IPV6_SCTP},
                {"ipv6-other", RTE_ETH_FLOW_NONFRAG_IPV6_OTHER},
                {"l2_payload", RTE_ETH_FLOW_L2_PAYLOAD},
+               {"ipv6-ex", RTE_ETH_FLOW_IPV6_EX},
+               {"ipv6-tcp-ex", RTE_ETH_FLOW_IPV6_TCP_EX},
+               {"ipv6-udp-ex", RTE_ETH_FLOW_IPV6_UDP_EX},
+               {"gtpu", RTE_ETH_FLOW_GTPU},
        };
 
        for (i = 0; i < RTE_DIM(flowtype_str); i++) {
@@ -11866,7 +12010,7 @@ cmd_set_macsec_offload_on_parsed(
        if (ret != 0)
                return;
 
-       if (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_MACSEC_INSERT) {
+       if (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_MACSEC_INSERT) {
 #ifdef RTE_NET_IXGBE
                ret = rte_pmd_ixgbe_macsec_enable(port_id, en, rp);
 #endif
@@ -11877,7 +12021,7 @@ cmd_set_macsec_offload_on_parsed(
        switch (ret) {
        case 0:
                ports[port_id].dev_conf.txmode.offloads |=
-                                               DEV_TX_OFFLOAD_MACSEC_INSERT;
+                                               RTE_ETH_TX_OFFLOAD_MACSEC_INSERT;
                cmd_reconfig_device_queue(port_id, 1, 1);
                break;
        case -ENODEV:
@@ -11963,7 +12107,7 @@ cmd_set_macsec_offload_off_parsed(
        if (ret != 0)
                return;
 
-       if (dev_info.tx_offload_capa & DEV_TX_OFFLOAD_MACSEC_INSERT) {
+       if (dev_info.tx_offload_capa & RTE_ETH_TX_OFFLOAD_MACSEC_INSERT) {
 #ifdef RTE_NET_IXGBE
                ret = rte_pmd_ixgbe_macsec_disable(port_id);
 #endif
@@ -11971,7 +12115,7 @@ cmd_set_macsec_offload_off_parsed(
        switch (ret) {
        case 0:
                ports[port_id].dev_conf.txmode.offloads &=
-                                               ~DEV_TX_OFFLOAD_MACSEC_INSERT;
+                                               ~RTE_ETH_TX_OFFLOAD_MACSEC_INSERT;
                cmd_reconfig_device_queue(port_id, 1, 1);
                break;
        case -ENODEV:
@@ -14686,11 +14830,10 @@ no_print_pctypes:
 
        ret = 0;
 no_print_return:
-       if (proto)
-               free(proto);
+       free(proto);
 #endif
        if (ret == -ENOTSUP)
-               fprintf(stderr, "Function not supported in PMD driver\n");
+               fprintf(stderr, "Function not supported in PMD\n");
        close_file(pkg);
 }
 
@@ -16034,6 +16177,7 @@ cmd_rx_offload_get_configuration_parsed(
        struct rte_eth_dev_info dev_info;
        portid_t port_id = res->port_id;
        struct rte_port *port = &ports[port_id];
+       struct rte_eth_conf dev_conf;
        uint64_t port_offloads;
        uint64_t queue_offloads;
        uint16_t nb_rx_queues;
@@ -16042,7 +16186,11 @@ cmd_rx_offload_get_configuration_parsed(
 
        printf("Rx Offloading Configuration of port %d :\n", port_id);
 
-       port_offloads = port->dev_conf.rxmode.offloads;
+       ret = eth_dev_conf_get_print_err(port_id, &dev_conf);
+       if (ret != 0)
+               return;
+
+       port_offloads = dev_conf.rxmode.offloads;
        printf("  Port :");
        print_rx_offloads(port_offloads);
        printf("\n");
@@ -16448,6 +16596,7 @@ cmd_tx_offload_get_configuration_parsed(
        struct rte_eth_dev_info dev_info;
        portid_t port_id = res->port_id;
        struct rte_port *port = &ports[port_id];
+       struct rte_eth_conf dev_conf;
        uint64_t port_offloads;
        uint64_t queue_offloads;
        uint16_t nb_tx_queues;
@@ -16456,7 +16605,11 @@ cmd_tx_offload_get_configuration_parsed(
 
        printf("Tx Offloading Configuration of port %d :\n", port_id);
 
-       port_offloads = port->dev_conf.txmode.offloads;
+       ret = eth_dev_conf_get_print_err(port_id, &dev_conf);
+       if (ret != 0)
+               return;
+
+       port_offloads = dev_conf.txmode.offloads;
        printf("  Port :");
        print_tx_offloads(port_offloads);
        printf("\n");
@@ -17580,6 +17733,77 @@ cmdline_parse_inst_t cmd_showport_macs = {
        },
 };
 
+/* *** show flow transfer proxy port ID for the given port *** */
+struct cmd_show_port_flow_transfer_proxy_result {
+       cmdline_fixed_string_t show;
+       cmdline_fixed_string_t port;
+       portid_t port_id;
+       cmdline_fixed_string_t flow;
+       cmdline_fixed_string_t transfer;
+       cmdline_fixed_string_t proxy;
+};
+
+cmdline_parse_token_string_t cmd_show_port_flow_transfer_proxy_show =
+       TOKEN_STRING_INITIALIZER
+               (struct cmd_show_port_flow_transfer_proxy_result,
+                show, "show");
+cmdline_parse_token_string_t cmd_show_port_flow_transfer_proxy_port =
+       TOKEN_STRING_INITIALIZER
+               (struct cmd_show_port_flow_transfer_proxy_result,
+                port, "port");
+cmdline_parse_token_num_t cmd_show_port_flow_transfer_proxy_port_id =
+       TOKEN_NUM_INITIALIZER
+               (struct cmd_show_port_flow_transfer_proxy_result,
+                port_id, RTE_UINT16);
+cmdline_parse_token_string_t cmd_show_port_flow_transfer_proxy_flow =
+       TOKEN_STRING_INITIALIZER
+               (struct cmd_show_port_flow_transfer_proxy_result,
+                flow, "flow");
+cmdline_parse_token_string_t cmd_show_port_flow_transfer_proxy_transfer =
+       TOKEN_STRING_INITIALIZER
+               (struct cmd_show_port_flow_transfer_proxy_result,
+                transfer, "transfer");
+cmdline_parse_token_string_t cmd_show_port_flow_transfer_proxy_proxy =
+       TOKEN_STRING_INITIALIZER
+               (struct cmd_show_port_flow_transfer_proxy_result,
+                proxy, "proxy");
+
+static void
+cmd_show_port_flow_transfer_proxy_parsed(void *parsed_result,
+                                        __rte_unused struct cmdline *cl,
+                                        __rte_unused void *data)
+{
+       struct cmd_show_port_flow_transfer_proxy_result *res = parsed_result;
+       portid_t proxy_port_id;
+       int ret;
+
+       printf("\n");
+
+       ret = rte_flow_pick_transfer_proxy(res->port_id, &proxy_port_id, NULL);
+       if (ret != 0) {
+               fprintf(stderr, "Failed to pick transfer proxy: %s\n",
+                       rte_strerror(-ret));
+               return;
+       }
+
+       printf("Transfer proxy port ID: %u\n\n", proxy_port_id);
+}
+
+cmdline_parse_inst_t cmd_show_port_flow_transfer_proxy = {
+       .f = cmd_show_port_flow_transfer_proxy_parsed,
+       .data = NULL,
+       .help_str = "show port <port_id> flow transfer proxy",
+       .tokens = {
+               (void *)&cmd_show_port_flow_transfer_proxy_show,
+               (void *)&cmd_show_port_flow_transfer_proxy_port,
+               (void *)&cmd_show_port_flow_transfer_proxy_port_id,
+               (void *)&cmd_show_port_flow_transfer_proxy_flow,
+               (void *)&cmd_show_port_flow_transfer_proxy_transfer,
+               (void *)&cmd_show_port_flow_transfer_proxy_proxy,
+               NULL,
+       }
+};
+
 /* ******************************************************************************** */
 
 /* list of instructions */
@@ -17653,12 +17877,16 @@ cmdline_parse_ctx_t main_ctx[] = {
        (cmdline_parse_inst_t *)&cmd_tso_show,
        (cmdline_parse_inst_t *)&cmd_tunnel_tso_set,
        (cmdline_parse_inst_t *)&cmd_tunnel_tso_show,
+#ifdef RTE_LIB_GRO
        (cmdline_parse_inst_t *)&cmd_gro_enable,
        (cmdline_parse_inst_t *)&cmd_gro_flush,
        (cmdline_parse_inst_t *)&cmd_gro_show,
+#endif
+#ifdef RTE_LIB_GSO
        (cmdline_parse_inst_t *)&cmd_gso_enable,
        (cmdline_parse_inst_t *)&cmd_gso_size,
        (cmdline_parse_inst_t *)&cmd_gso_show,
+#endif
        (cmdline_parse_inst_t *)&cmd_link_flow_control_set,
        (cmdline_parse_inst_t *)&cmd_link_flow_control_set_rx,
        (cmdline_parse_inst_t *)&cmd_link_flow_control_set_tx,
@@ -17670,6 +17898,7 @@ cmdline_parse_ctx_t main_ctx[] = {
        (cmdline_parse_inst_t *)&cmd_link_flow_control_set_autoneg,
        (cmdline_parse_inst_t *)&cmd_link_flow_control_show,
        (cmdline_parse_inst_t *)&cmd_priority_flow_control_set,
+       (cmdline_parse_inst_t *)&cmd_queue_priority_flow_control_set,
        (cmdline_parse_inst_t *)&cmd_config_dcb,
        (cmdline_parse_inst_t *)&cmd_read_reg,
        (cmdline_parse_inst_t *)&cmd_read_reg_bit_field,
@@ -17708,6 +17937,7 @@ cmdline_parse_ctx_t main_ctx[] = {
        (cmdline_parse_inst_t *)&cmd_config_rss_reta,
        (cmdline_parse_inst_t *)&cmd_showport_reta,
        (cmdline_parse_inst_t *)&cmd_showport_macs,
+       (cmdline_parse_inst_t *)&cmd_show_port_flow_transfer_proxy,
        (cmdline_parse_inst_t *)&cmd_config_burst,
        (cmdline_parse_inst_t *)&cmd_config_thresh,
        (cmdline_parse_inst_t *)&cmd_config_threshold,
@@ -17733,6 +17963,7 @@ cmdline_parse_ctx_t main_ctx[] = {
        (cmdline_parse_inst_t *)&cmd_show_port_meter_cap,
        (cmdline_parse_inst_t *)&cmd_add_port_meter_profile_srtcm,
        (cmdline_parse_inst_t *)&cmd_add_port_meter_profile_trtcm,
+       (cmdline_parse_inst_t *)&cmd_add_port_meter_profile_trtcm_rfc4115,
        (cmdline_parse_inst_t *)&cmd_del_port_meter_profile,
        (cmdline_parse_inst_t *)&cmd_create_port_meter,
        (cmdline_parse_inst_t *)&cmd_enable_port_meter,
@@ -17858,6 +18089,8 @@ cmdline_parse_ctx_t main_ctx[] = {
        (cmdline_parse_inst_t *)&cmd_show_fec_mode,
        (cmdline_parse_inst_t *)&cmd_set_fec_mode,
        (cmdline_parse_inst_t *)&cmd_show_capability,
+       (cmdline_parse_inst_t *)&cmd_set_flex_is_pattern,
+       (cmdline_parse_inst_t *)&cmd_set_flex_spec_pattern,
        NULL,
 };