From: Johannes Berg Date: Wed, 22 Apr 2015 09:55:14 +0000 (+0200) Subject: fs/9p: fix readdir() X-Git-Tag: v5.15~15857^2~3 X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=8e3c500594dca9a12c27eb6d77b82e0766879bfd;p=mirror_ubuntu-kernels.git fs/9p: fix readdir() Al Viro's IOV changes broke 9p readdir() because the new code didn't abort the read when it returned nothing. The original code checked if the combined error/length was <= 0 but in the new code that accidentally got changed to just an error check. Add back the return from the function when nothing is read. Cc: Al Viro Fixes: e1200fe68f20 ("9p: switch p9_client_read() to passing struct iov_iter *") Signed-off-by: Johannes Berg Signed-off-by: Al Viro --- diff --git a/fs/9p/vfs_dir.c b/fs/9p/vfs_dir.c index 76c3b1ab6361..5cc00e56206e 100644 --- a/fs/9p/vfs_dir.c +++ b/fs/9p/vfs_dir.c @@ -138,6 +138,8 @@ static int v9fs_dir_readdir(struct file *file, struct dir_context *ctx) &err); if (err) return err; + if (n == 0) + return 0; rdir->head = 0; rdir->tail = n;