summaryrefslogtreecommitdiffstats
path: root/sys/isofs/udf
diff options
context:
space:
mode:
authorbluhm <bluhm@openbsd.org>2016-05-22 20:27:04 +0000
committerbluhm <bluhm@openbsd.org>2016-05-22 20:27:04 +0000
commit9ee302b807409cb1f9713adc404a77fe222e525c (patch)
treeaa5fe5ae4375c8135911855d360673c191e7e222 /sys/isofs/udf
parentmakes sure the value of the asprintf buffer is zeroed on error (diff)
downloadwireguard-openbsd-9ee302b807409cb1f9713adc404a77fe222e525c.tar.xz
wireguard-openbsd-9ee302b807409cb1f9713adc404a77fe222e525c.zip
When pulling an msdos formated umass stick during mount while the
usb stack was busy, the kernel could trigger an uvm fault. There is a race between vop_generic_revoke() and sys_mount() where vgonel() could reset v_specinfo. Then v_specmountpoint is no longer valid. So after sleeping, msdosfs_mountfs() could crash in the error path. The code in the different *_mountfs() functions was inconsistent, implement the same check everywhere. OK krw@ natano@
Diffstat (limited to 'sys/isofs/udf')
-rw-r--r--sys/isofs/udf/udf_vfsops.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/sys/isofs/udf/udf_vfsops.c b/sys/isofs/udf/udf_vfsops.c
index b56e53ff41c..c4e2524047b 100644
--- a/sys/isofs/udf/udf_vfsops.c
+++ b/sys/isofs/udf/udf_vfsops.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: udf_vfsops.c,v 1.50 2016/04/26 18:37:02 natano Exp $ */
+/* $OpenBSD: udf_vfsops.c,v 1.51 2016/05/22 20:27:04 bluhm Exp $ */
/*
* Copyright (c) 2001, 2002 Scott Long <scottl@freebsd.org>
@@ -449,6 +449,8 @@ bail:
mp->mnt_data = NULL;
mp->mnt_flag &= ~MNT_LOCAL;
}
+ if (devvp->v_specinfo)
+ devvp->v_specmountpoint = NULL;
if (bp != NULL)
brelse(bp);