diff options
author | Paul E. McKenney <paulmck@kernel.org> | 2022-08-09 10:24:36 -0700 |
---|---|---|
committer | Paul E. McKenney <paulmck@kernel.org> | 2022-08-31 04:58:15 -0700 |
commit | 99cf092058e13f133ff9373fcbd25ae38509df03 (patch) | |
tree | 8c5a3e700b8a1059316be2183b582bb3fe8a2a5f /usr | |
parent | 022d1b356c8a687a58a74cbc90a92d56d3aa207d (diff) | |
download | lwn-99cf092058e13f133ff9373fcbd25ae38509df03.tar.gz lwn-99cf092058e13f133ff9373fcbd25ae38509df03.zip |
doc: SLAB_TYPESAFE_BY_RCU uses cannot rely on spinlocks
Because the SLAB_TYPESAFE_BY_RCU code does not zero pages that are
to be broken up into slabs, the memory returned by kmem_cache_alloc()
must be fully initialized, including any spinlocks included in the newly
allocated structure. This means that readers attempting to look up an
SLAB_TYPESAFE_BY_RCU object must use a reference-counting approach.
A spinlock may be acquired only after a reference is obtained, which
prevents that object from being passed to kmem_struct_free(), but only
while that reference continues to be held.
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Diffstat (limited to 'usr')
0 files changed, 0 insertions, 0 deletions