aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlfred Perlstein <alfred@FreeBSD.org>2000-11-30 20:04:44 +0000
committerAlfred Perlstein <alfred@FreeBSD.org>2000-11-30 20:04:44 +0000
commit237710275ea69a229b11e94083faf37d3fd8b10c (patch)
tree5095f67543fd60c2c606d3adcf8266f8b60812d4
parent9b67ac593b1594f88ec035b2f9442888a23ed562 (diff)
downloadsrc-237710275ea69a229b11e94083faf37d3fd8b10c.tar.gz
src-237710275ea69a229b11e94083faf37d3fd8b10c.zip
Notes
-rw-r--r--sys/kern/vfs_lookup.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/sys/kern/vfs_lookup.c b/sys/kern/vfs_lookup.c
index 4cd4b013d67a..b963a94f123d 100644
--- a/sys/kern/vfs_lookup.c
+++ b/sys/kern/vfs_lookup.c
@@ -404,6 +404,10 @@ dirloop:
if ((dp->v_flag & VROOT) == 0 ||
(cnp->cn_flags & NOCROSSMOUNT))
break;
+ if (dp->v_mount == NULL) { /* forced unmount */
+ error = EBADF;
+ goto bad;
+ }
tdp = dp;
dp = dp->v_mount->mnt_vnodecovered;
vput(tdp);
@@ -426,7 +430,7 @@ unionlookup:
printf("not found\n");
#endif
if ((error == ENOENT) &&
- (dp->v_flag & VROOT) &&
+ (dp->v_flag & VROOT) && (dp->v_mount != NULL) &&
(dp->v_mount->mnt_flag & MNT_UNION)) {
tdp = dp;
dp = dp->v_mount->mnt_vnodecovered;
@@ -510,6 +514,12 @@ unionlookup:
((cnp->cn_flags & FOLLOW) || trailing_slash ||
*ndp->ni_next == '/')) {
cnp->cn_flags |= ISSYMLINK;
+ if (dp->v_mount == NULL) {
+ /* We can't know whether the directory was mounted with
+ * NOSYMFOLLOW, so we can't follow safely. */
+ error = EBADF;
+ goto bad2;
+ }
if (dp->v_mount->mnt_flag & MNT_NOSYMFOLLOW) {
error = EACCES;
goto bad2;