Re: [dpdk-dev] [dpdk-stable] [PATCH 1/4] common/mlx5: share UAR allocation routine

2020-11-14 Thread Thomas Monjalon
10/11/2020 17:04, Viacheslav Ovsiienko:
> This patch introduces the routine to allocate the UAR (User
> Access Region) with various memory mapping types. The origin
> patch being fixed provided the UAR allocation workaround
> for the mlx5 net PMD only. As it was found the other mlx5
> based drivers - vdpa and regex are affected by the issue
> as well and must be fixed.
> 
> Fixes: a0bfe9d56f74 ("net/mlx5: fix UAR memory mapping type")
> Cc: sta...@dpdk.org
> 
> Signed-off-by: Viacheslav Ovsiienko 
> Acked-by: Matan Azrad 

Series applied, thanks





Re: [dpdk-dev] [PATCH v2] gro: fix an error when packet is IPv6

2020-11-14 Thread Thomas Monjalon
> > For VxLAN packets,  GRO will mistakenly reassemble them
> > if inner L3 is IPv6, inner L4 is TCP or UDP, and outer L3
> > is IPv4 because the value of IS_IPV4_VXLAN_TCP4/UDP4_PKT
> > is true for them.
> > 
> > This fix makes sure IS_IPV4_TCP_PKT, IS_IPV4_UDP_PKT,
> > IS_IPV4_VXLAN_TCP4_PKT and IS_IPV4_VXLAN_UDP4_PKT can make
> > decision precisely.
> > 
> > Fixes: e2d811063673 ("gro: support VXLAN UDP/IPv4")
> > Fixes: 1ca5e6740852 ("gro: support UDP/IPv4")
> > Fixes: 9e0b9d2ec0f4 ("gro: support VxLAN GRO")
> > Fixes: 0d2cbe59b719 ("lib/gro: support TCP/IPv4")
> > Signed-off-by: Yi Yang 
> Acked-by: Jiayu Hu 

Added missing Cc: sta...@dpdk.org

Tried to be more precise in the title:
"gro: fix packet type detection with IPv6 tunnel"

Applied, thanks




Re: [dpdk-dev] [dpdk-stable] [PATCH] config: enable packet prefetching with Meson

2020-11-14 Thread Thomas Monjalon
13/11/2020 16:05, Bruce Richardson:
> On Fri, Nov 13, 2020 at 03:52:12PM +0100, Maxime Coquelin wrote:
> > With Make build system, RTE_PMD_PACKET_PREFETCH was enabled
> > by default. It got lost when transitioning to Meson build
> > system.
> > 
> > In order to avoid performance changes, this patch enables
> > packet prefetching in rte_config.h.
> > 
> > Reported-by: Marvin Liu 
> > Suggested-by: David Marchand 
> > Signed-off-by: Maxime Coquelin 
> > ---
> > 
> > Hi Bruce,
> > 
> > We were not sure whether adding below Fixes tag so that it is
> > backported to LTSes. What do you think?
> > 
> > Fixes: 9314afb68a53 ("drivers: add infrastructure for meson build")
> > Cc: sta...@dpdk.org
> > 
> >  config/rte_config.h | 3 +++
> >  1 file changed, 3 insertions(+)
> > 
> I view it as a gap in the transition from make to meson, so +1 for
> adding these. Stable maintainers can then decide themselves on whether to
> accept the patch or not.

Applied with backport info, thanks.




Re: [dpdk-dev] [dpdk-stable] [PATCH] config: enable packet prefetching with Meson

2020-11-14 Thread Thomas Monjalon
14/11/2020 09:51, Thomas Monjalon:
> 13/11/2020 16:05, Bruce Richardson:
> > On Fri, Nov 13, 2020 at 03:52:12PM +0100, Maxime Coquelin wrote:
> > > With Make build system, RTE_PMD_PACKET_PREFETCH was enabled
> > > by default. It got lost when transitioning to Meson build
> > > system.
> > > 
> > > In order to avoid performance changes, this patch enables
> > > packet prefetching in rte_config.h.
> > > 
> > > Reported-by: Marvin Liu 
> > > Suggested-by: David Marchand 
> > > Signed-off-by: Maxime Coquelin 
[...]
> 
> Applied with backport info, thanks.

Note that it is added back for "compatibility",
but I am still in favour of dropping this config option,
replaced by arch decision if any:
http://inbox.dpdk.org/dev/3677226.MZCibFMyqQ@thomas/

The decision of such optimization should be done in DPDK project,
not in the hand of the packager.




[dpdk-dev] [PATCH v3 00/11] Examples compilation fixes

2020-11-14 Thread David Marchand
I tested external compilation for all possible examples (in my env).
The result is this series.

-- 
David Marchand

Changelog since v2:
- reworked patch 4 check on crypto driver availability,
- added patch 5 to fix misalignment with other examples makefiles,
- dropped last patch on checking all examples,
Changelog since v1:
- added patch 7 to fix performance-thread example,
- reworked last patch by introducing a new -Dexamples=buildall special
  value and removed exceptions for examples recently fixed in main thanks
  to Bruce,

David Marchand (11):
  examples/fips_validation: fix build with pkg-config
  examples/ipsec-gw: fix build with pkg-config
  examples/kni: fix build with pkg-config
  examples/l2fwd-crypto: fix build with pkg-config
  examples/l3fwd-graph: fix static build
  examples/l3fwd-graph: fix pkg-config usage
  examples/ntb: fix clean target
  examples/performance-thread: fix build with pkg-config
  examples/vhost_blk: fix build with pkg-config
  examples/rxtx_callbacks: fix build with pkg-config
  examples: restore trace point

 examples/cmdline/Makefile  | 2 ++
 examples/distributor/Makefile  | 2 ++
 examples/ethtool/ethtool-app/Makefile  | 2 ++
 examples/eventdev_pipeline/Makefile| 2 ++
 examples/fips_validation/Makefile  | 2 ++
 examples/flow_filtering/Makefile   | 2 ++
 examples/helloworld/Makefile   | 2 ++
 examples/ioat/Makefile | 2 ++
 examples/ip_reassembly/Makefile| 2 ++
 examples/ipsec-secgw/Makefile  | 1 +
 examples/ipv4_multicast/Makefile   | 2 ++
 examples/kni/Makefile  | 2 ++
 examples/l2fwd-cat/Makefile| 2 ++
 examples/l2fwd-crypto/Makefile | 6 ++
 examples/l2fwd-event/Makefile  | 2 ++
 examples/l2fwd-jobstats/Makefile   | 2 ++
 examples/l2fwd-keepalive/Makefile  | 2 ++
 examples/l2fwd-keepalive/ka-agent/Makefile | 2 ++
 examples/l3fwd-acl/Makefile| 2 ++
 examples/l3fwd-graph/Makefile  | 6 +++---
 examples/link_status_interrupt/Makefile| 2 ++
 examples/multi_process/client_server_mp/mp_client/Makefile | 2 ++
 examples/multi_process/client_server_mp/mp_server/Makefile | 2 ++
 examples/multi_process/hotplug_mp/Makefile | 2 ++
 examples/multi_process/simple_mp/Makefile  | 2 ++
 examples/multi_process/symmetric_mp/Makefile   | 2 ++
 examples/ntb/Makefile  | 2 +-
 examples/packet_ordering/Makefile  | 2 ++
 examples/performance-thread/l3fwd-thread/main.c| 5 +
 examples/ptpclient/Makefile| 2 ++
 examples/qos_sched/Makefile| 2 ++
 examples/rxtx_callbacks/Makefile   | 2 ++
 examples/server_node_efd/node/Makefile | 2 ++
 examples/server_node_efd/server/Makefile   | 2 ++
 examples/service_cores/Makefile| 2 ++
 examples/skeleton/Makefile | 2 ++
 examples/timer/Makefile| 2 ++
 examples/vhost_blk/vhost_blk.c | 6 ++
 examples/vm_power_manager/Makefile | 2 ++
 examples/vm_power_manager/guest_cli/Makefile   | 2 ++
 examples/vmdq/Makefile | 2 ++
 examples/vmdq_dcb/Makefile | 2 ++
 42 files changed, 94 insertions(+), 4 deletions(-)

-- 
2.23.0



[dpdk-dev] [PATCH v3 02/11] examples/ipsec-gw: fix build with pkg-config

