[v1 0/4] Add support for modifying ECN in IPv4/IPv6 header

2022-04-02 Thread Sean Zhang
This patch set adds support for modifying ECN fields in IPv4/IPv6 header, and also adds support for modify_filed action in meter. Jiawei Wang (1): ethdev: add IPv4/IPv6 ECN header rewrite action Sean Zhang (3): common/mlx5: add modify ECN capability check net/mlx5: add support to modify ECN

[v1 2/4] common/mlx5: add modify ECN capability check

2022-04-02 Thread Sean Zhang
Flag outer_ip_ecn in header modify capabilities properties layout is added in order to check if the firmware supports modification of ecn field. Signed-off-by: Sean Zhang --- drivers/common/mlx5/mlx5_devx_cmds.c | 3 ++ drivers/common/mlx5/mlx5_devx_cmds.h | 1 + drivers/common/mlx5/mlx5_prm.h

[v1 3/4] net/mlx5: add support to modify ECN field

2022-04-02 Thread Sean Zhang
This patch is to support modify ECN field in IPv4/IPv6 header. Signed-off-by: Sean Zhang --- drivers/net/mlx5/mlx5_flow_dv.c | 20 1 file changed, 20 insertions(+) diff --git a/drivers/net/mlx5/mlx5_flow_dv.c b/drivers/net/mlx5/mlx5_flow_dv.c index 1e9bd63635..e416eb5701 10

[v1 4/4] net/mlx5: add modify field support in meter

2022-04-02 Thread Sean Zhang
This patch introduces MODIFY_FIELD action support in meter. User can create meter policy with MODIFY_FIELD action in green/yellow action. For example: testpmd> add port meter policy 0 21 g_actions modify_field op set dst_type ipv4_ecn src_type value src_value 3 width 2 / ... Signed-off-b

[v1 1/4] ethdev: add IPv4/IPv6 ECN header rewrite action

2022-04-02 Thread Sean Zhang
From: Jiawei Wang This patch introduces the IPv4/IPv6 ECN modify field support, and adds the testpmd CLI commands support. Usage: modify_field op set dst_type ipv4_ecn src_type ... For example: flow create 0 ingress group 1 pattern eth / ipv4 / end actions modify_field op set

Re: [PATCH v2] ci: add Fedora 35 container in GHA

2022-04-02 Thread David Marchand
On Fri, Apr 1, 2022 at 8:03 PM David Marchand wrote: > > Build DPDK with Fedora 35 containers. > > GHA container support does not allow caching images and docker hub > seems to limit image pulls. > On the other hand, the Fedora project hub does not seem to limit them, > so prefer this hub. > Never

[PATCH] net/iavf: fix iavf crashed on dev_stop when running in multi-process mode

2022-04-02 Thread Ke Zhang
In the multi process environment, the sub process operates on the shared memory and changes the function pointer of the main process, resulting in the failure to find the address of the function when main preocess releasing, resulting in crash. similar with commit<20b631efe785819eb77aabbf500b3352e

[PATCH] net/iavf: fix iavf crashed on dev_stop when running in multi-process mode

2022-04-02 Thread Ke Zhang
In the multi process environment, the sub process operates on the shared memory and changes the function pointer of the main process, resulting in the failure to find the address of the function when main process releasing, resulting in crash. similar with commit<20b631efe785819eb77aabbf500b3352e5

RE: [PATCH v2] eal: add seqlock

2022-04-02 Thread Morten Brørup
> From: Stephen Hemminger [mailto:step...@networkplumber.org] > Sent: Saturday, 2 April 2022 02.54 > > Semantics and naming should be the same as Linux kernel or you risk > having to reeducate too many people. Although I do see significant value in that point, I don't consider the Linux kernel A

RE: [PATCH v3] eal: add seqlock

