diff --git a/sys/kern/vfs_vnops.c b/sys/kern/vfs_vnops.c index c6663de8b8fc..bb864901f956 100644 --- a/sys/kern/vfs_vnops.c +++ b/sys/kern/vfs_vnops.c @@ -36,7 +36,7 @@ * SUCH DAMAGE. * * @(#)vfs_vnops.c 8.2 (Berkeley) 1/21/94 - * $Id: vfs_vnops.c,v 1.71 1999/07/26 06:25:18 alc Exp $ + * $Id: vfs_vnops.c,v 1.72 1999/08/04 18:53:49 green Exp $ */ #include @@ -428,7 +428,20 @@ vn_stat(vp, sb, p) sb->st_atimespec = vap->va_atime; sb->st_mtimespec = vap->va_mtime; sb->st_ctimespec = vap->va_ctime; - sb->st_blksize = vap->va_blocksize; + /* + * For block and char device nodes we don't really care + * about what the filesystem told us, we want to know + * what the device told us + */ + switch (vap->va_type) { + case VBLK: + sb->st_blksize = vp->v_rdev->si_bsize_best; + case VCHR: + sb->st_blksize = vp->v_rdev->si_bsize_max; + default: + sb->st_blksize = vap->va_blocksize; + break; + } sb->st_flags = vap->va_flags; if (suser_xxx(p->p_ucred, 0, 0)) sb->st_gen = 0; diff --git a/sys/ufs/ufs/ufs_vnops.c b/sys/ufs/ufs/ufs_vnops.c index 4ae4f98a2dbb..e65f22b48160 100644 --- a/sys/ufs/ufs/ufs_vnops.c +++ b/sys/ufs/ufs/ufs_vnops.c @@ -36,7 +36,7 @@ * SUCH DAMAGE. * * @(#)ufs_vnops.c 8.27 (Berkeley) 5/27/95 - * $Id: ufs_vnops.c,v 1.117 1999/08/08 18:43:04 phk Exp $ + * $Id: ufs_vnops.c,v 1.118 1999/08/13 10:10:12 phk Exp $ */ #include "opt_quota.h" @@ -396,20 +396,7 @@ ufs_getattr(ap) vap->va_ctime.tv_nsec = ip->i_ctimensec; vap->va_flags = ip->i_flags; vap->va_gen = ip->i_gen; - - /* - * Use the information contained in v_rdev for VBLK and VCHR - * vnodes, and in the underlying mount point for (typically) VREG - * vnodes. Note that vp->v_specmountpoint can be NULL. - */ - if (vp->v_type == VBLK) { - vap->va_blocksize = vp->v_rdev->si_bsize_best; - } else if (vp->v_type == VCHR) { - vap->va_blocksize = vp->v_rdev->si_bsize_max; - } else { - vap->va_blocksize = vp->v_mount->mnt_stat.f_iosize; - } - + vap->va_blocksize = vp->v_mount->mnt_stat.f_iosize; vap->va_bytes = dbtob((u_quad_t)ip->i_blocks); vap->va_type = IFTOVT(ip->i_mode); vap->va_filerev = ip->i_modrev;