From: Patrick Donnelly Date: Tue, 24 Feb 2026 19:30:24 +0000 (-0500) Subject: reef: mds: use SimpleLock::WAIT_ALL for wait mask X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=0199784ab931d02e1a704ab4676bf1a3442dac97;p=ceph.git reef: mds: use SimpleLock::WAIT_ALL for wait mask The Locker uses has_any_waiter for a particular lock to evaluate whether to nudge the log. For the squid, tentacle, and main branches, this larger bit mask (all 64 bits) will cause this to wrongly return true for other locks which have waiters. The side-effect of waking requests spuriously is undesirable but should not affect performance significantly. For reef and older releases, using std::numeric_limits::max() in has_any_waiter() causes a bitwise overflow that sets the wait-queue search bound impossibly high, resulting in the method always incorrectly returning false. This results in nudge_log never nudging the log! Note: for reef the fix is different because of the interface refactor. For that reason, this fix is applied directly to reef. Fixes: db5c9dc2e6cc95a8d112c2131e4cac5340ca9dd0 Fixes: https://tracker.ceph.com/issues/75141 Signed-off-by: Patrick Donnelly --- diff --git a/src/mds/SimpleLock.h b/src/mds/SimpleLock.h index 2a852c29d29..58c4bbb9919 100644 --- a/src/mds/SimpleLock.h +++ b/src/mds/SimpleLock.h @@ -223,7 +223,7 @@ public: return parent->is_waiter_for(mask << get_wait_shift()); } bool has_any_waiter() const { - return is_waiter_for(std::numeric_limits::max()); + return parent->is_waiter_for(WAIT_ALL << get_wait_shift(), WAIT_RD << get_wait_shift()); } bool is_cached() const {