svn commit: r211684 - head/sys/kern

Kostik Belousov kostikbel at gmail.com
Mon Aug 23 10:29:01 UTC 2010


On Mon, Aug 23, 2010 at 05:33:31AM +0000, Brian Somers wrote:
> Author: brian
> Date: Mon Aug 23 05:33:31 2010
> New Revision: 211684
> URL: http://svn.freebsd.org/changeset/base/211684
> 
> Log:
>   uio_resid isn't updated by VOP_READDIR for nfs filesystems.  Use
>   the uio_offset adjustment instead to calculate a correct *len.
Isn't this should be fixed in nfs instead ? Please note that the moral
equivalent of the code is also present in compat/linux/linux_cwd.c:
linux_getcwd_scandir(). I did not inspected other callers of
VOP_READDIR.

>   
>   Without this change, we run off the end of the directory data
>   we're reading and panic horribly for nfs filesystems.
>   
>   MFC after:	1 week
> 
> Modified:
>   head/sys/kern/vfs_default.c
> 
> Modified: head/sys/kern/vfs_default.c
> ==============================================================================
> --- head/sys/kern/vfs_default.c	Mon Aug 23 05:33:20 2010	(r211683)
> +++ head/sys/kern/vfs_default.c	Mon Aug 23 05:33:31 2010	(r211684)
> @@ -281,10 +281,9 @@ get_next_dirent(struct vnode *vp, struct
>  		if (error)
>  			return (error);
>  
> -		*off = uio.uio_offset;
> -
>  		*cpos = dirbuf;
> -		*len = (dirbuflen - uio.uio_resid);
> +		*len = uio.uio_offset - *off;
> +		*off = uio.uio_offset;
>  	}
>  
>  	dp = (struct dirent *)(*cpos);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 196 bytes
Desc: not available
Url : http://lists.freebsd.org/pipermail/svn-src-all/attachments/20100823/1fddaa4b/attachment.pgp


More information about the svn-src-all mailing list