bin/138043: commit references a PR

dfilter service dfilter at FreeBSD.ORG
Thu Jan 7 02:00:15 UTC 2010


The following reply was made to PR bin/138043; it has been noted by GNATS.

From: dfilter at FreeBSD.ORG (dfilter service)
To: bug-followup at FreeBSD.org
Cc:  
Subject: Re: bin/138043: commit references a PR
Date: Thu,  7 Jan 2010 01:56:48 +0000 (UTC)

 Author: delphij
 Date: Thu Jan  7 01:56:35 2010
 New Revision: 201712
 URL: http://svn.freebsd.org/changeset/base/201712
 
 Log:
   MFC r176575:
   
   In pass1(), cap inosused to fs_ipg rather than allowing arbitrary
   number read from cylinder group.  Chances that we read a smarshed
   cylinder group, and we can not 100% trust information it has
   supplied.  fsck_ffs(8) will crash otherwise for some cases.
   
   PR:		bin/138043
   Reminded by:	mckusick
 
 Modified:
   stable/6/sbin/fsck_ffs/pass1.c
 Directory Properties:
   stable/6/sbin/fsck_ffs/   (props changed)
 
 Modified: stable/6/sbin/fsck_ffs/pass1.c
 ==============================================================================
 --- stable/6/sbin/fsck_ffs/pass1.c	Thu Jan  7 01:55:34 2010	(r201711)
 +++ stable/6/sbin/fsck_ffs/pass1.c	Thu Jan  7 01:56:35 2010	(r201712)
 @@ -93,9 +93,11 @@ pass1(void)
  		inumber = c * sblock.fs_ipg;
  		setinodebuf(inumber);
  		getblk(&cgblk, cgtod(&sblock, c), sblock.fs_cgsize);
 -		if (sblock.fs_magic == FS_UFS2_MAGIC)
 +		if (sblock.fs_magic == FS_UFS2_MAGIC) {
  			inosused = cgrp.cg_initediblk;
 -		else
 +			if (inosused > sblock.fs_ipg)
 +				inosused = sblock.fs_ipg;
 +		} else
  			inosused = sblock.fs_ipg;
  		if (got_siginfo) {
  			printf("%s: phase 1: cyl group %d of %d (%d%%)\n",
 _______________________________________________
 svn-src-all at freebsd.org mailing list
 http://lists.freebsd.org/mailman/listinfo/svn-src-all
 To unsubscribe, send any mail to "svn-src-all-unsubscribe at freebsd.org"
 


More information about the freebsd-fs mailing list