app/testpmd: add commands for filters
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>
This commit is contained in:
parent
76db0ac639
commit
0db70a8030
@ -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,
|
||||
};
|
||||
|
||||
|
@ -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);
|
||||
}
|
||||
}
|
||||
|
@ -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
|
||||
|
Loading…
Reference in New Issue
Block a user