ANDROID: Sdcardfs: Move gid derivation under flag
authorDaniel Rosenberg <drosen@google.com>
Thu, 20 Jul 2017 00:25:07 +0000 (17:25 -0700)
committerDaniel Rosenberg <drosen@google.com>
Tue, 30 Jan 2018 03:40:11 +0000 (19:40 -0800)
This moves the code to adjust the gid/uid of lower filesystem
files under the mount flag derive_gid.

Signed-off-by: Daniel Rosenberg <drosen@google.com>
Change-Id: I44eaad4ef67c7fcfda3b6ea3502afab94442610c
Bug: 63245673

fs/sdcardfs/derived_perm.c
fs/sdcardfs/inode.c
fs/sdcardfs/main.c
fs/sdcardfs/sdcardfs.h
fs/sdcardfs/super.c

index 1239d1cd208b627d4f7d723aaa727564582e52cc..fffaad4701cf160bc6c90ba658676e4a1c7dd749 100644 (file)
@@ -176,6 +176,9 @@ void fixup_lower_ownership(struct dentry *dentry, const char *name)
        gid_t gid = sbi->options.fs_low_gid;
        struct iattr newattrs;
 
+       if (!sbi->options.gid_derivation)
+               return;
+
        info = SDCARDFS_I(d_inode(dentry));
        info_d = info->data;
        perm = info_d->perm;
index 70a4e3cb8781bfbeb86b93946b78e9aa2f94f0f0..5e919e2956e04e50b4243fa75dd8dd5af654f84e 100644 (file)
@@ -34,10 +34,14 @@ const struct cred *override_fsids(struct sdcardfs_sb_info *sbi,
        if (!cred)
                return NULL;
 
-       if (data->under_obb)
-               uid = AID_MEDIA_OBB;
-       else
-               uid = multiuser_get_uid(data->userid, sbi->options.fs_low_uid);
+       if (sbi->options.gid_derivation) {
+               if (data->under_obb)
+                       uid = AID_MEDIA_OBB;
+               else
+                       uid = multiuser_get_uid(data->userid, sbi->options.fs_low_uid);
+       } else {
+               uid = sbi->options.fs_low_uid;
+       }
        cred->fsuid = make_kuid(&init_user_ns, uid);
        cred->fsgid = make_kgid(&init_user_ns, sbi->options.fs_low_gid);
 
index 80825b28783651ccee7d6fbf80ed830e321826f5..0a2b5167e9a2e5562b7af6e3642140c20816609b 100644 (file)
@@ -32,6 +32,7 @@ enum {
        Opt_multiuser,
        Opt_userid,
        Opt_reserved_mb,
+       Opt_gid_derivation,
        Opt_err,
 };
 
@@ -43,6 +44,7 @@ static const match_table_t sdcardfs_tokens = {
        {Opt_mask, "mask=%u"},
        {Opt_userid, "userid=%d"},
        {Opt_multiuser, "multiuser"},
+       {Opt_gid_derivation, "derive_gid"},
        {Opt_reserved_mb, "reserved_mb=%u"},
        {Opt_err, NULL}
 };
@@ -64,6 +66,8 @@ static int parse_options(struct super_block *sb, char *options, int silent,
        vfsopts->gid = 0;
        /* by default, 0MB is reserved */
        opts->reserved_mb = 0;
+       /* by default, gid derivation is off */
+       opts->gid_derivation = false;
 
        *debug = 0;
 
@@ -115,6 +119,9 @@ static int parse_options(struct super_block *sb, char *options, int silent,
                                return 0;
                        opts->reserved_mb = option;
                        break;
+               case Opt_gid_derivation:
+                       opts->gid_derivation = true;
+                       break;
                /* unknown option */
                default:
                        if (!silent)
index 4e0ce49a906db6f0390db8aa3691375de0788b15..d1d8bab00fe51282a847427ac76321bcc94b05e3 100644 (file)
@@ -219,6 +219,7 @@ struct sdcardfs_mount_options {
        gid_t fs_low_gid;
        userid_t fs_user_id;
        bool multiuser;
+       bool gid_derivation;
        unsigned int reserved_mb;
 };
 
index 7f4539b4b2493995d461c931a459feda900ffd42..b89947d878e33d50645502b60d27b9d9968d81fb 100644 (file)
@@ -302,6 +302,8 @@ static int sdcardfs_show_options(struct vfsmount *mnt, struct seq_file *m,
                seq_printf(m, ",mask=%u", vfsopts->mask);
        if (opts->fs_user_id)
                seq_printf(m, ",userid=%u", opts->fs_user_id);
+       if (opts->gid_derivation)
+               seq_puts(m, ",derive_gid");
        if (opts->reserved_mb != 0)
                seq_printf(m, ",reserved=%uMB", opts->reserved_mb);