Date: Tue, 2 Sep 2003 05:10:48 +1000 (EST) From: Bruce Evans <bde@zeta.org.au> To: Lefteris Chatzibarbas <lefcha@hellug.gr> Cc: freebsd-current@freebsd.org Subject: Re: Syncer "giving up" on buffers Message-ID: <20030902040856.U5166@gamplex.bde.org> In-Reply-To: <20030901165348.GA542@bsd> References: <20030901165348.GA542@bsd>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, 1 Sep 2003, Lefteris Chatzibarbas wrote: > I have a problem with kernels, built the last couple of days, where > during shutdown syncer is "giving up" on buffers. During the next boot > all filesystems are checked because of improper dismount. Here follow > the exact messages I get: > > Waiting (max 60 seconds) for system process `vnlru' to stop...stopped > Waiting (max 60 seconds) for system process `bufdaemon' to stop...stopped > Waiting (max 60 seconds) for system process `syncer' to stop...stopped > > syncing disks, buffers remaining... 8 8 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 > giving up on 6 buffers > Uptime: 41m20s > pfs_vncache_unload(): 1 entries remaining > Shutting down ACPI > Rebooting... > > After some testing I found out that this does _not_ happen if I manually > unmount my ext2 filesystems, before shutting down. In this case syncer > finishes without any problems. > > My last kernel which did not have this problem, is the one I built on > Wed Aug 27 23:14:12 EEST 2003. Apparently the bug fixed in ext2fs/fs.h revs 1.3, 1.4 and 1.6 (etc.) was restored in rev.1.14. I think this is because B_LOCKED buffers were ignored in the sync() in boot() and flushed later when vfs_unmountall() calls ext2fs_unmount(), but they are now seen in the sync() so vfs_unmountall() is not called. Rev.1.3 of ext2fs/fs.h (etc.) abuses B_LOCKED to do little more than make the sync() ignore ext2fs's private buffers (its complications are mainly to handle the resulting B_LOCKED buffers). It wants to brelse() the buffers so that their BUF_REFCOUNT() is 0 and the sync() in boot() is happy to handle them. In the original fix, I think the buffers could be B_DELWRI and then the sync() would fulush them, but setting B_DELWRI was wrong and was changed (in rev.1.4) to setting the private flag B_DIRTY instead. Rev.1.13 esssentially removes the brelse() and adds a new complication (BUF_KERNPROC()) and keeps the old ones. I think the BUF_KERNPROC() is less than useful -- without the brelse()'s, the buffers are completely private to the file system. Bruce
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030902040856.U5166>