Hi Honnappa, Reply inlined:
>-----Original Message----- > > Currently, reader-writer concurrency problems in rte_hash are > addressed using reader-writer locks. Use of reader-writer locks > results in following issues: > > 1) In many of the use cases for the hash table, writer threads > are running on control plane. If the writer is preempted while > holding the lock, it will block the readers for an extended period > resulting in packet drops. This problem seems to apply for platforms > with transactional memory support as well because of the algorithm > used for rte_rwlock_write_lock_tm: > > static inline void > rte_rwlock_write_lock_tm(rte_rwlock_t *rwl) > { > if (likely(rte_try_tm(&rwl->cnt))) > return; > rte_rwlock_write_lock(rwl); > } > > i.e. there is a posibility of using rte_rwlock_write_lock in > failure cases. [Wang, Yipeng] In our test, TSX failure happens very rarely on a TSX platform. But we agree that without TSX, the current rte_rwlock implementation may make the writer to hold a lock for a period of time. > 2) Reader-writer lock based solution does not address the following > issue. > rte_hash_lookup_xxx APIs return the index of the element in > the key store. Application(reader) can use that index to reference > other data structures in its scope. Because of this, the > index should not be freed till the application completes > using the index. [Wang, Yipeng] I agree on this use case. But I think we should provide new API functions for deletion to users who want this behavior, without changing the meaning of current API if that is possible. > Current code: > Cores Lookup Lookup > with add > 2 474 246 > 4 935 579 > 6 1387 1048 > 8 1766 1480 > 10 2119 1951 > 12 2546 2441 > > With this patch: > Cores Lookup Lookup > with add > 2 291 211 > 4 297 196 > 6 304 198 > 8 309 202 > 10 315 205 > 12 319 209 > [Wang, Yipeng] It would be good if you could provide the platform information on these results. Another comment is as you know we also have a new extension to rte_hash to enable extendable buckets and partial-key hashing. Thanks for the comments btw. Could you check if your lockless scheme also applies to those extensions?