diff options
author | Sage Weil <sage@newdream.net> | 2010-09-17 08:03:08 -0700 |
---|---|---|
committer | Sage Weil <sage@newdream.net> | 2010-09-17 08:03:08 -0700 |
commit | e835124c2be289515b918f2688ced4249e2de566 (patch) | |
tree | 1bf9bc86a2d1c3e9508dc304830a3bb42ad7de9b /fs/ceph/super.h | |
parent | ae00d4f37f4df56821331deb1028748110dd6dc9 (diff) | |
download | lwn-e835124c2be289515b918f2688ced4249e2de566.tar.gz lwn-e835124c2be289515b918f2688ced4249e2de566.zip |
ceph: only send one flushsnap per cap_snap per mds session
Sending multiple flushsnap messages is problematic because we ignore
the response if the tid doesn't match, and the server may only respond to
each one once. It's also a waste.
So, skip cap_snaps that are already on the flushing list, unless the caller
tells us to resend (because we are reconnecting).
Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs/ceph/super.h')
-rw-r--r-- | fs/ceph/super.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/ceph/super.h b/fs/ceph/super.h index c80bfbe27b05..b87638e84c4b 100644 --- a/fs/ceph/super.h +++ b/fs/ceph/super.h @@ -828,7 +828,8 @@ extern void ceph_put_cap_refs(struct ceph_inode_info *ci, int had); extern void ceph_put_wrbuffer_cap_refs(struct ceph_inode_info *ci, int nr, struct ceph_snap_context *snapc); extern void __ceph_flush_snaps(struct ceph_inode_info *ci, - struct ceph_mds_session **psession); + struct ceph_mds_session **psession, + int again); extern void ceph_check_caps(struct ceph_inode_info *ci, int flags, struct ceph_mds_session *session); extern void ceph_check_delayed_caps(struct ceph_mds_client *mdsc); |