mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-16 18:08:20 +00:00
fscache: Introduce fscache_cookie_is_dropped()
FSCACHE_COOKIE_STATE_DROPPED will be read more than once, so let's add a helper to avoid code duplication. Signed-off-by: Yue Hu <huyue2@coolpad.com> Signed-off-by: David Howells <dhowells@redhat.com> Link: https://listman.redhat.com/archives/linux-cachefs/2022-May/006919.html
This commit is contained in:
parent
bf17455b9c
commit
5c4588aea6
@ -372,17 +372,22 @@ nomem:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static inline bool fscache_cookie_is_dropped(struct fscache_cookie *cookie)
|
||||
{
|
||||
return READ_ONCE(cookie->state) == FSCACHE_COOKIE_STATE_DROPPED;
|
||||
}
|
||||
|
||||
static void fscache_wait_on_collision(struct fscache_cookie *candidate,
|
||||
struct fscache_cookie *wait_for)
|
||||
{
|
||||
enum fscache_cookie_state *statep = &wait_for->state;
|
||||
|
||||
wait_var_event_timeout(statep, READ_ONCE(*statep) == FSCACHE_COOKIE_STATE_DROPPED,
|
||||
wait_var_event_timeout(statep, fscache_cookie_is_dropped(wait_for),
|
||||
20 * HZ);
|
||||
if (READ_ONCE(*statep) != FSCACHE_COOKIE_STATE_DROPPED) {
|
||||
if (!fscache_cookie_is_dropped(wait_for)) {
|
||||
pr_notice("Potential collision c=%08x old: c=%08x",
|
||||
candidate->debug_id, wait_for->debug_id);
|
||||
wait_var_event(statep, READ_ONCE(*statep) == FSCACHE_COOKIE_STATE_DROPPED);
|
||||
wait_var_event(statep, fscache_cookie_is_dropped(wait_for));
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user