2020-11-14 Thread David Marchand
flow.c: In function ‘parse_flow_tokens’:
flow.c:153:23: error: taking address of packed member of ‘struct
rte_ipv4_hdr’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  153 | if (ipv4_addr_cpy(&rule->ipv4.spec.hdr.src_addr,
  |   ^
flow.c:154:9: error: taking address of packed member of ‘struct
rte_ipv4_hdr’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  154 | &rule->ipv4.mask.hdr.src_addr,
  | ^
flow.c:170:23: error: taking address of packed member of ‘struct
rte_ipv4_hdr’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  170 | if (ipv4_addr_cpy(&rule->ipv4.spec.hdr.dst_addr,
  |   ^
flow.c:171:9: error: taking address of packed member of ‘struct
rte_ipv4_hdr’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  171 | &rule->ipv4.mask.hdr.dst_addr,
  | ^
cc1: all warnings being treated as errors

Meson build is fine since we waive those warnings.
Replicate it for make.

Fixes: 8e693616fcb2 ("examples/ipsec-secgw: enable flow based distribution")
Cc: sta...@dpdk.org

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
 examples/ipsec-secgw/Makefile | 1 +
 1 file changed, 1 insertion(+)

diff --git a/examples/ipsec-secgw/Makefile b/examples/ipsec-secgw/Makefile
index 5e6cb51eac..7670cc3684 100644
--- a/examples/ipsec-secgw/Makefile
+++ b/examples/ipsec-secgw/Makefile
@@ -42,6 +42,7 @@ LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
 CFLAGS += -DALLOW_EXPERIMENTAL_API
+CFLAGS += -Wno-address-of-packed-member
 
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
-- 
2.23.0



[dpdk-dev] [PATCH v3 01/11] examples/fips_validation: fix build with pkg-config

2020-11-14 Thread David Marchand
When this example started using rte_cryptodev_sym_session_pool_create,
the part for pkg-config builds was not updated.

Fixes: 261bbff75e34 ("examples: use separate crypto session mempools")
Cc: sta...@dpdk.org

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
 examples/fips_validation/Makefile | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/examples/fips_validation/Makefile 
b/examples/fips_validation/Makefile
index 7ba9bcfea6..8f82a4c6c5 100644
--- a/examples/fips_validation/Makefile
+++ b/examples/fips_validation/Makefile
@@ -36,6 +36,8 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
-- 
2.23.0



[dpdk-dev] [PATCH v3 03/11] examples/kni: fix build with pkg-config

2020-11-14 Thread David Marchand
rm -f build/kni build/kni-static build/kni-shared
test -d build && rmdir -p build || true
[...]
/usr/bin/ld: /tmp/cc72ssnK.o: undefined reference to symbol
'pthread_join@@GLIBC_2.2.5'

This example explicitly call pthread API and should be linked against
the pthread library.

Fixes: 724beb913b44 ("examples/kni: monitor and update link state continually")
Cc: sta...@dpdk.org

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
 examples/kni/Makefile | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/examples/kni/Makefile b/examples/kni/Makefile
index fa9fa85319..bbf3bcae12 100644
--- a/examples/kni/Makefile
+++ b/examples/kni/Makefile
@@ -27,6 +27,8 @@ CFLAGS += -DALLOW_EXPERIMENTAL_API
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+LDFLAGS += -pthread
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
-- 
2.23.0



[dpdk-dev] [PATCH v3 05/11] examples/l3fwd-graph: fix static build

2020-11-14 Thread David Marchand
This example missed the rework from commit 8549295db07b
("build/pkg-config: improve static linking flags").

Fixes: 08bd1a174461 ("examples/l3fwd-graph: add graph-based l3fwd skeleton")

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
 examples/l3fwd-graph/Makefile | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/examples/l3fwd-graph/Makefile b/examples/l3fwd-graph/Makefile
index 368ac21147..1e4f0600ae 100644
--- a/examples/l3fwd-graph/Makefile
+++ b/examples/l3fwd-graph/Makefile
@@ -24,7 +24,7 @@ PKGCONF=pkg-config --define-prefix
 PC_FILE := $(shell $(PKGCONF) --path libdpdk)
 CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk) -DALLOW_EXPERIMENTAL_API
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
-LDFLAGS_STATIC = -Wl,-Bstatic $(shell $(PKGCONF) --static --libs libdpdk)
+LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
-- 
2.23.0



[dpdk-dev] [PATCH v3 04/11] examples/l2fwd-crypto: fix build with pkg-config

2020-11-14 Thread David Marchand
Two issues fixed here.

First add the experimental flag.
Then fix a link issue with the crypto scheduler driver:
/usr/bin/ld: /tmp/cchr7aHA.o: in function `main':
main.c:(.text.startup+0x1673): undefined reference to
`rte_cryptodev_scheduler_workers_get'
collect2: error: ld returned 1 exit status

Fixes: e3bcb99a5e13 ("examples/l2fwd-crypto: limit number of sessions")
Fixes: 261bbff75e34 ("examples: use separate crypto session mempools")

Signed-off-by: David Marchand 
---
Changelog since v2:
- reworked config check,

---
 examples/l2fwd-crypto/Makefile | 6 ++
 1 file changed, 6 insertions(+)

diff --git a/examples/l2fwd-crypto/Makefile b/examples/l2fwd-crypto/Makefile
index 4953ee2b95..7731eccd03 100644
--- a/examples/l2fwd-crypto/Makefile
+++ b/examples/l2fwd-crypto/Makefile
@@ -26,6 +26,12 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+CONFIG_DEFINES = $(shell $(CC) $(CFLAGS) -dM -E - < /dev/null)
+ifneq ($(findstring RTE_CRYPTO_SCHEDULER,$(CONFIG_DEFINES)),)
+LDFLAGS_SHARED += -lrte_crypto_scheduler
+endif
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
-- 
2.23.0



[dpdk-dev] [PATCH v3 06/11] examples/l3fwd-graph: fix pkg-config usage

2020-11-14 Thread David Marchand
This example missed the fixes from commit 69b1bb49ed82
("examples: hide error for missing pkg-config path flag") and
commit 12a652a02b08 ("examples: fix build with old pkg-config").

Fixes: 08bd1a174461 ("examples/l3fwd-graph: add graph-based l3fwd skeleton")

Signed-off-by: David Marchand 
---
 examples/l3fwd-graph/Makefile | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/examples/l3fwd-graph/Makefile b/examples/l3fwd-graph/Makefile
index 1e4f0600ae..6e3d0bca06 100644
--- a/examples/l3fwd-graph/Makefile
+++ b/examples/l3fwd-graph/Makefile
@@ -19,9 +19,9 @@ shared: build/$(APP)-shared
 static: build/$(APP)-static
ln -sf $(APP)-static build/$(APP)
 
-PKGCONF=pkg-config --define-prefix
+PKGCONF ?= pkg-config
 
-PC_FILE := $(shell $(PKGCONF) --path libdpdk)
+PC_FILE := $(shell $(PKGCONF) --path libdpdk 2>/dev/null)
 CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk) -DALLOW_EXPERIMENTAL_API
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
-- 
2.23.0



[dpdk-dev] [PATCH v3 08/11] examples/performance-thread: fix build with pkg-config

2020-11-14 Thread David Marchand
main.c: In function ‘lthread_tx’:
main.c:2091:25: error: implicit declaration of function ‘sched_getcpu’;
 did you mean ‘sched_getparam’? [-Werror=implicit-function-declaration]
 2091 |  tx_conf->conf.cpu_id = sched_getcpu();
  | ^~~~
  | sched_getparam
cc1: all warnings being treated as errors

Explicitly pass _GNU_SOURCE and include missing header (rather than
rely on automagic inclusion from other system headers).

Fixes: d48415e1fee3 ("examples/performance-thread: add l3fwd-thread app")
Cc: sta...@dpdk.org

Signed-off-by: David Marchand 
---
 examples/performance-thread/l3fwd-thread/main.c | 5 +
 1 file changed, 5 insertions(+)

diff --git a/examples/performance-thread/l3fwd-thread/main.c 
b/examples/performance-thread/l3fwd-thread/main.c
index 7bf61db6be..4d82fb82ef 100644
--- a/examples/performance-thread/l3fwd-thread/main.c
+++ b/examples/performance-thread/l3fwd-thread/main.c
@@ -2,6 +2,10 @@
  * Copyright(c) 2010-2016 Intel Corporation
  */
 
+#ifndef _GNU_SOURCE
+#define _GNU_SOURCE
+#endif
+
 #include 
 #include 
 #include 
@@ -12,6 +16,7 @@
 #include 
 #include 
 #include 
+#include 
 
 #include 
 #include 
-- 
2.23.0



[dpdk-dev] [PATCH v3 07/11] examples/ntb: fix clean target

2020-11-14 Thread David Marchand
When introducing this example, the cleanup from commit 7e9562a107f1
("examples: fix make clean when using pkg-config") was missed.

Fixes: c5eebf85badc ("examples/ntb: add example for NTB")
Cc: sta...@dpdk.org

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
Acked-by: Xiaoyun Li 
---
 examples/ntb/Makefile | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/examples/ntb/Makefile b/examples/ntb/Makefile
index 4675570fd2..d35dabc471 100644
--- a/examples/ntb/Makefile
+++ b/examples/ntb/Makefile
@@ -42,4 +42,4 @@ build:
 .PHONY: clean
 clean:
rm -f build/$(APP) build/$(APP)-static build/$(APP)-shared
-   rmdir --ignore-fail-on-non-empty build
+   test -d build && rmdir -p build || true
-- 
2.23.0



[dpdk-dev] [PATCH v3 09/11] examples/vhost_blk: fix build with pkg-config

2020-11-14 Thread David Marchand
vhost_blk.c: In function ‘ctrlr_worker’:
vhost_blk.c:543:2: warning: implicit declaration of function ‘CPU_ZERO’
[-Wimplicit-function-declaration]
  543 |  CPU_ZERO(&cpuset);
  |  ^~~~
vhost_blk.c:544:2: warning: implicit declaration of function ‘CPU_SET’
[-Wimplicit-function-declaration]
  544 |  CPU_SET(0, &cpuset);
  |  ^~~
vhost_blk.c:545:2: warning: implicit declaration of function
‘pthread_setaffinity_np’ [-Wimplicit-function-declaration]
  545 |  pthread_setaffinity_np(thread, sizeof(cpu_set_t), &cpuset);
  |  ^~
/usr/bin/ld: /tmp/cczpiMWH.o: in function `ctrlr_worker':
vhost_blk.c:(.text+0x1076): undefined reference to `CPU_ZERO'
/usr/bin/ld: vhost_blk.c:(.text+0x1082): undefined reference to
`CPU_SET'
collect2: error: ld returned 1 exit status
gmake: *** [Makefile:34: build/vhost-blk-shared] Error 1

Explicitly pass _GNU_SOURCE and include missing headers (rather than
rely on automagic inclusion from other system headers).

Fixes: c19beb3f38cd ("examples/vhost_blk: introduce vhost storage sample")

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
 examples/vhost_blk/vhost_blk.c | 6 ++
 1 file changed, 6 insertions(+)

diff --git a/examples/vhost_blk/vhost_blk.c b/examples/vhost_blk/vhost_blk.c
index 8f5d61a589..bb293d492f 100644
--- a/examples/vhost_blk/vhost_blk.c
+++ b/examples/vhost_blk/vhost_blk.c
@@ -2,6 +2,12 @@
  * Copyright(c) 2010-2019 Intel Corporation
  */
 
+#ifndef _GNU_SOURCE
+#define _GNU_SOURCE
+#endif
+#include 
+#include 
+
 #include 
 #include 
 #include 
-- 
2.23.0



[dpdk-dev] [PATCH v3 11/11] examples: restore trace point

2020-11-14 Thread David Marchand
Before make removal, those examples were built with experimental flag
for tracepoints to be compiled in but the pkg-config part of those
makefiles were missed.

Fixes: 78d44153de8f ("ethdev: add tracepoints")

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
Changelog since v2:
- added eventdev_pipeline,

---
 examples/cmdline/Makefile  | 2 ++
 examples/distributor/Makefile  | 2 ++
 examples/ethtool/ethtool-app/Makefile  | 2 ++
 examples/eventdev_pipeline/Makefile| 2 ++
 examples/flow_filtering/Makefile   | 2 ++
 examples/helloworld/Makefile   | 2 ++
 examples/ioat/Makefile | 2 ++
 examples/ip_reassembly/Makefile| 2 ++
 examples/ipv4_multicast/Makefile   | 2 ++
 examples/l2fwd-cat/Makefile| 2 ++
 examples/l2fwd-event/Makefile  | 2 ++
 examples/l2fwd-jobstats/Makefile   | 2 ++
 examples/l2fwd-keepalive/Makefile  | 2 ++
 examples/l2fwd-keepalive/ka-agent/Makefile | 2 ++
 examples/l3fwd-acl/Makefile| 2 ++
 examples/link_status_interrupt/Makefile| 2 ++
 examples/multi_process/client_server_mp/mp_client/Makefile | 2 ++
 examples/multi_process/client_server_mp/mp_server/Makefile | 2 ++
 examples/multi_process/hotplug_mp/Makefile | 2 ++
 examples/multi_process/simple_mp/Makefile  | 2 ++
 examples/multi_process/symmetric_mp/Makefile   | 2 ++
 examples/packet_ordering/Makefile  | 2 ++
 examples/ptpclient/Makefile| 2 ++
 examples/qos_sched/Makefile| 2 ++
 examples/server_node_efd/node/Makefile | 2 ++
 examples/server_node_efd/server/Makefile   | 2 ++
 examples/service_cores/Makefile| 2 ++
 examples/skeleton/Makefile | 2 ++
 examples/timer/Makefile| 2 ++
 examples/vm_power_manager/Makefile | 2 ++
 examples/vm_power_manager/guest_cli/Makefile   | 2 ++
 examples/vmdq/Makefile | 2 ++
 examples/vmdq_dcb/Makefile | 2 ++
 33 files changed, 66 insertions(+)

diff --git a/examples/cmdline/Makefile b/examples/cmdline/Makefile
index d8f51fb39b..09da84ba0b 100644
--- a/examples/cmdline/Makefile
+++ b/examples/cmdline/Makefile
@@ -26,6 +26,8 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
diff --git a/examples/distributor/Makefile b/examples/distributor/Makefile
index 4116064581..d7615f9a32 100644
--- a/examples/distributor/Makefile
+++ b/examples/distributor/Makefile
@@ -26,6 +26,8 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
diff --git a/examples/ethtool/ethtool-app/Makefile 
b/examples/ethtool/ethtool-app/Makefile
index 5ebeb200a8..93ef5c27c3 100644
--- a/examples/ethtool/ethtool-app/Makefile
+++ b/examples/ethtool/ethtool-app/Makefile
@@ -31,6 +31,8 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED += $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC += $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
diff --git a/examples/eventdev_pipeline/Makefile 
b/examples/eventdev_pipeline/Makefile
index 05c6f865ad..f5072a2b0c 100644
--- a/examples/eventdev_pipeline/Makefile
+++ b/examples/eventdev_pipeline/Makefile
@@ -28,6 +28,8 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
diff --git a/examples/flow_filtering/Makefile b/examples/flow_filtering/Makefile
index 0577e52985..9bc9179346 100644
--- a/examples/flow_filtering/Makefile
+++ b/examples/flow_filtering/Makefile
@@ -24,6 +24,8 @@ CFLAGS += -O3 $(s

[dpdk-dev] [PATCH v3 10/11] examples/rxtx_callbacks: fix build with pkg-config

2020-11-14 Thread David Marchand
This example is missing the experimental flag since it uses an
experimental API.

Fixes: cd1dadeb9b2a ("examples/rxtx_callbacks: support HW timestamp")
Cc: sta...@dpdk.org

Signed-off-by: David Marchand 
Acked-by: Bruce Richardson 
---
 examples/rxtx_callbacks/Makefile | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/examples/rxtx_callbacks/Makefile b/examples/rxtx_callbacks/Makefile
index bac3015d34..a618cdf751 100644
--- a/examples/rxtx_callbacks/Makefile
+++ b/examples/rxtx_callbacks/Makefile
@@ -26,6 +26,8 @@ CFLAGS += -O3 $(shell $(PKGCONF) --cflags libdpdk)
 LDFLAGS_SHARED = $(shell $(PKGCONF) --libs libdpdk)
 LDFLAGS_STATIC = $(shell $(PKGCONF) --static --libs libdpdk)
 
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
 build/$(APP)-shared: $(SRCS-y) Makefile $(PC_FILE) | build
$(CC) $(CFLAGS) $(SRCS-y) -o $@ $(LDFLAGS) $(LDFLAGS_SHARED)
 
-- 
2.23.0



Re: [dpdk-dev] [dpdk-stable] [PATCH 1/4] common/mlx5: share UAR allocation routine

2020-11-14 Thread Thomas Monjalon
10/11/2020 17:04, Viacheslav Ovsiienko:
> +void *
> +mlx5_devx_alloc_uar(void *ctx, int mapping)
> +{
> + void *uar;
> + uint32_t retry, uar_mapping;
> + void *base_addr;
> +
> + for (retry = 0; retry < MLX5_ALLOC_UAR_RETRY; ++retry) {
> +#ifdef MLX5DV_UAR_ALLOC_TYPE_NC
> + /* Control the mapping type according to the settings. */
> + uar_mapping = (mapping < 0) ?
> +   MLX5DV_UAR_ALLOC_TYPE_NC : mapping;
> +#else
> + /*
> +  * It seems we have no way to control the memory mapping type
> +  * for the UAR, the default "Write-Combining" type is supposed.
> +  */
> + uar_mapping = 0;
> +#endif

A failure was reported by the CI:
error: unused parameter ‘mapping’
It is fixed while merging by adding the below in the #else case:
RTE_SET_USED(mapping);

Please take care of CI results!




Re: [dpdk-dev] [PATCH] doc/rel_notes: remove old deprecation for meson version

2020-11-14 Thread David Marchand
On Fri, Nov 13, 2020 at 5:17 PM Bruce Richardson
 wrote:
>
> DPDK has been using meson 0.47 for some time now, so we can safely
> remove the note calling out this fact.
>
> Signed-off-by: Bruce Richardson 
> ---
>  doc/guides/rel_notes/deprecation.rst | 6 --
>  1 file changed, 6 deletions(-)
>
> diff --git a/doc/guides/rel_notes/deprecation.rst 
> b/doc/guides/rel_notes/deprecation.rst
> index efb09f0c5..e04cab7a1 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -19,12 +19,6 @@ Deprecation Notices
>``NET``, ``CRYPTO``, ``VDPA``. The old macros are deprecated and will be
>removed in a future release.
>
> -* meson: The minimum supported version of meson for configuring and building
> -  DPDK will be increased to v0.47.1 (from 0.41) from DPDK 19.05 onwards. For
> -  those users with a version earlier than 0.47.1, an updated copy of meson
> -  can be got using the ``pip3`` tool (or ``python3 -m pip``) for downloading
> -  python packages.
> -
>  * kvargs: The function ``rte_kvargs_process`` will get a new parameter
>for returning key match count. It will ease handling of no-match case.
>

Acked-by: David Marchand 

-- 
David Marchand



Re: [dpdk-dev] [dpdk-stable] [PATCH] config: enable packet prefetching with Meson

2020-11-14 Thread David Marchand
On Sat, Nov 14, 2020 at 10:00 AM Thomas Monjalon  wrote:
>
> 14/11/2020 09:51, Thomas Monjalon:
> > 13/11/2020 16:05, Bruce Richardson:
> > > On Fri, Nov 13, 2020 at 03:52:12PM +0100, Maxime Coquelin wrote:
> > > > With Make build system, RTE_PMD_PACKET_PREFETCH was enabled
> > > > by default. It got lost when transitioning to Meson build
> > > > system.
> > > >
> > > > In order to avoid performance changes, this patch enables
> > > > packet prefetching in rte_config.h.
> > > >
> > > > Reported-by: Marvin Liu 
> > > > Suggested-by: David Marchand 
> > > > Signed-off-by: Maxime Coquelin 
> [...]
> >
> > Applied with backport info, thanks.
>
> Note that it is added back for "compatibility",
> but I am still in favour of dropping this config option,
> replaced by arch decision if any:
> http://inbox.dpdk.org/dev/3677226.MZCibFMyqQ@thomas/
>
> The decision of such optimization should be done in DPDK project,
> not in the hand of the packager.

I am for dropping this too.
And for cleaning more prefetch-related stuff, like:

#if 1
#define RTE_PMD_USE_PREFETCH
#endif

#ifdef RTE_PMD_USE_PREFETCH
#define rte_em_prefetch(p) rte_prefetch0(p)
#else
#define rte_em_prefetch(p) do {} while(0)
#endif

This has been copied into other drivers.
The igc driver forgot(?) to force #define this macro, so it just
copied unused code.


-- 
David Marchand



Re: [dpdk-dev] [PATCH 5/7] examples/qos_sched: enhance getopt_long usage

2020-11-14 Thread David Marchand
On Wed, Nov 11, 2020 at 9:17 AM Ibtisam Tariq  wrote:
>
> Instead of using getopt_long return value, strcmp was used to
> compare the input parameters with the struct option array. This
> patch get rid of all those strcmp by directly binding each longopt
> with an int enum. This is to improve readability and consistency in
> all examples.
>
> Bugzilla ID: 238
> Cc: step...@networkplumber.org
>
> Reported-by: David Marchand 
> Signed-off-by: Ibtisam Tariq 

This patch breaks compilation with clang:
https://travis-ci.com/github/ovsrobot/dpdk/jobs/433053506#L1019

You can remove this str_is helper.


-- 
David Marchand



[dpdk-dev] [PATCH v2] app/testpmd: fix testpmd packets dump overlapping

2020-11-14 Thread Jiawei Wang
When testpmd enabled the verbosity for the received packets, if two packets
was received at the same time, for example, sampling packet and normal
packet, the dump output of these packets may be overlapping due to multiple
core handled the multiple queues simultaneously.

The patch uses one string buffer that collects all the packet dump output
into this buffer and then printout it at last, that guarantee to printout
separately the dump output per packet.

Fixes: d862c45 ("app/testpmd: move dumping packets to a separate function")

Signed-off-by: Jiawei Wang 
---
v2:
* Print dump output of per packet instead of per burst.
* Add the checking for return value of 'snprintf' and exit if required size 
exceed the print buffer size.
* Update the log messages.
---
 app/test-pmd/util.c | 378 
 1 file changed, 295 insertions(+), 83 deletions(-)

diff --git a/app/test-pmd/util.c b/app/test-pmd/util.c
index 649bf8f..ffae590 100644
--- a/app/test-pmd/util.c
+++ b/app/test-pmd/util.c
@@ -12,15 +12,20 @@
 #include 
 #include 
 #include 
+#include 
 
 #include "testpmd.h"
 
-static inline void
-print_ether_addr(const char *what, const struct rte_ether_addr *eth_addr)
+#define MAX_STRING_LEN 8192
+
+static inline int
+print_ether_addr(const char *what, const struct rte_ether_addr *eth_addr,
+char print_buf[], int buf_size)
 {
char buf[RTE_ETHER_ADDR_FMT_SIZE];
+
rte_ether_format_addr(buf, RTE_ETHER_ADDR_FMT_SIZE, eth_addr);
-   printf("%s%s", what, buf);
+   return snprintf(print_buf, buf_size, "%s%s", what, buf);
 }
 
 static inline bool
@@ -74,13 +79,18 @@
uint32_t vx_vni;
const char *reason;
int dynf_index;
+   int buf_size = MAX_STRING_LEN;
+   char print_buf[buf_size];
+   int cur_len = 0;
 
+   memset(print_buf, 0, sizeof(print_buf));
if (!nb_pkts)
return;
-   printf("port %u/queue %u: %s %u packets\n",
-   port_id, queue,
-  is_rx ? "received" : "sent",
-  (unsigned int) nb_pkts);
+   cur_len += snprintf(print_buf + cur_len, buf_size - cur_len,
+   "port %u/queue %u: %s %u packets\n",
+   port_id, queue,
+   is_rx ? "received" : "sent",
+   (unsigned int) nb_pkts);
for (i = 0; i < nb_pkts; i++) {
int ret;
struct rte_flow_error error;
@@ -93,95 +103,269 @@
is_encapsulation = RTE_ETH_IS_TUNNEL_PKT(packet_type);
ret = rte_flow_get_restore_info(port_id, mb, &info, &error);
if (!ret) {
-   printf("restore info:");
+   cur_len += snprintf(print_buf + cur_len,
+   buf_size - cur_len,
+   "restore info:");
+   if (cur_len >= buf_size)
+   goto error;
if (info.flags & RTE_FLOW_RESTORE_INFO_TUNNEL) {
struct port_flow_tunnel *port_tunnel;
 
port_tunnel = port_flow_locate_tunnel
  (port_id, &info.tunnel);
-   printf(" - tunnel");
-   if (port_tunnel)
-   printf(" #%u", port_tunnel->id);
-   else
-   printf(" %s", "-none-");
-   printf(" type %s",
-   port_flow_tunnel_type(&info.tunnel));
+   cur_len += snprintf(print_buf + cur_len,
+   buf_size - cur_len,
+   " - tunnel");
+   if (cur_len >= buf_size)
+   goto error;
+   if (port_tunnel) {
+   cur_len += snprintf(print_buf + cur_len,
+   buf_size-cur_len,
+   " #%u",
+   port_tunnel->id);
+   if (cur_len >= buf_size)
+   goto error;
+   } else {
+   cur_len += snprintf(print_buf + cur_len,
+   buf_size - cur_len,
+   " %s",
+   "-none-");
+   if (cur_len >= buf_size)
+   goto error;
+  

Re: [dpdk-dev] [PATCH v2 5/5] net/mlx5: fix non-dv compilation errors

2020-11-14 Thread Thomas Monjalon
13/11/2020 15:52, Gregory Etelson:
> +   ret = mlx5_flow_group_to_table(dev, tunnel, jump_data->group,
> +  &flow_table, grp_info, error);

The parameter grp_info is a struct passed as value.
I believe it should be passed as a pointer.

I see some other functions are passing arrays with [] syntax,
which does not make sense in parameters. I should be a simple pointer.

Matan, Slava, as maintainers, what are your policies in mlx5 code?




Re: [dpdk-dev] [PATCH v12 09/14] build: optional NUMA and cpu counts detection

2020-11-14 Thread Thomas Monjalon
13/11/2020 15:31, Juraj Linkeš:
> Add an option to automatically discover the host's numa and cpu counts
> and use those values for a non cross-build.
> Give users the option to override the per-arch default values or values
> from cross files by specifying them on the command line with -Dmax_lcores
> and -Dmax_numa_nodes.
> 
> Signed-off-by: Juraj Linkeš 
> Reviewed-by: Honnappa Nagarahalli 
[...]
>  create mode 100644 buildtools/get_cpu_count.py
>  create mode 100644 buildtools/get_numa_count.py

These new files should be added in the file MAINTAINERS.
The recommended pattern is to use - as word separator in script filenames.

I'm also worried there is no more review on such general change,
especially the description in meson_options.txt:

> +option('max_lcores', type: 'integer', value: 0,
> +   description: 'maximum number of cores/threads supported by EAL. Set 
> to positive integer to overwrite per-arch or cross-compilation defaults. Set 
> to -1 to detect the number of cores on the build machine.')
> +option('max_numa_nodes', type: 'integer', value: 0,
> +   description: 'maximum number of NUMA nodes supported by EAL. Set to 
> positive integer to overwrite per-arch or cross-compilation defaults. Set to 
> -1 to detect the number of numa

I didn't think this series is changing options for all archs.
It was supposed to be an Arm-only rework.
Clearly it is too late for such change in 20.11.

Re: [dpdk-dev] [PATCH v2 5/5] net/mlx5: fix non-dv compilation errors

2020-11-14 Thread Gregory Etelson
> 13/11/2020 15:52, Gregory Etelson:
> > +   ret = mlx5_flow_group_to_table(dev, tunnel, jump_data->group,
> > +  &flow_table, grp_info, error);
> 
> The parameter grp_info is a struct passed as value.
> I believe it should be passed as a pointer.

struct flow_grp_info is a 64 bit-field:  
struct flow_grp_info {
uint64_t external:1;
uint64_t transfer:1;
uint64_t fdb_def_rule:1;
/* force standard group translation */
uint64_t std_tbl_fix:1;
uint64_t skip_scale:1;
};
Since mlx5_flow_group_to_table() does not change bits configuration,
there is no need to pass this type as a pointer.

> 
> I see some other functions are passing arrays with [] syntax, which does
> not make sense in parameters. I should be a simple pointer.
> 

I agree that arrays should not be passed with [] syntax.
However, I kept existing rte flow style - see rte_flow_create

> Matan, Slava, as maintainers, what are your policies in mlx5 code?
> 



Re: [dpdk-dev] [PATCH v2 1/5] net/mlx5: fix tunnel offload object allocation

2020-11-14 Thread Gregory Etelson
> 13/11/2020 15:52, Gregory Etelson:
> > The original patch allocated tunnel offload objects with invalid
> > indexes. As the result, PMD tunnel object allocation failed.
> >
> > In this patch indexed pool provides both an index and memory for a new
> > tunnel offload object.
> > Also tunnel offload ipool moved to dv enabled code only.
> >
> > Fixes: f2e8093 ("net/mlx5: use indexed pool as id generator")
> >
> > Signed-off-by: Gregory Etelson 2
> 
> Typo above
> 
> > Acked-by: Viacheslav Ovsiienko 
> 
> This patch is breaking compilation in non-DV mode.
> You should move it at the end of this series, after moving all in DV
> areas.

Patch "[PATCH v2 5/5] net/mlx5: fix non-dv compilation errors" in that series
resolves the compilation error.
To restore tunnel offload functionality all 5 patches must be applied.

 



Re: [dpdk-dev] [EXT] [PATCH v12 14/14] config: fix Arm implementer and its SoCs

2020-11-14 Thread Liron Himi
Reviewed-by: Liron Himi

-Original Message-
From: Juraj Linkeš  
Sent: Friday, 13 November 2020 16:31
To: bruce.richard...@intel.com; ruifeng.w...@arm.com; 
honnappa.nagaraha...@arm.com; phil.y...@arm.com; vcchu...@amazon.com; 
dharmik.thak...@arm.com; jerinjac...@gmail.com; hemant.agra...@nxp.com; 
ajit.khapa...@broadcom.com; ferruh.yi...@intel.com
Cc: dev@dpdk.org; Juraj Linkeš ; Liron Himi 
; ys...@mellanox.com
Subject: [EXT] [PATCH v12 14/14] config: fix Arm implementer and its SoCs

External Email

--
Fix the implementer and part number of DPAA and ARMADA SoCs.
The current values of 16 cores and 1 NUMA node don't cover all SoCs from the 
Arm implementer, e.g. Taishan 2280 has 64 cores and 4 NUMA nodes.
Increase these to 64 and 4 to widen the coverage.
Add configuration to SoC options where smaller values are needed.

Fixes: 6ec78c2463ac ("build: add meson support for dpaaX platforms")
Cc: hemant.agra...@nxp.com
Fixes: dd1cd845c102 ("config: add Marvell ARMADA based on armv8-a")
Cc: lir...@marvell.com
Fixes: d97108a33231 ("config: change defaults of armv8")
Cc: ys...@mellanox.com

Signed-off-by: Juraj Linkeš 
Reviewed-by: Honnappa Nagarahalli 
---
 config/arm/meson.build | 54 ++
 1 file changed, 23 insertions(+), 31 deletions(-)

diff --git a/config/arm/meson.build b/config/arm/meson.build index 
1738e36c3..f25a7dbab 100644
--- a/config/arm/meson.build
+++ b/config/arm/meson.build
@@ -75,8 +75,8 @@ implementer_arm = {
['RTE_MACHINE', '"armv8a"'],
['RTE_USE_C11_MEM_MODEL', true],
['RTE_CACHE_LINE_SIZE', 64],
-   ['RTE_MAX_LCORE', 16],
-   ['RTE_MAX_NUMA_NODES', 1]
+   ['RTE_MAX_LCORE', 64],
+   ['RTE_MAX_NUMA_NODES', 4]
],
'part_number_config': part_number_config_arm  } @@ -146,38 +146,12 @@ 
implementer_ampere = {
}
 }
 
-implementer_marvell = {
-   'description': 'Marvell ARMADA',
-   'flags': [
-   ['RTE_MACHINE', '"armv8a"'],
-   ['RTE_CACHE_LINE_SIZE', 64],
-   ['RTE_MAX_LCORE', 16],
-   ['RTE_MAX_NUMA_NODES', 1]
-   ],
-   'part_number_config': part_number_config_arm
-}
-
-implementer_dpaa = {
-   'description': 'NXP DPAA',
-   'flags': [
-   ['RTE_MACHINE', '"dpaa"'],
-   ['RTE_LIBRTE_DPAA2_USE_PHYS_IOVA', false],
-   ['RTE_USE_C11_MEM_MODEL', true],
-   ['RTE_CACHE_LINE_SIZE', 64],
-   ['RTE_MAX_LCORE', 16],
-   ['RTE_MAX_NUMA_NODES', 1]
-   ],
-   'part_number_config': part_number_config_arm
-}
-
 ## Arm implementers (ID from MIDR in Arm Architecture Reference Manual)  
implementers = {
'generic': implementer_generic,
'0x41': implementer_arm,
'0x43': implementer_cavium,
-   '0x50': implementer_ampere,
-   '0x56': implementer_marvell,
-   'dpaa': implementer_dpaa
+   '0x50': implementer_ampere
 }
 
 # soc specific aarch64 flags have the highest priority @@ -190,8 +164,12 @@ 
soc_generic = {
 
 soc_armada = {
'description': 'Marvell ARMADA',
-   'implementer': '0x56',
+   'implementer': '0x41',
'part_number': '0xd08',
+   'flags': [
+   ['RTE_MAX_LCORE', 16],
+   ['RTE_MAX_NUMA_NODES', 1]
+   ],
'numa': false,
'disabled_drivers': ['bus/dpaa', 'bus/fslmc', 'common/dpaax']  } @@ 
-200,13 +178,23 @@ soc_bluefield = {
'description': 'NVIDIA BlueField',
'implementer': '0x41',
'part_number': '0xd08',
+   'flags': [
+   ['RTE_MAX_LCORE', 16],
+   ['RTE_MAX_NUMA_NODES', 1]
+   ],
'numa': false
 }
 
 soc_dpaa = {
'description': 'NXP DPAA',
-   'implementer': 'dpaa',
+   'implementer': '0x41',
'part_number': '0xd08',
+   'flags': [
+   ['RTE_MACHINE', '"dpaa"'],
+   ['RTE_LIBRTE_DPAA2_USE_PHYS_IOVA', false],
+   ['RTE_MAX_LCORE', 16],
+   ['RTE_MAX_NUMA_NODES', 1]
+   ],
'numa': false
 }
 
@@ -243,6 +231,10 @@ soc_octeontx2 = {
 soc_stingray = {
'description': 'Broadcom Stingray',
'implementer': '0x41',
+   'flags': [
+   ['RTE_MAX_LCORE', 16],
+   ['RTE_MAX_NUMA_NODES', 1]
+   ],
'part_number': '0xd08',
'numa': false
 }
--
2.20.1



Re: [dpdk-dev] [PATCH v2 5/5] net/mlx5: fix non-dv compilation errors

2020-11-14 Thread Thomas Monjalon
14/11/2020 18:41, Gregory Etelson:
> > 13/11/2020 15:52, Gregory Etelson:
> > > +   ret = mlx5_flow_group_to_table(dev, tunnel, jump_data->group,
> > > +  &flow_table, grp_info, error);
> > 
> > The parameter grp_info is a struct passed as value.
> > I believe it should be passed as a pointer.
> 
> struct flow_grp_info is a 64 bit-field:  
> struct flow_grp_info {
>   uint64_t external:1;
>   uint64_t transfer:1;
>   uint64_t fdb_def_rule:1;
>   /* force standard group translation */
>   uint64_t std_tbl_fix:1;
>   uint64_t skip_scale:1;
> };
> Since mlx5_flow_group_to_table() does not change bits configuration,
> there is no need to pass this type as a pointer.

I feel passing struct as pointer is a better practice.

> > I see some other functions are passing arrays with [] syntax, which does
> > not make sense in parameters. I should be a simple pointer.
> 
> I agree that arrays should not be passed with [] syntax.
> However, I kept existing rte flow style - see rte_flow_create

I recommend not following this bad code style.
Later other occurences should be fixed.

> > Matan, Slava, as maintainers, what are your policies in mlx5 code?





Re: [dpdk-dev] [PATCH v2 1/5] net/mlx5: fix tunnel offload object allocation

2020-11-14 Thread Thomas Monjalon
14/11/2020 18:47, Gregory Etelson:
> > 13/11/2020 15:52, Gregory Etelson:
> > > The original patch allocated tunnel offload objects with invalid
> > > indexes. As the result, PMD tunnel object allocation failed.
> > >
> > > In this patch indexed pool provides both an index and memory for a new
> > > tunnel offload object.
> > > Also tunnel offload ipool moved to dv enabled code only.
> > >
> > > Fixes: f2e8093 ("net/mlx5: use indexed pool as id generator")
> > >
> > > Signed-off-by: Gregory Etelson 2
> > 
> > Typo above
> > 
> > > Acked-by: Viacheslav Ovsiienko 
> > 
> > This patch is breaking compilation in non-DV mode.
> > You should move it at the end of this series, after moving all in DV
> > areas.
> 
> Patch "[PATCH v2 5/5] net/mlx5: fix non-dv compilation errors" in that series
> resolves the compilation error.
> To restore tunnel offload functionality all 5 patches must be applied.

All patches must compile.
That's why I recommend moving this patch later in the series.




Re: [dpdk-dev] [PATCH v2 5/5] net/mlx5: fix non-dv compilation errors

2020-11-14 Thread Gregory Etelson
> 14/11/2020 18:41, Gregory Etelson:
> > > 13/11/2020 15:52, Gregory Etelson:
> > > > +   ret = mlx5_flow_group_to_table(dev, tunnel, jump_data-
> >group,
> > > > +  &flow_table, grp_info,
> > > > + error);
> > >
> > > The parameter grp_info is a struct passed as value.
> > > I believe it should be passed as a pointer.
> >
> > struct flow_grp_info is a 64 bit-field:
> > struct flow_grp_info {
> >   uint64_t external:1;
> >   uint64_t transfer:1;
> >   uint64_t fdb_def_rule:1;
> >   /* force standard group translation */
> >   uint64_t std_tbl_fix:1;
> >   uint64_t skip_scale:1;
> > };
> > Since mlx5_flow_group_to_table() does not change bits configuration,
> > there is no need to pass this type as a pointer.
> 
> I feel passing struct as pointer is a better practice.
>

The parameter in question is 64 bit unsigned long value.
Structure coating is a syntactic sugar, because
C language does not have bit-field types.
In general, if structure size does not exceed 64 bit it can be passed
by value.
Passing it by reference would create unnecessary indirect access.

> > > I see some other functions are passing arrays with [] syntax, which
> > > does not make sense in parameters. I should be a simple pointer.
> >
> > I agree that arrays should not be passed with [] syntax.
> > However, I kept existing rte flow style - see rte_flow_create
> 
> I recommend not following this bad code style.
> Later other occurences should be fixed.
> 
> > > Matan, Slava, as maintainers, what are your policies in mlx5 code?
> 
> 



Re: [dpdk-dev] [PATCH v2 5/5] net/mlx5: fix non-dv compilation errors

2020-11-14 Thread Thomas Monjalon
14/11/2020 19:31, Gregory Etelson:
> > 14/11/2020 18:41, Gregory Etelson:
> > > > 13/11/2020 15:52, Gregory Etelson:
> > > > > +   ret = mlx5_flow_group_to_table(dev, tunnel, jump_data-
> > >group,
> > > > > +  &flow_table, grp_info,
> > > > > + error);
> > > >
> > > > The parameter grp_info is a struct passed as value.
> > > > I believe it should be passed as a pointer.
> > >
> > > struct flow_grp_info is a 64 bit-field:
> > > struct flow_grp_info {
> > >   uint64_t external:1;
> > >   uint64_t transfer:1;
> > >   uint64_t fdb_def_rule:1;
> > >   /* force standard group translation */
> > >   uint64_t std_tbl_fix:1;
> > >   uint64_t skip_scale:1;
> > > };
> > > Since mlx5_flow_group_to_table() does not change bits configuration,
> > > there is no need to pass this type as a pointer.
> > 
> > I feel passing struct as pointer is a better practice.
> 
> The parameter in question is 64 bit unsigned long value.
> Structure coating is a syntactic sugar, because
> C language does not have bit-field types.
> In general, if structure size does not exceed 64 bit it can be passed
> by value.
> Passing it by reference would create unnecessary indirect access.

Did you measure a performance difference?

This current code triggers this compiler note:
drivers/net/mlx5/mlx5_flow.c:7106:1: note:
parameter passing for argument of type 'struct flow_grp_info' changed in GCC 9.1

I'm afraid it can be a problem.
In general we don't have such note on the whole DPDK code base.




[dpdk-dev] [PATCH] eal/windows: definition for ETOOMANYREFS errno

2020-11-14 Thread Tal Shnaiderman
The ETOOMANYREFS errno is missing from the Windows clang build
is it used in initialization of flow error structures.

The commit will define it as it is done in the minGW Windows build.

Signed-off-by: Tal Shnaiderman 
---
 lib/librte_eal/windows/include/rte_os.h | 1 +
 1 file changed, 1 insertion(+)

diff --git a/lib/librte_eal/windows/include/rte_os.h 
b/lib/librte_eal/windows/include/rte_os.h
index 569ed92d51..2a91ebf6a1 100644
--- a/lib/librte_eal/windows/include/rte_os.h
+++ b/lib/librte_eal/windows/include/rte_os.h
@@ -90,6 +90,7 @@ eal_strerror(int code)
 }
 
 #define strerror eal_strerror
+#define ETOOMANYREFS WSAETOOMANYREFS
 
 #endif /* RTE_TOOLCHAIN_GCC */
 
-- 
2.16.1.windows.4



Re: [dpdk-dev] [PATCH v1 59/72] net/mlx5/windows: support VF PCI address

2020-11-14 Thread Tal Shnaiderman
> Subject: Re: [dpdk-dev] [PATCH v1 59/72] net/mlx5/windows: support VF PCI
> address
> 
> On Tue, Oct 27, 2020 at 11:23:22PM +, Ophir Munk wrote:
> > From: Tal Shnaiderman 
> >
> > Support VF BDF scanning by checking both the BDF and raw BDF provided
> > by DevX. In Linux a PCI address is formatted as: domain, bus, device,
> > function (DBDF).  This is right for both a PF and a VF. In Windows a
> > PF also has a DBDF format, but the domain is always 0, while a VF has
> > a special "domain" called "Virtual PCI Bus, Serial" (for example:
> > "Virtual PCI Bus Slot 2 Serial 2") or segment.  The full VF format
> > under Windows is called raw DBF.  Windows special domain must be
> > considered and DevX must be called to support it.
> >
> > Signed-off-by: Tal Shnaiderman 
> > ---
> >  drivers/net/mlx5/windows/mlx5_os.c | 67
> > --
> >  1 file changed, 64 insertions(+), 3 deletions(-)
> >
> > diff --git a/drivers/net/mlx5/windows/mlx5_os.c
> > b/drivers/net/mlx5/windows/mlx5_os.c
> > index f9b469f..4374b05 100644
> > --- a/drivers/net/mlx5/windows/mlx5_os.c
> > +++ b/drivers/net/mlx5/windows/mlx5_os.c
> > @@ -901,6 +901,68 @@ mlx5_os_set_allmulti(struct rte_eth_dev *dev, int
> > enable)  }
> > + * @return
> > + *   1 on Device match, 0 on mismatch, rte_errno code on failure.
> > + */
> > +static int
> > +mlx5_match_devx_devices_to_addr(struct devx_device_bdf *devx_bdf,
> > +   struct rte_pci_addr *addr)
> > +{
> > +   err = mlx5_glue->query_device(devx_bdf, &mlx5_dev);
> > +   if (err) {
> > +   DRV_LOG(ERR, "query_device failed");
> > +   rte_errno = err;
> > +   return 0;
> 
> Return rte_errno.

Actually updating rte_errno is enough in the function, but the caller need to 
check it, I'll fix in v2.

> 
> > +   }
> > +   if (mlx5_match_devx_bdf_to_addr(&mlx5_dev.raw_bdf, addr))
> > +   return 1;
> > +   return 0;
> > +}
> > +
> > --
> > 2.8.4


Re: [dpdk-dev] [PATCH v1 48/72] net/mlx5/windows: support link update

2020-11-14 Thread Tal Shnaiderman
> Subject: Re: [dpdk-dev] [PATCH v1 48/72] net/mlx5/windows: support link
> update
> 
> On Tue, Oct 27, 2020 at 11:23:11PM +, Ophir Munk wrote:
> > From: Tal Shnaiderman 
> >
> > Add support for mlx5_link_update() to get link speed and link state.
> > Other parameters are currently hard-coded.
> >
> > Signed-off-by: Tal Shnaiderman 
> > ---
> >  drivers/net/mlx5/windows/mlx5_ethdev_os.c | 39
> > +++
> >  1 file changed, 39 insertions(+)
> >
> > diff --git a/drivers/net/mlx5/windows/mlx5_ethdev_os.c
> > b/drivers/net/mlx5/windows/mlx5_ethdev_os.c
> > index 4925fd8..0c45101 100644
> > --- a/drivers/net/mlx5/windows/mlx5_ethdev_os.c
> > +++ b/drivers/net/mlx5/windows/mlx5_ethdev_os.c
> > @@ -171,6 +171,45 @@ mlx5_os_read_dev_counters(struct rte_eth_dev
> > *dev, uint64_t *stats)  }
> >
> >  /**
> > + * @return
> > + *   0 if link status was not updated, positive if it was, a negative errno
> > + *   value otherwise and rte_errno is set.
> > + */
> > +int
> > +mlx5_link_update(struct rte_eth_dev *dev, int wait_to_complete) {
> > +   RTE_SET_USED(wait_to_complete);
> > +   struct mlx5_priv *priv;
> > +   mlx5_context_st *context_obj;
> > +   struct rte_eth_link dev_link;
> > +   int ret;
> > +
> > +   ret = 0;
> > +   if (!dev) {
> > +   rte_errno = EINVAL;
> > +   return rte_errno;
> 
> Should this be "return -rte_errno", as per the function description above?

Right, will fix in v2.

> 
> > +   }
> > +   priv = dev->data->dev_private;
> > +   context_obj = (mlx5_context_st *)priv->sh->ctx;
> > 2.8.4


Re: [dpdk-dev] [PATCH v1 42/72] common/mlx5/windows: add DevX UAR getters

2020-11-14 Thread Tal Shnaiderman
> Subject: Re: [dpdk-dev] [PATCH v1 42/72] common/mlx5/windows: add
> DevX UAR getters
> 
> On Tue, Oct 27, 2020 at 11:23:05PM +, Ophir Munk wrote:
> > The following getters are added: mlx5_os_get_devx_uar_mmap_offset,
> > mlx5_os_get_devx_uar_base_addr, mlx5_os_get_devx_uar_reg_addr,
> > mlx5_os_get_devx_uar_page_id.  This commit is the Windows equivalent
> > of the Linux implementation in (1).
> >
> > (1)
> > commit 8638e19a10aa ("net/mlx5: remove more DV dependencies")
> >
> > Signed-off-by: Ophir Munk 
> > ---
> >  drivers/common/mlx5/windows/mlx5_common_os.h | 74
> > 
> >  1 file changed, 74 insertions(+)
> >
> > diff --git a/drivers/common/mlx5/windows/mlx5_common_os.h
> > b/drivers/common/mlx5/windows/mlx5_common_os.h
> > + * Get mmap offset. Given a pointer to an DevX UAR object of type
> > + * 'struct mlx5dv_devx_uar *' - return its mmap offset.
> > + *
> > + * @param[in] uar
> > + *Pointer to UAR object.
> > + *
> > + * @return
> > + *The mmap offset if uar is valid, 0 otherwise.
> > + */
> > +static inline off_t
> > +mlx5_os_get_devx_uar_mmap_offset(void *uar) {
> > +   if (!uar)
> > +   return 0;
> > +   return 0;
> 
> Should we return uar->mmap_off here?

In Windows, this function will always return 0 as mmap offset is unneeded, I'll 
update the function docu and change it to reflect it, thanks.

> 
> > +}
> > +
> > +/**
> > + * Get base addr pointer. Given a pointer to an UAR object of type
> > + * 'struct mlx5dv_devx_uar *' - return its base address.
> > + *


Re: [dpdk-dev] [PATCH v1 34/72] net/mlx5/windows: implement mlx5 mac addr add

2020-11-14 Thread Tal Shnaiderman
> Subject: Re: [dpdk-dev] [PATCH v1 34/72] net/mlx5/windows: implement
> mlx5 mac addr add
> 
> On Tue, Oct 27, 2020 at 11:22:57PM +, Ophir Munk wrote:
> > From: Tal Shnaiderman 
> >
> > Get the list of MAC addresses and verify if the input mac parameter
> > already exists. If not - return -ENOTSUP (as Windows does not support
> > adding new MAC addresses). If the MAC address exists (EEXIST) return 0
> > (the equivalent of Linux implementation of this API).
> >
> > Signed-off-by: Tal Shnaiderman 
> > ---
> >  drivers/net/mlx5/windows/mlx5_os.c | 36
> > 
> >  1 file changed, 36 insertions(+)
> >
> > diff --git a/drivers/net/mlx5/windows/mlx5_os.c
> > b/drivers/net/mlx5/windows/mlx5_os.c
> > index b0cc9f3..6e27474 100644
> > --- a/drivers/net/mlx5/windows/mlx5_os.c
> > +++ b/drivers/net/mlx5/windows/mlx5_os.c
> > @@ -183,6 +183,42 @@ mlx5_os_mac_addr_remove(struct rte_eth_dev
> *dev,
> > uint32_t index)  }
> >
> > + *
> > + * @return
> > + *   0 on success, a negative errno value otherwise
> > + */
> > +int
> > +mlx5_os_mac_addr_add(struct rte_eth_dev *dev, struct rte_ether_addr
> *mac,
> > +uint32_t index)
> > +{
> > +   (void)index;
> > +   struct rte_ether_addr lmac;
> > +
> > +   if (mlx5_get_mac(dev, &lmac.addr_bytes)) {
> > +   DRV_LOG(ERR,
> > +   "port %u cannot get MAC address, is mlx5_en"
> > +   " loaded? (errno: %s)",
> > +   dev->data->port_id, strerror(rte_errno));
> > +   return rte_errno;
> 
> Should it be "return -rte_errno" here?

Actually, mlx5_get_mac return a negative value in rte_errno in case of failure.

> 
> > +   }
> > +   if (memcmp(&lmac, mac, sizeof(struct rte_ether_addr))) {
> > +   DRV_LOG(ERR,
> > +   "adding new mac address to device is unsupported");
> > +   return -ENOTSUP;
> > +   }
> > +   return 0;
> > +}
> > +
> > +/**
> >   * Modify a VF MAC address
> >   * Currently it has no support under Windows.
> >   *
> > --
> > 2.8.4


Re: [dpdk-dev] [PATCH v1 27/72] common/mlx5/windows: add OS alloc/dealloc pd

2020-11-14 Thread Tal Shnaiderman
> Subject: Re: [dpdk-dev] [PATCH v1 27/72] common/mlx5/windows: add OS
> alloc/dealloc pd
> 
> On Tue, Oct 27, 2020 at 11:22:50PM +, Ophir Munk wrote:
> > From: Tal Shnaiderman 
> >
> > Implement Windows API mlx5_os_alloc_pd() and mlx5_os_dealloc_pd().
> > They are equivalent to the Linux implementation.
> >
> > Signed-off-by: Tal Shnaiderman 
> > Acked-by: Matan Azrad 
> > ---
> >  drivers/common/mlx5/rte_common_mlx5_exports.def |  3 +-
> >  drivers/common/mlx5/windows/mlx5_common_os.c| 47
> +
> >  drivers/common/mlx5/windows/mlx5_common_os.h|  3 ++
> >  drivers/common/mlx5/windows/mlx5_win_ext.h  |  6 
> >  4 files changed, 58 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/common/mlx5/rte_common_mlx5_exports.def
> > b/drivers/common/mlx5/rte_common_mlx5_exports.def
> > + * @return
> > + *The mlx5_pd if pd is valid, NULL and errno otherwise.
> > + */
> > +void *
> > +mlx5_os_alloc_pd(void *ctx)
> > +{
> > +   struct mlx5_pd *ppd =  mlx5_malloc(MLX5_MEM_ZERO,
> > +   sizeof(struct mlx5_pd), 0, SOCKET_ID_ANY);
> > +   if (!ppd)
> > +   return NULL;
> > +
> > +   struct mlx5_devx_obj *obj = mlx5_devx_cmd_alloc_pd(ctx);
> > +   if (!obj)
> 
> Free ppd here, to avoid memory leak.

Right, will do in v2.

> 
> > +   return NULL;
> > +
> > +   ppd->obj = obj;
> > +   ppd->pdn = obj->id;
> > +   ppd->devx_ctx = ctx;
> > +   return ppd;
> > +}
> > +


Re: [dpdk-dev] [PATCH] eal/windows: definition for ETOOMANYREFS errno

2020-11-14 Thread Dmitry Kozlyuk
On Sat, 14 Nov 2020 23:11:56 +0200, Tal Shnaiderman wrote:
> The ETOOMANYREFS errno is missing from the Windows clang build
> is it used in initialization of flow error structures.

"is it" -> "it is"
 
> The commit will define it as it is done in the minGW Windows build.

"The commit will" is unnecessary.

"minGW" -> "MinGW"
 
> Signed-off-by: Tal Shnaiderman 
> ---
>  lib/librte_eal/windows/include/rte_os.h | 1 +
>  1 file changed, 1 insertion(+)
> 
> diff --git a/lib/librte_eal/windows/include/rte_os.h 
> b/lib/librte_eal/windows/include/rte_os.h
> index 569ed92d51..2a91ebf6a1 100644
> --- a/lib/librte_eal/windows/include/rte_os.h
> +++ b/lib/librte_eal/windows/include/rte_os.h
> @@ -90,6 +90,7 @@ eal_strerror(int code)
>  }
>  
>  #define strerror eal_strerror
> +#define ETOOMANYREFS WSAETOOMANYREFS
>  
>  #endif /* RTE_TOOLCHAIN_GCC */

Should be #define ETOOMANYREFS 10059 /* WSAETOOMANYREFS */ for all toolchains:

1. Users of librte_ethdev, who check for ETOOMANYREFS, may not wish to include
 because of its defines that break librte_net headers.

2. Now that I looked closely, MinGW-w64's #define ETOOMANYREFS
WSAETOOMANYREFS is under #if 0 clause (for documentation?). Apologies for
earlier misinformation.



Re: [dpdk-dev] [PATCH] eal/windows: definition for ETOOMANYREFS errno

2020-11-14 Thread Tal Shnaiderman
> Subject: Re: [PATCH] eal/windows: definition for ETOOMANYREFS errno
> 
> External email: Use caution opening links or attachments
> 
> 
> On Sat, 14 Nov 2020 23:11:56 +0200, Tal Shnaiderman wrote:
> > The ETOOMANYREFS errno is missing from the Windows clang build is it
> > used in initialization of flow error structures.
> 
> "is it" -> "it is"
> 
> > The commit will define it as it is done in the minGW Windows build.
> 
> "The commit will" is unnecessary.
> 
> "minGW" -> "MinGW"
> 
> > Signed-off-by: Tal Shnaiderman 
> > ---
> >  lib/librte_eal/windows/include/rte_os.h | 1 +
> >  1 file changed, 1 insertion(+)
> >
> > diff --git a/lib/librte_eal/windows/include/rte_os.h
> > b/lib/librte_eal/windows/include/rte_os.h
> > index 569ed92d51..2a91ebf6a1 100644
> > --- a/lib/librte_eal/windows/include/rte_os.h
> > +++ b/lib/librte_eal/windows/include/rte_os.h
> > @@ -90,6 +90,7 @@ eal_strerror(int code)  }
> >
> >  #define strerror eal_strerror
> > +#define ETOOMANYREFS WSAETOOMANYREFS
> >
> >  #endif /* RTE_TOOLCHAIN_GCC */
> 
> Should be #define ETOOMANYREFS 10059 /* WSAETOOMANYREFS */ for all
> toolchains:
> 
> 1. Users of librte_ethdev, who check for ETOOMANYREFS, may not wish to
> include  because of its defines that break librte_net headers.
> 
> 2. Now that I looked closely, MinGW-w64's #define ETOOMANYREFS
> WSAETOOMANYREFS is under #if 0 clause (for documentation?). Apologies
> for earlier misinformation.

Thank you for the comments Dmitry, will send a v2 promptly.


[dpdk-dev] [PATCH v2] eal/windows: definition for ETOOMANYREFS errno

2020-11-14 Thread Tal Shnaiderman
The ETOOMANYREFS errno is missing from the Windows build.
it is used in initialization of flow error structures.

The commit will define it with the same error code used by
WSAETOOMANYREFS.

Signed-off-by: Tal Shnaiderman 

---
v2: log message fix, apply errno to both Windows builds
and remove dependency on winsock2.h [DmitryK]
---
---
 lib/librte_eal/windows/include/rte_os.h | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/lib/librte_eal/windows/include/rte_os.h 
b/lib/librte_eal/windows/include/rte_os.h
index 569ed92d51..8300ea483a 100644
--- a/lib/librte_eal/windows/include/rte_os.h
+++ b/lib/librte_eal/windows/include/rte_os.h
@@ -51,6 +51,8 @@ extern "C" {
 /* as in  */
 typedef long long ssize_t;
 
+#define ETOOMANYREFS 10059 /* WSAETOOMANYREFS */
+
 #ifndef RTE_TOOLCHAIN_GCC
 
 static inline int
-- 
2.16.1.windows.4



Re: [dpdk-dev] [PATCH v2] eal/windows: definition for ETOOMANYREFS errno

2020-11-14 Thread Dmitry Kozlyuk
On Sun, 15 Nov 2020 00:21:29 +0200, Tal Shnaiderman wrote:
> The ETOOMANYREFS errno is missing from the Windows build.
> it is used in initialization of flow error structures.
> 
> The commit will define it with the same error code used by
> WSAETOOMANYREFS.
> 
> Signed-off-by: Tal Shnaiderman 
> 
> ---
> v2: log message fix, apply errno to both Windows builds
> and remove dependency on winsock2.h [DmitryK]

Acked-by: Dmitry Kozlyuk 


Re: [dpdk-dev] [PATCH v2 5/5] net/mlx5: fix non-dv compilation errors

2020-11-14 Thread Gregory Etelson
> 14/11/2020 19:31, Gregory Etelson:
> > > 14/11/2020 18:41, Gregory Etelson:
> > > > > 13/11/2020 15:52, Gregory Etelson:
> > > > > > +   ret = mlx5_flow_group_to_table(dev, tunnel, jump_data-
> > > >group,
> > > > > > +  &flow_table, grp_info,
> > > > > > + error);
> > > > >
> > > > > The parameter grp_info is a struct passed as value.
> > > > > I believe it should be passed as a pointer.
> > > >
> > > > struct flow_grp_info is a 64 bit-field:
> > > > struct flow_grp_info {
> > > >   uint64_t external:1;
> > > >   uint64_t transfer:1;
> > > >   uint64_t fdb_def_rule:1;
> > > >   /* force standard group translation */
> > > >   uint64_t std_tbl_fix:1;
> > > >   uint64_t skip_scale:1;
> > > > };
> > > > Since mlx5_flow_group_to_table() does not change bits
> > > > configuration, there is no need to pass this type as a pointer.
> > >
> > > I feel passing struct as pointer is a better practice.
> >
> > The parameter in question is 64 bit unsigned long value.
> > Structure coating is a syntactic sugar, because C language does not
> > have bit-field types.
> > In general, if structure size does not exceed 64 bit it can be passed
> > by value.
> > Passing it by reference would create unnecessary indirect access.
> 
> Did you measure a performance difference?
> 
> This current code triggers this compiler note:
> drivers/net/mlx5/mlx5_flow.c:7106:1: note:
> parameter passing for argument of type 'struct flow_grp_info' changed in
> GCC 9.1
> 
> I'm afraid it can be a problem.
> In general we don't have such note on the whole DPDK code base.
> 

I'll handle this issue in DV compilation patch.