> From: dev [mailto:dev-boun...@dpdk.org] On Behalf Of Ferruh Yigit
> Sent: Thursday, January 28, 2021 7:28 PM
> 
> On 1/25/2021 1:20 AM, Li Zhang wrote:
> > Currently the flow Meter algorithms in rte_flow
> > only supports bytes per second(BPS).
> > Such as Single Rate Three Color Marker (srTCM rfc2697)
> > This RFC adds the packet per second definition in
> > Meter algorithms structure,
> > to support the rte_mtr APIs with type srTCM pps mode.
> > The below structure will be extended:
> > rte_mtr_algorithm
> > rte_mtr_meter_profile
> > Signed-off-by: Li Zhang <l...@nvidia.com>
> 
> cc'ed Cristian for review/comment.
> 
> > ---
> >   lib/librte_ethdev/rte_mtr.h | 28 ++++++++++++++++++++++++++++
> >   1 file changed, 28 insertions(+)
> >
> > diff --git a/lib/librte_ethdev/rte_mtr.h
> b/lib/librte_ethdev/rte_mtr.h
> > index 916a09c5c3..3e88904faf 100644
> > --- a/lib/librte_ethdev/rte_mtr.h
> > +++ b/lib/librte_ethdev/rte_mtr.h
> > @@ -119,6 +119,9 @@ enum rte_mtr_algorithm {
> >
> >     /** Two Rate Three Color Marker (trTCM) - IETF RFC 4115. */
> >     RTE_MTR_TRTCM_RFC4115,
> > +
> > +   /** Single Rate Three Color Marker (srTCM) in Packet per second
> mode */
> > +   RTE_MTR_SRTCM_PPS,
> >   };
> >
> >   /**
> > @@ -171,6 +174,18 @@ struct rte_mtr_meter_profile {
> >                     /** Excess Burst Size (EBS) (bytes). */
> >                     uint64_t ebs;
> >             } trtcm_rfc4115;
> > +
> > +           /** Items only valid when *alg* is set to srTCM - PPS. */
> > +           struct {
> > +                   /** Committed Information Rate (CIR)(packets/second).
> */
> > +                   uint64_t cir;
> > +
> > +                   /** Committed Burst Size (CBS) (bytes). */
> > +                   uint64_t cbs;
> > +
> > +                   /** Excess Burst Size (EBS) (bytes). */
> > +                   uint64_t ebs;
> > +           } srtcm_pps;

In PPS mode, the burst sizes (ebs, ebs) must be packets, not bytes.

> >     };
> >   };
> >
> > @@ -317,6 +332,13 @@ struct rte_mtr_capabilities {
> >      */
> >     uint32_t meter_trtcm_rfc4115_n_max;
> >
> > +   /** Maximum number of MTR objects that can have their meter
> configured
> > +    * to run the srTCM packet per second algorithm. The value of 0
> > +    * indicates this metering algorithm is not supported.
> > +    * The maximum value is *n_max*.
> > +    */
> > +   uint32_t meter_srtcm_pps_n_max;
> > +
> >     /** Maximum traffic rate that can be metered by a single MTR
> object. For
> >      * srTCM RFC 2697, this is the maximum CIR rate. For trTCM RFC
> 2698,
> >      * this is the maximum PIR rate. For trTCM RFC 4115, this is the
> maximum
> > @@ -342,6 +364,12 @@ struct rte_mtr_capabilities {
> >      */
> >     int color_aware_trtcm_rfc4115_supported;
> >
> > +   /**
> > +    * When non-zero, it indicates that color aware mode is supported
> for
> > +    * the srTCM packet per second  metering algorithm.

No need for two spaces between the words second and metering.

> > +    */
> > +   int color_aware_srtcm_pps_supported;
> > +
> >     /** When non-zero, it indicates that the policer packet recolor
> actions
> >      * are supported.
> >      * @see enum rte_mtr_policer_action
> >
> 

Reply via email to