Commit 193e7b37 authored by David Disseldorp's avatar David Disseldorp Committed by Ilya Dryomov

ceph: carry snapshot creation time with inodes

MDS InodeStat v3 wire structures include a trailing snapshot creation
time member. Unmarshall this and retain it for a future vxattr.
Signed-off-by: default avatarDavid Disseldorp <ddiss@suse.de>
Reviewed-by: default avatar"Yan, Zheng" <zyan@redhat.com>
Signed-off-by: default avatarIlya Dryomov <idryomov@gmail.com>
parent e1b81439
...@@ -813,6 +813,7 @@ static int fill_inode(struct inode *inode, struct page *locked_page, ...@@ -813,6 +813,7 @@ static int fill_inode(struct inode *inode, struct page *locked_page,
dout("%p mode 0%o uid.gid %d.%d\n", inode, inode->i_mode, dout("%p mode 0%o uid.gid %d.%d\n", inode, inode->i_mode,
from_kuid(&init_user_ns, inode->i_uid), from_kuid(&init_user_ns, inode->i_uid),
from_kgid(&init_user_ns, inode->i_gid)); from_kgid(&init_user_ns, inode->i_gid));
ceph_decode_timespec64(&ci->i_snap_btime, &iinfo->snap_btime);
} }
if ((new_version || (new_issued & CEPH_CAP_LINK_SHARED)) && if ((new_version || (new_issued & CEPH_CAP_LINK_SHARED)) &&
......
...@@ -166,6 +166,15 @@ static int parse_reply_info_in(void **p, void *end, ...@@ -166,6 +166,15 @@ static int parse_reply_info_in(void **p, void *end,
info->dir_pin = -ENODATA; info->dir_pin = -ENODATA;
} }
/* snapshot birth time, remains zero for v<=2 */
if (struct_v >= 3) {
ceph_decode_need(p, end, sizeof(info->snap_btime), bad);
ceph_decode_copy(p, &info->snap_btime,
sizeof(info->snap_btime));
} else {
memset(&info->snap_btime, 0, sizeof(info->snap_btime));
}
*p = end; *p = end;
} else { } else {
if (features & CEPH_FEATURE_MDS_INLINE_DATA) { if (features & CEPH_FEATURE_MDS_INLINE_DATA) {
...@@ -198,6 +207,7 @@ static int parse_reply_info_in(void **p, void *end, ...@@ -198,6 +207,7 @@ static int parse_reply_info_in(void **p, void *end,
} }
info->dir_pin = -ENODATA; info->dir_pin = -ENODATA;
/* info->snap_btime remains zero */
} }
return 0; return 0;
bad: bad:
......
...@@ -69,6 +69,7 @@ struct ceph_mds_reply_info_in { ...@@ -69,6 +69,7 @@ struct ceph_mds_reply_info_in {
u64 max_bytes; u64 max_bytes;
u64 max_files; u64 max_files;
s32 dir_pin; s32 dir_pin;
struct ceph_timespec snap_btime;
}; };
struct ceph_mds_reply_dir_entry { struct ceph_mds_reply_dir_entry {
......
...@@ -384,6 +384,7 @@ struct ceph_inode_info { ...@@ -384,6 +384,7 @@ struct ceph_inode_info {
int i_snap_realm_counter; /* snap realm (if caps) */ int i_snap_realm_counter; /* snap realm (if caps) */
struct list_head i_snap_realm_item; struct list_head i_snap_realm_item;
struct list_head i_snap_flush_item; struct list_head i_snap_flush_item;
struct timespec64 i_snap_btime;
struct work_struct i_work; struct work_struct i_work;
unsigned long i_work_mask; unsigned long i_work_mask;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment