app/testpmd: add commands for filters
authorJingjing Wu <jingjing.wu@intel.com>
Mon, 16 Jun 2014 07:31:46 +0000 (15:31 +0800)
committerThomas Monjalon <thomas.monjalon@6wind.com>
Mon, 16 Jun 2014 17:55:14 +0000 (19:55 +0200)
add commands in testpmd for NIC filters:
add_ethertype_filter
remove_ethertype_filter
get_ethertype_filter
add_2tuple_filter
remove_2tuple_filter
get_2tuple_filter
add_5tuple_filter
remove_5tuple_filter
get_5tuple_filter
add_syn_filter
remove_syn_filter
get_syn_filter
add_flex_filter
remove_flex_filter
get_flex_filter

Signed-off-by: jingjing.wu <jingjing.wu@intel.com>
Tested-by: Waterman Cao <waterman.cao@intel.com>
Reviewed-by: Vladimir Medvedkin <medvedkinv@gmail.com>
Acked-by: Thomas Monjalon <thomas.monjalon@6wind.com>
app/test-pmd/cmdline.c
app/test-pmd/config.c
app/test-pmd/testpmd.h

index 4678977..8c35825 100644 (file)
@@ -113,6 +113,7 @@ static void cmd_help_brief_parsed(__attribute__((unused)) void *parsed_result,
                "    help ports      : Configuring ports.\n"
                "    help flowdir    : Flow Director filter help.\n"
                "    help registers  : Reading and setting port registers.\n"
+               "    help filters    : Filters configuration help.\n"
                "    help all        : All of the above sections.\n\n"
        );
 
@@ -554,6 +555,67 @@ static void cmd_help_long_parsed(void *parsed_result,
                        "    Set single bit value of a port register.\n\n"
                );
        }
+       if (show_all || !strcmp(res->section, "filters")) {
+
+               cmdline_printf(
+                       cl,
+                       "\n"
+                       "filters:\n"
+                       "--------\n\n"
+
+                       "add_ethertype_filter (port_id) ethertype (eth_value)"
+                       " priority (enable|disable)(pri_value) queue (queue_id) index (idx)\n"
+                       "    add an ethertype filter.\n\n"
+
+                       "remove_ethertype_filter (port_id) index (idx)\n"
+                       "    remove an ethertype filter.\n\n"
+
+                       "get_ethertype_filter (port_id) index (idx)\n"
+                       "    get info of a ethertype filter.\n\n"
+
+                       "add_2tuple_filter (port_id) protocol (pro_value) (pro_mask)"
+                       " dst_port (port_value) (port_mask) flags (flg_value) priority (prio_value)"
+                       " queue (queue_id) index (idx)\n"
+                       "    add a 2tuple filter.\n\n"
+
+                       "remove_2tuple_filter (port_id) index (idx)\n"
+                       "    remove a 2tuple filter.\n\n"
+
+                       "get_2tuple_filter (port_id) index (idx)\n"
+                       "    get info of a 2tuple filter.\n\n"
+
+                       "add_5tuple_filter (port_id) dst_ip (dst_address) src_ip (src_address)"
+                       " dst_port (dst_port_value) src_port (src_port_value) protocol (protocol_value)"
+                       " mask (mask_value) flags (flags_value) priority (prio_value)"
+                       " queue (queue_id) index (idx)\n"
+                       "    add a 5tuple filter.\n\n"
+
+                       "remove_5tuple_filter (port_id) index (idx)\n"
+                       "    remove a 5tuple filter.\n\n"
+
+                       "get_5tuple_filter (port_id) index (idx)\n"
+                       "    get info of a 5tuple filter.\n\n"
+
+                       "add_syn_filter (port_id) priority (high|low) queue (queue_id)"
+                       "    add syn filter.\n\n"
+
+                       "remove_syn_filter (port_id)"
+                       "    remove syn filter.\n\n"
+
+                       "get_syn_filter (port_id) "
+                       "    get syn filter info.\n\n"
+
+                       "add_flex_filter (port_id) len (len_value) bytes (bytes_string) mask (mask_value)"
+                       " priority (prio_value) queue (queue_id) index (idx)\n"
+                       "    add a flex filter.\n\n"
+
+                       "remove_flex_filter (port_id) index (idx)\n"
+                       "    remove a flex filter.\n\n"
+
+                       "get_flex_filter (port_id) index (idx)\n"
+                       "    get info of a flex filter.\n\n"
+               );
+       }
 }
 
 cmdline_parse_token_string_t cmd_help_long_help =
@@ -562,7 +624,7 @@ cmdline_parse_token_string_t cmd_help_long_help =
 cmdline_parse_token_string_t cmd_help_long_section =
        TOKEN_STRING_INITIALIZER(struct cmd_help_long_result, section,
                        "all#control#display#config#flowdir#"
-                       "ports#registers");
+                       "ports#registers#filters");
 
 cmdline_parse_inst_t cmd_help_long = {
        .f = cmd_help_long_parsed,
@@ -5534,6 +5596,836 @@ cmdline_parse_inst_t cmd_dump_one = {
        },
 };
 
