summaryrefslogtreecommitdiffstats
path: root/fs/ceph
diff options
context:
space:
mode:
authorYan, Zheng <zyan@redhat.com>2016-07-05 03:32:31 +0200
committerIlya Dryomov <idryomov@gmail.com>2016-07-28 03:00:41 +0200
commit3469ed0d149ba7066e8fef72be55f67ee7de196d (patch)
treec8466d7f992286328a117a671fb0a43fb23c1a2a /fs/ceph
parentceph: update cap reconnect message to version 3 (diff)
downloadlinux-3469ed0d149ba7066e8fef72be55f67ee7de196d.tar.xz
linux-3469ed0d149ba7066e8fef72be55f67ee7de196d.zip
ceph: include 'follows' of pending snapflush in cap reconnect message
This helps the recovering MDS to reconstruct the internal states that tracking pending snapflush. Signed-off-by: Yan, Zheng <zyan@redhat.com>
Diffstat (limited to 'fs/ceph')
-rw-r--r--fs/ceph/mds_client.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/fs/ceph/mds_client.c b/fs/ceph/mds_client.c
index 131a61f17d8a..bcf20344d904 100644
--- a/fs/ceph/mds_client.c
+++ b/fs/ceph/mds_client.c
@@ -2797,6 +2797,7 @@ static int encode_caps_cb(struct inode *inode, struct ceph_cap *cap,
char *path;
int pathlen, err;
u64 pathbase;
+ u64 snap_follows;
struct dentry *dentry;
ci = cap->ci;
@@ -2843,6 +2844,15 @@ static int encode_caps_cb(struct inode *inode, struct ceph_cap *cap,
rec.v1.snaprealm = cpu_to_le64(ci->i_snap_realm->ino);
rec.v1.pathbase = cpu_to_le64(pathbase);
}
+
+ if (list_empty(&ci->i_cap_snaps)) {
+ snap_follows = 0;
+ } else {
+ struct ceph_cap_snap *capsnap =
+ list_first_entry(&ci->i_cap_snaps,
+ struct ceph_cap_snap, ci_item);
+ snap_follows = capsnap->follows;
+ }
spin_unlock(&ci->i_ceph_lock);
if (recon_state->msg_version >= 2) {
@@ -2872,7 +2882,7 @@ encode_again:
if (recon_state->msg_version >= 3) {
/* version, compat_version and struct_len */
total_len = 2 * sizeof(u8) + sizeof(u32);
- struct_v = 1;
+ struct_v = 2;
}
/*
* number of encoded locks is stable, so copy to pagelist
@@ -2885,6 +2895,9 @@ encode_again:
struct_len += sizeof(rec.v2);
struct_len += sizeof(u32) + pathlen;
+ if (struct_v >= 2)
+ struct_len += sizeof(u64); /* snap_follows */
+
total_len += struct_len;
err = ceph_pagelist_reserve(pagelist, total_len);
@@ -2899,6 +2912,8 @@ encode_again:
ceph_locks_to_pagelist(flocks, pagelist,
num_fcntl_locks,
num_flock_locks);
+ if (struct_v >= 2)
+ ceph_pagelist_encode_64(pagelist, snap_follows);
}
kfree(flocks);
} else {