On 14/09/2022 10:29, Kevin Laatz wrote:
Currently, there is no way to measure lcore polling busyness in a passive
way, without any modifications to the application. This patchset adds a new
EAL API that will be able to passively track core polling busyness. As part
of the set, new telemetry endpoints are added to read the generate metrics.
---
v7:
* Rename funcs, vars, files to include "poll" where missing.
v6:
* Add API and perf unit tests
v5:
* Fix Windows build
* Make lcore_telemetry_free() an internal interface
* Minor cleanup
v4:
* Fix doc build
* Rename timestamp macro to RTE_LCORE_POLL_BUSYNESS_TIMESTAMP
* Make enable/disable read and write atomic
* Change rte_lcore_poll_busyness_enabled_set() param to bool
* Move mem alloc from enable/disable to init/cleanup
* Other minor fixes
v3:
* Fix missing renaming to poll busyness
* Fix clang compilation
* Fix arm compilation
v2:
* Use rte_get_tsc_hz() to adjust the telemetry period
* Rename to reflect polling busyness vs general busyness
* Fix segfault when calling telemetry timestamp from an unregistered
non-EAL thread.
* Minor cleanup
Anatoly Burakov (2):
eal: add lcore poll busyness telemetry
eal: add cpuset lcore telemetry entries
Kevin Laatz (2):
app/test: add unit tests for lcore poll busyness
doc: add howto guide for lcore poll busyness
app/test/meson.build | 4 +
app/test/test_lcore_poll_busyness_api.c | 134 +++++++
app/test/test_lcore_poll_busyness_perf.c | 72 ++++
config/meson.build | 1 +
config/rte_config.h | 1 +
doc/guides/howto/index.rst | 1 +
doc/guides/howto/lcore_poll_busyness.rst | 93 +++++
lib/bbdev/rte_bbdev.h | 17 +-
lib/compressdev/rte_compressdev.c | 2 +
lib/cryptodev/rte_cryptodev.h | 2 +
lib/distributor/rte_distributor.c | 21 +-
lib/distributor/rte_distributor_single.c | 14 +-
lib/dmadev/rte_dmadev.h | 15 +-
.../common/eal_common_lcore_poll_telemetry.c | 350 ++++++++++++++++++
lib/eal/common/meson.build | 1 +
lib/eal/freebsd/eal.c | 1 +
lib/eal/include/rte_lcore.h | 85 ++++-
lib/eal/linux/eal.c | 1 +
lib/eal/meson.build | 3 +
lib/eal/version.map | 7 +
lib/ethdev/rte_ethdev.h | 2 +
lib/eventdev/rte_eventdev.h | 10 +-
lib/rawdev/rte_rawdev.c | 6 +-
lib/regexdev/rte_regexdev.h | 5 +-
lib/ring/rte_ring_elem_pvt.h | 1 +
meson_options.txt | 2 +
26 files changed, 826 insertions(+), 25 deletions(-)
create mode 100644 app/test/test_lcore_poll_busyness_api.c
create mode 100644 app/test/test_lcore_poll_busyness_perf.c
create mode 100644 doc/guides/howto/lcore_poll_busyness.rst
create mode 100644 lib/eal/common/eal_common_lcore_poll_telemetry.c
Based on the feedback in the discussions on this patchset, we have
decided to revoke the submission of this patchset for the 22.11 release.
We will re-evaluate the design with the aim to provide a more acceptable
solution in a future release.
---
Kevin