On Fri, 21 Feb 2025 10:03:28 +0800
Junlong Wang <wang.junlo...@zte.com.cn> wrote:

> V2:
>   - modify CI some error results(checkpatches warnings、Wrong headline format)
>   - fix warnings when enable extra warnings.
>   - modify apply memcpy script for coccinelle and unnecessary init and
>     unneccessary cast of void when use malloc.
> 
> V1:
>   - updated net zxdh driver.
>     optimize init and some ops.
>     provided csum/lro/tso 、extend stats、fw_version、module_info 、meter, etc.
> 
> Junlong Wang (16):
>   net/zxdh: optimize np dtb channel initialization
>   net/zxdh: optimize queue res alloc/free process
>   net/zxdh: optimize link update process
>   net/zxdh: update Rx/Tx to latest
>   net/zxdh: provided PF/VF msg intr callback
>   net/zxdh: optimize MAC ops
>   net/zxdh: optimize promisc ops
>   net/zxdh: optimize VLAN filter/offload ops
>   net/zxdh: optimize RSS/RETA hash config/update/get
>   net/zxdh: optimize MTU set ops
>   net/zxdh: optimize basic stats ops
>   net/zxdh: provided CSUM/TSO/LRO config
>   net/zxdh: provided rxq/txq info get implementations
>   net/zxdh: provide extended stats ops implementations
>   net/zxdh: provide ptypes FW version EEPROM ops
>   net/zxdh: provide meter ops implementations
> 
>  doc/guides/nics/features/zxdh.ini  |   11 +
>  doc/guides/nics/zxdh.rst           |    5 +
>  drivers/net/zxdh/meson.build       |    1 +
>  drivers/net/zxdh/zxdh_common.c     |   46 +-
>  drivers/net/zxdh/zxdh_common.h     |    3 +
>  drivers/net/zxdh/zxdh_ethdev.c     |  724 +++++++++++++---
>  drivers/net/zxdh/zxdh_ethdev.h     |   69 +-
>  drivers/net/zxdh/zxdh_ethdev_ops.c |  916 ++++++++++++++++++---
>  drivers/net/zxdh/zxdh_ethdev_ops.h |   53 +-
>  drivers/net/zxdh/zxdh_msg.c        |  985 +++++++++++++++++++++-
>  drivers/net/zxdh/zxdh_msg.h        |  175 +++-
>  drivers/net/zxdh/zxdh_mtr.c        | 1223 ++++++++++++++++++++++++++++
>  drivers/net/zxdh/zxdh_mtr.h        |  114 +++
>  drivers/net/zxdh/zxdh_np.c         |  811 ++++++++++++++++--
>  drivers/net/zxdh/zxdh_np.h         |  262 ++++++
>  drivers/net/zxdh/zxdh_pci.c        |   10 -
>  drivers/net/zxdh/zxdh_queue.c      |  132 +--
>  drivers/net/zxdh/zxdh_queue.h      |  118 +--
>  drivers/net/zxdh/zxdh_rxtx.c       |  695 +++++++++-------
>  drivers/net/zxdh/zxdh_rxtx.h       |   27 +
>  drivers/net/zxdh/zxdh_tables.c     |  378 +++++++--
>  drivers/net/zxdh/zxdh_tables.h     |  220 +++--
>  22 files changed, 6040 insertions(+), 938 deletions(-)
>  create mode 100644 drivers/net/zxdh/zxdh_mtr.c
>  create mode 100644 drivers/net/zxdh/zxdh_mtr.h

Still several checklist items, some of these are likely pre-existing conditions.
The one that matters are the build issue with RTE_ASSERT enabled.

Mark items with:
    ✔ passed
    ✘ Failed
    o N/A

Basic hygiene
    ✔ Look at CI results in patchwork
    ✔ Merge cleanly with git am
    ✔ Run checkpatches
      - bug in checkpatch around __rte_packed_begin macros
      - warning from stub

    ✔ Run check-git-log
    ✔ Run check-symbol-maps.sh
    ✔ Run check-doc-vs-code
    ✔ Run check-spdk-tag

Builds
    ✔ Normal Gcc build; make sure driver is built!
    ✔ Use latest experimental Gcc 15 to catch new warnings
    ✔ Clang build using current version (clang-19)
    ✔ Doc build
    o Build for 32 bit x86
    o Cross build for Windows (if applicable)
    ✔ Debug build
    x Enable asserts
