summaryrefslogtreecommitdiffstats
path: root/sys/ufs
diff options
context:
space:
mode:
authordillon <dillon@FreeBSD.org>2001-10-08 00:37:54 +0000
committerdillon <dillon@FreeBSD.org>2001-10-08 00:37:54 +0000
commitdbebfe18a15ceac757fc126dd8caa59045ec9e47 (patch)
treec22ac1c7e5803249f9a3ae9fcb20d98fb4717ead /sys/ufs
parent54bd95ef308d9aa96b17d556be6e5c22306cdee6 (diff)
downloadFreeBSD-src-dbebfe18a15ceac757fc126dd8caa59045ec9e47.zip
FreeBSD-src-dbebfe18a15ceac757fc126dd8caa59045ec9e47.tar.gz
Remove panics for rename() race conditions. The panics are inappropriate
because the IN_RENAME flag only fixes a few of the huge number of race conditions that can result in the source path becoming invalid even prior to the VOP_RENAME() call. The panics created a serious security issue whereby an attacker could fairly easily cause the panic to occur, crashing the machine. The correct solution requires a great deal of work in the namei path cache code. MFC after: 0 days
Diffstat (limited to 'sys/ufs')
-rw-r--r--sys/ufs/ufs/ufs_vnops.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/sys/ufs/ufs/ufs_vnops.c b/sys/ufs/ufs/ufs_vnops.c
index b7d0c28..6af0750 100644
--- a/sys/ufs/ufs/ufs_vnops.c
+++ b/sys/ufs/ufs/ufs_vnops.c
@@ -1261,10 +1261,16 @@ abortit:
dp = VTOI(fdvp);
} else {
/*
- * From name has disappeared.
+ * From name has disappeared. IN_RENAME is not sufficient
+ * to protect against directory races due to timing windows,
+ * so we have to remove the panic. XXX the only real way
+ * to solve this issue is at a much higher level. By the
+ * time we hit ufs_rename() it's too late.
*/
+#if 0
if (doingdirectory)
panic("ufs_rename: lost dir entry");
+#endif
vrele(ap->a_fvp);
return (0);
}
@@ -1278,8 +1284,17 @@ abortit:
* by a rmdir.
*/
if (xp != ip) {
+ /*
+ * From name resolves to a different inode. IN_RENAME is
+ * not sufficient protection against timing window races
+ * so we can't panic here. XXX the only real way
+ * to solve this issue is at a much higher level. By the
+ * time we hit ufs_rename() it's too late.
+ */
+#if 0
if (doingdirectory)
panic("ufs_rename: lost dir entry");
+#endif
} else {
/*
* If the source is a directory with a
OpenPOWER on IntegriCloud