Skip to content

Commit 106e459

Browse files
mihalicynMiklos Szeredi
authored andcommitted
fs/fuse: convert to use invalid_mnt_idmap
We should convert fs/fuse code to use a newly introduced invalid_mnt_idmap instead of passing a NULL as idmap pointer. Suggested-by: Christian Brauner <brauner@kernel.org> Signed-off-by: Alexander Mikhalitsyn <aleksandr.mikhalitsyn@canonical.com> Reviewed-by: Christian Brauner <brauner@kernel.org> Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
1 parent ffcdc4c commit 106e459

File tree

3 files changed

+27
-28
lines changed

3 files changed

+27
-28
lines changed

fs/fuse/dev.c

Lines changed: 23 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -114,7 +114,11 @@ static struct fuse_req *fuse_get_req(struct mnt_idmap *idmap,
114114
{
115115
struct fuse_conn *fc = fm->fc;
116116
struct fuse_req *req;
117+
bool no_idmap = !fm->sb || (fm->sb->s_iflags & SB_I_NOIDMAP);
118+
kuid_t fsuid;
119+
kgid_t fsgid;
117120
int err;
121+
118122
atomic_inc(&fc->num_waiting);
119123

120124
if (fuse_block_alloc(fc, for_background)) {
@@ -148,29 +152,24 @@ static struct fuse_req *fuse_get_req(struct mnt_idmap *idmap,
148152
if (for_background)
149153
__set_bit(FR_BACKGROUND, &req->flags);
150154

151-
if (!fm->sb || (fm->sb->s_iflags & SB_I_NOIDMAP) || idmap) {
152-
kuid_t idmapped_fsuid;
153-
kgid_t idmapped_fsgid;
155+
/*
156+
* Keep the old behavior when idmappings support was not
157+
* declared by a FUSE server.
158+
*
159+
* For those FUSE servers who support idmapped mounts,
160+
* we send UID/GID only along with "inode creation"
161+
* fuse requests, otherwise idmap == &invalid_mnt_idmap and
162+
* req->in.h.{u,g}id will be equal to FUSE_INVALID_UIDGID.
163+
*/
164+
fsuid = no_idmap ? current_fsuid() : mapped_fsuid(idmap, fc->user_ns);
165+
fsgid = no_idmap ? current_fsgid() : mapped_fsgid(idmap, fc->user_ns);
166+
req->in.h.uid = from_kuid(fc->user_ns, fsuid);
167+
req->in.h.gid = from_kgid(fc->user_ns, fsgid);
154168

155-
/*
156-
* Note, that when
157-
* (fm->sb->s_iflags & SB_I_NOIDMAP) is true, then
158-
* (idmap == &nop_mnt_idmap) is always true and therefore,
159-
* mapped_fsuid(idmap, fc->user_ns) == current_fsuid().
160-
*/
161-
idmapped_fsuid = idmap ? mapped_fsuid(idmap, fc->user_ns) : current_fsuid();
162-
idmapped_fsgid = idmap ? mapped_fsgid(idmap, fc->user_ns) : current_fsgid();
163-
req->in.h.uid = from_kuid(fc->user_ns, idmapped_fsuid);
164-
req->in.h.gid = from_kgid(fc->user_ns, idmapped_fsgid);
165-
166-
if (unlikely(req->in.h.uid == ((uid_t)-1) ||
167-
req->in.h.gid == ((gid_t)-1))) {
168-
fuse_put_request(req);
169-
return ERR_PTR(-EOVERFLOW);
170-
}
171-
} else {
172-
req->in.h.uid = FUSE_INVALID_UIDGID;
173-
req->in.h.gid = FUSE_INVALID_UIDGID;
169+
if (no_idmap && unlikely(req->in.h.uid == ((uid_t)-1) ||
170+
req->in.h.gid == ((gid_t)-1))) {
171+
fuse_put_request(req);
172+
return ERR_PTR(-EOVERFLOW);
174173
}
175174

176175
return req;
@@ -619,7 +618,7 @@ int fuse_simple_background(struct fuse_mount *fm, struct fuse_args *args,
619618
__set_bit(FR_BACKGROUND, &req->flags);
620619
} else {
621620
WARN_ON(args->nocreds);
622-
req = fuse_get_req(NULL, fm, true);
621+
req = fuse_get_req(&invalid_mnt_idmap, fm, true);
623622
if (IS_ERR(req))
624623
return PTR_ERR(req);
625624
}
@@ -641,7 +640,7 @@ static int fuse_simple_notify_reply(struct fuse_mount *fm,
641640
struct fuse_req *req;
642641
struct fuse_iqueue *fiq = &fm->fc->iq;
643642

644-
req = fuse_get_req(NULL, fm, false);
643+
req = fuse_get_req(&invalid_mnt_idmap, fm, false);
645644
if (IS_ERR(req))
646645
return PTR_ERR(req);
647646

fs/fuse/dir.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1093,7 +1093,7 @@ static int fuse_rename2(struct mnt_idmap *idmap, struct inode *olddir,
10931093
if (fc->no_rename2 || fc->minor < 23)
10941094
return -EINVAL;
10951095

1096-
err = fuse_rename_common((flags & RENAME_WHITEOUT) ? idmap : NULL,
1096+
err = fuse_rename_common((flags & RENAME_WHITEOUT) ? idmap : &invalid_mnt_idmap,
10971097
olddir, oldent, newdir, newent, flags,
10981098
FUSE_RENAME2,
10991099
sizeof(struct fuse_rename2_in));
@@ -1102,7 +1102,7 @@ static int fuse_rename2(struct mnt_idmap *idmap, struct inode *olddir,
11021102
err = -EINVAL;
11031103
}
11041104
} else {
1105-
err = fuse_rename_common(NULL, olddir, oldent, newdir, newent, 0,
1105+
err = fuse_rename_common(&invalid_mnt_idmap, olddir, oldent, newdir, newent, 0,
11061106
FUSE_RENAME,
11071107
sizeof(struct fuse_rename_in));
11081108
}
@@ -1127,7 +1127,7 @@ static int fuse_link(struct dentry *entry, struct inode *newdir,
11271127
args.in_args[0].value = &inarg;
11281128
args.in_args[1].size = newent->d_name.len + 1;
11291129
args.in_args[1].value = newent->d_name.name;
1130-
err = create_new_entry(NULL, fm, &args, newdir, newent, inode->i_mode);
1130+
err = create_new_entry(&invalid_mnt_idmap, fm, &args, newdir, newent, inode->i_mode);
11311131
if (!err)
11321132
fuse_update_ctime_in_cache(inode);
11331133
else if (err == -EINTR)

fs/fuse/fuse_i.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1153,7 +1153,7 @@ ssize_t __fuse_simple_request(struct mnt_idmap *idmap,
11531153

11541154
static inline ssize_t fuse_simple_request(struct fuse_mount *fm, struct fuse_args *args)
11551155
{
1156-
return __fuse_simple_request(NULL, fm, args);
1156+
return __fuse_simple_request(&invalid_mnt_idmap, fm, args);
11571157
}
11581158

11591159
static inline ssize_t fuse_simple_idmap_request(struct mnt_idmap *idmap,

0 commit comments

Comments
 (0)