From: "Singh, Jasvinder" <jasvinder.singh@intel.com>
To: "Dharmappa, Savinay" <savinay.dharmappa@intel.com>,
"dev@dpdk.org" <dev@dpdk.org>,
"Dumitrescu, Cristian" <cristian.dumitrescu@intel.com>
Subject: Re: [dpdk-dev] [RFC PATCH 2/2] example/qos_sched: subport bandwidth profile config
Date: Thu, 16 Jul 2020 08:14:44 +0000 [thread overview]
Message-ID: <CY4PR11MB0072F66E264EF7E22ABBD5EAE07F0@CY4PR11MB0072.namprd11.prod.outlook.com> (raw)
In-Reply-To: <1594837677-313175-3-git-send-email-savinay.dharmappa@intel.com>
> -----Original Message-----
> From: Dharmappa, Savinay <savinay.dharmappa@intel.com>
> Sent: Wednesday, July 15, 2020 7:28 PM
> To: Dharmappa, Savinay <savinay.dharmappa@intel.com>; Singh, Jasvinder
> <jasvinder.singh@intel.com>; dev@dpdk.org
> Subject: [RFC PATCH 2/2] example/qos_sched: subport bandwidth profile
> config
>
> qos sched application uses the new apis introduced as part of dynamic
> configuration of subport bandwidth to configure the deafult subport
> bandwidth profile while buidling the hirerachical scheduler.
>
> Signed-off-by: Savinay Dharmappa <savinay.dharmappa@intel.com>
> Signed-off-by: Jasvinder Singh <jasvinder.singh@intel.com>
> ---
> examples/qos_sched/cfg_file.c | 158 ++++++++++++++++++++++++-------------
> ----
> examples/qos_sched/cfg_file.h | 4 ++
> examples/qos_sched/init.c | 24 +++++--
> examples/qos_sched/main.h | 1 +
> examples/qos_sched/profile.cfg | 3 +
> 5 files changed, 120 insertions(+), 70 deletions(-)
>
> diff --git a/examples/qos_sched/cfg_file.c b/examples/qos_sched/cfg_file.c
> index f078e4f..9e1341c 100644
> --- a/examples/qos_sched/cfg_file.c
> +++ b/examples/qos_sched/cfg_file.c
> @@ -53,8 +53,11 @@ cfg_load_pipe(struct rte_cfgfile *cfg, struct
> rte_sched_pipe_params *pipe_params
> if (!cfg || !pipe_params)
> return -1;
>
> - profiles = rte_cfgfile_num_sections(cfg, "pipe profile", sizeof("pipe
> profile") - 1);
> - subport_params[0].n_pipe_profiles = profiles;
> + profiles = rte_cfgfile_num_sections(cfg, "pipe profile",
> + sizeof("pipe profile") - 1);
> + port_params.n_subport_profiles = profiles;
> +
> + printf(" profiles = %d", profiles);
>
> for (j = 0; j < profiles; j++) {
> char pipe_name[32];
> @@ -143,6 +146,93 @@ cfg_load_pipe(struct rte_cfgfile *cfg, struct
> rte_sched_pipe_params *pipe_params }
>
> int
> +cfg_load_subport_profile(struct rte_cfgfile *cfg,
> + struct rte_sched_subport_profile_params *subport_profile) {
> + int i;
> + const char *entry;
> + int profiles;
> +
> + if (!cfg || !subport_profile)
> + return -1;
> +
> + profiles = rte_cfgfile_num_sections(cfg, "subport profile",
> + sizeof("subport profile") - 1);
> + subport_params[0].n_pipe_profiles = profiles;
> +
> + for (i = 0; i < profiles; i++) {
> + char sec_name[32];
> + snprintf(sec_name, sizeof(sec_name), "subport profile %d",
> i);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tb rate");
> + if (entry)
> + subport_profile[i].tb_rate = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tb size");
> + if (entry)
> + subport_profile[i].tb_size = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc period");
> + if (entry)
> + subport_profile[i].tc_period = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 0 rate");
> + if (entry)
> + subport_profile[i].tc_rate[0] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 1 rate");
> + if (entry)
> + subport_profile[i].tc_rate[1] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 2 rate");
> + if (entry)
> + subport_profile[i].tc_rate[2] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 3 rate");
> + if (entry)
> + subport_profile[i].tc_rate[3] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 4 rate");
> + if (entry)
> + subport_profile[i].tc_rate[4] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 5 rate");
> + if (entry)
> + subport_profile[i].tc_rate[5] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 6 rate");
> + if (entry)
> + subport_profile[i].tc_rate[6] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 7 rate");
> + if (entry)
> + subport_profile[i].tc_rate[7] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 8 rate");
> + if (entry)
> + subport_profile[i].tc_rate[8] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 9 rate");
> + if (entry)
> + subport_profile[i].tc_rate[9] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 10 rate");
> + if (entry)
> + subport_profile[i].tc_rate[10] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 11 rate");
> + if (entry)
> + subport_profile[i].tc_rate[11] = (uint64_t)atoi(entry);
> +
> + entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 12 rate");
> + if (entry)
> + subport_profile[i].tc_rate[12] = (uint64_t)atoi(entry);
> + }
> +
> + return 0;
> +}
> +
> +int
> cfg_load_subport(struct rte_cfgfile *cfg, struct rte_sched_subport_params
> *subport_params) {
> const char *entry;
> @@ -267,70 +357,6 @@ cfg_load_subport(struct rte_cfgfile *cfg, struct
> rte_sched_subport_params *subpo
> }
> }
>
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tb
> rate");
> - if (entry)
> - subport_params[i].tb_rate =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tb
> size");
> - if (entry)
> - subport_params[i].tb_size =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc
> period");
> - if (entry)
> - subport_params[i].tc_period =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 0
> rate");
> - if (entry)
> - subport_params[i].tc_rate[0] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 1
> rate");
> - if (entry)
> - subport_params[i].tc_rate[1] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 2
> rate");
> - if (entry)
> - subport_params[i].tc_rate[2] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 3
> rate");
> - if (entry)
> - subport_params[i].tc_rate[3] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 4
> rate");
> - if (entry)
> - subport_params[i].tc_rate[4] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 5
> rate");
> - if (entry)
> - subport_params[i].tc_rate[5] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 6
> rate");
> - if (entry)
> - subport_params[i].tc_rate[6] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 7
> rate");
> - if (entry)
> - subport_params[i].tc_rate[7] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 8
> rate");
> - if (entry)
> - subport_params[i].tc_rate[8] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 9
> rate");
> - if (entry)
> - subport_params[i].tc_rate[9] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 10
> rate");
> - if (entry)
> - subport_params[i].tc_rate[10] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 11
> rate");
> - if (entry)
> - subport_params[i].tc_rate[11] =
> (uint64_t)atoi(entry);
> -
> - entry = rte_cfgfile_get_entry(cfg, sec_name, "tc 12
> rate");
> - if (entry)
> - subport_params[i].tc_rate[12] =
> (uint64_t)atoi(entry);
> -
> int n_entries = rte_cfgfile_section_num_entries(cfg,
> sec_name);
> struct rte_cfgfile_entry entries[n_entries];
>
> diff --git a/examples/qos_sched/cfg_file.h b/examples/qos_sched/cfg_file.h
> index 2eccf1c..0dc458a 100644
> --- a/examples/qos_sched/cfg_file.h
> +++ b/examples/qos_sched/cfg_file.h
> @@ -14,4 +14,8 @@ int cfg_load_pipe(struct rte_cfgfile *cfg, struct
> rte_sched_pipe_params *pipe);
>
> int cfg_load_subport(struct rte_cfgfile *cfg, struct
> rte_sched_subport_params *subport);
>
> +int cfg_load_subport_profile(struct rte_cfgfile *cfg,
> + struct rte_sched_subport_profile_params
> + *subport_profile);
> +
> #endif
> diff --git a/examples/qos_sched/init.c b/examples/qos_sched/init.c index
> 9626c15..541adb7 100644
> --- a/examples/qos_sched/init.c
> +++ b/examples/qos_sched/init.c
> @@ -196,15 +196,20 @@ static struct rte_sched_pipe_params
> pipe_profiles[MAX_SCHED_PIPE_PROFILES] = {
> },
> };
>
> -struct rte_sched_subport_params
> subport_params[MAX_SCHED_SUBPORTS] = {
> +static struct rte_sched_subport_profile_params
> + subport_profile[MAX_SCHED_SUBPORT_PROFILES] = {
> {
> .tb_rate = 1250000000,
> .tb_size = 1000000,
> -
> .tc_rate = {1250000000, 1250000000, 1250000000,
> 1250000000,
> 1250000000, 1250000000, 1250000000, 1250000000,
> 1250000000,
> 1250000000, 1250000000, 1250000000, 1250000000},
> .tc_period = 10,
> + },
> +};
> +
> +struct rte_sched_subport_params
> subport_params[MAX_SCHED_SUBPORTS] = {
> + {
> .n_pipes_per_subport_enabled = 4096,
> .qsize = {64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64},
> .pipe_profiles = pipe_profiles,
> @@ -289,6 +294,9 @@ struct rte_sched_port_params port_params = {
> .mtu = 6 + 6 + 4 + 4 + 2 + 1500,
> .frame_overhead = RTE_SCHED_FRAME_OVERHEAD_DEFAULT,
> .n_subports_per_port = 1,
> + .n_subport_profiles = 1,
> + .subport_profiles = subport_profile,
> + .n_max_subport_profiles = MAX_SCHED_SUBPORT_PROFILES,
> .n_pipes_per_subport = MAX_SCHED_PIPES, };
>
> @@ -320,8 +328,15 @@ app_init_sched_port(uint32_t portid, uint32_t
> socketid)
> for (subport = 0; subport < port_params.n_subports_per_port;
> subport ++) {
> err = rte_sched_subport_config(port, subport,
> &subport_params[subport]);
> if (err) {
> - rte_exit(EXIT_FAILURE, "Unable to config sched
> subport %u, err=%d\n",
> - subport, err);
> + rte_exit(EXIT_FAILURE, "Unable to config schedi "
> + "subport %u, err=%d\n", subport, err);
> + }
> +
> + err = rte_sched_subport_profile_config(port, subport, 0);
> + if (err) {
> + rte_exit(EXIT_FAILURE, "failed to configure "
> + "profile err=%d\n", err);
> +
> }
>
> uint32_t n_pipes_per_subport =
> @@ -354,6 +369,7 @@ app_load_cfg_profile(const char *profile)
>
> cfg_load_port(file, &port_params);
> cfg_load_subport(file, subport_params);
> + cfg_load_subport_profile(file, subport_profile);
> cfg_load_pipe(file, pipe_profiles);
>
> rte_cfgfile_close(file);
> diff --git a/examples/qos_sched/main.h b/examples/qos_sched/main.h
> index 23bc418..0d6815a 100644
> --- a/examples/qos_sched/main.h
> +++ b/examples/qos_sched/main.h
> @@ -51,6 +51,7 @@ extern "C" {
> #define MAX_SCHED_SUBPORTS 8
> #define MAX_SCHED_PIPES 4096
> #define MAX_SCHED_PIPE_PROFILES 256
> +#define MAX_SCHED_SUBPORT_PROFILES 8
>
> #ifndef APP_COLLECT_STAT
> #define APP_COLLECT_STAT 1
> diff --git a/examples/qos_sched/profile.cfg
> b/examples/qos_sched/profile.cfg index 61b8b70..4486d27 100644
> --- a/examples/qos_sched/profile.cfg
> +++ b/examples/qos_sched/profile.cfg
> @@ -26,6 +26,9 @@ number of subports per port = 1 number of pipes per
> subport = 4096 queue sizes = 64 64 64 64 64 64 64 64 64 64 64 64 64
>
> +subport 0-8 = 0 ; These subports are configured with subport profile
> 0
> +
> +[subport profile 0]
> tb rate = 1250000000 ; Bytes per second
> tb size = 1000000 ; Bytes
>
> --
> 2.7.4
+ Cristian
next prev parent reply other threads:[~2020-07-16 8:14 UTC|newest]
Thread overview: 107+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-07-15 18:27 [dpdk-dev] [RFC PATCH 0/2] Enable dyynamic configuration of subport bandwidth profile Savinay Dharmappa
2020-07-15 18:27 ` [dpdk-dev] [RFC PATCH 1/2] sched: add dynamic config " Savinay Dharmappa
2020-07-16 8:14 ` Singh, Jasvinder
2020-07-20 11:20 ` Dumitrescu, Cristian
2020-07-20 11:21 ` Dumitrescu, Cristian
2020-09-02 8:56 ` [dpdk-dev] [PATCH v1 1/4] " Savinay Dharmappa
2020-09-02 8:56 ` [dpdk-dev] [PATCH v1 2/4] " Savinay Dharmappa
2020-09-02 8:56 ` [dpdk-dev] [PATCH v1 3/4] " Savinay Dharmappa
2020-09-02 8:56 ` [dpdk-dev] [PATCH v1 4/4] " Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 00/10] Enable dynamic config of subport bandwidth Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 01/10] sched: add support profile data structure Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 02/10] sched: add subport profile table Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 03/10] sched: add subport profile add and config api Savinay Dharmappa
2020-09-14 14:05 ` Singh, Jasvinder
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 04/10] sched: update the grinder credit update function Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 05/10] sched: update the pipe config api implementation Savinay Dharmappa
2020-09-14 14:26 ` Singh, Jasvinder
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 06/10] example/qos_sched: add dynamic config of subport Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 07/10] example/ip_pipeline: " Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 08/10] drivers/softnic: " Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 09/10] app/test_sched: " Savinay Dharmappa
2020-09-10 18:48 ` [dpdk-dev] [PATCH v2 10/10] sched: remove the redundant code Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 0/9] Enable dynamic config of subport bandwidth Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 1/9] sched: add support profile data structure Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 2/9] sched: add subport profile table Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 3/9] sched: add subport profile add and config api Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 4/9] sched: update grinder credit and pipe config function Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 5/9] example/qos_sched: add dynamic config of subport Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 6/9] example/ip_pipeline: " Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 7/9] drivers/softnic: " Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 8/9] app/test_sched: " Savinay Dharmappa
2020-09-16 16:43 ` [dpdk-dev] [PATCH v3 9/9] sched: remove the redundant code Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 0/9] Enable dynamic config of subport bandwidth Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 1/9] sched: add support profile data structure Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 2/9] sched: add subport profile table Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 3/9] sched: add subport profile add and config api Savinay Dharmappa
2020-09-29 21:19 ` Dumitrescu, Cristian
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 4/9] sched: update grinder credit and pipe config function Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 5/9] example/qos_sched: add dynamic config of subport Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 6/9] example/ip_pipeline: " Savinay Dharmappa
2020-09-29 21:23 ` Dumitrescu, Cristian
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 7/9] drivers/softnic: " Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 8/9] app/test_sched: " Savinay Dharmappa
2020-09-17 8:42 ` [dpdk-dev] [PATCH v4 9/9] sched: remove the redundant code Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 0/9] Enable dynamic config of subport bandwidth Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 1/9] sched: add support profile table Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 2/9] sched: add subport profile add api Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 3/9] sched : add dynamic config of subport bandwidth Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 4/9] sched: update grinder credit and pipe config function Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 5/9] example/qos_sched: add dynamic config of subport Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 6/9] example/ip_pipeline: " Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 7/9] drivers/softnic: " Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 8/9] app/test_sched: " Savinay Dharmappa
2020-09-30 19:24 ` [dpdk-dev] [PATCH v5 9/9] sched : remove redundant code Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 0/8] Enable dynamic config of subport bandwidth Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 1/8] sched: add support profile table Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 2/8] sched: introduce subport profile add function Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 3/8] sched: update subport rate dynamically Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 4/8] example/qos_sched: " Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 5/8] example/ip_pipeline: " Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 6/8] drivers/softnic: " Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 7/8] app/test_sched: " Savinay Dharmappa
2020-10-06 15:27 ` [dpdk-dev] [PATCH v6 8/8] sched: remove redundant code Savinay Dharmappa
2020-10-06 15:52 ` [dpdk-dev] [PATCH v6 0/8] Enable dynamic config of subport bandwidth Dumitrescu, Cristian
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 " Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 1/8] sched: add support profile table Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 2/8] sched: introduce subport profile add function Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 3/8] sched: update subport rate dynamically Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 4/8] example/qos_sched: " Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 5/8] example/ip_pipeline: " Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 6/8] drivers/softnic: " Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 7/8] app/test_sched: " Savinay Dharmappa
2020-10-06 18:02 ` [dpdk-dev] [PATCH v7 8/8] sched: remove redundant code Savinay Dharmappa
2020-10-06 19:05 ` [dpdk-dev] [PATCH v7 0/8] Enable dynamic config of subport bandwidth Dumitrescu, Cristian
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 " Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 1/8] sched: add support profile table Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 2/8] sched: introduce subport profile add function Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 3/8] sched: update subport rate dynamically Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 4/8] example/qos_sched: " Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 5/8] example/ip_pipeline: " Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 6/8] drivers/softnic: " Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 7/8] app/test_sched: " Savinay Dharmappa
2020-10-07 14:09 ` [dpdk-dev] [PATCH v8 8/8] sched: remove redundant code Savinay Dharmappa
2020-10-09 8:28 ` Thomas Monjalon
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 0/8] Enable dynamic config of subport bandwidth Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 1/8] sched: add support profile table Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 2/8] sched: introduce subport profile add function Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 3/8] sched: update subport rate dynamically Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 4/8] example/qos_sched: " Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 5/8] example/ip_pipeline: " Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 6/8] drivers/softnic: " Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 7/8] app/test_sched: " Savinay Dharmappa
2020-10-09 12:39 ` [dpdk-dev] [PATCH v9 8/8] sched: remove redundant code Savinay Dharmappa
2020-10-11 20:11 ` [dpdk-dev] [PATCH v9 0/8] Enable dynamic config of subport bandwidth Thomas Monjalon
2020-10-12 5:24 ` Dharmappa, Savinay
2020-10-12 23:08 ` Dharmappa, Savinay
2020-10-13 13:56 ` Dharmappa, Savinay
2020-10-13 14:06 ` Thomas Monjalon
2020-10-15 0:17 ` Thomas Monjalon
2020-07-15 18:27 ` [dpdk-dev] [RFC PATCH 2/2] example/qos_sched: subport bandwidth profile config Savinay Dharmappa
2020-07-16 8:14 ` Singh, Jasvinder [this message]
2020-09-02 9:07 ` [dpdk-dev] [PATCH v1 1/4] example/qos_sched: subport bandwidth dynmaic conf Savinay Dharmappa
2020-09-02 9:07 ` [dpdk-dev] [PATCH v1 2/4] example/ip_pipeline: " Savinay Dharmappa
2020-09-02 9:07 ` [dpdk-dev] [PATCH v1 3/4] drivers/softnic: subport bandwidth profile config Savinay Dharmappa
2020-09-02 9:07 ` [dpdk-dev] [PATCH v1 4/4] app/test_sched: " Savinay Dharmappa
2020-09-02 10:46 ` [dpdk-dev] [PATCH v1 1/4] example/qos_sched: subport bandwidth dynmaic conf Dharmappa, Savinay
2020-07-16 8:14 ` [dpdk-dev] [RFC PATCH 0/2] Enable dyynamic configuration of subport bandwidth profile Singh, Jasvinder
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CY4PR11MB0072F66E264EF7E22ABBD5EAE07F0@CY4PR11MB0072.namprd11.prod.outlook.com \
--to=jasvinder.singh@intel.com \
--cc=cristian.dumitrescu@intel.com \
--cc=dev@dpdk.org \
--cc=savinay.dharmappa@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).