[dpdk-dev] [PATCH v7 19/27] app/testpmd: use unicast promiscuous mode on i40e
Lu, Wenzhuo
wenzhuo.lu at intel.com
Fri Jan 6 08:25:42 CET 2017
Hi Jingjing,
> -----Original Message-----
> From: Wu, Jingjing
> Sent: Friday, January 6, 2017 9:22 AM
> To: Lu, Wenzhuo; dev at dpdk.org
> Cc: Lu, Wenzhuo
> Subject: RE: [dpdk-dev] [PATCH v7 19/27] app/testpmd: use unicast
> promiscuous mode on i40e
>
>
>
> > -----Original Message-----
> > From: dev [mailto:dev-bounces at dpdk.org] On Behalf Of Wenzhuo Lu
> > Sent: Tuesday, January 3, 2017 2:55 PM
> > To: dev at dpdk.org
> > Cc: Lu, Wenzhuo <wenzhuo.lu at intel.com>
> > Subject: [dpdk-dev] [PATCH v7 19/27] app/testpmd: use unicast
> > promiscuous mode on i40e
> >
> > Add testpmd CLI to set VF unicast promiscuous mode on i40e.
> >
> > Signed-off-by: Wenzhuo Lu <wenzhuo.lu at intel.com>
> > ---
> > app/test-pmd/cmdline.c | 93 +++++++++++++++++++++++++++++
> > doc/guides/testpmd_app_ug/testpmd_funcs.rst | 9 +++
> > 2 files changed, 102 insertions(+)
> >
> > diff --git a/app/test-pmd/cmdline.c b/app/test-pmd/cmdline.c index
> > 9a44b4f..affe9d1 100644
> > --- a/app/test-pmd/cmdline.c
> > +++ b/app/test-pmd/cmdline.c
> > @@ -400,6 +400,9 @@ static void cmd_help_long_parsed(void
> *parsed_result,
> > "set allmulti (port_id|all) (on|off)\n"
> > " Set the allmulti mode on port_id, or all.\n\n"
> >
> > + "set vf promisc (port_id) (vf_id) (on|off)\n"
> > + " Set unicast promiscuous mode for a VF from the
> > PF.\n\n"
> > +
> > "set flow_ctrl rx (on|off) tx (on|off) (high_water)"
> > " (low_water) (pause_time) (send_xon)
> mac_ctrl_frame_fwd"
> > " (on|off) autoneg (on|off) (port_id)\n"
> > @@ -11559,6 +11562,95 @@ struct cmd_set_vf_mac_addr_result {
> > },
> > };
> >
> > +/* VF unicast promiscuous mode configuration */
> > +
> > +/* Common result structure for VF unicast promiscuous mode */ struct
> > +cmd_vf_promisc_result {
> > + cmdline_fixed_string_t set;
> > + cmdline_fixed_string_t vf;
> > + cmdline_fixed_string_t promisc;
> > + uint8_t port_id;
> > + uint32_t vf_id;
> > + cmdline_fixed_string_t on_off;
> > +};
> > +
> > +/* Common CLI fields for VF unicast promiscuous mode enable disable
> > +*/ cmdline_parse_token_string_t cmd_vf_promisc_set =
> > + TOKEN_STRING_INITIALIZER
> > + (struct cmd_vf_promisc_result,
> > + set, "set");
> > +cmdline_parse_token_string_t cmd_vf_promisc_vf =
> > + TOKEN_STRING_INITIALIZER
> > + (struct cmd_vf_promisc_result,
> > + vf, "vf");
> > +cmdline_parse_token_string_t cmd_vf_promisc_promisc =
> > + TOKEN_STRING_INITIALIZER
> > + (struct cmd_vf_promisc_result,
> > + promisc, "promisc");
> > +cmdline_parse_token_num_t cmd_vf_promisc_port_id =
> > + TOKEN_NUM_INITIALIZER
> > + (struct cmd_vf_promisc_result,
> > + port_id, UINT8);
> > +cmdline_parse_token_num_t cmd_vf_promisc_vf_id =
> > + TOKEN_NUM_INITIALIZER
> > + (struct cmd_vf_promisc_result,
> > + vf_id, UINT32);
> > +cmdline_parse_token_string_t cmd_vf_promisc_on_off =
> > + TOKEN_STRING_INITIALIZER
> > + (struct cmd_vf_promisc_result,
> > + on_off, "on#off");
> > +
> > +static void
> > +cmd_set_vf_promisc_parsed(
> > + void *parsed_result,
> > + __attribute__((unused)) struct cmdline *cl,
> > + __attribute__((unused)) void *data)
> > +{
> > + struct cmd_vf_promisc_result *res = parsed_result;
> > + int ret = -ENOTSUP;
> > +
> > + __rte_unused int is_on = (strcmp(res->on_off, "on") == 0) ? 1 : 0;
> > +
> > + if (port_id_is_invalid(res->port_id, ENABLED_WARN))
> > + return;
> > +
> > +#ifdef RTE_LIBRTE_I40E_PMD
> > + ret = rte_pmd_i40e_set_vf_unicast_promisc(res->port_id,
> > + res->vf_id, is_on);
> > +#endif
> > +
>
> It's better to wrap the command by +#ifdef RTE_LIBRTE_I40E_PMD #endif Or
> at least, need to check if the port is handled i40e pmd.
Yes, I'll add the check.
More information about the dev
mailing list