aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2023-02-10 09:04:00 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2023-02-10 09:04:00 -0800
commit3647d2d70640ff85be60793fa4b204bdae26ca44 (patch)
tree4b36ca8cbaa3eaf65cce4027e524f23a9db023f8
parent29716680adbb221a5cd1604e11e81c6f2938e06f (diff)
parente7d84c6a1296d059389f7342d9b4b7defb518d3a (diff)
downloadlinux-3647d2d70640ff85be60793fa4b204bdae26ca44.tar.gz
Merge tag 'ceph-for-6.2-rc8' of https://github.com/ceph/ceph-client
Pull ceph fix from Ilya Dryomov: "A fix for a pretty embarrassing omission in the session flush handler from Xiubo, marked for stable" * tag 'ceph-for-6.2-rc8' of https://github.com/ceph/ceph-client: ceph: flush cap releases when the session is flushed
-rw-r--r--fs/ceph/mds_client.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/ceph/mds_client.c b/fs/ceph/mds_client.c
index e163f58ff3c505..27a245d959c0ad 100644
--- a/fs/ceph/mds_client.c
+++ b/fs/ceph/mds_client.c
@@ -3685,6 +3685,12 @@ static void handle_session(struct ceph_mds_session *session,
break;
case CEPH_SESSION_FLUSHMSG:
+ /* flush cap releases */
+ spin_lock(&session->s_cap_lock);
+ if (session->s_num_cap_releases)
+ ceph_flush_cap_releases(mdsc, session);
+ spin_unlock(&session->s_cap_lock);
+
send_flushmsg_ack(mdsc, session, seq);
break;