Module Name: src
Committed By: pooka
Date: Tue May 25 11:02:07 UTC 2010
Modified Files:
src/sys/ufs/ufs: ufs_wapbl.c
Log Message:
Add a comment describing an observed boom-crash-burn problem in
the code. Fixing it will require a full tank of gas, half a pack
of cigarettes, sunglasses, darkness, and most importantly:
someone else.
To generate a diff of this commit:
cvs rdiff -u -r1.8 -r1.9 src/sys/ufs/ufs/ufs_wapbl.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/ufs/ufs/ufs_wapbl.c
diff -u src/sys/ufs/ufs/ufs_wapbl.c:1.8 src/sys/ufs/ufs/ufs_wapbl.c:1.9
--- src/sys/ufs/ufs/ufs_wapbl.c:1.8 Tue Mar 2 14:45:55 2010
+++ src/sys/ufs/ufs/ufs_wapbl.c Tue May 25 11:02:07 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: ufs_wapbl.c,v 1.8 2010/03/02 14:45:55 pooka Exp $ */
+/* $NetBSD: ufs_wapbl.c,v 1.9 2010/05/25 11:02:07 pooka Exp $ */
/*-
* Copyright (c) 2003,2006,2008 The NetBSD Foundation, Inc.
@@ -66,7 +66,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ufs_wapbl.c,v 1.8 2010/03/02 14:45:55 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ufs_wapbl.c,v 1.9 2010/05/25 11:02:07 pooka Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -371,6 +371,10 @@
error = ENOENT; /* XXX ufs_rename sets "0" here */
goto out2;
}
+ /*
+ * XXX: if fvp != a_fvp, a_fvp can now have 0 references and yet we
+ * access a_fvp->inode via ip later. boom.
+ */
vrele(ap->a_fvp);
/* save directory lookup information in case tdvp == fdvp */