Prevent leaking of fsid to non-root users in linux_statfs and linux_fstatfs.

Matches native syscalls now.

PR:		kern/58793
Submitted by:	David P. Reese Jr. <daver@gomerbud.com>
MFC after:	1 week
This commit is contained in:
Eric Anholt 2003-11-05 23:52:54 +00:00
parent d3be1471c7
commit 0b399cc8a6

View File

@ -268,8 +268,13 @@ linux_statfs(struct thread *td, struct linux_statfs_args *args)
linux_statfs.f_bavail = bsd_statfs->f_bavail;
linux_statfs.f_ffree = bsd_statfs->f_ffree;
linux_statfs.f_files = bsd_statfs->f_files;
if (suser(td)) {
linux_statfs.f_fsid.val[0] = 0;
linux_statfs.f_fsid.val[1] = 0;
} else {
linux_statfs.f_fsid.val[0] = bsd_statfs->f_fsid.val[0];
linux_statfs.f_fsid.val[1] = bsd_statfs->f_fsid.val[1];
}
linux_statfs.f_namelen = MAXNAMLEN;
return copyout(&linux_statfs, args->buf, sizeof(linux_statfs));
}
@ -312,8 +317,13 @@ linux_fstatfs(struct thread *td, struct linux_fstatfs_args *args)
linux_statfs.f_bavail = bsd_statfs->f_bavail;
linux_statfs.f_ffree = bsd_statfs->f_ffree;
linux_statfs.f_files = bsd_statfs->f_files;
if (suser(td)) {
linux_statfs.f_fsid.val[0] = 0;
linux_statfs.f_fsid.val[1] = 0;
} else {
linux_statfs.f_fsid.val[0] = bsd_statfs->f_fsid.val[0];
linux_statfs.f_fsid.val[1] = bsd_statfs->f_fsid.val[1];
}
linux_statfs.f_namelen = MAXNAMLEN;
error = copyout(&linux_statfs, args->buf, sizeof(linux_statfs));
fdrop(fp, td);