On Mon, Nov 11, 2019 at 10:26 AM Pavan Nikhilesh Bhagavatula
<pbhagavat...@marvell.com> wrote:
>
> >On Fri, Nov 8, 2019 at 7:24 PM Ananyev, Konstantin
> ><konstantin.anan...@intel.com> wrote:
> >>
> >>
> >>
> >> > -----Original Message-----
> >> > From: dev <dev-boun...@dpdk.org> On Behalf Of Ferruh Yigit
> >> > Sent: Thursday, November 7, 2019 7:41 PM
> >> > To: Jerin Jacob <jerinjac...@gmail.com>
> >> > Cc: Pavan Nikhilesh <pbhagavat...@marvell.com>; Andrew
> >Rybchenko <arybche...@solarflare.com>; jer...@marvell.com;
> >> > tho...@monjalon.net; Lu, Wenzhuo <wenzhuo...@intel.com>;
> >Wu, Jingjing <jingjing...@intel.com>; Iremonger, Bernard
> >> > <bernard.iremon...@intel.com>; Mcnamara, John
> ><john.mcnam...@intel.com>; Kovacevic, Marko
> ><marko.kovace...@intel.com>;
> >> > dev@dpdk.org
> >> > Subject: Re: [dpdk-dev] [PATCH v16 8/8] app/testpmd: add
> >command to set supported ptype mask
> >> >
> >> > On 11/7/2019 6:55 PM, Jerin Jacob wrote:
> >> > >
> >> > >
> >> > > On Fri, 8 Nov, 2019, 12:10 am Ferruh Yigit, <ferruh.yi...@intel.com
> >> > > <mailto:ferruh.yi...@intel.com>> wrote:
> >> > >
> >> > >     On 11/6/2019 7:18 PM, pbhagavat...@marvell.com
> >> > >     <mailto:pbhagavat...@marvell.com> wrote:
> >> > >     > From: Pavan Nikhilesh <pbhagavat...@marvell.com
> >> > >     <mailto:pbhagavat...@marvell.com>>
> >> > >     >
> >> > >     > Add command to set supported ptype mask.
> >> > >     > Usage:
> >> > >     >       set port <port_id> ptype_mask >  /* ***************
> >> > >     >
> >> > >     >  /* list of instructions */
> >> > >     > @@ -19155,6 +19237,7 @@ cmdline_parse_ctx_t main_ctx[] =
> >{
> >> > >     >       (cmdline_parse_inst_t *)&cmd_show_vf_stats,
> >> > >     >       (cmdline_parse_inst_t *)&cmd_clear_vf_stats,
> >> > >     >       (cmdline_parse_inst_t
> >*)&cmd_show_port_supported_ptypes,
> >> > >     > +     (cmdline_parse_inst_t *)&cmd_set_port_ptypes,
> >> > >     >       (cmdline_parse_inst_t *)&cmd_ptype_mapping_get,
> >> > >     >       (cmdline_parse_inst_t *)&cmd_ptype_mapping_replace,
> >> > >     >       (cmdline_parse_inst_t *)&cmd_ptype_mapping_reset,
> >> > >     > diff --git a/app/test-pmd/testpmd.c b/app/test-
> >pmd/testpmd.c
> >> > >     > index 5ba974162..812aebf35 100644
> >> > >     > --- a/app/test-pmd/testpmd.c
> >> > >     > +++ b/app/test-pmd/testpmd.c
> >> > >     > @@ -2024,6 +2024,7 @@ start_port(portid_t pid)
> >> > >     >       queueid_t qi;
> >> > >     >       struct rte_port *port;
> >> > >     >       struct rte_ether_addr mac_addr;
> >> > >     > +     static uint8_t clr_ptypes = 1;
> >> > >     >
> >> > >     >       if (port_id_is_invalid(pid, ENABLED_WARN))
> >> > >     >               return 0;
> >> > >     > @@ -2153,6 +2154,10 @@ start_port(portid_t pid)
> >> > >     >                       }
> >> > >     >               }
> >> > >     >               configure_rxtx_dump_callbacks(verbose_level);
> >> > >     > +             if (clr_ptypes) {
> >> > >     > +                     clr_ptypes = 0;
> >> > >     > +                     rte_eth_dev_set_ptypes(pi,
> >RTE_PTYPE_UNKNOWN, NULL, 0);
> >> > >     > +             }
> >> > >
> >> > >     I am not sure about this command, we have now capability to
> >set/disable ptypes
> >> > >     on demand, why disabling them by default?
> >> > >
> >> > >
> >> > > As forward engines are not using the ptype offload. If a specific
> >forwa
> >> > > need the offload, it can be enabled.
> >>
> >> Well, at least now user can see ptype in pkt dump with 'set verbose >
> >0'
> >> It's definitely looks loke a a behavior change.
> >> Wonder why it can't be done visa-versa?
> >> Keep current behavior as default one (all ptypes are un-masked) and
> >> have special command to disable/enable ptypes.
> >> as I understand such command was added by these series. correct?
> >
> >IMO, we are following the principle that by default all offloads are
> >disabled and enable it
> >based on the need to have optimal performance across the DPDK. This
> >change will be
> >on the same theme.
> >
> >Regarding the verbose > 0 cases, I think, we can call
> >rte_eth_dev_set_ptypes() to all PTYPES on
> >the setting verbose callback.
>
> Agree verbose > 0 case we can do set_ptypes with
> RTE_PTYPE_ALL_MASK. But what if the user wants to verify
> rte_eth_dev_set_ptypes() call itself in verbose mode?.
> Example:
>
>         set port 0 ptype_mask RTE_PTYPE_L3_MASK
>         set verbose 1
>
> In this case user expects to see only L3 mask set. Wouldn’t it be confusing if
> we set RTE_PTYPE_ALL_MASK under the hood when verbose level is increased?

I thought of adding RTE_PTYPE_ALL_MASK in the callback to maintain the
existing behavior
if there is any concern in that area.

Either way is fine with me. (implicit RTE_PTYPE_ALL_MASK  in a
callback or explicit mask set in command line)

Reply via email to