[1594/3244] Compiling C object 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_msg.c.o
FAILED: drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_msg.c.o
cc -Idrivers/libtmp_rte_net_zxdh.a.p -Idrivers -I../drivers -Idrivers/net/zxdh 
-I../drivers/net/zxdh -Ilib/ethdev -I../lib/ethdev -I. -I.. -Iconfig 
-I../config -Ilib/eal/include -I../lib/eal/include -Ilib/eal/linux/include 
-I../lib/eal/linux/include -Ilib/eal/x86/include -I../lib/eal/x86/include 
-I../kernel/linux -Ilib/eal/common -I../lib/eal/common -Ilib/eal -I../lib/eal 
-Ilib/kvargs -I../lib/kvargs -Ilib/log -I../lib/log -Ilib/metrics 
-I../lib/metrics -Ilib/telemetry -I../lib/telemetry -Ilib/net -I../lib/net 
-Ilib/mbuf -I../lib/mbuf -Ilib/mempool -I../lib/mempool -Ilib/ring 
-I../lib/ring -Ilib/meter -I../lib/meter -Idrivers/bus/pci -I../drivers/bus/pci 
-I../drivers/bus/pci/linux -Ilib/pci -I../lib/pci -Idrivers/bus/vdev 
-I../drivers/bus/vdev -I/usr/include/x86_64-linux-gnu 
-fdiagnostics-color=always -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -Wextra 
-std=c11 -O3 -include rte_config.h -Wvla -Wcast-qual -Wdeprecated -Wformat 
-Wformat-nonliteral -Wformat-security -Wmissing-declarations 
-Wmissing-prototypes -Wnested-externs -Wold-style-definition -Wpointer-arith 
-Wsign-compare -Wstrict-prototypes -Wundef -Wwrite-strings 
-Wno-packed-not-aligned -Wno-missing-field-initializers -D_GNU_SOURCE 
-DRTE_ENABLE_ASSERT -DRTE_LIBRTE_ETHDEV_DEBUG=1 -fPIC -march=native -mrtm 
-DALLOW_EXPERIMENTAL_API -DALLOW_INTERNAL_API -Wno-format-truncation 
-Wno-address-of-packed-member -Wno-vla -DRTE_LOG_DEFAULT_LOGTYPE=pmd.net.zxdh 
-MD -MQ drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_msg.c.o -MF 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_msg.c.o.d -o 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_msg.c.o -c 
../drivers/net/zxdh/zxdh_msg.c
In file included from ../lib/eal/x86/include/rte_spinlock.h:11,
                 from ../drivers/net/zxdh/zxdh_msg.c:9:
../drivers/net/zxdh/zxdh_msg.c: In function ‘zxdh_vf_promisc_set’:
../drivers/net/zxdh/zxdh_msg.c:1450:41: error: ‘res_info’ undeclared (first use 
in this function)
 1450 |         RTE_ASSERT(!cfg_data || !hw || !res_info || !res_len);
      |                                         ^~~~~~~~
../lib/eal/include/rte_branch_prediction.h:43:45: note: in definition of macro 
‘unlikely’
   43 | #define unlikely(x)     __builtin_expect(!!(x), 0)
      |                                             ^
../lib/eal/include/rte_debug.h:47:25: note: in expansion of macro ‘RTE_VERIFY’
   47 | #define RTE_ASSERT(exp) RTE_VERIFY(exp)
      |                         ^~~~~~~~~~
../drivers/net/zxdh/zxdh_msg.c:1450:9: note: in expansion of macro ‘RTE_ASSERT’
 1450 |         RTE_ASSERT(!cfg_data || !hw || !res_info || !res_len);
      |         ^~~~~~~~~~
../drivers/net/zxdh/zxdh_msg.c:1450:41: note: each undeclared identifier is 
reported only once for each function it appears in
 1450 |         RTE_ASSERT(!cfg_data || !hw || !res_info || !res_len);
      |                                         ^~~~~~~~
../lib/eal/include/rte_branch_prediction.h:43:45: note: in definition of macro 
‘unlikely’
   43 | #define unlikely(x)     __builtin_expect(!!(x), 0)
      |                                             ^
../lib/eal/include/rte_debug.h:47:25: note: in expansion of macro ‘RTE_VERIFY’
   47 | #define RTE_ASSERT(exp) RTE_VERIFY(exp)
      |                         ^~~~~~~~~~
