aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ceph/caps.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ceph/caps.c')
-rw-r--r--fs/ceph/caps.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/fs/ceph/caps.c b/fs/ceph/caps.c
index a1d9bb30c1bf..ae2be696eb5b 100644
--- a/fs/ceph/caps.c
+++ b/fs/ceph/caps.c
@@ -930,7 +930,7 @@ static int send_cap_msg(struct ceph_mds_session *session,
930 u64 size, u64 max_size, 930 u64 size, u64 max_size,
931 struct timespec *mtime, struct timespec *atime, 931 struct timespec *mtime, struct timespec *atime,
932 u64 time_warp_seq, 932 u64 time_warp_seq,
933 uid_t uid, gid_t gid, umode_t mode, 933 kuid_t uid, kgid_t gid, umode_t mode,
934 u64 xattr_version, 934 u64 xattr_version,
935 struct ceph_buffer *xattrs_buf, 935 struct ceph_buffer *xattrs_buf,
936 u64 follows) 936 u64 follows)
@@ -974,8 +974,8 @@ static int send_cap_msg(struct ceph_mds_session *session,
974 ceph_encode_timespec(&fc->atime, atime); 974 ceph_encode_timespec(&fc->atime, atime);
975 fc->time_warp_seq = cpu_to_le32(time_warp_seq); 975 fc->time_warp_seq = cpu_to_le32(time_warp_seq);
976 976
977 fc->uid = cpu_to_le32(uid); 977 fc->uid = cpu_to_le32(from_kuid(&init_user_ns, uid));
978 fc->gid = cpu_to_le32(gid); 978 fc->gid = cpu_to_le32(from_kgid(&init_user_ns, gid));
979 fc->mode = cpu_to_le32(mode); 979 fc->mode = cpu_to_le32(mode);
980 980
981 fc->xattr_version = cpu_to_le64(xattr_version); 981 fc->xattr_version = cpu_to_le64(xattr_version);
@@ -1081,8 +1081,8 @@ static int __send_cap(struct ceph_mds_client *mdsc, struct ceph_cap *cap,
1081 struct timespec mtime, atime; 1081 struct timespec mtime, atime;
1082 int wake = 0; 1082 int wake = 0;
1083 umode_t mode; 1083 umode_t mode;
1084 uid_t uid; 1084 kuid_t uid;
1085 gid_t gid; 1085 kgid_t gid;
1086 struct ceph_mds_session *session; 1086 struct ceph_mds_session *session;
1087 u64 xattr_version = 0; 1087 u64 xattr_version = 0;
1088 struct ceph_buffer *xattr_blob = NULL; 1088 struct ceph_buffer *xattr_blob = NULL;
@@ -2359,10 +2359,11 @@ static void handle_cap_grant(struct inode *inode, struct ceph_mds_caps *grant,
2359 2359
2360 if ((issued & CEPH_CAP_AUTH_EXCL) == 0) { 2360 if ((issued & CEPH_CAP_AUTH_EXCL) == 0) {
2361 inode->i_mode = le32_to_cpu(grant->mode); 2361 inode->i_mode = le32_to_cpu(grant->mode);
2362 inode->i_uid = le32_to_cpu(grant->uid); 2362 inode->i_uid = make_kuid(&init_user_ns, le32_to_cpu(grant->uid));
2363 inode->i_gid = le32_to_cpu(grant->gid); 2363 inode->i_gid = make_kgid(&init_user_ns, le32_to_cpu(grant->gid));
2364 dout("%p mode 0%o uid.gid %d.%d\n", inode, inode->i_mode, 2364 dout("%p mode 0%o uid.gid %d.%d\n", inode, inode->i_mode,
2365 inode->i_uid, inode->i_gid); 2365 from_kuid(&init_user_ns, inode->i_uid),
2366 from_kgid(&init_user_ns, inode->i_gid));
2366 } 2367 }
2367 2368
2368 if ((issued & CEPH_CAP_LINK_EXCL) == 0) 2369 if ((issued & CEPH_CAP_LINK_EXCL) == 0)