> From: dev [mailto:dev-boun...@dpdk.org] On Behalf Of David Marchand
> Sent: Monday, 6 July 2020 22.53
> 
> DPDK allows calling some part of its API from a non-EAL thread but this
> has some limitations.
> OVS (and other applications) has its own thread management but still
> want to avoid such limitations by hacking RTE_PER_LCORE(_lcore_id) and
> faking EAL threads potentially unknown of some DPDK component.
> 
> Introduce a new API to register non-EAL thread and associate them to a
> free lcore with a new NON_EAL role.
> This role denotes lcores that do not run DPDK mainloop and as such
> prevents use of rte_eal_wait_lcore() and consorts.
> 
> Multiprocess is not supported as the need for cohabitation with this
> new
> feature is unclear at the moment.
> 
> Signed-off-by: David Marchand <david.march...@redhat.com>
> Acked-by: Andrew Rybchenko <arybche...@solarflare.com>
> Acked-by: Thomas Monjalon <tho...@monjalon.net>
> ---

Following up on a two+ years old patch series, triggered by the discussion [1] 
about statistics counters in the mempool library...

The rte_lcore_role_t enum values are missing the RTE_ prefix, and the meanings 
of the four values should be documented with comments in the source code.

Also, the documentation [2] could benefit from some elaboration about the lcore 
roles. I had to read the source code in depth to understand that each 
"registered non-EAL thread" has a unique lcore_id, which is not used by any 
other EAL or non-EAL thread.

[1]: 
http://inbox.dpdk.org/dev/98cbd80474fa8b44bf855df32c47dc35d87...@smartserver.smartshare.dk/T/#u
[2]: 
http://doc.dpdk.org/guides/prog_guide/env_abstraction_layer.html#multiple-pthread

Reply via email to