+/* *** ADD/REMOVE an ethertype FILTER *** */
+struct cmd_ethertype_filter_result {
+       cmdline_fixed_string_t filter;
+       uint8_t port_id;
+       cmdline_fixed_string_t ethertype;
+       uint16_t ethertype_value;
+       cmdline_fixed_string_t priority;
+       cmdline_fixed_string_t priority_en;
+       uint8_t priority_value;
+       cmdline_fixed_string_t queue;
+       uint16_t queue_id;
+       cmdline_fixed_string_t index;
+       uint16_t index_value;
+};
+
+static void
+cmd_ethertype_filter_parsed(void *parsed_result,
+                       __attribute__((unused)) struct cmdline *cl,
+                       __attribute__((unused)) void *data)
+{
+       int ret = 0;
+       struct cmd_ethertype_filter_result *res = parsed_result;
+       struct rte_ethertype_filter filter;
+
+       memset(&filter, 0, sizeof(struct rte_ethertype_filter));
+       filter.ethertype = rte_cpu_to_le_16(res->ethertype_value);
+       filter.priority = res->priority_value;
+
+       if (!strcmp(res->priority_en, "enable"))
+               filter.priority_en = 1;
+       if (!strcmp(res->filter, "add_ethertype_filter"))
+               ret = rte_eth_dev_add_ethertype_filter(res->port_id,
+                               res->index_value,
+                               &filter, res->queue_id);
+       else if (!strcmp(res->filter, "remove_ethertype_filter"))
+               ret = rte_eth_dev_remove_ethertype_filter(res->port_id,
+                               res->index_value);
+       else if (!strcmp(res->filter, "get_ethertype_filter"))
+               get_ethertype_filter(res->port_id, res->index_value);
+
+       if (ret < 0)
+               printf("ethertype filter setting error: (%s)\n",
+                       strerror(-ret));
+}
+
+cmdline_parse_token_num_t cmd_ethertype_filter_port_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_ethertype_filter_result,
+                               port_id, UINT8);
+cmdline_parse_token_string_t cmd_ethertype_filter_ethertype =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                               ethertype, "ethertype");
+cmdline_parse_token_ipaddr_t cmd_ethertype_filter_ethertype_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_ethertype_filter_result,
+                               ethertype_value, UINT16);
+cmdline_parse_token_string_t cmd_ethertype_filter_priority =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                               priority, "priority");
+cmdline_parse_token_string_t cmd_ethertype_filter_priority_en =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                               priority_en, "enable#disable");
+cmdline_parse_token_num_t cmd_ethertype_filter_priority_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_ethertype_filter_result,
+                               priority_value, UINT8);
+cmdline_parse_token_string_t cmd_ethertype_filter_queue =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                               queue, "queue");
+cmdline_parse_token_num_t cmd_ethertype_filter_queue_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_ethertype_filter_result,
+                               queue_id, UINT16);
+cmdline_parse_token_string_t cmd_ethertype_filter_index =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                               index, "index");
+cmdline_parse_token_num_t cmd_ethertype_filter_index_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_ethertype_filter_result,
+                               index_value, UINT16);
+cmdline_parse_token_string_t cmd_ethertype_filter_add_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                               filter, "add_ethertype_filter");
+cmdline_parse_inst_t cmd_add_ethertype_filter = {
+       .f = cmd_ethertype_filter_parsed,
+       .data = NULL,
+       .help_str = "add an ethertype filter",
+       .tokens = {
+               (void *)&cmd_ethertype_filter_add_filter,
+               (void *)&cmd_ethertype_filter_port_id,
+               (void *)&cmd_ethertype_filter_ethertype,
+               (void *)&cmd_ethertype_filter_ethertype_value,
+               (void *)&cmd_ethertype_filter_priority,
+               (void *)&cmd_ethertype_filter_priority_en,
+               (void *)&cmd_ethertype_filter_priority_value,
+               (void *)&cmd_ethertype_filter_queue,
+               (void *)&cmd_ethertype_filter_queue_id,
+               (void *)&cmd_ethertype_filter_index,
+               (void *)&cmd_ethertype_filter_index_value,
+               NULL,
+       },
+};
+
+cmdline_parse_token_string_t cmd_ethertype_filter_remove_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                                filter, "remove_ethertype_filter");
+cmdline_parse_inst_t cmd_remove_ethertype_filter = {
+       .f = cmd_ethertype_filter_parsed,
+       .data = NULL,
+       .help_str = "remove an ethertype filter",
+       .tokens = {
+               (void *)&cmd_ethertype_filter_remove_filter,
+               (void *)&cmd_ethertype_filter_port_id,
+               (void *)&cmd_ethertype_filter_index,
+               (void *)&cmd_ethertype_filter_index_value,
+               NULL,
+       },
+};
+cmdline_parse_token_string_t cmd_ethertype_filter_get_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_ethertype_filter_result,
+                                filter, "get_ethertype_filter");
+cmdline_parse_inst_t cmd_get_ethertype_filter = {
+       .f = cmd_ethertype_filter_parsed,
+       .data = NULL,
+       .help_str = "get an ethertype filter",
+       .tokens = {
+               (void *)&cmd_ethertype_filter_get_filter,
+               (void *)&cmd_ethertype_filter_port_id,
+               (void *)&cmd_ethertype_filter_index,
+               (void *)&cmd_ethertype_filter_index_value,
+               NULL,
+       },
+};
+
+/* *** set SYN filter *** */
+struct cmd_set_syn_filter_result {
+       cmdline_fixed_string_t filter;
+       uint8_t port_id;
+       cmdline_fixed_string_t priority;
+       cmdline_fixed_string_t high;
+       cmdline_fixed_string_t queue;
+       uint16_t  queue_id;
+};
+
+static void
+cmd_set_syn_filter_parsed(void *parsed_result,
+                       __attribute__((unused)) struct cmdline *cl,
+                       __attribute__((unused)) void *data)
+{
+       int ret = 0;
+       struct cmd_set_syn_filter_result *res = parsed_result;
+       struct rte_syn_filter filter;
+
+       if (!strcmp(res->filter, "add_syn_filter")) {
+               if (!strcmp(res->high, "high"))
+                       filter.hig_pri = 1;
+               else
+                       filter.hig_pri = 0;
+               ret = rte_eth_dev_add_syn_filter(res->port_id,
+                               &filter, res->queue_id);
+       } else if (!strcmp(res->filter, "remove_syn_filter"))
+               ret = rte_eth_dev_remove_syn_filter(res->port_id);
+       else if (!strcmp(res->filter, "get_syn_filter"))
+               get_syn_filter(res->port_id);
+       if (ret < 0)
+               printf("syn filter setting error: (%s)\n", strerror(-ret));
+
+}
+cmdline_parse_token_string_t cmd_syn_filter_portid =
+       TOKEN_NUM_INITIALIZER(struct cmd_set_syn_filter_result,
+                               port_id, UINT8);
+cmdline_parse_token_string_t cmd_syn_filter_priority =
+       TOKEN_STRING_INITIALIZER(struct cmd_set_syn_filter_result,
+                               priority, "priority");
+cmdline_parse_token_string_t cmd_syn_filter_high =
+       TOKEN_STRING_INITIALIZER(struct cmd_set_syn_filter_result,
+                               high, "high#low");
+cmdline_parse_token_string_t cmd_syn_filter_queue =
+       TOKEN_STRING_INITIALIZER(struct cmd_set_syn_filter_result,
+                               queue, "queue");
+cmdline_parse_token_num_t cmd_syn_filter_queue_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_set_syn_filter_result,
+                               queue_id, UINT16);
+cmdline_parse_token_string_t cmd_syn_filter_add_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_set_syn_filter_result,
+                               filter, "add_syn_filter");
+cmdline_parse_token_string_t cmd_syn_filter_remove_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_set_syn_filter_result,
+                               filter, "remove_syn_filter");
+cmdline_parse_inst_t cmd_add_syn_filter = {
+               .f = cmd_set_syn_filter_parsed,
+               .data = NULL,
+               .help_str = "add syn filter",
+               .tokens = {
+                       (void *)&cmd_syn_filter_add_filter,
+                       (void *)&cmd_syn_filter_portid,
+                       (void *)&cmd_syn_filter_priority,
+                       (void *)&cmd_syn_filter_high,
+                       (void *)&cmd_syn_filter_queue,
+                       (void *)&cmd_syn_filter_queue_id,
+                       NULL,
+               },
+};
+cmdline_parse_inst_t cmd_remove_syn_filter = {
+               .f = cmd_set_syn_filter_parsed,
+               .data = NULL,
+               .help_str = "remove syn filter",
+               .tokens = {
+                       (void *)&cmd_syn_filter_remove_filter,
+                       (void *)&cmd_syn_filter_portid,
+                       NULL,
+               },
+};
+
+cmdline_parse_token_string_t cmd_syn_filter_get_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_set_syn_filter_result,
+                               filter, "get_syn_filter");
+
+cmdline_parse_inst_t cmd_get_syn_filter = {
+               .f = cmd_set_syn_filter_parsed,
+               .data = NULL,
+               .help_str = "get syn filter",
+               .tokens = {
+                       (void *)&cmd_syn_filter_get_filter,
+                       (void *)&cmd_syn_filter_portid,
+                       NULL,
+               },
+};
+
+/* *** ADD/REMOVE A 2tuple FILTER *** */
+struct cmd_2tuple_filter_result {
+       cmdline_fixed_string_t filter;
+       uint8_t port_id;
+       cmdline_fixed_string_t protocol;
+       uint8_t protocol_value;
+       uint8_t protocol_mask;
+       cmdline_fixed_string_t dst_port;
+       uint16_t dst_port_value;
+       uint16_t dst_port_mask;
+       cmdline_fixed_string_t flags;
+       uint8_t flags_value;
+       cmdline_fixed_string_t priority;
+       uint8_t priority_value;
+       cmdline_fixed_string_t queue;
+       uint16_t queue_id;
+       cmdline_fixed_string_t index;
+       uint16_t index_value;
+};
+
+static void
+cmd_2tuple_filter_parsed(void *parsed_result,
+                       __attribute__((unused)) struct cmdline *cl,
+                       __attribute__((unused)) void *data)
+{
+       int ret = 0;
+       struct rte_2tuple_filter filter;
+       struct cmd_2tuple_filter_result *res = parsed_result;
+
+       memset(&filter, 0, sizeof(struct rte_2tuple_filter));
+
+       if (!strcmp(res->filter, "add_2tuple_filter")) {
+               /* need convert to big endian. */
+               filter.dst_port = rte_cpu_to_be_16(res->dst_port_value);
+               filter.protocol = res->protocol_value;
+               filter.dst_port_mask = (res->dst_port_mask) ? 0 : 1;
+               filter.protocol_mask = (res->protocol_mask) ? 0 : 1;
+               filter.priority = res->priority_value;
+               filter.tcp_flags = res->flags_value;
+               ret = rte_eth_dev_add_2tuple_filter(res->port_id,
+                       res->index_value, &filter, res->queue_id);
+       } else if (!strcmp(res->filter, "remove_2tuple_filter"))
+               ret = rte_eth_dev_remove_2tuple_filter(res->port_id,
+                       res->index_value);
+       else if (!strcmp(res->filter, "get_2tuple_filter"))
+               get_2tuple_filter(res->port_id, res->index_value);
+
+       if (ret < 0)
+               printf("2tuple filter setting error: (%s)\n", strerror(-ret));
+}
+
+cmdline_parse_token_num_t cmd_2tuple_filter_port_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               port_id, UINT8);
+cmdline_parse_token_string_t cmd_2tuple_filter_protocol =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                                protocol, "protocol");
+cmdline_parse_token_string_t cmd_2tuple_filter_protocol_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                                protocol_value, UINT8);
+cmdline_parse_token_num_t cmd_2tuple_filter_protocol_mask =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               protocol_mask, UINT8);
+cmdline_parse_token_string_t cmd_2tuple_filter_dst_port =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               dst_port, "dst_port");
+cmdline_parse_token_num_t cmd_2tuple_filter_dst_port_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               dst_port_value, UINT16);
+cmdline_parse_token_num_t cmd_2tuple_filter_dst_port_mask =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               dst_port_mask, UINT16);
+cmdline_parse_token_string_t cmd_2tuple_filter_flags =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               flags, "flags");
+cmdline_parse_token_string_t cmd_2tuple_filter_flags_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               flags_value, UINT8);
+cmdline_parse_token_string_t cmd_2tuple_filter_priority =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               priority, "priority");
+cmdline_parse_token_num_t cmd_2tuple_filter_priority_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               priority_value, UINT8);
+cmdline_parse_token_string_t cmd_2tuple_filter_queue =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               queue, "queue");
+cmdline_parse_token_num_t cmd_2tuple_filter_queue_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               queue_id, UINT16);
+cmdline_parse_token_string_t cmd_2tuple_filter_index =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               index, "index");
+cmdline_parse_token_num_t cmd_2tuple_filter_index_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_2tuple_filter_result,
+                               index_value, UINT16);
+cmdline_parse_token_string_t cmd_2tuple_filter_add_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               filter, "add_2tuple_filter");
+cmdline_parse_inst_t cmd_add_2tuple_filter = {
+       .f = cmd_2tuple_filter_parsed,
+       .data = NULL,
+       .help_str = "add a 2tuple filter",
+       .tokens = {
+               (void *)&cmd_2tuple_filter_add_filter,
+               (void *)&cmd_2tuple_filter_port_id,
+               (void *)&cmd_2tuple_filter_protocol,
+               (void *)&cmd_2tuple_filter_protocol_value,
+               (void *)&cmd_2tuple_filter_protocol_mask,
+               (void *)&cmd_2tuple_filter_dst_port,
+               (void *)&cmd_2tuple_filter_dst_port_value,
+               (void *)&cmd_2tuple_filter_dst_port_mask,
+               (void *)&cmd_2tuple_filter_flags,
+               (void *)&cmd_2tuple_filter_flags_value,
+               (void *)&cmd_2tuple_filter_priority,
+               (void *)&cmd_2tuple_filter_priority_value,
+               (void *)&cmd_2tuple_filter_queue,
+               (void *)&cmd_2tuple_filter_queue_id,
+               (void *)&cmd_2tuple_filter_index,
+               (void *)&cmd_2tuple_filter_index_value,
+               NULL,
+       },
+};
+
+cmdline_parse_token_string_t cmd_2tuple_filter_remove_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               filter, "remove_2tuple_filter");
+cmdline_parse_inst_t cmd_remove_2tuple_filter = {
+       .f = cmd_2tuple_filter_parsed,
+       .data = NULL,
+       .help_str = "remove a 2tuple filter",
+       .tokens = {
+               (void *)&cmd_2tuple_filter_remove_filter,
+               (void *)&cmd_2tuple_filter_port_id,
+               (void *)&cmd_2tuple_filter_index,
+               (void *)&cmd_2tuple_filter_index_value,
+               NULL,
+       },
+};
+cmdline_parse_token_string_t cmd_2tuple_filter_get_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_2tuple_filter_result,
+                               filter, "get_2tuple_filter");
+cmdline_parse_inst_t cmd_get_2tuple_filter = {
+       .f = cmd_2tuple_filter_parsed,
+       .data = NULL,
+       .help_str = "get a 2tuple filter",
+       .tokens = {
+               (void *)&cmd_2tuple_filter_get_filter,
+               (void *)&cmd_2tuple_filter_port_id,
+               (void *)&cmd_2tuple_filter_index,
+               (void *)&cmd_2tuple_filter_index_value,
+               NULL,
+       },
+};
+
+/* *** ADD/REMOVE A 5tuple FILTER *** */
+struct cmd_5tuple_filter_result {
+       cmdline_fixed_string_t filter;
+       uint8_t  port_id;
+       cmdline_fixed_string_t dst_ip;
+       cmdline_ipaddr_t dst_ip_value;
+       cmdline_fixed_string_t src_ip;
+       cmdline_ipaddr_t src_ip_value;
+       cmdline_fixed_string_t dst_port;
+       uint16_t dst_port_value;
+       cmdline_fixed_string_t src_port;
+       uint16_t src_port_value;
+       cmdline_fixed_string_t protocol;
+       uint8_t protocol_value;
+       cmdline_fixed_string_t mask;
+       uint8_t  mask_value;
+       cmdline_fixed_string_t flags;
+       uint8_t flags_value;
+       cmdline_fixed_string_t priority;
+       uint8_t  priority_value;
+       cmdline_fixed_string_t queue;
+       uint16_t  queue_id;
+       cmdline_fixed_string_t index;
+       uint16_t  index_value;
+};
+
+static void
+cmd_5tuple_filter_parsed(void *parsed_result,
+                       __attribute__((unused)) struct cmdline *cl,
+                       __attribute__((unused)) void *data)
+{
+       int ret = 0;
+       struct rte_5tuple_filter filter;
+       struct cmd_5tuple_filter_result *res = parsed_result;
+
+       memset(&filter, 0, sizeof(struct rte_5tuple_filter));
+
+       if (!strcmp(res->filter, "add_5tuple_filter")) {
+               filter.dst_ip_mask = (res->mask_value & 0x10) ? 0 : 1;
+               filter.src_ip_mask = (res->mask_value & 0x08) ? 0 : 1;
+               filter.dst_port_mask = (res->mask_value & 0x04) ? 0 : 1;
+               filter.src_port_mask = (res->mask_value & 0x02) ? 0 : 1;
+               filter.protocol = res->protocol_value;
+               filter.protocol_mask = (res->mask_value & 0x01) ? 0 : 1;
+               filter.priority = res->priority_value;
+               filter.tcp_flags = res->flags_value;
+
+               if (res->dst_ip_value.family == AF_INET)
+                       /* no need to convert, already big endian. */
+                       filter.dst_ip = res->dst_ip_value.addr.ipv4.s_addr;
+               else {
+                       if (filter.dst_ip_mask == 0) {
+                               printf("can not support ipv6 involved compare.\n");
+                               return;
+                       }
+                       filter.dst_ip = 0;
+               }
+
+               if (res->src_ip_value.family == AF_INET)
+                       /* no need to convert, already big endian. */
+                       filter.src_ip = res->src_ip_value.addr.ipv4.s_addr;
+               else {
+                       if (filter.src_ip_mask == 0) {
+                               printf("can not support ipv6 involved compare.\n");
+                               return;
+                       }
+                       filter.src_ip = 0;
+               }
+               /* need convert to big endian. */
+               filter.dst_port = rte_cpu_to_be_16(res->dst_port_value);
+               filter.src_port = rte_cpu_to_be_16(res->src_port_value);
+
+               ret = rte_eth_dev_add_5tuple_filter(res->port_id,
+                       res->index_value, &filter, res->queue_id);
+       } else if (!strcmp(res->filter, "remove_5tuple_filter"))
+               ret = rte_eth_dev_remove_5tuple_filter(res->port_id,
+                       res->index_value);
+       else if (!strcmp(res->filter, "get_5tuple_filter"))
+               get_5tuple_filter(res->port_id, res->index_value);
+       if (ret < 0)
+               printf("5tuple filter setting error: (%s)\n", strerror(-ret));
+}
+
+
+cmdline_parse_token_num_t cmd_5tuple_filter_port_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               port_id, UINT8);
+cmdline_parse_token_string_t cmd_5tuple_filter_dst_ip =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               dst_ip, "dst_ip");
+cmdline_parse_token_ipaddr_t cmd_5tuple_filter_dst_ip_value =
+       TOKEN_IPADDR_INITIALIZER(struct cmd_5tuple_filter_result,
+                               dst_ip_value);
+cmdline_parse_token_string_t cmd_5tuple_filter_src_ip =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               src_ip, "src_ip");
+cmdline_parse_token_ipaddr_t cmd_5tuple_filter_src_ip_value =
+       TOKEN_IPADDR_INITIALIZER(struct cmd_5tuple_filter_result,
+                               src_ip_value);
+cmdline_parse_token_string_t cmd_5tuple_filter_dst_port =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               dst_port, "dst_port");
+cmdline_parse_token_num_t cmd_5tuple_filter_dst_port_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               dst_port_value, UINT16);
+cmdline_parse_token_string_t cmd_5tuple_filter_src_port =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               src_port, "src_port");
+cmdline_parse_token_num_t cmd_5tuple_filter_src_port_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               src_port_value, UINT16);
+cmdline_parse_token_string_t cmd_5tuple_filter_protocol =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               protocol, "protocol");
+cmdline_parse_token_string_t cmd_5tuple_filter_protocol_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               protocol_value, UINT8);
+cmdline_parse_token_string_t cmd_5tuple_filter_mask =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               mask, "mask");
+cmdline_parse_token_num_t cmd_5tuple_filter_mask_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               mask_value, INT8);
+cmdline_parse_token_string_t cmd_5tuple_filter_flags =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               flags, "flags");
+cmdline_parse_token_num_t cmd_5tuple_filter_flags_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               flags_value, UINT8);
+cmdline_parse_token_string_t cmd_5tuple_filter_priority =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               priority, "priority");
+cmdline_parse_token_num_t cmd_5tuple_filter_priority_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               priority_value, UINT8);
+cmdline_parse_token_string_t cmd_5tuple_filter_queue =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               queue, "queue");
+cmdline_parse_token_num_t cmd_5tuple_filter_queue_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               queue_id, UINT16);
+cmdline_parse_token_string_t cmd_5tuple_filter_index =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               index, "index");
+cmdline_parse_token_num_t cmd_5tuple_filter_index_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_5tuple_filter_result,
+                               index_value, UINT16);
+
+cmdline_parse_token_string_t cmd_5tuple_filter_add_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                                filter, "add_5tuple_filter");
+cmdline_parse_inst_t cmd_add_5tuple_filter = {
+       .f = cmd_5tuple_filter_parsed,
+       .data = NULL,
+       .help_str = "add a 5tuple filter",
+       .tokens = {
+               (void *)&cmd_5tuple_filter_add_filter,
+               (void *)&cmd_5tuple_filter_port_id,
+               (void *)&cmd_5tuple_filter_dst_ip,
+               (void *)&cmd_5tuple_filter_dst_ip_value,
+               (void *)&cmd_5tuple_filter_src_ip,
+               (void *)&cmd_5tuple_filter_src_ip_value,
+               (void *)&cmd_5tuple_filter_dst_port,
+               (void *)&cmd_5tuple_filter_dst_port_value,
+               (void *)&cmd_5tuple_filter_src_port,
+               (void *)&cmd_5tuple_filter_src_port_value,
+               (void *)&cmd_5tuple_filter_protocol,
+               (void *)&cmd_5tuple_filter_protocol_value,
+               (void *)&cmd_5tuple_filter_mask,
+               (void *)&cmd_5tuple_filter_mask_value,
+               (void *)&cmd_5tuple_filter_flags,
+               (void *)&cmd_5tuple_filter_flags_value,
+               (void *)&cmd_5tuple_filter_priority,
+               (void *)&cmd_5tuple_filter_priority_value,
+               (void *)&cmd_5tuple_filter_queue,
+               (void *)&cmd_5tuple_filter_queue_id,
+               (void *)&cmd_5tuple_filter_index,
+               (void *)&cmd_5tuple_filter_index_value,
+               NULL,
+       },
+};
+
+cmdline_parse_token_string_t cmd_5tuple_filter_remove_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               filter, "remove_5tuple_filter");
+cmdline_parse_inst_t cmd_remove_5tuple_filter = {
+       .f = cmd_5tuple_filter_parsed,
+       .data = NULL,
+       .help_str = "remove a 5tuple filter",
+       .tokens = {
+               (void *)&cmd_5tuple_filter_remove_filter,
+               (void *)&cmd_5tuple_filter_port_id,
+               (void *)&cmd_5tuple_filter_index,
+               (void *)&cmd_5tuple_filter_index_value,
+               NULL,
+       },
+};
+
+cmdline_parse_token_string_t cmd_5tuple_filter_get_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_5tuple_filter_result,
+                               filter, "get_5tuple_filter");
+cmdline_parse_inst_t cmd_get_5tuple_filter = {
+       .f = cmd_5tuple_filter_parsed,
+       .data = NULL,
+       .help_str = "get a 5tuple filter",
+       .tokens = {
+               (void *)&cmd_5tuple_filter_get_filter,
+               (void *)&cmd_5tuple_filter_port_id,
+               (void *)&cmd_5tuple_filter_index,
+               (void *)&cmd_5tuple_filter_index_value,
+               NULL,
+       },
+};
+
+/* *** ADD/REMOVE A flex FILTER *** */
+struct cmd_flex_filter_result {
+       cmdline_fixed_string_t filter;
+       uint8_t port_id;
+       cmdline_fixed_string_t len;
+       uint8_t len_value;
+       cmdline_fixed_string_t bytes;
+       cmdline_fixed_string_t bytes_value;
+       cmdline_fixed_string_t mask;
+       cmdline_fixed_string_t mask_value;
+       cmdline_fixed_string_t priority;
+       uint8_t priority_value;
+       cmdline_fixed_string_t queue;
+       uint16_t queue_id;
+       cmdline_fixed_string_t index;
+       uint16_t index_value;
+};
+
+static int xdigit2val(unsigned char c)
+{
+       int val;
+       if (isdigit(c))
+               val = c - '0';
+       else if (isupper(c))
+               val = c - 'A' + 10;
+       else
+               val = c - 'a' + 10;
+       return val;
+}
+
+static void
+cmd_flex_filter_parsed(void *parsed_result,
+                         __attribute__((unused)) struct cmdline *cl,
+                         __attribute__((unused)) void *data)
+{
+       int ret = 0;
+       struct rte_flex_filter filter;
+       struct cmd_flex_filter_result *res = parsed_result;
+       char *bytes_ptr, *mask_ptr;
+       uint16_t len, i, j;
+       char c;
+       int val, mod = 0;
+       uint32_t dword = 0;
+       uint8_t byte = 0;
+       uint8_t hex = 0;
+
+       if (!strcmp(res->filter, "add_flex_filter")) {
+               if (res->len_value > 128) {
+                       printf("the len exceed the max length 128\n");
+                       return;
+               }
+               memset(&filter, 0, sizeof(struct rte_flex_filter));
+               filter.len = res->len_value;
+               filter.priority = res->priority_value;
+               bytes_ptr = res->bytes_value;
+               mask_ptr = res->mask_value;
+
+               j = 0;
+                /* translate bytes string to uint_32 array. */
+               if (bytes_ptr[0] == '0' && ((bytes_ptr[1] == 'x') ||
+                       (bytes_ptr[1] == 'X')))
+                       bytes_ptr += 2;
+               len = strnlen(bytes_ptr, res->len_value * 2);
+               if (len == 0 || (len % 8 != 0)) {
+                       printf("please check len and bytes input\n");
+                       return;
+               }
+               for (i = 0; i < len; i++) {
+                       c = bytes_ptr[i];
+                       if (isxdigit(c) == 0) {
+                               /* invalid characters. */
+                               printf("invalid input\n");
+                               return;
+                       }
+                       val = xdigit2val(c);
+                       mod = i % 8;
+                       if (i % 2) {
+                               byte |= val;
+                               dword |= byte << (4 * mod - 4);
+                               byte = 0;
+                       } else
+                               byte |= val << 4;
+                       if (mod == 7) {
+                               filter.dwords[j] = dword;
+                               printf("dwords[%d]:%08x ", j, filter.dwords[j]);
+                               j++;
+                               dword = 0;
+                       }
+               }
+               printf("\n");
+                /* translate mask string to uint8_t array. */
+               j = 0;
+               if (mask_ptr[0] == '0' && ((mask_ptr[1] == 'x') ||
+                       (mask_ptr[1] == 'X')))
+                       mask_ptr += 2;
+               len = strnlen(mask_ptr, (res->len_value+3)/4);
+               if (len == 0) {
+                       printf("invalid input\n");
+                       return;
+               }
+               for (i = 0; i < len; i++) {
+                       c = mask_ptr[i];
+                       if (isxdigit(c) == 0) {
+                               /* invalid characters. */
+                               printf("invalid input\n");
+                               return;
+                       }
+                       val = xdigit2val(c);
+                       hex |= (uint8_t)(val & 0x8) >> 3;
+                       hex |= (uint8_t)(val & 0x4) >> 1;
+                       hex |= (uint8_t)(val & 0x2) << 1;
+                       hex |= (uint8_t)(val & 0x1) << 3;
+                       if (i % 2) {
+                               byte |= hex << 4;
+                               filter.mask[j] = byte;
+                               printf("mask[%d]:%02x ", j, filter.mask[j]);
+                               j++;
+                               byte = 0;
+                       } else
+                               byte |= hex;
+                       hex = 0;
+               }
+               printf("\n");
+               printf("call function rte_eth_dev_add_flex_filter: "
+                       "index = %d, queue-id = %d, len = %d, priority = %d\n",
+                       res->index_value, res->queue_id,
+                       filter.len, filter.priority);
+               ret = rte_eth_dev_add_flex_filter(res->port_id, res->index_value,
+                               &filter, res->queue_id);
+
+       } else if (!strcmp(res->filter, "remove_flex_filter"))
+               ret = rte_eth_dev_remove_flex_filter(res->port_id,
+                       res->index_value);
+       else if (!strcmp(res->filter, "get_flex_filter"))
+               get_flex_filter(res->port_id, res->index_value);
+
+       if (ret < 0)
+               printf("flex filter setting error: (%s)\n", strerror(-ret));
+}
+
+cmdline_parse_token_num_t cmd_flex_filter_port_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_flex_filter_result,
+                               port_id, UINT8);
+cmdline_parse_token_string_t cmd_flex_filter_len =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               len, "len");
+cmdline_parse_token_string_t cmd_flex_filter_len_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_flex_filter_result,
+                               len_value, UINT8);
+cmdline_parse_token_string_t cmd_flex_filter_bytes =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               bytes, "bytes");
+cmdline_parse_token_string_t cmd_flex_filter_bytes_value =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               bytes_value, NULL);
+cmdline_parse_token_string_t cmd_flex_filter_mask =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               mask, "mask");
+cmdline_parse_token_string_t cmd_flex_filter_mask_value =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               mask_value, NULL);
+cmdline_parse_token_string_t cmd_flex_filter_priority =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               priority, "priority");
+cmdline_parse_token_num_t cmd_flex_filter_priority_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_flex_filter_result,
+                               priority_value, UINT8);
+cmdline_parse_token_string_t cmd_flex_filter_queue =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               queue, "queue");
+cmdline_parse_token_num_t cmd_flex_filter_queue_id =
+       TOKEN_NUM_INITIALIZER(struct cmd_flex_filter_result,
+                               queue_id, UINT16);
+cmdline_parse_token_string_t cmd_flex_filter_index =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               index, "index");
+cmdline_parse_token_num_t cmd_flex_filter_index_value =
+       TOKEN_NUM_INITIALIZER(struct cmd_flex_filter_result,
+                               index_value, UINT16);
+cmdline_parse_token_string_t cmd_flex_filter_add_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               filter, "add_flex_filter");
+cmdline_parse_inst_t cmd_add_flex_filter = {
+       .f = cmd_flex_filter_parsed,
+       .data = NULL,
+       .help_str = "add a flex filter",
+       .tokens = {
+               (void *)&cmd_flex_filter_add_filter,
+               (void *)&cmd_flex_filter_port_id,
+               (void *)&cmd_flex_filter_len,
+               (void *)&cmd_flex_filter_len_value,
+               (void *)&cmd_flex_filter_bytes,
+               (void *)&cmd_flex_filter_bytes_value,
+               (void *)&cmd_flex_filter_mask,
+               (void *)&cmd_flex_filter_mask_value,
+               (void *)&cmd_flex_filter_priority,
+               (void *)&cmd_flex_filter_priority_value,
+               (void *)&cmd_flex_filter_queue,
+               (void *)&cmd_flex_filter_queue_id,
+               (void *)&cmd_flex_filter_index,
+               (void *)&cmd_flex_filter_index_value,
+               NULL,
+       },
+};
+
+cmdline_parse_token_string_t cmd_flex_filter_remove_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               filter, "remove_flex_filter");
+cmdline_parse_inst_t cmd_remove_flex_filter = {
+       .f = cmd_flex_filter_parsed,
+       .data = NULL,
+       .help_str = "remove a flex filter",
+       .tokens = {
+               (void *)&cmd_flex_filter_remove_filter,
+               (void *)&cmd_flex_filter_port_id,
+               (void *)&cmd_flex_filter_index,
+               (void *)&cmd_flex_filter_index_value,
+               NULL,
+       },
+};
+
+cmdline_parse_token_string_t cmd_flex_filter_get_filter =
+       TOKEN_STRING_INITIALIZER(struct cmd_flex_filter_result,
+                               filter, "get_flex_filter");
+cmdline_parse_inst_t cmd_get_flex_filter = {
+       .f = cmd_flex_filter_parsed,
+       .data = NULL,
+       .help_str = "get a flex filter",
+       .tokens = {
+               (void *)&cmd_flex_filter_get_filter,
+               (void *)&cmd_flex_filter_port_id,
+               (void *)&cmd_flex_filter_index,
+               (void *)&cmd_flex_filter_index_value,
+               NULL,
+       },
+};
+
 /* ******************************************************************************** */
 
 /* list of instructions */
