diff options
author | Christian Brauner <brauner@kernel.org> | 2022-04-04 12:51:52 +0200 |
---|---|---|
committer | Miklos Szeredi <mszeredi@redhat.com> | 2022-04-28 16:31:12 +0200 |
commit | ba9ea771ec8a9da4e3aa5cb8c8549fc3b15b2641 (patch) | |
tree | 8a7b2992a7a56db470f2ce201630fd4be96eecb6 /fs/overlayfs/export.c | |
parent | 50db8d0273551f8792b4d9367d43a0093fb4512d (diff) | |
download | linux-ba9ea771ec8a9da4e3aa5cb8c8549fc3b15b2641.tar.gz linux-ba9ea771ec8a9da4e3aa5cb8c8549fc3b15b2641.tar.bz2 linux-ba9ea771ec8a9da4e3aa5cb8c8549fc3b15b2641.zip |
ovl: handle idmappings for layer lookup
Make the two places where lookup helpers can be called either on lower
or upper layers take the mount's idmapping into account. To this end we
pass down the mount in struct ovl_lookup_data. It can later also be used
to construct struct path for various other helpers. This is needed to
support idmapped base layers with overlay.
Cc: <linux-unionfs@vger.kernel.org>
Tested-by: Giuseppe Scrivano <gscrivan@redhat.com>
Reviewed-by: Amir Goldstein <amir73il@gmail.com>
Signed-off-by: Christian Brauner (Microsoft) <brauner@kernel.org>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Diffstat (limited to 'fs/overlayfs/export.c')
-rw-r--r-- | fs/overlayfs/export.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/fs/overlayfs/export.c b/fs/overlayfs/export.c index ebde05c9cf62..2eada97bbd23 100644 --- a/fs/overlayfs/export.c +++ b/fs/overlayfs/export.c @@ -391,6 +391,11 @@ static struct dentry *ovl_lookup_real_one(struct dentry *connected, * pointer because we hold no lock on the real dentry. */ take_dentry_name_snapshot(&name, real); + /* + * No mnt_userns handling here: it's an internal lookup. Could skip + * permission checking altogether, but for now just use non-mnt_userns + * transformed ids. + */ this = lookup_one_len(name.name.name, connected, name.name.len); release_dentry_name_snapshot(&name); err = PTR_ERR(this); |