../drivers/net/zxdh/zxdh_msg.c:1450:9: note: in expansion of macro ‘RTE_ASSERT’
 1450 |         RTE_ASSERT(!cfg_data || !hw || !res_info || !res_len);
      |         ^~~~~~~~~~
[1603/3244] Compiling C object 
drivers/libtmp_rte_net_virtio.a.p/net_virtio_virtio_rxtx.c.o
ninja: build stopped: subcommand failed.

    ✔ Test meson builds

Experimental builds:
    ✘ Enable address sanitizer for undefined checks

[1603/3244] Compiling C object 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_np.c.o
In function ‘zxdh_np_dtb_smmu0_write_entry_data’,
    inlined from ‘zxdh_np_dtb_se_smmu0_ind_write’ at 
../drivers/net/zxdh/zxdh_np.c:1104:7,
    inlined from ‘zxdh_np_dtb_eram_one_entry’ at 
../drivers/net/zxdh/zxdh_np.c:1181:8,
    inlined from ‘zxdh_np_dtb_table_entry_write’ at 
../drivers/net/zxdh/zxdh_np.c:1452:9:
../drivers/net/zxdh/zxdh_np.c:75:12: warning: ‘rc’ may be used uninitialized 
[-Wmaybe-uninitialized]
   75 |         if ((rc) != 0) {\
      |            ^
../drivers/net/zxdh/zxdh_np.c:1051:17: note: in expansion of macro 
‘ZXDH_COMM_CHECK_RC_NO_ASSERT’
 1051 |                 ZXDH_COMM_CHECK_RC_NO_ASSERT(rc, 
"dpp_dtb_write_table_cmd");
      |                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
../drivers/net/zxdh/zxdh_np.c: In function ‘zxdh_np_dtb_table_entry_write’:
../drivers/net/zxdh/zxdh_np.c:983:26: note: ‘rc’ was declared here
  983 |         uint32_t         rc;
      |                          ^~

    ✘ Enable extra warnings (edit meson.build) for
        -Wvla, -Wformat-truncation, -Waddress-of-packed-member

[1600/3244] Compiling C object 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_queue.c.o
../drivers/net/zxdh/zxdh_queue.c: In function ‘zxdh_dev_rx_queue_setup_finish’:
../drivers/net/zxdh/zxdh_queue.c:357:24: warning: ISO C90 forbids variable 
length array ‘new_pkts’ [-Wvla]
  357 |                 struct rte_mbuf *new_pkts[free_cnt];
      |                        ^~~~~~~~
[1603/3244] Compiling C object 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_rxtx.c.o
../drivers/net/zxdh/zxdh_rxtx.c: In function ‘zxdh_recv_pkts_packed’:
../drivers/net/zxdh/zxdh_rxtx.c:903:24: warning: ISO C90 forbids variable 
length array ‘new_pkts’ [-Wvla]
  903 |                 struct rte_mbuf *new_pkts[free_cnt];
      |                        ^~~~~~~~
[1616/3244] Compiling C object 
drivers/libtmp_rte_net_zxdh.a.p/net_zxdh_zxdh_ethdev_ops.c.o
../drivers/net/zxdh/zxdh_ethdev_ops.c: In function ‘zxdh_dev_xstats_get_names’:
../drivers/net/zxdh/zxdh_ethdev_ops.c:1983:26: warning: ‘%s’ directive output 
may be truncated writing up to 1359 bytes into a region of size 64 
[-Wformat-truncation=]
 1983 |                         "%s", zxdh_np_stat_strings[i].name);
      |                          ^~
../drivers/net/zxdh/zxdh_ethdev_ops.c:1982:25: note: ‘snprintf’ output between 
1 and 1360 bytes into a destination of size 64
 1982 |                         snprintf(xstats_names[count].name, 
sizeof(xstats_names[count].name),
      |                         
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 1983 |                         "%s", zxdh_np_stat_strings[i].name);
      |                         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
../drivers/net/zxdh/zxdh_ethdev_ops.c:1989:34: warning: ‘%s’ directive output 
may be truncated writing up to 2991 bytes into a region of size 64 
[-Wformat-truncation=]
 1989 |                                 "%s", zxdh_mac_stat_strings[i].name);
      |                                  ^~
../drivers/net/zxdh/zxdh_ethdev_ops.c:1988:33: note: ‘snprintf’ output between 
1 and 2992 bytes into a destination of size 64
 1988 |                                 snprintf(xstats_names[count].name, 
sizeof(xstats_names[count].name),
      |                                 
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 1989 |                                 "%s", zxdh_mac_stat_strings[i].name);
      |                                 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
