Skip to content

Commit f47c834

Browse files
amir73ilgregkh
authored andcommitted
fs: relax assertions on failure to encode file handles
commit 974e3fe upstream. Encoding file handles is usually performed by a filesystem >encode_fh() method that may fail for various reasons. The legacy users of exportfs_encode_fh(), namely, nfsd and name_to_handle_at(2) syscall are ready to cope with the possibility of failure to encode a file handle. There are a few other users of exportfs_encode_{fh,fid}() that currently have a WARN_ON() assertion when ->encode_fh() fails. Relax those assertions because they are wrong. The second linked bug report states commit 16aac5a ("ovl: support encoding non-decodable file handles") in v6.6 as the regressing commit, but this is not accurate. The aforementioned commit only increases the chances of the assertion and allows triggering the assertion with the reproducer using overlayfs, inotify and drop_caches. Triggering this assertion was always possible with other filesystems and other reasons of ->encode_fh() failures and more particularly, it was also possible with the exact same reproducer using overlayfs that is mounted with options index=on,nfs_export=on also on kernels < v6.6. Therefore, I am not listing the aforementioned commit as a Fixes commit. Backport hint: this patch will have a trivial conflict applying to v6.6.y, and other trivial conflicts applying to stable kernels < v6.6. Reported-by: syzbot+ec07f6f5ce62b858579f@syzkaller.appspotmail.com Tested-by: syzbot+ec07f6f5ce62b858579f@syzkaller.appspotmail.com Closes: https://lore.kernel.org/linux-unionfs/671fd40c.050a0220.4735a.024f.GAE@google.com/ Reported-by: Dmitry Safonov <dima@arista.com> Closes: https://lore.kernel.org/linux-fsdevel/CAGrbwDTLt6drB9eaUagnQVgdPBmhLfqqxAf3F+Juqy_o6oP8uw@mail.gmail.com/ Cc: stable@vger.kernel.org Signed-off-by: Amir Goldstein <amir73il@gmail.com> Link: https://lore.kernel.org/r/20241219115301.465396-1-amir73il@gmail.com Signed-off-by: Christian Brauner <brauner@kernel.org> Signed-off-by: Amir Goldstein <amir73il@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent f0c0ac8 commit f47c834

File tree

2 files changed

+3
-6
lines changed

2 files changed

+3
-6
lines changed

fs/notify/fdinfo.c

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -51,10 +51,8 @@ static void show_mark_fhandle(struct seq_file *m, struct inode *inode)
5151
size = f.handle.handle_bytes >> 2;
5252

5353
ret = exportfs_encode_fid(inode, (struct fid *)f.handle.f_handle, &size);
54-
if ((ret == FILEID_INVALID) || (ret < 0)) {
55-
WARN_ONCE(1, "Can't encode file handler for inotify: %d\n", ret);
54+
if ((ret == FILEID_INVALID) || (ret < 0))
5655
return;
57-
}
5856

5957
f.handle.handle_type = ret;
6058
f.handle.handle_bytes = size * sizeof(u32);

fs/overlayfs/copy_up.c

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -399,9 +399,8 @@ struct ovl_fh *ovl_encode_real_fh(struct ovl_fs *ofs, struct inode *realinode,
399399
buflen = (dwords << 2);
400400

401401
err = -EIO;
402-
if (WARN_ON(fh_type < 0) ||
403-
WARN_ON(buflen > MAX_HANDLE_SZ) ||
404-
WARN_ON(fh_type == FILEID_INVALID))
402+
if (fh_type < 0 || fh_type == FILEID_INVALID ||
403+
WARN_ON(buflen > MAX_HANDLE_SZ))
405404
goto out_err;
406405

407406
fh->fb.version = OVL_FH_VERSION;

0 commit comments

Comments
 (0)