Change the new NFS server so that it returns 0 when the f_bavail

or f_ffree fields of "struct statfs" are negative, since the
values that go on the wire are unsigned and will appear to be
very large positive values otherwise. This makes the handling
of a negative f_bavail compatible with the old/regular NFS server.

MFC after:	2 weeks
This commit is contained in:
Rick Macklem 2011-05-06 01:29:14 +00:00
parent 3792a4d286
commit 78e4b1f838

View File

@ -1280,8 +1280,23 @@ nfsvno_fsync(struct vnode *vp, u_int64_t off, int cnt, struct ucred *cred,
int
nfsvno_statfs(struct vnode *vp, struct statfs *sf)
{
int error;
return (VFS_STATFS(vp->v_mount, sf));
error = VFS_STATFS(vp->v_mount, sf);
if (error == 0) {
/*
* Since NFS handles these values as unsigned on the
* wire, there is no way to represent negative values,
* so set them to 0. Without this, they will appear
* to be very large positive values for clients like
* Solaris10.
*/
if (sf->f_bavail < 0)
sf->f_bavail = 0;
if (sf->f_ffree < 0)
sf->f_ffree = 0;
}
return (error);
}
/*