DPDK patches and discussions
 help / color / mirror / Atom feed
* [PATCH v6 0/3] net/macb: updated net macb driver.
@ 2025-04-08  6:19 liwencheng
  2025-04-16 15:27 ` Stephen Hemminger
  2025-04-18  3:24 ` [PATCH v7 " Wencheng Li
  0 siblings, 2 replies; 11+ messages in thread
From: liwencheng @ 2025-04-08  6:19 UTC (permalink / raw)
  To: dev

v6:
- Fixed build failures across different OS.

v5:
- Putting __rte_unused after the declaration.
- Correct RX-bytes and TX-bytes statistics.
- Initialize the mbuf_initializer.
- Add driver based on 25.07.
- Fixed some code style issues.

v4:
- Fix tab errors in meson.build file.
- Use RTE_LOG_LINE instead of rte_log.
- Replace %l with %PRI*64.
- Replace rte_smp_[r/w]mb with rte_[r/w]mb.
- Do not use variadic arguments in macros.
- Do not use variable-length array pkts[nb_bufs].
- Use __rte_cache_aligned only for struct or union types alignment.
- Support hardware Rx/Tx checksum offload.
- Fixed some code style issues.
v3:
- Changed functions that always return 0 and whose return value
is unused to void type, improving code simplicity and readability.
- Fixed the implicit conversion issues in the
macb_usxgmii_pcs_check_for_link and
macb_usxgmii_pcs_check_for_link functions.
- Added the missing SPDX license tags.
- Added the missing mailmap entry.
- Updated the MAINTAINERS file to include the missing information.

v2:
- Split the driver into three logically independent patches,
rather than one large patch.
- Added conditional compilation to address the issue of
macb_rxtx_vec_neon.c failing to compile in certain modes.
- Fixed some code style issues.

v1:
- updated net macb driver.

*** BLURB HERE ***

Wencheng Li (3):
  net/macb: add new poll mode driver
  net/macb: add NEON vectorized Rx/Tx
  net/macb: add necessary docs and update related files

 .mailmap                               |    1 +
 MAINTAINERS                            |    6 +
 doc/guides/nics/features/macb.ini      |   27 +
 doc/guides/nics/index.rst              |    1 +
 doc/guides/nics/macb.rst               |   26 +
 doc/guides/rel_notes/release_25_07.rst |    4 +
 drivers/net/macb/base/generic_phy.c    |  271 +++++
 drivers/net/macb/base/generic_phy.h    |  202 ++++
 drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
 drivers/net/macb/base/macb_common.h    |  253 +++++
 drivers/net/macb/base/macb_errno.h     |   58 +
 drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++
 drivers/net/macb/base/macb_type.h      |   23 +
 drivers/net/macb/base/macb_uio.c       |  351 ++++++
 drivers/net/macb/base/macb_uio.h       |   50 +
 drivers/net/macb/base/meson.build      |   25 +
 drivers/net/macb/macb_ethdev.c         | 1861 ++++++++++++++++++++++++++++++++
 drivers/net/macb/macb_ethdev.h         |   91 ++
 drivers/net/macb/macb_log.h            |   19 +
 drivers/net/macb/macb_rxtx.c           | 1394 ++++++++++++++++++++++++
 drivers/net/macb/macb_rxtx.h           |  325 ++++++
 drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
 drivers/net/macb/meson.build           |   22 +
 drivers/net/meson.build                |    1 +
 24 files changed, 7494 insertions(+)
 create mode 100644 doc/guides/nics/features/macb.ini
 create mode 100644 doc/guides/nics/macb.rst
 create mode 100644 drivers/net/macb/base/generic_phy.c
 create mode 100644 drivers/net/macb/base/generic_phy.h
 create mode 100644 drivers/net/macb/base/macb_common.c
 create mode 100644 drivers/net/macb/base/macb_common.h
 create mode 100644 drivers/net/macb/base/macb_errno.h
 create mode 100644 drivers/net/macb/base/macb_hw.h
 create mode 100644 drivers/net/macb/base/macb_type.h
 create mode 100644 drivers/net/macb/base/macb_uio.c
 create mode 100644 drivers/net/macb/base/macb_uio.h
 create mode 100644 drivers/net/macb/base/meson.build
 create mode 100644 drivers/net/macb/macb_ethdev.c
 create mode 100644 drivers/net/macb/macb_ethdev.h
 create mode 100644 drivers/net/macb/macb_log.h
 create mode 100644 drivers/net/macb/macb_rxtx.c
 create mode 100644 drivers/net/macb/macb_rxtx.h
 create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
 create mode 100644 drivers/net/macb/meson.build

-- 
2.7.4


^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: [PATCH v6 0/3] net/macb: updated net macb driver.
  2025-04-08  6:19 [PATCH v6 0/3] net/macb: updated net macb driver liwencheng
@ 2025-04-16 15:27 ` Stephen Hemminger
  2025-04-18  3:24 ` [PATCH v7 " Wencheng Li
  1 sibling, 0 replies; 11+ messages in thread
From: Stephen Hemminger @ 2025-04-16 15:27 UTC (permalink / raw)
  To: liwencheng; +Cc: dev

On Tue,  8 Apr 2025 06:19:07 +0000
liwencheng <liwencheng@phytium.com.cn> wrote:

> v6:
> - Fixed build failures across different OS.
> 
> v5:
> - Putting __rte_unused after the declaration.
> - Correct RX-bytes and TX-bytes statistics.
> - Initialize the mbuf_initializer.
> - Add driver based on 25.07.
> - Fixed some code style issues.
> 
> v4:
> - Fix tab errors in meson.build file.
> - Use RTE_LOG_LINE instead of rte_log.
> - Replace %l with %PRI*64.
> - Replace rte_smp_[r/w]mb with rte_[r/w]mb.
> - Do not use variadic arguments in macros.
> - Do not use variable-length array pkts[nb_bufs].
> - Use __rte_cache_aligned only for struct or union types alignment.
> - Support hardware Rx/Tx checksum offload.
> - Fixed some code style issues.
> v3:
> - Changed functions that always return 0 and whose return value
> is unused to void type, improving code simplicity and readability.
> - Fixed the implicit conversion issues in the
> macb_usxgmii_pcs_check_for_link and
> macb_usxgmii_pcs_check_for_link functions.
> - Added the missing SPDX license tags.
> - Added the missing mailmap entry.
> - Updated the MAINTAINERS file to include the missing information.
> 
> v2:
> - Split the driver into three logically independent patches,
> rather than one large patch.
> - Added conditional compilation to address the issue of
> macb_rxtx_vec_neon.c failing to compile in certain modes.
> - Fixed some code style issues.
> 
> v1:
> - updated net macb driver.
> 
> *** BLURB HERE ***
> 
> Wencheng Li (3):
>   net/macb: add new poll mode driver
>   net/macb: add NEON vectorized Rx/Tx
>   net/macb: add necessary docs and update related files
> 
>  .mailmap                               |    1 +
>  MAINTAINERS                            |    6 +
>  doc/guides/nics/features/macb.ini      |   27 +
>  doc/guides/nics/index.rst              |    1 +
>  doc/guides/nics/macb.rst               |   26 +
>  doc/guides/rel_notes/release_25_07.rst |    4 +
>  drivers/net/macb/base/generic_phy.c    |  271 +++++
>  drivers/net/macb/base/generic_phy.h    |  202 ++++
>  drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
>  drivers/net/macb/base/macb_common.h    |  253 +++++
>  drivers/net/macb/base/macb_errno.h     |   58 +
>  drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++
>  drivers/net/macb/base/macb_type.h      |   23 +
>  drivers/net/macb/base/macb_uio.c       |  351 ++++++
>  drivers/net/macb/base/macb_uio.h       |   50 +
>  drivers/net/macb/base/meson.build      |   25 +
>  drivers/net/macb/macb_ethdev.c         | 1861 ++++++++++++++++++++++++++++++++
>  drivers/net/macb/macb_ethdev.h         |   91 ++
>  drivers/net/macb/macb_log.h            |   19 +
>  drivers/net/macb/macb_rxtx.c           | 1394 ++++++++++++++++++++++++
>  drivers/net/macb/macb_rxtx.h           |  325 ++++++
>  drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
>  drivers/net/macb/meson.build           |   22 +
>  drivers/net/meson.build                |    1 +
>  24 files changed, 7494 insertions(+)
>  create mode 100644 doc/guides/nics/features/macb.ini
>  create mode 100644 doc/guides/nics/macb.rst
>  create mode 100644 drivers/net/macb/base/generic_phy.c
>  create mode 100644 drivers/net/macb/base/generic_phy.h
>  create mode 100644 drivers/net/macb/base/macb_common.c
>  create mode 100644 drivers/net/macb/base/macb_common.h
>  create mode 100644 drivers/net/macb/base/macb_errno.h
>  create mode 100644 drivers/net/macb/base/macb_hw.h
>  create mode 100644 drivers/net/macb/base/macb_type.h
>  create mode 100644 drivers/net/macb/base/macb_uio.c
>  create mode 100644 drivers/net/macb/base/macb_uio.h
>  create mode 100644 drivers/net/macb/base/meson.build
>  create mode 100644 drivers/net/macb/macb_ethdev.c
>  create mode 100644 drivers/net/macb/macb_ethdev.h
>  create mode 100644 drivers/net/macb/macb_log.h
>  create mode 100644 drivers/net/macb/macb_rxtx.c
>  create mode 100644 drivers/net/macb/macb_rxtx.h
>  create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
>  create mode 100644 drivers/net/macb/meson.build
> 

When using Developer's Certificate of Origin, it is important to use
you legal name rather just the mail alias. If you send a follow up
use:
    Signed-off-by: Wencheng Li <liwencheng@phytium.com.cn>

not:
    Signed-off-by: liwencheng <liwencheng@phytium.com.cn>

That is what is causing some check-git-log.sh warnings.

^ permalink raw reply	[flat|nested] 11+ messages in thread

* [PATCH v7 0/3] net/macb: updated net macb driver
  2025-04-08  6:19 [PATCH v6 0/3] net/macb: updated net macb driver liwencheng
  2025-04-16 15:27 ` Stephen Hemminger
@ 2025-04-18  3:24 ` Wencheng Li
  2025-05-27 14:27   ` Stephen Hemminger
  2025-06-04  6:58   ` [PATCH v8 " Wencheng Li
  1 sibling, 2 replies; 11+ messages in thread
From: Wencheng Li @ 2025-04-18  3:24 UTC (permalink / raw)
  To: dev

v7:
- Use a legal name instead of an email alias.
- Do not use additional __rte_cold.
- Replace unsigned long with standard uint64_t.
- Describe the devargs used by the driver in the documentation.
- Update macb.ini.

v6:
- Fixed build failures across different OS.

v5:
- Putting __rte_unused after the declaration.
- Correct RX-bytes and TX-bytes statistics.
- Initialize the mbuf_initializer.
- Add driver based on 25.07.
- Fixed some code style issues.

v4:
- Fix tab errors in meson.build file.
- Use RTE_LOG_LINE instead of rte_log.
- Replace %l with %PRI*64.
- Replace rte_smp_[r/w]mb with rte_[r/w]mb.
- Do not use variadic arguments in macros.
- Do not use variable-length array pkts[nb_bufs].
- Use __rte_cache_aligned only for struct or union types alignment.
- Support hardware Rx/Tx checksum offload.
- Fixed some code style issues.
v3:
- Changed functions that always return 0 and whose return value
is unused to void type, improving code simplicity and readability.
- Fixed the implicit conversion issues in the
macb_usxgmii_pcs_check_for_link and
macb_usxgmii_pcs_check_for_link functions.
- Added the missing SPDX license tags.
- Added the missing mailmap entry.
- Updated the MAINTAINERS file to include the missing information.

v2:
- Split the driver into three logically independent patches,
rather than one large patch.
- Added conditional compilation to address the issue of
macb_rxtx_vec_neon.c failing to compile in certain modes.
- Fixed some code style issues.

v1:
- updated net macb driver.

*** BLURB HERE ***

Wencheng Li (3):
  net/macb: add new poll mode driver
  net/macb: add NEON vectorized Rx/Tx
  net/macb: add necessary docs and update related files

 .mailmap                               |    1 +
 MAINTAINERS                            |    6 +
 doc/guides/nics/features/macb.ini      |   19 +
 doc/guides/nics/index.rst              |    1 +
 doc/guides/nics/macb.rst               |  180 +++
 doc/guides/rel_notes/release_25_07.rst |    4 +
 drivers/net/macb/base/generic_phy.c    |  271 +++++
 drivers/net/macb/base/generic_phy.h    |  202 ++++
 drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
 drivers/net/macb/base/macb_common.h    |  253 +++++
 drivers/net/macb/base/macb_errno.h     |   58 +
 drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++
 drivers/net/macb/base/macb_type.h      |   23 +
 drivers/net/macb/base/macb_uio.c       |  351 ++++++
 drivers/net/macb/base/macb_uio.h       |   50 +
 drivers/net/macb/base/meson.build      |   25 +
 drivers/net/macb/macb_ethdev.c         | 1861 ++++++++++++++++++++++++++++++++
 drivers/net/macb/macb_ethdev.h         |   91 ++
 drivers/net/macb/macb_log.h            |   19 +
 drivers/net/macb/macb_rxtx.c           | 1394 ++++++++++++++++++++++++
 drivers/net/macb/macb_rxtx.h           |  325 ++++++
 drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
 drivers/net/macb/meson.build           |   22 +
 drivers/net/meson.build                |    1 +
 24 files changed, 7640 insertions(+)
 create mode 100644 doc/guides/nics/features/macb.ini
 create mode 100644 doc/guides/nics/macb.rst
 create mode 100644 drivers/net/macb/base/generic_phy.c
 create mode 100644 drivers/net/macb/base/generic_phy.h
 create mode 100644 drivers/net/macb/base/macb_common.c
 create mode 100644 drivers/net/macb/base/macb_common.h
 create mode 100644 drivers/net/macb/base/macb_errno.h
 create mode 100644 drivers/net/macb/base/macb_hw.h
 create mode 100644 drivers/net/macb/base/macb_type.h
 create mode 100644 drivers/net/macb/base/macb_uio.c
 create mode 100644 drivers/net/macb/base/macb_uio.h
 create mode 100644 drivers/net/macb/base/meson.build
 create mode 100644 drivers/net/macb/macb_ethdev.c
 create mode 100644 drivers/net/macb/macb_ethdev.h
 create mode 100644 drivers/net/macb/macb_log.h
 create mode 100644 drivers/net/macb/macb_rxtx.c
 create mode 100644 drivers/net/macb/macb_rxtx.h
 create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
 create mode 100644 drivers/net/macb/meson.build

-- 
2.7.4


^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: [PATCH v7 0/3] net/macb: updated net macb driver
  2025-04-18  3:24 ` [PATCH v7 " Wencheng Li
@ 2025-05-27 14:27   ` Stephen Hemminger
  2025-06-04  6:58   ` [PATCH v8 " Wencheng Li
  1 sibling, 0 replies; 11+ messages in thread
From: Stephen Hemminger @ 2025-05-27 14:27 UTC (permalink / raw)
  To: Wencheng Li; +Cc: dev

On Fri, 18 Apr 2025 03:24:34 +0000
Wencheng Li <liwencheng@phytium.com.cn> wrote:

> v7:
> - Use a legal name instead of an email alias.
> - Do not use additional __rte_cold.
> - Replace unsigned long with standard uint64_t.
> - Describe the devargs used by the driver in the documentation.
> - Update macb.ini.
> 
> v6:
> - Fixed build failures across different OS.
> 
> v5:
> - Putting __rte_unused after the declaration.
> - Correct RX-bytes and TX-bytes statistics.
> - Initialize the mbuf_initializer.
> - Add driver based on 25.07.
> - Fixed some code style issues.
> 
> v4:
> - Fix tab errors in meson.build file.
> - Use RTE_LOG_LINE instead of rte_log.
> - Replace %l with %PRI*64.
> - Replace rte_smp_[r/w]mb with rte_[r/w]mb.
> - Do not use variadic arguments in macros.
> - Do not use variable-length array pkts[nb_bufs].
> - Use __rte_cache_aligned only for struct or union types alignment.
> - Support hardware Rx/Tx checksum offload.
> - Fixed some code style issues.
> v3:
> - Changed functions that always return 0 and whose return value
> is unused to void type, improving code simplicity and readability.
> - Fixed the implicit conversion issues in the
> macb_usxgmii_pcs_check_for_link and
> macb_usxgmii_pcs_check_for_link functions.
> - Added the missing SPDX license tags.
> - Added the missing mailmap entry.
> - Updated the MAINTAINERS file to include the missing information.
> 
> v2:
> - Split the driver into three logically independent patches,
> rather than one large patch.
> - Added conditional compilation to address the issue of
> macb_rxtx_vec_neon.c failing to compile in certain modes.
> - Fixed some code style issues.
> 
> v1:
> - updated net macb driver.
> 
> *** BLURB HERE ***

This part is supposed to be removed when sending the commit message.

> 
> Wencheng Li (3):
>   net/macb: add new poll mode driver
>   net/macb: add NEON vectorized Rx/Tx
>   net/macb: add necessary docs and update related files
> 
>  .mailmap                               |    1 +
>  MAINTAINERS                            |    6 +
>  doc/guides/nics/features/macb.ini      |   19 +
>  doc/guides/nics/index.rst              |    1 +
>  doc/guides/nics/macb.rst               |  180 +++
>  doc/guides/rel_notes/release_25_07.rst |    4 +
>  drivers/net/macb/base/generic_phy.c    |  271 +++++
>  drivers/net/macb/base/generic_phy.h    |  202 ++++
>  drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
>  drivers/net/macb/base/macb_common.h    |  253 +++++
>  drivers/net/macb/base/macb_errno.h     |   58 +
>  drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++
>  drivers/net/macb/base/macb_type.h      |   23 +
>  drivers/net/macb/base/macb_uio.c       |  351 ++++++
>  drivers/net/macb/base/macb_uio.h       |   50 +
>  drivers/net/macb/base/meson.build      |   25 +
>  drivers/net/macb/macb_ethdev.c         | 1861 ++++++++++++++++++++++++++++++++
>  drivers/net/macb/macb_ethdev.h         |   91 ++
>  drivers/net/macb/macb_log.h            |   19 +
>  drivers/net/macb/macb_rxtx.c           | 1394 ++++++++++++++++++++++++
>  drivers/net/macb/macb_rxtx.h           |  325 ++++++
>  drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
>  drivers/net/macb/meson.build           |   22 +
>  drivers/net/meson.build                |    1 +
>  24 files changed, 7640 insertions(+)
>  create mode 100644 doc/guides/nics/features/macb.ini
>  create mode 100644 doc/guides/nics/macb.rst
>  create mode 100644 drivers/net/macb/base/generic_phy.c
>  create mode 100644 drivers/net/macb/base/generic_phy.h
>  create mode 100644 drivers/net/macb/base/macb_common.c
>  create mode 100644 drivers/net/macb/base/macb_common.h
>  create mode 100644 drivers/net/macb/base/macb_errno.h
>  create mode 100644 drivers/net/macb/base/macb_hw.h
>  create mode 100644 drivers/net/macb/base/macb_type.h
>  create mode 100644 drivers/net/macb/base/macb_uio.c
>  create mode 100644 drivers/net/macb/base/macb_uio.h
>  create mode 100644 drivers/net/macb/base/meson.build
>  create mode 100644 drivers/net/macb/macb_ethdev.c
>  create mode 100644 drivers/net/macb/macb_ethdev.h
>  create mode 100644 drivers/net/macb/macb_log.h
>  create mode 100644 drivers/net/macb/macb_rxtx.c
>  create mode 100644 drivers/net/macb/macb_rxtx.h
>  create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
>  create mode 100644 drivers/net/macb/meson.build
> 

Noticed that this driver is resetting the log level values.
This doesn't follow pattern of other drivers.

 $ git grep rte_log_set_level
macb/macb_ethdev.c:     rte_log_set_level(macb_logtype, rte_log_get_global_level());
macb/macb_ethdev.c:             rte_log_set_level(macb_logtype, RTE_LOG_NOTICE);

Noticed that driver has option where it needs to link with external
phy library. That should be documented more; what is the library, how to get it etc.

You are using eth0, eth1, etc in the doc but not clear what relationship if any
is with kernel driver.

I would also leave out any non-driver specific options to test-pmd in macb.rst.
These might change in the future, and are not specific to this device.
The default test-pmd values for rxq, txq, rxd, txd should be good enough.

Since macb requires out of tree kernel module.
Where is source for kernel module, what is its license?
If it is not going to be submitted to kernel as GPLv2 then this needs discussion
and approval by Technical Board.

Out of tree kernel modules are a real negative. It is hard to write good, safe, and correct
kernel code for UIO. That is why DPDK abandoned igb_uio and kni. They were buggy,
hard to support and prone to failure.




^ permalink raw reply	[flat|nested] 11+ messages in thread

* [PATCH v8 0/3] net/macb: updated net macb driver
  2025-04-18  3:24 ` [PATCH v7 " Wencheng Li
  2025-05-27 14:27   ` Stephen Hemminger
@ 2025-06-04  6:58   ` Wencheng Li
  2025-06-06  9:05     ` [PATCH v9 " Wencheng Li
  1 sibling, 1 reply; 11+ messages in thread
From: Wencheng Li @ 2025-06-04  6:58 UTC (permalink / raw)
  To: dev

v8:
- Delete log level reset code.
- Delete code that links to external phy library.
- Update document macb.rst.
- Add usage instructions for the macb_uio module.
- Update the explanation of testpmd parameters.

v7:
- Use a legal name instead of an email alias.
- Do not use additional __rte_cold.
- Replace unsigned long with standard uint64_t.
- Describe the devargs used by the driver in the documentation.
- Update macb.ini.

v6:
- Fixed build failures across different OS.

v5:
- Putting __rte_unused after the declaration.
- Correct RX-bytes and TX-bytes statistics.
- Initialize the mbuf_initializer.
- Add driver based on 25.07.
- Fixed some code style issues.

v4:
- Fix tab errors in meson.build file.
- Use RTE_LOG_LINE instead of rte_log.
- Replace %l with %PRI*64.
- Replace rte_smp_[r/w]mb with rte_[r/w]mb.
- Do not use variadic arguments in macros.
- Do not use variable-length array pkts[nb_bufs].
- Use __rte_cache_aligned only for struct or union types alignment.
- Support hardware Rx/Tx checksum offload.
- Fixed some code style issues.
v3:
- Changed functions that always return 0 and whose return value
is unused to void type, improving code simplicity and readability.
- Fixed the implicit conversion issues in the
macb_usxgmii_pcs_check_for_link and
macb_usxgmii_pcs_check_for_link functions.
- Added the missing SPDX license tags.
- Added the missing mailmap entry.
- Updated the MAINTAINERS file to include the missing information.

v2:
- Split the driver into three logically independent patches,
rather than one large patch.
- Added conditional compilation to address the issue of
macb_rxtx_vec_neon.c failing to compile in certain modes.
- Fixed some code style issues.

v1:
- updated net macb driver.

*** BLURB HERE ***

Wencheng Li (3):
  net/macb: add new poll mode driver
  net/macb: add NEON vectorized Rx/Tx
  net/macb: add necessary docs and update related files

 .mailmap                               |    1 +
 MAINTAINERS                            |    6 +
 doc/guides/nics/features/macb.ini      |   19 +
 doc/guides/nics/index.rst              |    1 +
 doc/guides/nics/macb.rst               |  181 ++++
 doc/guides/rel_notes/release_25_07.rst |    4 +
 drivers/net/macb/base/generic_phy.c    |  271 +++++
 drivers/net/macb/base/generic_phy.h    |  202 ++++
 drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
 drivers/net/macb/base/macb_common.h    |  253 +++++
 drivers/net/macb/base/macb_errno.h     |   58 ++
 drivers/net/macb/base/macb_hw.h        | 1138 ++++++++++++++++++++
 drivers/net/macb/base/macb_type.h      |   23 +
 drivers/net/macb/base/macb_uio.c       |  351 +++++++
 drivers/net/macb/base/macb_uio.h       |   50 +
 drivers/net/macb/base/meson.build      |   25 +
 drivers/net/macb/macb_ethdev.c         | 1764 ++++++++++++++++++++++++++++++++
 drivers/net/macb/macb_ethdev.h         |   75 ++
 drivers/net/macb/macb_log.h            |   19 +
 drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
 drivers/net/macb/macb_rxtx.h           |  325 ++++++
 drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
 drivers/net/macb/meson.build           |   22 +
 drivers/net/meson.build                |    1 +
 24 files changed, 7528 insertions(+)
 create mode 100644 doc/guides/nics/features/macb.ini
 create mode 100644 doc/guides/nics/macb.rst
 create mode 100644 drivers/net/macb/base/generic_phy.c
 create mode 100644 drivers/net/macb/base/generic_phy.h
 create mode 100644 drivers/net/macb/base/macb_common.c
 create mode 100644 drivers/net/macb/base/macb_common.h
 create mode 100644 drivers/net/macb/base/macb_errno.h
 create mode 100644 drivers/net/macb/base/macb_hw.h
 create mode 100644 drivers/net/macb/base/macb_type.h
 create mode 100644 drivers/net/macb/base/macb_uio.c
 create mode 100644 drivers/net/macb/base/macb_uio.h
 create mode 100644 drivers/net/macb/base/meson.build
 create mode 100644 drivers/net/macb/macb_ethdev.c
 create mode 100644 drivers/net/macb/macb_ethdev.h
 create mode 100644 drivers/net/macb/macb_log.h
 create mode 100644 drivers/net/macb/macb_rxtx.c
 create mode 100644 drivers/net/macb/macb_rxtx.h
 create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
 create mode 100644 drivers/net/macb/meson.build

-- 
2.7.4


^ permalink raw reply	[flat|nested] 11+ messages in thread

* [PATCH v9 0/3] net/macb: updated net macb driver
  2025-06-04  6:58   ` [PATCH v8 " Wencheng Li
@ 2025-06-06  9:05     ` Wencheng Li
  2025-06-06 15:38       ` Stephen Hemminger
                         ` (2 more replies)
  0 siblings, 3 replies; 11+ messages in thread
From: Wencheng Li @ 2025-06-06  9:05 UTC (permalink / raw)
  To: dev

v9:
- Added RTE_PMD_REGISTER_KMOD_DEP macro to
 declare dependency on macb_uio kernel module.
- The source link for the macb_uio module
 can be found in macb.rst.

v8:
- Delete log level reset code.
- Delete code that links to external phy library.
- Update document macb.rst.
- Add usage instructions for the macb_uio module.
- Update the explanation of testpmd parameters.

v7:
- Use a legal name instead of an email alias.
- Do not use additional __rte_cold.
- Replace unsigned long with standard uint64_t.
- Describe the devargs used by the driver in the documentation.
- Update macb.ini.

v6:
- Fixed build failures across different OS.

v5:
- Putting __rte_unused after the declaration.
- Correct RX-bytes and TX-bytes statistics.
- Initialize the mbuf_initializer.
- Add driver based on 25.07.
- Fixed some code style issues.

v4:
- Fix tab errors in meson.build file.
- Use RTE_LOG_LINE instead of rte_log.
- Replace %l with %PRI*64.
- Replace rte_smp_[r/w]mb with rte_[r/w]mb.
- Do not use variadic arguments in macros.
- Do not use variable-length array pkts[nb_bufs].
- Use __rte_cache_aligned only for struct or union types alignment.
- Support hardware Rx/Tx checksum offload.
- Fixed some code style issues.
v3:
- Changed functions that always return 0 and whose return value
is unused to void type, improving code simplicity and readability.
- Fixed the implicit conversion issues in the
macb_usxgmii_pcs_check_for_link and
macb_usxgmii_pcs_check_for_link functions.
- Added the missing SPDX license tags.
- Added the missing mailmap entry.
- Updated the MAINTAINERS file to include the missing information.

v2:
- Split the driver into three logically independent patches,
rather than one large patch.
- Added conditional compilation to address the issue of
macb_rxtx_vec_neon.c failing to compile in certain modes.
- Fixed some code style issues.

v1:
- updated net macb driver.

*** BLURB HERE ***

Wencheng Li (3):
  net/macb: add new poll mode driver
  net/macb: add NEON vectorized Rx/Tx
  net/macb: add necessary docs and update related files

 .mailmap                               |    1 +
 MAINTAINERS                            |    6 +
 doc/guides/nics/features/macb.ini      |   19 +
 doc/guides/nics/index.rst              |    1 +
 doc/guides/nics/macb.rst               |  181 ++++
 doc/guides/rel_notes/release_25_07.rst |    4 +
 drivers/net/macb/base/generic_phy.c    |  271 +++++
 drivers/net/macb/base/generic_phy.h    |  202 ++++
 drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
 drivers/net/macb/base/macb_common.h    |  253 +++++
 drivers/net/macb/base/macb_errno.h     |   58 ++
 drivers/net/macb/base/macb_hw.h        | 1138 ++++++++++++++++++++
 drivers/net/macb/base/macb_type.h      |   23 +
 drivers/net/macb/base/macb_uio.c       |  351 +++++++
 drivers/net/macb/base/macb_uio.h       |   50 +
 drivers/net/macb/base/meson.build      |   25 +
 drivers/net/macb/macb_ethdev.c         | 1765 ++++++++++++++++++++++++++++++++
 drivers/net/macb/macb_ethdev.h         |   75 ++
 drivers/net/macb/macb_log.h            |   19 +
 drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
 drivers/net/macb/macb_rxtx.h           |  325 ++++++
 drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
 drivers/net/macb/meson.build           |   22 +
 drivers/net/meson.build                |    1 +
 24 files changed, 7529 insertions(+)
 create mode 100644 doc/guides/nics/features/macb.ini
 create mode 100644 doc/guides/nics/macb.rst
 create mode 100644 drivers/net/macb/base/generic_phy.c
 create mode 100644 drivers/net/macb/base/generic_phy.h
 create mode 100644 drivers/net/macb/base/macb_common.c
 create mode 100644 drivers/net/macb/base/macb_common.h
 create mode 100644 drivers/net/macb/base/macb_errno.h
 create mode 100644 drivers/net/macb/base/macb_hw.h
 create mode 100644 drivers/net/macb/base/macb_type.h
 create mode 100644 drivers/net/macb/base/macb_uio.c
 create mode 100644 drivers/net/macb/base/macb_uio.h
 create mode 100644 drivers/net/macb/base/meson.build
 create mode 100644 drivers/net/macb/macb_ethdev.c
 create mode 100644 drivers/net/macb/macb_ethdev.h
 create mode 100644 drivers/net/macb/macb_log.h
 create mode 100644 drivers/net/macb/macb_rxtx.c
 create mode 100644 drivers/net/macb/macb_rxtx.h
 create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
 create mode 100644 drivers/net/macb/meson.build

-- 
2.7.4


^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: [PATCH v9 0/3] net/macb: updated net macb driver
  2025-06-06  9:05     ` [PATCH v9 " Wencheng Li
@ 2025-06-06 15:38       ` Stephen Hemminger
  2025-06-10  0:20       ` Stephen Hemminger
  2025-08-20  4:32       ` [PATCH v10 " Wencheng Li
  2 siblings, 0 replies; 11+ messages in thread
From: Stephen Hemminger @ 2025-06-06 15:38 UTC (permalink / raw)
  To: Wencheng Li; +Cc: dev

On Fri,  6 Jun 2025 09:05:14 +0000
Wencheng Li <liwencheng@phytium.com.cn> wrote:

> v9:
> - Added RTE_PMD_REGISTER_KMOD_DEP macro to
>  declare dependency on macb_uio kernel module.
> - The source link for the macb_uio module
>  can be found in macb.rst.
> 
> v8:
> - Delete log level reset code.
> - Delete code that links to external phy library.
> - Update document macb.rst.
> - Add usage instructions for the macb_uio module.
> - Update the explanation of testpmd parameters.
> 
> v7:
> - Use a legal name instead of an email alias.
> - Do not use additional __rte_cold.
> - Replace unsigned long with standard uint64_t.
> - Describe the devargs used by the driver in the documentation.
> - Update macb.ini.
> 
> v6:
> - Fixed build failures across different OS.
> 
> v5:
> - Putting __rte_unused after the declaration.
> - Correct RX-bytes and TX-bytes statistics.
> - Initialize the mbuf_initializer.
> - Add driver based on 25.07.
> - Fixed some code style issues.
> 
> v4:
> - Fix tab errors in meson.build file.
> - Use RTE_LOG_LINE instead of rte_log.
> - Replace %l with %PRI*64.
> - Replace rte_smp_[r/w]mb with rte_[r/w]mb.
> - Do not use variadic arguments in macros.
> - Do not use variable-length array pkts[nb_bufs].
> - Use __rte_cache_aligned only for struct or union types alignment.
> - Support hardware Rx/Tx checksum offload.
> - Fixed some code style issues.
> v3:
> - Changed functions that always return 0 and whose return value
> is unused to void type, improving code simplicity and readability.
> - Fixed the implicit conversion issues in the
> macb_usxgmii_pcs_check_for_link and
> macb_usxgmii_pcs_check_for_link functions.
> - Added the missing SPDX license tags.
> - Added the missing mailmap entry.
> - Updated the MAINTAINERS file to include the missing information.
> 
> v2:
> - Split the driver into three logically independent patches,
> rather than one large patch.
> - Added conditional compilation to address the issue of
> macb_rxtx_vec_neon.c failing to compile in certain modes.
> - Fixed some code style issues.
> 
> v1:
> - updated net macb driver.
> 
> *** BLURB HERE ***
> 
> Wencheng Li (3):
>   net/macb: add new poll mode driver
>   net/macb: add NEON vectorized Rx/Tx
>   net/macb: add necessary docs and update related files
> 
>  .mailmap                               |    1 +
>  MAINTAINERS                            |    6 +
>  doc/guides/nics/features/macb.ini      |   19 +
>  doc/guides/nics/index.rst              |    1 +
>  doc/guides/nics/macb.rst               |  181 ++++
>  doc/guides/rel_notes/release_25_07.rst |    4 +
>  drivers/net/macb/base/generic_phy.c    |  271 +++++
>  drivers/net/macb/base/generic_phy.h    |  202 ++++
>  drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
>  drivers/net/macb/base/macb_common.h    |  253 +++++
>  drivers/net/macb/base/macb_errno.h     |   58 ++
>  drivers/net/macb/base/macb_hw.h        | 1138 ++++++++++++++++++++
>  drivers/net/macb/base/macb_type.h      |   23 +
>  drivers/net/macb/base/macb_uio.c       |  351 +++++++
>  drivers/net/macb/base/macb_uio.h       |   50 +
>  drivers/net/macb/base/meson.build      |   25 +
>  drivers/net/macb/macb_ethdev.c         | 1765 ++++++++++++++++++++++++++++++++
>  drivers/net/macb/macb_ethdev.h         |   75 ++
>  drivers/net/macb/macb_log.h            |   19 +
>  drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
>  drivers/net/macb/macb_rxtx.h           |  325 ++++++
>  drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
>  drivers/net/macb/meson.build           |   22 +
>  drivers/net/meson.build                |    1 +
>  24 files changed, 7529 insertions(+)
>  create mode 100644 doc/guides/nics/features/macb.ini
>  create mode 100644 doc/guides/nics/macb.rst
>  create mode 100644 drivers/net/macb/base/generic_phy.c
>  create mode 100644 drivers/net/macb/base/generic_phy.h
>  create mode 100644 drivers/net/macb/base/macb_common.c
>  create mode 100644 drivers/net/macb/base/macb_common.h
>  create mode 100644 drivers/net/macb/base/macb_errno.h
>  create mode 100644 drivers/net/macb/base/macb_hw.h
>  create mode 100644 drivers/net/macb/base/macb_type.h
>  create mode 100644 drivers/net/macb/base/macb_uio.c
>  create mode 100644 drivers/net/macb/base/macb_uio.h
>  create mode 100644 drivers/net/macb/base/meson.build
>  create mode 100644 drivers/net/macb/macb_ethdev.c
>  create mode 100644 drivers/net/macb/macb_ethdev.h
>  create mode 100644 drivers/net/macb/macb_log.h
>  create mode 100644 drivers/net/macb/macb_rxtx.c
>  create mode 100644 drivers/net/macb/macb_rxtx.h
>  create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
>  create mode 100644 drivers/net/macb/meson.build
> 

Could you submit the macb_uio driver for review in dpdk-kmods repo?

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: [PATCH v9 0/3] net/macb: updated net macb driver
  2025-06-06  9:05     ` [PATCH v9 " Wencheng Li
  2025-06-06 15:38       ` Stephen Hemminger
@ 2025-06-10  0:20       ` Stephen Hemminger
  2025-08-20  4:32       ` [PATCH v10 " Wencheng Li
  2 siblings, 0 replies; 11+ messages in thread
From: Stephen Hemminger @ 2025-06-10  0:20 UTC (permalink / raw)
  To: Wencheng Li; +Cc: dev

On Fri,  6 Jun 2025 09:05:14 +0000
Wencheng Li <liwencheng@phytium.com.cn> wrote:

> v9:
> - Added RTE_PMD_REGISTER_KMOD_DEP macro to
>  declare dependency on macb_uio kernel module.
> - The source link for the macb_uio module
>  can be found in macb.rst.
> 
> v8:
> - Delete log level reset code.
> - Delete code that links to external phy library.
> - Update document macb.rst.
> - Add usage instructions for the macb_uio module.
> - Update the explanation of testpmd parameters.
> 
> v7:
> - Use a legal name instead of an email alias.
> - Do not use additional __rte_cold.
> - Replace unsigned long with standard uint64_t.
> - Describe the devargs used by the driver in the documentation.
> - Update macb.ini.
> 
> v6:
> - Fixed build failures across different OS.
> 
> v5:
> - Putting __rte_unused after the declaration.
> - Correct RX-bytes and TX-bytes statistics.
> - Initialize the mbuf_initializer.
> - Add driver based on 25.07.
> - Fixed some code style issues.
> 
> v4:
> - Fix tab errors in meson.build file.
> - Use RTE_LOG_LINE instead of rte_log.
> - Replace %l with %PRI*64.
> - Replace rte_smp_[r/w]mb with rte_[r/w]mb.
> - Do not use variadic arguments in macros.
> - Do not use variable-length array pkts[nb_bufs].
> - Use __rte_cache_aligned only for struct or union types alignment.
> - Support hardware Rx/Tx checksum offload.
> - Fixed some code style issues.
> v3:
> - Changed functions that always return 0 and whose return value
> is unused to void type, improving code simplicity and readability.
> - Fixed the implicit conversion issues in the
> macb_usxgmii_pcs_check_for_link and
> macb_usxgmii_pcs_check_for_link functions.
> - Added the missing SPDX license tags.
> - Added the missing mailmap entry.
> - Updated the MAINTAINERS file to include the missing information.
> 
> v2:
> - Split the driver into three logically independent patches,
> rather than one large patch.
> - Added conditional compilation to address the issue of
> macb_rxtx_vec_neon.c failing to compile in certain modes.
> - Fixed some code style issues.
> 
> v1:
> - updated net macb driver.
> 
> *** BLURB HERE ***
> 
> Wencheng Li (3):
>   net/macb: add new poll mode driver
>   net/macb: add NEON vectorized Rx/Tx
>   net/macb: add necessary docs and update related files
> 
>  .mailmap                               |    1 +
>  MAINTAINERS                            |    6 +
>  doc/guides/nics/features/macb.ini      |   19 +
>  doc/guides/nics/index.rst              |    1 +
>  doc/guides/nics/macb.rst               |  181 ++++
>  doc/guides/rel_notes/release_25_07.rst |    4 +
>  drivers/net/macb/base/generic_phy.c    |  271 +++++
>  drivers/net/macb/base/generic_phy.h    |  202 ++++
>  drivers/net/macb/base/macb_common.c    |  670 ++++++++++++
>  drivers/net/macb/base/macb_common.h    |  253 +++++
>  drivers/net/macb/base/macb_errno.h     |   58 ++
>  drivers/net/macb/base/macb_hw.h        | 1138 ++++++++++++++++++++
>  drivers/net/macb/base/macb_type.h      |   23 +
>  drivers/net/macb/base/macb_uio.c       |  351 +++++++
>  drivers/net/macb/base/macb_uio.h       |   50 +
>  drivers/net/macb/base/meson.build      |   25 +
>  drivers/net/macb/macb_ethdev.c         | 1765 ++++++++++++++++++++++++++++++++
>  drivers/net/macb/macb_ethdev.h         |   75 ++
>  drivers/net/macb/macb_log.h            |   19 +
>  drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
>  drivers/net/macb/macb_rxtx.h           |  325 ++++++
>  drivers/net/macb/macb_rxtx_vec_neon.c  |  675 ++++++++++++
>  drivers/net/macb/meson.build           |   22 +
>  drivers/net/meson.build                |    1 +
>  24 files changed, 7529 insertions(+)
>  create mode 100644 doc/guides/nics/features/macb.ini
>  create mode 100644 doc/guides/nics/macb.rst
>  create mode 100644 drivers/net/macb/base/generic_phy.c
>  create mode 100644 drivers/net/macb/base/generic_phy.h
>  create mode 100644 drivers/net/macb/base/macb_common.c
>  create mode 100644 drivers/net/macb/base/macb_common.h
>  create mode 100644 drivers/net/macb/base/macb_errno.h
>  create mode 100644 drivers/net/macb/base/macb_hw.h
>  create mode 100644 drivers/net/macb/base/macb_type.h
>  create mode 100644 drivers/net/macb/base/macb_uio.c
>  create mode 100644 drivers/net/macb/base/macb_uio.h
>  create mode 100644 drivers/net/macb/base/meson.build
>  create mode 100644 drivers/net/macb/macb_ethdev.c
>  create mode 100644 drivers/net/macb/macb_ethdev.h
>  create mode 100644 drivers/net/macb/macb_log.h
>  create mode 100644 drivers/net/macb/macb_rxtx.c
>  create mode 100644 drivers/net/macb/macb_rxtx.h
>  create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
>  create mode 100644 drivers/net/macb/meson.build
> 

Driver is looking much better, still see some issues to address.
All check scrips and builds passed.

Uio
    The macb_uio driver has its own issues. It should be submitted and reviewed
    first. Maybe the ARM maintainers have better idea on how to read platform
    values.

Multiq
    Having multiple queues (8) without RSS is confusing.
    If you have 8 Rx queues, then in theory without RSS or RTE flow
    all packets should arrive on only one queue. I doubt that is what
    this hardware does.

Pragmas
    Using pragmas should be avoided.
    Why does vector neon need to disable cast-qual?

Dead code
    Why does base/macb_common.h include a spinlock, but it is  never used?


Name conflicts
    Symbol namespace issues (static linkage).
    C does not have namespaces, all drivers need to play nice and not
    overlap with libraries and each other.

 $ nm build/drivers/librte_net_macb.a | grep ' T ' | grep -v ' macb_'
0000000000000330 T get_last_num_from_string
00000000000000ec T hw_is_native_io
000000000000053e T genphy_check_for_link
00000000000003c4 T genphy_force_speed_duplex
00000000000005c5 T genphy_read_status
00000000000002ee T genphy_resume
000000000000027f T genphy_soft_reset
0000000000000360 T genphy_suspend
0000000000008068 T eth_macb_recv_pkts
0000000000015226 T eth_macb_recv_pkts_vec
000000000000862c T eth_macb_recv_scattered_pkts
000000000001523f T eth_macb_recv_scattered_pkts_vec
0000000000014f98 T eth_macb_rx_init
0000000000014058 T eth_macb_rx_queue_release
00000000000144a9 T eth_macb_rx_queue_setup
000000000000d86a T eth_macb_tx_init
000000000000cdb8 T eth_macb_tx_queue_release
000000000000cf9d T eth_macb_tx_queue_setup
0000000000005a75 T eth_macb_xmit_pkts
0000000000015258 T eth_macb_xmit_pkts_vec


> +int get_last_num_from_string(char *buf, int *id)
> +{
> +	int len = strlen(buf);
> +	int i, found = 0;
> +
> +	for (i = len - 1; (i >= 0); i--) {
> +		if (isdigit(buf[i]))
> +			found++;
> +		else if (found)
> +			break;
> +	}
> +
> +	if (found) {
> +		*id = atoi(&buf[i + 1]);
> +		return 0;
> +	}
> +
> +	return -1;
> +}
> +

Only called in macb_common.c so should be static.
This avoid exposing non-macb function names in static linkage.

Whitespace

> +/**
> + * DPDK callback to get device statistics.
> + *
> + * @param dev
> + *   Pointer to Ethernet device structure.
> + * @param stats
> + *   Stats structure output buffer.
> + *
> + * @return
> + *   0 on success, negative error value otherwise.
> + */
> +static int eth_macb_stats_get(struct rte_eth_dev *dev,
> +							  struct rte_eth_stats *stats)
> +{

The indentation style here (and a couple of other places) is odd.
Please indent so that the arguments line up not so far right.

If in doubt, use clang-format to find/fix things



> +static int eth_macb_stats_get(struct rte_eth_dev *dev,
> +							  struct rte_eth_stats *stats)
> +{
> +	struct macb_priv *priv = dev->data->dev_private;
> +	struct gem_stats *hwstat = &priv->bp->hw_stats.gem;
> +
> +	if (!priv->bp) {
> +		MACB_LOG(ERR, "Failed to get private data!");
> +		return -EPERM;
> +	}
> +

You are checking in several places for something that should never happen.
You are setting priv->bp as part of the init/probe process.
Maybe use RTE_ASSERT()?


> +static int eth_macb_set_default_mac_addr(struct rte_eth_dev *dev,
> +				     struct rte_ether_addr *mac_addr)
> +{
> +	struct macb_priv *priv = dev->data->dev_private;
> +	struct macb *bp = priv->bp;
> +
> +	if (!rte_is_valid_assigned_ether_addr(mac_addr)) {
> +		MACB_LOG(ERR, "Tried to set invalid MAC address.");
> +		return -EINVAL;
> +	}
> +

This check is already done by caller rte_eth_dev_default_mac_addr_set

> +static int rte_pmd_macb_remove(struct rte_vdev_device *vdev)
> +{
> +	uint16_t dev_id;
> +	int ret = 0;
> +
> +	if (rte_eal_process_type() != RTE_PROC_PRIMARY)
> +		return 0;
> +
> +	RTE_ETH_FOREACH_DEV(dev_id)
> +	{
> +

Minor nit:
Prefer { on same line as RTE_ETH_FOREACH_DEV

^ permalink raw reply	[flat|nested] 11+ messages in thread

* [PATCH v10 0/3] net/macb: updated net macb driver
  2025-06-06  9:05     ` [PATCH v9 " Wencheng Li
  2025-06-06 15:38       ` Stephen Hemminger
  2025-06-10  0:20       ` Stephen Hemminger
@ 2025-08-20  4:32       ` Wencheng Li
  2025-10-24 16:00         ` Stephen Hemminger
  2025-10-24 16:09         ` Stephen Hemminger
  2 siblings, 2 replies; 11+ messages in thread
From: Wencheng Li @ 2025-08-20  4:32 UTC (permalink / raw)
  To: dev

v10:
- Removed unused spinlock from base/macb_common.h.
- Renamed symbols to avoid name conflicts.
- Remove unnecessary pragmas
- Fixed some code style issues.

v9:
- Added RTE_PMD_REGISTER_KMOD_DEP macro to
 declare dependency on macb_uio kernel module.
- The source link for the macb_uio module
 can be found in macb.rst.

v8:
- Delete log level reset code.
- Delete code that links to external phy library.
- Update document macb.rst.
- Add usage instructions for the macb_uio module.
- Update the explanation of testpmd parameters.

v7:
- Use a legal name instead of an email alias.
- Do not use additional __rte_cold.
- Replace unsigned long with standard uint64_t.

* Describe the devargs used by the driver in the documentation.
* Update macb.ini.

v6:
- Fixed build failures across different OS.

v5:
- Putting __rte_unused after the declaration.
- Correct RX-bytes and TX-bytes statistics.
- Initialize the mbuf_initializer.
- Add driver based on 25.07.
- Fixed some code style issues.

v4:
- Fix tab errors in meson.build file.
- Use RTE_LOG_LINE instead of rte_log.
- Replace %l with %PRI*64.
- Replace rte_smp_[r/w]mb with rte_[r/w]mb.
- Do not use variadic arguments in macros.
- Do not use variable-length array pkts[nb_bufs].
- Use __rte_cache_aligned only for struct or union types alignment.
- Support hardware Rx/Tx checksum offload.
- Fixed some code style issues.
v3:
- Changed functions that always return 0 and whose return value
is unused to void type, improving code simplicity and readability.
- Fixed the implicit conversion issues in the
macb_usxgmii_pcs_check_for_link and
macb_usxgmii_pcs_check_for_link functions.
- Added the missing SPDX license tags.
- Added the missing mailmap entry.
- Updated the MAINTAINERS file to include the missing information.

v2:
- Split the driver into three logically independent patches,
rather than one large patch.
- Added conditional compilation to address the issue of
macb_rxtx_vec_neon.c failing to compile in certain modes.
- Fixed some code style issues.

v1:
- updated net macb driver.

Wencheng Li (3):
  net/macb: add new poll mode driver
  net/macb: add NEON vectorized Rx/Tx
  net/macb: add necessary docs and update related files

 .mailmap                               |    1 +
 MAINTAINERS                            |    6 +
 doc/guides/nics/features/macb.ini      |   19 +
 doc/guides/nics/index.rst              |    1 +
 doc/guides/nics/macb.rst               |  181 ++++
 doc/guides/rel_notes/release_25_11.rst |   32 +-
 drivers/net/macb/base/generic_phy.c    |  271 +++++
 drivers/net/macb/base/generic_phy.h    |  195 ++++
 drivers/net/macb/base/macb_common.c    |  650 ++++++++++++
 drivers/net/macb/base/macb_common.h    |  250 +++++
 drivers/net/macb/base/macb_errno.h     |   58 ++
 drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++++
 drivers/net/macb/base/macb_type.h      |   23 +
 drivers/net/macb/base/macb_uio.c       |  351 +++++++
 drivers/net/macb/base/macb_uio.h       |   50 +
 drivers/net/macb/base/meson.build      |   25 +
 drivers/net/macb/macb_ethdev.c         | 1755 ++++++++++++++++++++++++++++++++
 drivers/net/macb/macb_ethdev.h         |   75 ++
 drivers/net/macb/macb_log.h            |   19 +
 drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
 drivers/net/macb/macb_rxtx.h           |  325 ++++++
 drivers/net/macb/macb_rxtx_vec_neon.c  |  673 ++++++++++++
 drivers/net/macb/meson.build           |   22 +
 drivers/net/meson.build                |    1 +
 24 files changed, 7486 insertions(+), 29 deletions(-)
 create mode 100644 doc/guides/nics/features/macb.ini
 create mode 100644 doc/guides/nics/macb.rst
 create mode 100644 drivers/net/macb/base/generic_phy.c
 create mode 100644 drivers/net/macb/base/generic_phy.h
 create mode 100644 drivers/net/macb/base/macb_common.c
 create mode 100644 drivers/net/macb/base/macb_common.h
 create mode 100644 drivers/net/macb/base/macb_errno.h
 create mode 100644 drivers/net/macb/base/macb_hw.h
 create mode 100644 drivers/net/macb/base/macb_type.h
 create mode 100644 drivers/net/macb/base/macb_uio.c
 create mode 100644 drivers/net/macb/base/macb_uio.h
 create mode 100644 drivers/net/macb/base/meson.build
 create mode 100644 drivers/net/macb/macb_ethdev.c
 create mode 100644 drivers/net/macb/macb_ethdev.h
 create mode 100644 drivers/net/macb/macb_log.h
 create mode 100644 drivers/net/macb/macb_rxtx.c
 create mode 100644 drivers/net/macb/macb_rxtx.h
 create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
 create mode 100644 drivers/net/macb/meson.build

-- 
2.7.4


^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: [PATCH v10 0/3] net/macb: updated net macb driver
  2025-08-20  4:32       ` [PATCH v10 " Wencheng Li
@ 2025-10-24 16:00         ` Stephen Hemminger
  2025-10-24 16:09         ` Stephen Hemminger
  1 sibling, 0 replies; 11+ messages in thread
From: Stephen Hemminger @ 2025-10-24 16:00 UTC (permalink / raw)
  To: Wencheng Li; +Cc: dev

On Wed, 20 Aug 2025 04:32:07 +0000
Wencheng Li <liwencheng@phytium.com.cn> wrote:

> v10:
> - Removed unused spinlock from base/macb_common.h.
> - Renamed symbols to avoid name conflicts.
> - Remove unnecessary pragmas
> - Fixed some code style issues.
> 
> v9:
> - Added RTE_PMD_REGISTER_KMOD_DEP macro to
>  declare dependency on macb_uio kernel module.
> - The source link for the macb_uio module
>  can be found in macb.rst.
> 
> v8:
> - Delete log level reset code.
> - Delete code that links to external phy library.
> - Update document macb.rst.
> - Add usage instructions for the macb_uio module.
> - Update the explanation of testpmd parameters.
> 
> v7:
> - Use a legal name instead of an email alias.
> - Do not use additional __rte_cold.
> - Replace unsigned long with standard uint64_t.
> 
> * Describe the devargs used by the driver in the documentation.
> * Update macb.ini.
> 
> v6:
> - Fixed build failures across different OS.
> 
> v5:
> - Putting __rte_unused after the declaration.
> - Correct RX-bytes and TX-bytes statistics.
> - Initialize the mbuf_initializer.
> - Add driver based on 25.07.
> - Fixed some code style issues.
> 
> v4:
> - Fix tab errors in meson.build file.
> - Use RTE_LOG_LINE instead of rte_log.
> - Replace %l with %PRI*64.
> - Replace rte_smp_[r/w]mb with rte_[r/w]mb.
> - Do not use variadic arguments in macros.
> - Do not use variable-length array pkts[nb_bufs].
> - Use __rte_cache_aligned only for struct or union types alignment.
> - Support hardware Rx/Tx checksum offload.
> - Fixed some code style issues.
> v3:
> - Changed functions that always return 0 and whose return value
> is unused to void type, improving code simplicity and readability.
> - Fixed the implicit conversion issues in the
> macb_usxgmii_pcs_check_for_link and
> macb_usxgmii_pcs_check_for_link functions.
> - Added the missing SPDX license tags.
> - Added the missing mailmap entry.
> - Updated the MAINTAINERS file to include the missing information.
> 
> v2:
> - Split the driver into three logically independent patches,
> rather than one large patch.
> - Added conditional compilation to address the issue of
> macb_rxtx_vec_neon.c failing to compile in certain modes.
> - Fixed some code style issues.
> 
> v1:
> - updated net macb driver.
> 
> Wencheng Li (3):
>   net/macb: add new poll mode driver
>   net/macb: add NEON vectorized Rx/Tx
>   net/macb: add necessary docs and update related files
> 
>  .mailmap                               |    1 +
>  MAINTAINERS                            |    6 +
>  doc/guides/nics/features/macb.ini      |   19 +
>  doc/guides/nics/index.rst              |    1 +
>  doc/guides/nics/macb.rst               |  181 ++++
>  doc/guides/rel_notes/release_25_11.rst |   32 +-
>  drivers/net/macb/base/generic_phy.c    |  271 +++++
>  drivers/net/macb/base/generic_phy.h    |  195 ++++
>  drivers/net/macb/base/macb_common.c    |  650 ++++++++++++
>  drivers/net/macb/base/macb_common.h    |  250 +++++
>  drivers/net/macb/base/macb_errno.h     |   58 ++
>  drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++++
>  drivers/net/macb/base/macb_type.h      |   23 +
>  drivers/net/macb/base/macb_uio.c       |  351 +++++++
>  drivers/net/macb/base/macb_uio.h       |   50 +
>  drivers/net/macb/base/meson.build      |   25 +
>  drivers/net/macb/macb_ethdev.c         | 1755 ++++++++++++++++++++++++++++++++
>  drivers/net/macb/macb_ethdev.h         |   75 ++
>  drivers/net/macb/macb_log.h            |   19 +
>  drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
>  drivers/net/macb/macb_rxtx.h           |  325 ++++++
>  drivers/net/macb/macb_rxtx_vec_neon.c  |  673 ++++++++++++
>  drivers/net/macb/meson.build           |   22 +
>  drivers/net/meson.build                |    1 +
>  24 files changed, 7486 insertions(+), 29 deletions(-)
>  create mode 100644 doc/guides/nics/features/macb.ini
>  create mode 100644 doc/guides/nics/macb.rst
>  create mode 100644 drivers/net/macb/base/generic_phy.c
>  create mode 100644 drivers/net/macb/base/generic_phy.h
>  create mode 100644 drivers/net/macb/base/macb_common.c
>  create mode 100644 drivers/net/macb/base/macb_common.h
>  create mode 100644 drivers/net/macb/base/macb_errno.h
>  create mode 100644 drivers/net/macb/base/macb_hw.h
>  create mode 100644 drivers/net/macb/base/macb_type.h
>  create mode 100644 drivers/net/macb/base/macb_uio.c
>  create mode 100644 drivers/net/macb/base/macb_uio.h
>  create mode 100644 drivers/net/macb/base/meson.build
>  create mode 100644 drivers/net/macb/macb_ethdev.c
>  create mode 100644 drivers/net/macb/macb_ethdev.h
>  create mode 100644 drivers/net/macb/macb_log.h
>  create mode 100644 drivers/net/macb/macb_rxtx.c
>  create mode 100644 drivers/net/macb/macb_rxtx.h
>  create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
>  create mode 100644 drivers/net/macb/meson.build
> 

The driver can be merged as is. But it would prefer that drivers
do not have gratuitous inclusion of linux headers. The base code has
stuff referring to ioctl's, sockets, and ethtool which is irrelevant
in DPDK. It limits the portability of the driver.

Disabling unused warnings in base code is allowed, but consider it
sloppy practice and there could be bugs.


^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: [PATCH v10 0/3] net/macb: updated net macb driver
  2025-08-20  4:32       ` [PATCH v10 " Wencheng Li
  2025-10-24 16:00         ` Stephen Hemminger
@ 2025-10-24 16:09         ` Stephen Hemminger
  1 sibling, 0 replies; 11+ messages in thread
From: Stephen Hemminger @ 2025-10-24 16:09 UTC (permalink / raw)
  To: Wencheng Li; +Cc: dev

On Wed, 20 Aug 2025 04:32:07 +0000
Wencheng Li <liwencheng@phytium.com.cn> wrote:

> v10:
> - Removed unused spinlock from base/macb_common.h.
> - Renamed symbols to avoid name conflicts.
> - Remove unnecessary pragmas
> - Fixed some code style issues.
> 
> v9:
> - Added RTE_PMD_REGISTER_KMOD_DEP macro to
>  declare dependency on macb_uio kernel module.
> - The source link for the macb_uio module
>  can be found in macb.rst.
> 
> v8:
> - Delete log level reset code.
> - Delete code that links to external phy library.
> - Update document macb.rst.
> - Add usage instructions for the macb_uio module.
> - Update the explanation of testpmd parameters.
> 
> v7:
> - Use a legal name instead of an email alias.
> - Do not use additional __rte_cold.
> - Replace unsigned long with standard uint64_t.
> 
> * Describe the devargs used by the driver in the documentation.
> * Update macb.ini.
> 
> v6:
> - Fixed build failures across different OS.
> 
> v5:
> - Putting __rte_unused after the declaration.
> - Correct RX-bytes and TX-bytes statistics.
> - Initialize the mbuf_initializer.
> - Add driver based on 25.07.
> - Fixed some code style issues.
> 
> v4:
> - Fix tab errors in meson.build file.
> - Use RTE_LOG_LINE instead of rte_log.
> - Replace %l with %PRI*64.
> - Replace rte_smp_[r/w]mb with rte_[r/w]mb.
> - Do not use variadic arguments in macros.
> - Do not use variable-length array pkts[nb_bufs].
> - Use __rte_cache_aligned only for struct or union types alignment.
> - Support hardware Rx/Tx checksum offload.
> - Fixed some code style issues.
> v3:
> - Changed functions that always return 0 and whose return value
> is unused to void type, improving code simplicity and readability.
> - Fixed the implicit conversion issues in the
> macb_usxgmii_pcs_check_for_link and
> macb_usxgmii_pcs_check_for_link functions.
> - Added the missing SPDX license tags.
> - Added the missing mailmap entry.
> - Updated the MAINTAINERS file to include the missing information.
> 
> v2:
> - Split the driver into three logically independent patches,
> rather than one large patch.
> - Added conditional compilation to address the issue of
> macb_rxtx_vec_neon.c failing to compile in certain modes.
> - Fixed some code style issues.
> 
> v1:
> - updated net macb driver.
> 
> Wencheng Li (3):
>   net/macb: add new poll mode driver
>   net/macb: add NEON vectorized Rx/Tx
>   net/macb: add necessary docs and update related files
> 
>  .mailmap                               |    1 +
>  MAINTAINERS                            |    6 +
>  doc/guides/nics/features/macb.ini      |   19 +
>  doc/guides/nics/index.rst              |    1 +
>  doc/guides/nics/macb.rst               |  181 ++++
>  doc/guides/rel_notes/release_25_11.rst |   32 +-
>  drivers/net/macb/base/generic_phy.c    |  271 +++++
>  drivers/net/macb/base/generic_phy.h    |  195 ++++
>  drivers/net/macb/base/macb_common.c    |  650 ++++++++++++
>  drivers/net/macb/base/macb_common.h    |  250 +++++
>  drivers/net/macb/base/macb_errno.h     |   58 ++
>  drivers/net/macb/base/macb_hw.h        | 1138 +++++++++++++++++++++
>  drivers/net/macb/base/macb_type.h      |   23 +
>  drivers/net/macb/base/macb_uio.c       |  351 +++++++
>  drivers/net/macb/base/macb_uio.h       |   50 +
>  drivers/net/macb/base/meson.build      |   25 +
>  drivers/net/macb/macb_ethdev.c         | 1755 ++++++++++++++++++++++++++++++++
>  drivers/net/macb/macb_ethdev.h         |   75 ++
>  drivers/net/macb/macb_log.h            |   19 +
>  drivers/net/macb/macb_rxtx.c           | 1394 +++++++++++++++++++++++++
>  drivers/net/macb/macb_rxtx.h           |  325 ++++++
>  drivers/net/macb/macb_rxtx_vec_neon.c  |  673 ++++++++++++
>  drivers/net/macb/meson.build           |   22 +
>  drivers/net/meson.build                |    1 +
>  24 files changed, 7486 insertions(+), 29 deletions(-)
>  create mode 100644 doc/guides/nics/features/macb.ini
>  create mode 100644 doc/guides/nics/macb.rst
>  create mode 100644 drivers/net/macb/base/generic_phy.c
>  create mode 100644 drivers/net/macb/base/generic_phy.h
>  create mode 100644 drivers/net/macb/base/macb_common.c
>  create mode 100644 drivers/net/macb/base/macb_common.h
>  create mode 100644 drivers/net/macb/base/macb_errno.h
>  create mode 100644 drivers/net/macb/base/macb_hw.h
>  create mode 100644 drivers/net/macb/base/macb_type.h
>  create mode 100644 drivers/net/macb/base/macb_uio.c
>  create mode 100644 drivers/net/macb/base/macb_uio.h
>  create mode 100644 drivers/net/macb/base/meson.build
>  create mode 100644 drivers/net/macb/macb_ethdev.c
>  create mode 100644 drivers/net/macb/macb_ethdev.h
>  create mode 100644 drivers/net/macb/macb_log.h
>  create mode 100644 drivers/net/macb/macb_rxtx.c
>  create mode 100644 drivers/net/macb/macb_rxtx.h
>  create mode 100644 drivers/net/macb/macb_rxtx_vec_neon.c
>  create mode 100644 drivers/net/macb/meson.build
> 

Queued to next-net


^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2025-10-24 16:09 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-04-08  6:19 [PATCH v6 0/3] net/macb: updated net macb driver liwencheng
2025-04-16 15:27 ` Stephen Hemminger
2025-04-18  3:24 ` [PATCH v7 " Wencheng Li
2025-05-27 14:27   ` Stephen Hemminger
2025-06-04  6:58   ` [PATCH v8 " Wencheng Li
2025-06-06  9:05     ` [PATCH v9 " Wencheng Li
2025-06-06 15:38       ` Stephen Hemminger
2025-06-10  0:20       ` Stephen Hemminger
2025-08-20  4:32       ` [PATCH v10 " Wencheng Li
2025-10-24 16:00         ` Stephen Hemminger
2025-10-24 16:09         ` Stephen Hemminger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).