cvs commit: src/sys/kern vfs_mount.c src/sys/vfs/ufs ffs_inode.c src/sys/vfs/msdosfs msdosfs_denode.c msdosfs_vfsops.c
Matthew Dillon
dillon at crater.dragonflybsd.org
Wed Jun 13 19:56:42 PDT 2007
dillon 2007/06/13 19:55:27 PDT
DragonFly src repository
Modified files:
sys/kern vfs_mount.c
sys/vfs/ufs ffs_inode.c
sys/vfs/msdosfs msdosfs_denode.c msdosfs_vfsops.c
Log:
When getnewvnode() is called the vnode's v_type defaults to VNON. Syncer
vnodes are also set to VNON and any vnode that is accessed without locking
whos v_type is VNON is probably in the middle of being initialized. For
this reason the mountlist scan and vflush code typically ignores such
vnodes.
If a read error occurs while initializing a vnode, in particular if a hash
collision occurs or an I/O error occurs reading the inode, the vnode's
v_type was being left set to VNON. Explicitly set it to VBAD for msdosfs
and ufs (other FS's probably need the same treatment) so the flush and
reclaim code can reuse the vnode.
This fixes 'dangling vnode' panics on unmount for filesystems which incur
I/O errors, such as when one pulls a USB memory stick out while it is
still mounted.
Revision Changes Path
1.28 +2 -4 src/sys/kern/vfs_mount.c
1.24 +8 -0 src/sys/vfs/ufs/ffs_inode.c
1.29 +2 -0 src/sys/vfs/msdosfs/msdosfs_denode.c
1.47 +1 -1 src/sys/vfs/msdosfs/msdosfs_vfsops.c
http://www.dragonflybsd.org/cvsweb/src/sys/kern/vfs_mount.c.diff?r1=1.27&r2=1.28&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/ufs/ffs_inode.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/msdosfs/msdosfs_denode.c.diff?r1=1.28&r2=1.29&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/msdosfs/msdosfs_vfsops.c.diff?r1=1.46&r2=1.47&f=u
More information about the Commits
mailing list