../drivers/net/zxdh/zxdh_ethdev_ops.c:1994:34: warning: ‘%s’ directive output 
may be truncated writing up to 271 bytes into a region of size 64 
[-Wformat-truncation=]
 1994 |                                 "%s", zxdh_mac_bytes_strings[i].name);
      |                                  ^~
../drivers/net/zxdh/zxdh_ethdev_ops.c:1993:33: note: ‘snprintf’ output between 
1 and 272 bytes into a destination of size 64
 1993 |                                 snprintf(xstats_names[count].name, 
sizeof(xstats_names[count].name),
      |                                 
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 1994 |                                 "%s", zxdh_mac_bytes_strings[i].name);
      |                                 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
../drivers/net/zxdh/zxdh_ethdev_ops.c:2000:26: warning: ‘%s’ directive output 
may be truncated writing up to 339 bytes into a region of size 64 
[-Wformat-truncation=]
 2000 |                         "%s", zxdh_vqm_stat_strings[i].name);
      |                          ^~
../drivers/net/zxdh/zxdh_ethdev_ops.c:1999:25: note: ‘snprintf’ output between 
1 and 340 bytes into a destination of size 64
 1999 |                         snprintf(xstats_names[count].name, 
sizeof(xstats_names[count].name),
      |                         
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 2000 |                         "%s", zxdh_vqm_stat_strings[i].name);
      |                         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
../drivers/net/zxdh/zxdh_ethdev_ops.c:2010:41: warning: ‘%s’ directive output 
may be truncated writing up to 1359 bytes into a region of size between 54 and 
58 [-Wformat-truncation=]
 2010 |                                 "rx_q%u_%s", i, 
zxdh_rxq_stat_strings[t].name);
      |                                         ^~
../drivers/net/zxdh/zxdh_ethdev_ops.c:2009:33: note: ‘snprintf’ output between 
7 and 1370 bytes into a destination of size 64
 2009 |                                 snprintf(xstats_names[count].name, 
sizeof(xstats_names[count].name),
      |                                 
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 2010 |                                 "rx_q%u_%s", i, 
zxdh_rxq_stat_strings[t].name);
      |                                 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
../drivers/net/zxdh/zxdh_ethdev_ops.c:2022:41: warning: ‘%s’ directive output 
may be truncated writing up to 1291 bytes into a region of size between 54 and 
58 [-Wformat-truncation=]
 2022 |                                 "tx_q%u_%s", i, 
zxdh_txq_stat_strings[t].name);
      |                                         ^~
../drivers/net/zxdh/zxdh_ethdev_ops.c:2021:33: note: ‘snprintf’ output between 
7 and 1302 bytes into a destination of size 64
 2021 |                                 snprintf(xstats_names[count].name, 
sizeof(xstats_names[count].name),
      |                                 
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 2022 |                                 "tx_q%u_%s", i, 
zxdh_txq_stat_strings[t].name);
      |                                 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Look for anti-patterns:
    ✔ Do not put brackets on each switch case.
    ✔ Driver must not disable warnings with compiler flags or pragma's
    ✔ Driver must not use thread and signal
    ✔ Driver should not call abort() or assert() directly
    ✔ Review exposed symbol names

    ✔ Apply coccinelle scripts; look that for example null free checks

  - Apply memcpy script for coccinelle
      Lots of fixed size memcpy's that can get fixed later (see other patch 
series)

    ✔ Review use of malloc
      Several places could use rte_calloc instead of rte_zmalloc (low priority)

    ✘  Review use of memset

Extra memset and cast here:
static int32_t
zxdh_fill_common_msg(struct zxdh_hw *hw, struct zxdh_pci_bar_msg *desc,
                uint8_t type, uint8_t field,
                void *buff, uint16_t buff_size)
{
        uint64_t msg_len = sizeof(struct zxdh_common_msg) + buff_size;

        desc->payload_addr = rte_zmalloc(NULL, msg_len, 0);
        if (unlikely(desc->payload_addr == NULL)) {
                PMD_DRV_LOG(ERR, "Failed to allocate msg_data");
                return -ENOMEM;
        }
        memset(desc->payload_addr, 0, msg_len); // zmalloc memory is already 
zero!
        desc->payload_len = msg_len;
        // payload_addr is void *, cast not needed
        struct zxdh_common_msg *msg_data = (struct zxdh_common_msg 
*)desc->payload_addr;

Reply via email to