@@ -5624,6 +6516,21 @@ cmdline_parse_ctx_t main_ctx[] = {
        (cmdline_parse_inst_t *)&cmd_config_rss_hash_key,
        (cmdline_parse_inst_t *)&cmd_dump,
        (cmdline_parse_inst_t *)&cmd_dump_one,
+       (cmdline_parse_inst_t *)&cmd_add_ethertype_filter,
+       (cmdline_parse_inst_t *)&cmd_remove_ethertype_filter,
+       (cmdline_parse_inst_t *)&cmd_get_ethertype_filter,
+       (cmdline_parse_inst_t *)&cmd_add_syn_filter,
+       (cmdline_parse_inst_t *)&cmd_remove_syn_filter,
+       (cmdline_parse_inst_t *)&cmd_get_syn_filter,
+       (cmdline_parse_inst_t *)&cmd_add_2tuple_filter,
+       (cmdline_parse_inst_t *)&cmd_remove_2tuple_filter,
+       (cmdline_parse_inst_t *)&cmd_get_2tuple_filter,
+       (cmdline_parse_inst_t *)&cmd_add_5tuple_filter,
+       (cmdline_parse_inst_t *)&cmd_remove_5tuple_filter,
+       (cmdline_parse_inst_t *)&cmd_get_5tuple_filter,
+       (cmdline_parse_inst_t *)&cmd_add_flex_filter,
+       (cmdline_parse_inst_t *)&cmd_remove_flex_filter,
+       (cmdline_parse_inst_t *)&cmd_get_flex_filter,
        NULL,
 };
 