2022-04-02 Thread Morten Brørup
> From: Honnappa Nagarahalli [mailto:honnappa.nagaraha...@arm.com] > Sent: Saturday, 2 April 2022 02.22 > > > From: Mattias Rönnblom > > Sent: Friday, April 1, 2022 10:08 AM > > > > diff --git a/lib/eal/include/rte_seqlock.h > > b/lib/eal/include/rte_seqlock.h new file > Other lock implementation

[v4 1/3] ethdev: introduce protocol type based header split

2022-04-02 Thread wenxuanx . wu
From: Xuan Ding Header split consists of splitting a received packet into two separate regions based on the packet content. The split happens after the packet header and before the packet payload. Splitting is usually between the packet header that can be posted to a dedicated buffer and the pack

[v4 0/3] ethdev: introduce protocol type based header split

2022-04-02 Thread wenxuanx . wu
From: Xuan Ding Header split consists of splitting a received packet into two separate regions based on the packet content. It is useful in some scenarios, such as GPU acceleration. The splitting will help to enable true zero copy and hence improve the performance significantly. This patchset ex

[v4 2/3] app/testpmd: add header split configuration

2022-04-02 Thread wenxuanx . wu
From: Xuan Ding This patch adds header split configuration in testpmd. The header split feature is off by default. To enable header split, you need: 1. Configure Rx queue with rx_offload header split on. 2. Set the protocol type of header split. Command for set header split protocol type: testpm

[v4 3/3] net/ice: support header split in Rx data path

2022-04-02 Thread wenxuanx . wu
From: Xuan Ding This patch adds support for header split in normal Rx data paths. When the Rx queue is configured with header split for specific protocol type, packets received will be directly splited into header and payload parts. And the two parts will be put into different mempools. Currentl

RE: [PATCH v2] examples/l3fwd: merge l3fwd-acl into l3fwd

2022-04-02 Thread Ananyev, Konstantin
Hi Sean, My comments inline. Thanks Konstantin > l3fwd-acl contains duplicate functions to l3fwd. > For this reason we merge l3fwd-acl code into l3fwd > with '--lookup acl' cmdline option to run ACL. > > Signed-off-by: Sean Morrissey > --- > V2: > * add doc changes > * minor code cleanup > --

Re: [PATCH v2] eal: add seqlock

2022-04-02 Thread Ola Liljedahl
On 4/2/22 12:25, Morten Brørup wrote: From: Stephen Hemminger [mailto:step...@networkplumber.org] Sent: Saturday, 2 April 2022 02.54 Semantics and naming should be the same as Linux kernel or you risk having to reeducate too many people. Although I do see significant value in that point, I do

Re: [PATCH v2] eal: add seqlock

2022-04-02 Thread Ola Liljedahl
On 4/2/22 02:50, Stephen Hemminger wrote: On Wed, 30 Mar 2022 16:26:02 +0200 Mattias Rönnblom wrote: + __atomic_store_n(&seqlock->sn, sn, __ATOMIC_RELAXED); + + /* __ATOMIC_RELEASE to prevent stores after (in program order) +* from happening before the sn store. +

Re: [PATCH v3] eal: add seqlock

2022-04-02 Thread Ola Liljedahl
On 4/1/22 17:07, Mattias Rönnblom wrote: + +/** + * End a read-side critical section. + * + * A call to this function marks the end of a read-side critical + * section, for @p seqlock. The application must supply the sequence + * number produced by the corresponding rte_seqlock_read_lock() (or, +

RE: [PATCH v3] eal: add seqlock

2022-04-02 Thread Honnappa Nagarahalli
> > +__rte_experimental > > +static inline bool > > +rte_seqlock_read_tryunlock(const rte_seqlock_t *seqlock, uint32_t > > +*begin_sn) { > > + uint32_t end_sn; > > + > > + /* make sure the data loads happens before the sn load */ > > + rte_atomic_thread_fence(__ATOMIC_ACQUIRE); > > + > > +

RE: [PATCH v2] eal: add seqlock

