ceph: ceph_kick_flushing_caps needs the s_mutex
The mdsc->cap_dirty_lock is not held while walking the list in ceph_kick_flushing_caps, which is not safe. ceph_early_kick_flushing_caps does something similar, but the s_mutex is held while it's called and I think that guards against changes to the list. Ensure we hold the s_mutex when calling ceph_kick_flushing_caps, and add some clarifying comments. Signed-off-by: Jeff Layton <jlayton@kernel.org> Reviewed-by: "Yan, Zheng" <zyan@redhat.com> Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
This commit is contained in:

committed by
Ilya Dryomov

parent
d67c72e6cc
commit
829ad4db95
@@ -4024,7 +4024,9 @@ static void check_new_map(struct ceph_mds_client *mdsc,
|
||||
oldstate != CEPH_MDS_STATE_STARTING)
|
||||
pr_info("mds%d recovery completed\n", s->s_mds);
|
||||
kick_requests(mdsc, i);
|
||||
mutex_lock(&s->s_mutex);
|
||||
ceph_kick_flushing_caps(mdsc, s);
|
||||
mutex_unlock(&s->s_mutex);
|
||||
wake_up_session_caps(s, RECONNECT);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user