[dpdk-dev] [PATCH] ip_pipeline: add command for multiple execution of run <file>

Dumitrescu, Cristian cristian.dumitrescu at intel.com
Tue May 24 19:20:19 CEST 2016



> -----Original Message-----
> From: Singh, Jasvinder
> Sent: Friday, May 6, 2016 8:09 PM
> To: dev at dpdk.org
> Cc: Dumitrescu, Cristian <cristian.dumitrescu at intel.com>; Chokkalingam,
> SankarX <sankarx.chokkalingam at intel.com>
> Subject: [PATCH] ip_pipeline: add command for multiple execution of run
> <file>
> 
> From: Sankar Chokkalingam <sankarx.chokkalingam at intel.com>
> 
> The new command enables the execution of script-file for 'n' number of
> times in regular intervals. It takes script-file, number of times to be
> executed, interval between each execution as inputs.
> 
> Syntax: run <file> <count> <interval>
> 
> Usage: This command helps to collect statistics of ports and pipelines in
> periodic interval.
> 
> Example: run port_stats 5 30
> 
> The port_stats file may contain the list of port stats commands like
> p 1 port in 0 stats
> p 1 port out 0 stats
> p 2 port in 0 stats
> p 2 port out 0 stats
> p 2 port in 1 stats
> p 2 port out stats.
> 
> The list of commands in the file will be executed 5 times with the
> interval of 30 seconds.
> 
> Signed-off-by: Sankar Chokkalingam <sankarx.chokkalingam at intel.com>
> ---
>  examples/ip_pipeline/pipeline/pipeline_common_fe.c | 50
> ++++++++++++++++++++++
>  1 file changed, 50 insertions(+)
> 
> diff --git a/examples/ip_pipeline/pipeline/pipeline_common_fe.c
> b/examples/ip_pipeline/pipeline/pipeline_common_fe.c
> index a691d42..9f7ef08 100644
> --- a/examples/ip_pipeline/pipeline/pipeline_common_fe.c
> +++ b/examples/ip_pipeline/pipeline/pipeline_common_fe.c
> @@ -1267,9 +1267,59 @@ cmdline_parse_inst_t cmd_run = {
>  	},
>  };
> 
> +struct cmd_multirun_file_result {
> +	cmdline_fixed_string_t run_string;
> +	char file_name[APP_FILE_NAME_SIZE];
> +	uint32_t count;
> +	uint32_t interval;
> +};
> +
> +static void
> +cmd_multirun_parsed(
> +	void *parsed_result,
> +	struct cmdline *cl,
> +	__attribute__((unused)) void *data)
> +{
> +	struct cmd_multirun_file_result *params = parsed_result;
> +	uint32_t i;
> +
> +	for (i = 0; i < params->count; i++) {
> +		app_run_file(cl->ctx, params->file_name);
> +		sleep(params->interval);
> +	}
> +}
> +
> +cmdline_parse_token_string_t cmd_multirun_run_string =
> +	TOKEN_STRING_INITIALIZER(struct cmd_multirun_file_result,
> run_string,
> +		"run");
> +
> +cmdline_parse_token_string_t cmd_multirun_file_name =
> +	TOKEN_STRING_INITIALIZER(struct cmd_multirun_file_result,
> file_name, NULL);
> +
> +static cmdline_parse_token_num_t cmd_multirun_count =
> +	TOKEN_NUM_INITIALIZER(struct cmd_multirun_file_result, count,
> UINT32);
> +
> +static cmdline_parse_token_num_t cmd_multirun_interval =
> +	TOKEN_NUM_INITIALIZER(struct cmd_multirun_file_result, interval,
> UINT32);
> +
> +cmdline_parse_inst_t cmd_multirun = {
> +	.f = cmd_multirun_parsed,
> +	.data = NULL,
> +	.help_str = "Run CLI script file",
> +	.tokens = {
> +		(void *) &cmd_multirun_run_string,
> +		(void *) &cmd_multirun_file_name,
> +		(void *) &cmd_multirun_count,
> +		(void *) &cmd_multirun_interval,
> +		NULL,
> +	},
> +};
> +
> +
>  static cmdline_parse_ctx_t pipeline_common_cmds[] = {
>  	(cmdline_parse_inst_t *) &cmd_quit,
>  	(cmdline_parse_inst_t *) &cmd_run,
> +	(cmdline_parse_inst_t *) &cmd_multirun,
> 
>  	(cmdline_parse_inst_t *) &cmd_link_config,
>  	(cmdline_parse_inst_t *) &cmd_link_up,
> --
> 1.8.3.1

Hi Jasvinder and Sankar,

This patch is now  reworked and included into the ip_pipeline CLI rework patch set that Michal and Piotr sent: http://www.dpdk.org/ml/archives/dev/2016-May/039429.html

So we can safely discard this patch now.

Thanks,
Cristian



More information about the dev mailing list