2022-04-02 Thread Honnappa Nagarahalli
> >> +static inline void > >> +rte_seqlock_write_end(rte_seqlock_t *seqlock) { > >> + uint32_t sn; > >> + > >> + sn = seqlock->sn + 1; > >> + > >> + /* synchronizes-with the load acquire in rte_seqlock_begin() > >> */ > >> + __atomic_store_n(&seqlock->sn, sn, __ATOMIC_RELEASE); > >> + > >> +

RE: [PATCH v3] eal: add seqlock

2022-04-02 Thread Honnappa Nagarahalli
> > > > +__rte_experimental > > > +static inline bool > > > +rte_seqlock_read_tryunlock(const rte_seqlock_t *seqlock, uint32_t > > > +*begin_sn) { > > Did anyone object to adding the __attribute__((warn_unused_result))? > > Otherwise, I think you should add it. +1

RE: [PATCH v3] eal: add seqlock

2022-04-02 Thread Morten Brørup
> From: Honnappa Nagarahalli [mailto:honnappa.nagaraha...@arm.com] > Sent: Saturday, 2 April 2022 21.31 > > > > > > +__rte_experimental > > > +static inline bool > > > +rte_seqlock_read_tryunlock(const rte_seqlock_t *seqlock, uint32_t > > > +*begin_sn) { > > > + uint32_t end_sn; > > > + > > > +

RE: [PATCH v3] eal: add seqlock

2022-04-02 Thread Honnappa Nagarahalli
> > > > > > +__rte_experimental > > > > +static inline bool > > > > +rte_seqlock_read_tryunlock(const rte_seqlock_t *seqlock, uint32_t > > > > +*begin_sn) { > > > > + uint32_t end_sn; > > > > + > > > > + /* make sure the data loads happens before the sn load */ > > > > + rte_atom

RE: [PATCH] net/iavf: fix iavf crashed on dev_stop when running in multi-process mode

2022-04-02 Thread Zhang, Qi Z
> -Original Message- > From: Ke Zhang > Sent: Saturday, April 2, 2022 5:51 PM > To: Li, Xiaoyun ; Wu, Jingjing ; > Xing, Beilei ; dev@dpdk.org > Cc: Zhang, Ke1X > Subject: [PATCH] net/iavf: fix iavf crashed on dev_stop when running in > multi-process mode > > In the multi process envi

Re: [PATCH v3] eal: add seqlock

2022-04-02 Thread Mattias Rönnblom
On 2022-04-02 02:21, Honnappa Nagarahalli wrote: Hi Mattias, Few comments inline. -Original Message- From: Mattias Rönnblom Sent: Friday, April 1, 2022 10:08 AM To: dev@dpdk.org Cc: tho...@monjalon.net; David Marchand ; onar.ol...@ericsson.com; Honnappa Nagarahalli ; nd ; konst

Re: [PATCH v2] eal: add seqlock

2022-04-02 Thread Mattias Rönnblom
On 2022-04-02 02:52, Stephen Hemminger wrote: On Thu, 31 Mar 2022 16:53:00 +0200 Ola Liljedahl wrote: From: Ola Liljedahl To: Mattias Rönnblom , "dev@dpdk.org" Cc: Thomas Monjalon , David Marchand , Onar Olsen , "honnappa.nagaraha...@arm.com" , "n...@arm.com" , "konstantin.anan...@intel

Re: [PATCH v3] eal: add seqlock

2022-04-02 Thread Mattias Rönnblom
I missed some of your comments. On 2022-04-02 02:21, Honnappa Nagarahalli wrote: + * Example usage: + * @code{.c} + * #define MAX_Y_LEN (16) + * // Application-defined example data structure, protected by a seqlock. + * struct config { + * rte_seqlock_t lock; + * int param_x;

Re: [PATCH v3] eal: add seqlock

2022-04-02 Thread Mattias Rönnblom
On 2022-04-02 20:15, Ola Liljedahl wrote: On 4/1/22 17:07, Mattias Rönnblom wrote: + +/** + * End a read-side critical section. + * + * A call to this function marks the end of a read-side critical + * section, for @p seqlock. The application must supply the sequence + * number produced by the c