Thread (4 messages) 4 messages, 2 authors, 2024-09-28

Re: [GIT PULL] bcachefs changes for 6.12-rc1

From: Kent Overstreet <kent.overstreet@linux.dev>
Date: 2024-09-28 00:11:13
Also in: linux-bcachefs, linux-fsdevel, lkml

On Fri, Sep 27, 2024 at 08:48:14AM GMT, Herbert Xu wrote:
On Tue, Sep 24, 2024 at 10:48:07PM -0400, Kent Overstreet wrote:
quoted
I've been noticing rhashtable resize is surprisingly heavy (the default
parameters don't ever shrink the table, which is why it's not seen as
much).
Most rhashtable users enable automatic shrinking.
quoted
And, when I was torture testing that code I tripped over what appeared
to be an infinite loop in rht_bucket() when a rehsah is in progress,
which I worked around in

  a592cdf5164d bcachefs: don't use rht_bucket() in btree_key_cache_scan()
You must not walk the rhashtable internal data structures by hand.
If you need to iterate through the whole table, use the provided
walking mechanism.
I was just doing rht_for_each_entry_rcu() (open coded because you don't
provide a safe version).
However, as rhashtable is dynamic, walking it during a resize may
cause you to see some elements twice.  If you want to avoid that,
set up your own linked list of all elements for a completely stable
walk.
Yeah that's fine, but like I said, I was seeing an infinite loop inside
rht_bucket(). That would be an rhashtable bug...
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help