On 3/6/2015 4:11 PM, Ouyang Changchun wrote:
> This patch enables testpmd user can config port hw_vlan with more fine 
> granularity:
> hw vlan filter, hw vlan strip, and hw vlan extend.
>
> Don't remove the original command(hw-vlan) considering that some user still 
> want to use
> only one command to switch on/off all 3 options.
>
> Signed-off-by: Changchun Ouyang <changchun.ouyang at intel.com>
> Acked-by: Pablo de Lara <pablo.de.lara.guarch at intel.com>
> ---
>  app/test-pmd/cmdline.c    | 36 +++++++++++++++++++++++++++++++++---
>  app/test-pmd/parameters.c | 18 ++++++++++++++++++
>  2 files changed, 51 insertions(+), 3 deletions(-)
>
> diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c
> index 590e427..99cc307 100644
> --- a/app/test-pmd/cmdline.c
> +++ b/app/test-pmd/cmdline.c
> @@ -584,7 +584,8 @@ static void cmd_help_long_parsed(void *parsed_result,
>                       "port config all max-pkt-len (value)\n"
>                       "    Set the max packet length.\n\n"
>  
> -                     "port config all (crc-strip|rx-cksum|hw-vlan|drop-en)"
> +                     "port config all 
> (crc-strip|rx-cksum|hw-vlan|hw-vlan-filter|"
> +                     "hw-vlan-strip|hw-vlan-extend|drop-en)"
>                       " (on|off)\n"
>                       "    Set crc-strip/rx-checksum/hardware-vlan/drop_en"
>                       " for ports.\n\n"
> @@ -1327,6 +1328,33 @@ cmd_config_rx_mode_flag_parsed(void *parsed_result,
>                       printf("Unknown parameter\n");
>                       return;
>               }
> +     } else if (!strcmp(res->name, "hw-vlan-filter")) {
> +             if (!strcmp(res->value, "on"))
> +                     rx_mode.hw_vlan_filter = 1;
> +             else if (!strcmp(res->value, "off"))
> +                     rx_mode.hw_vlan_filter = 0;
> +             else {
> +                     printf("Unknown parameter\n");
> +                     return;
> +             }
> +     } else if (!strcmp(res->name, "hw-vlan-strip")) {
> +             if (!strcmp(res->value, "on"))
> +                     rx_mode.hw_vlan_strip  = 1;
> +             else if (!strcmp(res->value, "off"))
> +                     rx_mode.hw_vlan_strip  = 0;
> +             else {
> +                     printf("Unknown parameter\n");
> +                     return;
> +             }
> +     } else if (!strcmp(res->name, "hw-vlan-extend")) {
> +             if (!strcmp(res->value, "on"))
> +                     rx_mode.hw_vlan_extend = 1;
> +             else if (!strcmp(res->value, "off"))
> +                     rx_mode.hw_vlan_extend = 0;
> +             else {
> +                     printf("Unknown parameter\n");
> +                     return;
> +             }
>       } else if (!strcmp(res->name, "drop-en")) {
>               if (!strcmp(res->value, "on"))
>                       rx_drop_en = 1;
> @@ -1355,7 +1383,8 @@ cmdline_parse_token_string_t 
> cmd_config_rx_mode_flag_all =
>       TOKEN_STRING_INITIALIZER(struct cmd_config_rx_mode_flag, all, "all");
>  cmdline_parse_token_string_t cmd_config_rx_mode_flag_name =
>       TOKEN_STRING_INITIALIZER(struct cmd_config_rx_mode_flag, name,
> -                                     "crc-strip#rx-cksum#hw-vlan");
> +                                     "crc-strip#rx-cksum#hw-vlan#"
> +                                     
> "hw-vlan-filter#hw-vlan-strip#hw-vlan-extend");
>  cmdline_parse_token_string_t cmd_config_rx_mode_flag_value =
>       TOKEN_STRING_INITIALIZER(struct cmd_config_rx_mode_flag, value,
>                                                       "on#off");
> @@ -1363,7 +1392,8 @@ cmdline_parse_token_string_t 
> cmd_config_rx_mode_flag_value =
>  cmdline_parse_inst_t cmd_config_rx_mode_flag = {
>       .f = cmd_config_rx_mode_flag_parsed,
>       .data = NULL,
> -     .help_str = "port config all crc-strip|rx-cksum|hw-vlan on|off",
> +     .help_str = "port config all crc-strip|rx-cksum|hw-vlan|"
> +             "hw-vlan-filter|hw-vlan-strip|hw-vlan-extend on|off",
>       .tokens = {
>               (void *)&cmd_config_rx_mode_flag_port,
>               (void *)&cmd_config_rx_mode_flag_keyword,
> diff --git a/app/test-pmd/parameters.c b/app/test-pmd/parameters.c
> index adf3203..04dc129 100644
> --- a/app/test-pmd/parameters.c
> +++ b/app/test-pmd/parameters.c
> @@ -157,6 +157,9 @@ usage(char* progname)
>       printf("  --crc-strip: enable CRC stripping by hardware.\n");
>       printf("  --enable-rx-cksum: enable rx hardware checksum offload.\n");
>       printf("  --disable-hw-vlan: disable hardware vlan.\n");
> +     printf("  --disable-hw-vlan-filter: disable hardware vlan filter.\n");
> +     printf("  --disable-hw-vlan-strip: disable hardware vlan strip.\n");
> +     printf("  --disable-hw-vlan-extend: disable hardware vlan extend.\n");
>       printf("  --enable-drop-en: enable per queue packet drop.\n");
>       printf("  --disable-rss: disable rss.\n");
>       printf("  --port-topology=N: set port topology (N: paired (default) or "
> @@ -528,6 +531,9 @@ launch_args_parse(int argc, char** argv)
>               { "crc-strip",                  0, 0, 0 },
>               { "enable-rx-cksum",            0, 0, 0 },
>               { "disable-hw-vlan",            0, 0, 0 },
> +             { "disable-hw-vlan-filter",     0, 0, 0 },
> +             { "disable-hw-vlan-strip",      0, 0, 0 },
> +             { "disable-hw-vlan-extend",     0, 0, 0 },
>               { "enable-drop-en",            0, 0, 0 },

Hi,  Ouyang

Could you help to make this line the same as others?
Also below line:
{ "no-flush-rx",        0, 0, 0 },

I found that, not all of those lines use "Tab" after first field, lots
of them use white space, if all use "Tab", then will keep the same style.

Thanks,
Michael
>               { "disable-rss",                0, 0, 0 },
>               { "port-topology",              1, 0, 0 },
> @@ -778,6 +784,18 @@ launch_args_parse(int argc, char** argv)
>                               rx_mode.hw_vlan_extend = 0;
>                       }
>  
> +                     if (!strcmp(lgopts[opt_idx].name,
> +                                     "disable-hw-vlan-filter"))
> +                             rx_mode.hw_vlan_filter = 0;
> +
> +                     if (!strcmp(lgopts[opt_idx].name,
> +                                     "disable-hw-vlan-strip"))
> +                             rx_mode.hw_vlan_strip  = 0;
> +
> +                     if (!strcmp(lgopts[opt_idx].name,
> +                                     "disable-hw-vlan-extend"))
> +                             rx_mode.hw_vlan_extend = 0;
> +
>                       if (!strcmp(lgopts[opt_idx].name, "enable-drop-en"))
>                               rx_drop_en = 1;
>  

Reply via email to