summaryrefslogtreecommitdiff
path: root/sys/ufs/ffs/ffs_vfsops.c
diff options
context:
space:
mode:
authorOtto Moerbeek <otto@cvs.openbsd.org>2004-08-12 07:48:54 +0000
committerOtto Moerbeek <otto@cvs.openbsd.org>2004-08-12 07:48:54 +0000
commit090846a43ee80a1044510b2fc185bd2a16728658 (patch)
treec7c0904db08d8ac4c1f756a6a8a802133326b804 /sys/ufs/ffs/ffs_vfsops.c
parentea738fcf3d432a4bfc4b3ec529a2fa9193ea4da2 (diff)
Prevent a panic by validating the super block size as recorded in the
superblock; make the block size check also catch negative values. ok miller@ tedu@
Diffstat (limited to 'sys/ufs/ffs/ffs_vfsops.c')
-rw-r--r--sys/ufs/ffs/ffs_vfsops.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/sys/ufs/ffs/ffs_vfsops.c b/sys/ufs/ffs/ffs_vfsops.c
index 3c35e6dae63..831954fc4f2 100644
--- a/sys/ufs/ffs/ffs_vfsops.c
+++ b/sys/ufs/ffs/ffs_vfsops.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ffs_vfsops.c,v 1.67 2004/07/14 18:48:43 pedro Exp $ */
+/* $OpenBSD: ffs_vfsops.c,v 1.68 2004/08/12 07:48:53 otto Exp $ */
/* $NetBSD: ffs_vfsops.c,v 1.19 1996/02/09 22:22:26 christos Exp $ */
/*
@@ -551,8 +551,9 @@ ffs_reload(mountp, cred, p)
if (error)
return (error);
newfs = (struct fs *)bp->b_data;
- if (newfs->fs_magic != FS_MAGIC || newfs->fs_bsize > MAXBSIZE ||
- newfs->fs_bsize < sizeof(struct fs)) {
+ if (newfs->fs_magic != FS_MAGIC || (u_int)newfs->fs_bsize > MAXBSIZE ||
+ newfs->fs_bsize < sizeof(struct fs) ||
+ (u_int)newfs->fs_sbsize > SBSIZE) {
brelse(bp);
return (EIO); /* XXX needs translation */
}
@@ -664,8 +665,9 @@ ffs_mountfs(devvp, mp, p)
if (error)
goto out;
fs = (struct fs *)bp->b_data;
- if (fs->fs_magic != FS_UFS1_MAGIC || fs->fs_bsize > MAXBSIZE ||
- fs->fs_bsize < sizeof(struct fs)) {
+ if (fs->fs_magic != FS_UFS1_MAGIC || (u_int)fs->fs_bsize > MAXBSIZE ||
+ fs->fs_bsize < sizeof(struct fs) ||
+ (u_int)fs->fs_sbsize > SBSIZE) {
if (fs->fs_magic == FS_UFS2_MAGIC)
printf("no UFS2 support\n");
error = EFTYPE; /* Inappropriate format */