userns: Convert hfs to use kuid and kgid where appropriate
authorEric W. Biederman <ebiederm@xmission.com>
Wed, 8 Feb 2012 00:26:59 +0000 (16:26 -0800)
committerEric W. Biederman <ebiederm@xmission.com>
Fri, 21 Sep 2012 10:13:11 +0000 (03:13 -0700)
Acked-by: Serge Hallyn <serge.hallyn@canonical.com>
Signed-off-by: Eric W. Biederman <ebiederm@xmission.com>
fs/hfs/hfs_fs.h
fs/hfs/inode.c
fs/hfs/super.c
init/Kconfig

index 8275175acf6eaaf8606b940d6f05c96d7ae08a5c..693df9fe52b2a8dc7cda4d675749941c0fe4b760 100644 (file)
@@ -134,8 +134,8 @@ struct hfs_sb_info {
                                                   permissions on all files */
        umode_t s_dir_umask;                    /* The umask applied to the
                                                   permissions on all dirs */
-       uid_t s_uid;                            /* The uid of all files */
-       gid_t s_gid;                            /* The gid of all files */
+       kuid_t s_uid;                           /* The uid of all files */
+       kgid_t s_gid;                           /* The gid of all files */
 
        int session, part;
        struct nls_table *nls_io, *nls_disk;
index ee1bc55677f1486c6f27a2549d8f6ce60c1581de..5d5c22da1960f738717ca47b50e034896e2ccf53 100644 (file)
@@ -594,9 +594,9 @@ int hfs_inode_setattr(struct dentry *dentry, struct iattr * attr)
 
        /* no uig/gid changes and limit which mode bits can be set */
        if (((attr->ia_valid & ATTR_UID) &&
-            (attr->ia_uid != hsb->s_uid)) ||
+            (!uid_eq(attr->ia_uid, hsb->s_uid))) ||
            ((attr->ia_valid & ATTR_GID) &&
-            (attr->ia_gid != hsb->s_gid)) ||
+            (!gid_eq(attr->ia_gid, hsb->s_gid))) ||
            ((attr->ia_valid & ATTR_MODE) &&
             ((S_ISDIR(inode->i_mode) &&
               (attr->ia_mode != inode->i_mode)) ||
index 4eb873e0c07b137c0225f30b20fdf78bfb0c0006..0b63d135a092e89c5251ba0f2b87aacd718827ea 100644 (file)
@@ -138,7 +138,9 @@ static int hfs_show_options(struct seq_file *seq, struct dentry *root)
                seq_printf(seq, ",creator=%.4s", (char *)&sbi->s_creator);
        if (sbi->s_type != cpu_to_be32(0x3f3f3f3f))
                seq_printf(seq, ",type=%.4s", (char *)&sbi->s_type);
-       seq_printf(seq, ",uid=%u,gid=%u", sbi->s_uid, sbi->s_gid);
+       seq_printf(seq, ",uid=%u,gid=%u",
+                       from_kuid_munged(&init_user_ns, sbi->s_uid),
+                       from_kgid_munged(&init_user_ns, sbi->s_gid));
        if (sbi->s_file_umask != 0133)
                seq_printf(seq, ",file_umask=%o", sbi->s_file_umask);
        if (sbi->s_dir_umask != 0022)
@@ -254,14 +256,22 @@ static int parse_options(char *options, struct hfs_sb_info *hsb)
                                printk(KERN_ERR "hfs: uid requires an argument\n");
                                return 0;
                        }
-                       hsb->s_uid = (uid_t)tmp;
+                       hsb->s_uid = make_kuid(current_user_ns(), (uid_t)tmp);
+                       if (!uid_valid(hsb->s_uid)) {
+                               printk(KERN_ERR "hfs: invalid uid %d\n", tmp);
+                               return 0;
+                       }
                        break;
                case opt_gid:
                        if (match_int(&args[0], &tmp)) {
                                printk(KERN_ERR "hfs: gid requires an argument\n");
                                return 0;
                        }
-                       hsb->s_gid = (gid_t)tmp;
+                       hsb->s_gid = make_kgid(current_user_ns(), (gid_t)tmp);
+                       if (!gid_valid(hsb->s_gid)) {
+                               printk(KERN_ERR "hfs: invalid gid %d\n", tmp);
+                               return 0;
+                       }
                        break;
                case opt_umask:
                        if (match_octal(&args[0], &tmp)) {
index 39e55d614f2c077b4a9fbd26b5d46ebd6a962252..6038d64b64b6c14d7882c9a833902a4d0ee6ef3a 100644 (file)
@@ -943,7 +943,6 @@ config UIDGID_CONVERTED
        depends on CODA_FS = n
        depends on FUSE_FS = n
        depends on GFS2_FS = n
-       depends on HFS_FS = n
        depends on HFSPLUS_FS = n
        depends on HPFS_FS = n
        depends on ISO9660_FS = n