Date: Wed, 12 Mar 1997 21:54:15 -0700 (MST) From: Marc Slemko <marcs@znep.com> To: Michael Hancock <michaelh@cet.co.jp> Cc: isp@FreeBSD.ORG, hackers@FreeBSD.ORG Subject: Re: block and frag size for news (was Re: freebsd as a news server?) Message-ID: <Pine.BSF.3.95.970312215004.24128A-100000@alive.znep.com> In-Reply-To: <Pine.SV4.3.95.970313104650.24048C-100000@parkplace.cet.co.jp>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, 13 Mar 1997, Michael Hancock wrote: > I used -a 8 to leave it at the default and as Bruce points out since the > rotational delay now defaults to 0 the maxcontig setting probably doesn't > matter. It might matter I suppose if it actually goes thru the motion of > triggering a rotational delay, even if it's 0, after every 8 blocks. /sys/ufs/ffs/ffs_alloc.c (from 2.2; 2.1 is different but does a similar thing): /* * One or more previous blocks have been laid out. If less * than fs_maxcontig previous blocks are contiguous, the * next block is requested contiguously, otherwise it is * requested rotationally delayed by fs_rotdelay milliseconds. */ nextblk = bap[indx - 1] + fs->fs_frag; if (fs->fs_rotdelay == 0 || indx < fs->fs_maxcontig || bap[indx - fs->fs_maxcontig] + blkstofrags(fs, fs->fs_maxcontig) != nextblk) return (nextblk); /* * Here we convert ms of delay to frags as: * (frags) = (ms) * (rev/sec) * (sect/rev) / * ((sect/frag) * (ms/sec)) * then round up to the next block. */ nextblk += roundup(fs->fs_rotdelay * fs->fs_rps * fs->fs_nsect / (NSPF(fs) * 1000), fs->fs_frag); return (nextblk); To me, this says that if fs_rotdelay is 0 who cares about fs_maxcontig.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.BSF.3.95.970312215004.24128A-100000>