From owner-freebsd-stable@FreeBSD.ORG Sat Apr 19 16:42:14 2003 Return-Path: Delivered-To: freebsd-stable@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 2E9AD37B404; Sat, 19 Apr 2003 16:42:14 -0700 (PDT) Received: from stork.mail.pas.earthlink.net (stork.mail.pas.earthlink.net [207.217.120.188]) by mx1.FreeBSD.org (Postfix) with ESMTP id 7C91243FA3; Sat, 19 Apr 2003 16:42:13 -0700 (PDT) (envelope-from tlambert2@mindspring.com) Received: from pool0077.cvx40-bradley.dialup.earthlink.net ([216.244.42.77] helo=mindspring.com) by stork.mail.pas.earthlink.net with asmtp (SSLv3:RC4-MD5:128) (Exim 3.33 #1) id 1971yE-0007HZ-00; Sat, 19 Apr 2003 16:42:11 -0700 Message-ID: <3EA1DE82.68F32B77@mindspring.com> Date: Sat, 19 Apr 2003 16:40:50 -0700 From: Terry Lambert X-Mailer: Mozilla 4.79 [en] (Win98; U) X-Accept-Language: en MIME-Version: 1.0 To: Marko Zec References: <3E976EBD.C3E66EF8@tel.fer.hr> <200304192134.51484.zec@tel.fer.hr> <3EA1B72D.B8B96268@mindspring.com> <200304192350.48576.zec@tel.fer.hr> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit X-ELNK-Trace: b1a02af9316fbb217a47c185c03b154d40683398e744b8a4c348be04d95caf49280f378ec0a8b4c6a2d4e88014a4647c350badd9bab72f9c350badd9bab72f9c cc: freebsd-fs@FreeBSD.org cc: David Schultz cc: freebsd-stable@FreeBSD.org Subject: Re: PATCH: Forcible delaying of UFS (soft)updates X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 19 Apr 2003 23:42:14 -0000 Marko Zec wrote: > Does the laptop owner care if the system freezes for a couple of miliseconds > more than usual? I am a laptop owner. I care. > If you have tried the patch yourself, you would certainly observe > that the freeze you are talking about is completely unnoticable. I run 13 jails for 12 virtual machines on my laptop. I noticed. > Therefore the disk head seek latency you mentioned won't be > noticeable in most cases. Define "most cases". > > Your changes makes it so the insertion *does not* put it in a > > different slot (because the fsync is most likely delayed). > ^^^^^ > > Therefore we are *not* safe. > > Again, in my understanding the (modified) fsync() handler is completely > unrelated to the (unmodified) sync_fsync() function. You're wrong. You have to take into account both the vnodes on the FS, and the vnodes that the FS is mounted on on devfs. > > The other FS corruption occurs because you don't specifically > > disable the delaying code before a shutdown or umount or mount > > -u -o ro, etc.. > > Such a problem simply does not exist. Please try out the patch, enable the > delaying, fill in as much dirty buffers as possible, and unmount the FS. You > will notice that a) all the dirty buffers will be automatically written to > the disk; b) the unmount operation will succeed; c) the system will not crash > and d) the FS will be perfectly consistent at the next mount. This is not true. I've proved it by corrupting an FS by holding down the power button on my laptop to force an ATX power-off, with no recourse. This is the same type of failure that could occur on a normal laptop when battery output drops the power out from under you. The basic problem is that the forces fsync is no longer forced. > > This is totally irrelevent; it's anecdotal, and therefore has > > nothing whatsoever to do with provable correctness. > > No offence please, but your argumentation would look much more > convincing if you could provoke a system crash with the patch > enabled, and then provide a backtrace. If the patch is as bad > as you are suggesting, that shouldn't be that hard to do, should it? I've done it. I guess you want me to do it again, citing that absence of evidence is not evidence of absence? The problem her is well understood. Rather than arguing further, I will offer a modification of your patches. Note that this modification is still unsafe, due to the lack of a "force" flag for the fsync in the unmount and mount -u cases; give me a couple of days, since I test patches before I post them (normally 2 weeks; I'll make an exception in this case). -- Terry