path: root/lib/librte_rcu
diff options
authorNikhil Rao <>2019-09-16 15:31:02 +0530
committerDavid Marchand <>2019-10-18 06:09:24 +0200
commite484ccddbe1b41886fef1e445ef2fdfa55086198 (patch)
treefb9a186d3bb66825f7b48cb4c3e6f62e4d1055ef /lib/librte_rcu
parentc1077933d45b2bb6b8721746e63f5a125bd2353a (diff)
service: avoid false sharing on core state
For a valid service, the core mask of the service is checked against the current core and the corresponding entry in the active_on_lcore array is set or reset. Upto 8 cores share the same cache line for their service active_on_lcore array entries since each entry is a uint8_t. Some number of these entries also share the cache line with the internal_flags member of struct rte_service_spec_impl, hence this false sharing also makes the service_valid() check expensive. Eliminate false sharing by moving the active_on_lcore array to a per-core data structure. The array is now indexed by service id. Signed-off-by: Nikhil Rao <> Acked-by: Gage Eads <> Acked-by: Harry van Haaren <>
Diffstat (limited to 'lib/librte_rcu')
0 files changed, 0 insertions, 0 deletions