summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sys/kern/vfs_extattr.c9
-rw-r--r--sys/kern/vfs_syscalls.c9
2 files changed, 12 insertions, 6 deletions
diff --git a/sys/kern/vfs_extattr.c b/sys/kern/vfs_extattr.c
index 3e8c968..ed4505a 100644
--- a/sys/kern/vfs_extattr.c
+++ b/sys/kern/vfs_extattr.c
@@ -516,7 +516,7 @@ freebsd4_getfsstat(td, uap)
} */ *uap;
{
struct mount *mp, *nmp;
- struct statfs *sp;
+ struct statfs *sp, sb;
struct ostatfs osb;
caddr_t sfsp;
long count, maxcount, error;
@@ -556,9 +556,12 @@ freebsd4_getfsstat(td, uap)
continue;
}
sp->f_flags = mp->mnt_flag & MNT_VISFLAGMASK;
+ if (suser(td)) {
+ bcopy(sp, &sb, sizeof(sb));
+ sb.f_fsid.val[0] = sb.f_fsid.val[1] = 0;
+ sp = &sb;
+ }
cvtstatfs(td, sp, &osb);
- if (suser(td))
- osb.f_fsid.val[0] = osb.f_fsid.val[1] = 0;
error = copyout(&osb, sfsp, sizeof(osb));
if (error) {
vfs_unbusy(mp, td);
diff --git a/sys/kern/vfs_syscalls.c b/sys/kern/vfs_syscalls.c
index 3e8c968..ed4505a 100644
--- a/sys/kern/vfs_syscalls.c
+++ b/sys/kern/vfs_syscalls.c
@@ -516,7 +516,7 @@ freebsd4_getfsstat(td, uap)
} */ *uap;
{
struct mount *mp, *nmp;
- struct statfs *sp;
+ struct statfs *sp, sb;
struct ostatfs osb;
caddr_t sfsp;
long count, maxcount, error;
@@ -556,9 +556,12 @@ freebsd4_getfsstat(td, uap)
continue;
}
sp->f_flags = mp->mnt_flag & MNT_VISFLAGMASK;
+ if (suser(td)) {
+ bcopy(sp, &sb, sizeof(sb));
+ sb.f_fsid.val[0] = sb.f_fsid.val[1] = 0;
+ sp = &sb;
+ }
cvtstatfs(td, sp, &osb);
- if (suser(td))
- osb.f_fsid.val[0] = osb.f_fsid.val[1] = 0;
error = copyout(&osb, sfsp, sizeof(osb));
if (error) {
vfs_unbusy(mp, td);
OpenPOWER on IntegriCloud