cifs: Convert struct cifs_fattr to use kuid and kgids
authorEric W. Biederman <ebiederm@xmission.com>
Wed, 6 Feb 2013 09:53:25 +0000 (01:53 -0800)
committerEric W. Biederman <ebiederm@xmission.com>
Wed, 13 Feb 2013 15:28:51 +0000 (07:28 -0800)
In cifs_unix_to_basic_fattr only update the cifs_fattr with an id if
it is valid after conversion.

Cc: Steve French <smfrench@gmail.com>
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
fs/cifs/cifsglob.h
fs/cifs/inode.c

index 7993a7a07ae2150e50bcd36dccd69c9f2a7ad376..98312fda0d35006c2538da86ea5ee2140e94ec9e 100644 (file)
@@ -1245,8 +1245,8 @@ struct cifs_fattr {
        u64             cf_eof;
        u64             cf_bytes;
        u64             cf_createtime;
-       uid_t           cf_uid;
-       gid_t           cf_gid;
+       kuid_t          cf_uid;
+       kgid_t          cf_gid;
        umode_t         cf_mode;
        dev_t           cf_rdev;
        unsigned int    cf_nlink;
index 7376439405406dc5ea18add963de1fda503cad43..9638233964fc68f3b36d3b5b7693bdf85e08014a 100644 (file)
@@ -247,15 +247,21 @@ cifs_unix_basic_to_fattr(struct cifs_fattr *fattr, FILE_UNIX_BASIC_INFO *info,
        fattr->cf_uid = cifs_sb->mnt_uid;
        if (!(cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_UID)) {
                u64 id = le64_to_cpu(info->Uid);
-               if (id < ((uid_t)-1))
-                       fattr->cf_uid = id;
+               if (id < ((uid_t)-1)) {
+                       kuid_t uid = make_kuid(&init_user_ns, id);
+                       if (uid_valid(uid))
+                               fattr->cf_uid = uid;
+               }
        }
        
        fattr->cf_gid = cifs_sb->mnt_gid;
        if (!(cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_GID)) {
                u64 id = le64_to_cpu(info->Gid);
-               if (id < ((gid_t)-1))
-                       fattr->cf_gid = id;
+               if (id < ((gid_t)-1)) {
+                       kgid_t gid = make_kgid(&init_user_ns, id);
+                       if (gid_valid(gid))
+                               fattr->cf_gid = gid;
+               }
        }
 
        fattr->cf_nlink = le64_to_cpu(info->Nlinks);