index 52ad01a..7a505a1 100644 (file)
@@ -1871,3 +1871,150 @@ set_vf_rate_limit(portid_t port_id, uint16_t vf, uint16_t rate, uint64_t q_msk)
        return diag;
 }
 
+void
+get_ethertype_filter(uint8_t port_id, uint16_t index)
+{
+       struct rte_ethertype_filter filter;
+       int ret = 0;
+       uint16_t rx_queue;
+
+       memset(&filter, 0, sizeof(filter));
+       ret = rte_eth_dev_get_ethertype_filter(port_id, index,
+                               &filter, &rx_queue);
+       if (ret < 0) {
+               if (ret == (-ENOENT))
+                       printf("filter[%d] is not enabled\n", index);
+               else
+                       printf("get ethertype filter fails(%s)\n", strerror(-ret));
+               return;
+       } else {
+               printf("filter[%d]:\n", index);
+               printf("    ethertype:  0x%04x\n",
+                       rte_le_to_cpu_32(filter.ethertype));
+               printf("    priority: %s, %d\n",
+                       filter.priority_en ? "enable" : "disable",
+                       filter.priority);
+               printf("    queue: %d\n", rx_queue);
+       }
+}
+
+void
+get_syn_filter(uint8_t port_id)
+{
+       struct rte_syn_filter filter;
+       int ret = 0;
+       uint16_t rx_queue;
+
+       memset(&filter, 0, sizeof(filter));
+       ret = rte_eth_dev_get_syn_filter(port_id, &filter, &rx_queue);
+
+       if (ret < 0) {
+               if (ret == (-ENOENT))
+                       printf("syn filter is not enabled\n");
+               else
+                       printf("get syn filter fails(%s)\n", strerror(-ret));
+               return;
+       }
+       printf("syn filter: priority: %s, queue: %d\n",
+               filter.hig_pri ? "high" : "low",
+               rx_queue);
+}
+void
+get_2tuple_filter(uint8_t port_id, uint16_t index)
+{
+       struct rte_2tuple_filter filter;
+       int ret = 0;
+       uint16_t rx_queue;
+
+       memset(&filter, 0, sizeof(filter));
+       ret = rte_eth_dev_get_2tuple_filter(port_id, index,
+                               &filter, &rx_queue);
+       if (ret < 0) {
+               if (ret == (-ENOENT))
+                       printf("filter[%d] is not enabled\n", index);
+               else
+                       printf("get 2tuple filter fails(%s)\n", strerror(-ret));
+               return;
+       } else {
+               printf("filter[%d]:\n", index);
+               printf("    Destination Port:     0x%04x    mask: %d\n",
+                       rte_be_to_cpu_16(filter.dst_port),
+                       filter.dst_port_mask ? 0 : 1);
+               printf("    protocol:  0x%02x     mask:%d     tcp_flags: 0x%02x\n",
+                       filter.protocol, filter.protocol_mask ? 0 : 1,
+                       filter.tcp_flags);
+               printf("    priority: %d    queue: %d\n",
+                       filter.priority, rx_queue);
+       }
+}
+
+void
+get_5tuple_filter(uint8_t port_id, uint16_t index)
+{
+       struct rte_5tuple_filter filter;
+       int ret = 0;
+       uint16_t rx_queue;
+
+       memset(&filter, 0, sizeof(filter));
+       ret = rte_eth_dev_get_5tuple_filter(port_id, index,
+                               &filter, &rx_queue);
+       if (ret < 0) {
+               if (ret == (-ENOENT))
+                       printf("filter[%d] is not enabled\n", index);
+               else
+                       printf("get 5tuple filter fails(%s)\n", strerror(-ret));
+               return;
+       } else {
+               printf("filter[%d]:\n", index);
+               printf("    Destination IP:  0x%08x    mask: %d\n",
+                       (unsigned)rte_be_to_cpu_32(filter.dst_ip),
+                       filter.dst_ip_mask ? 0 : 1);
+               printf("    Source IP:       0x%08x    mask: %d\n",
+                       (unsigned)rte_be_to_cpu_32(filter.src_ip),
+                       filter.src_ip_mask ? 0 : 1);
+               printf("    Destination Port:       0x%04x    mask: %d\n",
+                       rte_be_to_cpu_16(filter.dst_port),
+                       filter.dst_port_mask ? 0 : 1);
+               printf("    Source Port:       0x%04x    mask: %d\n",
+                       rte_be_to_cpu_16(filter.src_port),
+                       filter.src_port_mask ? 0 : 1);
+               printf("    protocol:           0x%02x    mask: %d\n",
+                       filter.protocol,
+                       filter.protocol_mask ? 0 : 1);
+               printf("    priority: %d    flags: 0x%02x    queue: %d\n",
+                       filter.priority, filter.tcp_flags, rx_queue);
+       }
+}
+void
+get_flex_filter(uint8_t port_id, uint16_t index)
+
+{
+       struct rte_flex_filter filter;
+       int ret = 0;
+       uint16_t rx_queue;
+       int i, j;
+
+       memset(&filter, 0, sizeof(filter));
+       ret = rte_eth_dev_get_flex_filter(port_id, index,
+                               &filter, &rx_queue);
+       if (ret < 0) {
+               if (ret == (-ENOENT))
+                       printf("filter[%d] is not enabled\n", index);
+               else
+                       printf("get flex filter fails(%s)\n", strerror(-ret));
+               return;
+       } else {
+               printf("filter[%d]: ", index);
+               printf("\n    length: %d", filter.len);
+               printf("\n    dword[]: 0x");
+               for (i = 0; i < 32; i++)
+                       printf("%08x ", (unsigned)rte_be_to_cpu_32(filter.dwords[i]));
+               printf("\n    mask[]: 0b");
+               for (i = 0; i < 16; i++) {
+                       for (j = 0; j < 8; j++)
+                               printf("%c", (filter.mask[i] & (1 << j)) ? '1' : '0');
+               }
+               printf("\n    priority: %d    queue: %d\n",
+                       filter.priority, rx_queue);
+       }
+}
index 4fabf1c..d750a35 100644 (file)
@@ -538,6 +538,11 @@ int set_vf_rate_limit(portid_t port_id, uint16_t vf, uint16_t rate,
 
 void port_rss_hash_conf_show(portid_t port_id, int show_rss_key);
 void port_rss_hash_key_update(portid_t port_id, uint8_t *hash_key);
+void get_syn_filter(uint8_t port_id);
+void get_ethertype_filter(uint8_t port_id, uint16_t index);
+void get_2tuple_filter(uint8_t port_id, uint16_t index);
+void get_5tuple_filter(uint8_t port_id, uint16_t index);
+void get_flex_filter(uint8_t port_id, uint16_t index);
 
 /*
  * Work-around of a compilation error with ICC on invocations of the