summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjh <jh@FreeBSD.org>2010-12-15 16:42:44 +0000
committerjh <jh@FreeBSD.org>2010-12-15 16:42:44 +0000
commit309885e54efae18606115421f1817260429a5f4b (patch)
tree8daf60f98b7478101442612e53ad4b5ad8b09f45
parentd0d6cc47b623162ad60bc6fe23e8a31b2c81e696 (diff)
downloadFreeBSD-src-309885e54efae18606115421f1817260429a5f4b.zip
FreeBSD-src-309885e54efae18606115421f1817260429a5f4b.tar.gz
- Assert that dm_lock is exclusively held in devfs_rules_apply() and
in devfs_vmkdir() while adding the entry to de_list of the parent. - Apply devfs rules to newly created directories and symbolic links. PR: kern/125034 Submitted by: Mateusz Guzik (original version)
-rw-r--r--sys/fs/devfs/devfs_devs.c2
-rw-r--r--sys/fs/devfs/devfs_rule.c2
-rw-r--r--sys/fs/devfs/devfs_vnops.c1
3 files changed, 5 insertions, 0 deletions
diff --git a/sys/fs/devfs/devfs_devs.c b/sys/fs/devfs/devfs_devs.c
index 52e6567..d72ada0 100644
--- a/sys/fs/devfs/devfs_devs.c
+++ b/sys/fs/devfs/devfs_devs.c
@@ -281,8 +281,10 @@ devfs_vmkdir(struct devfs_mount *dmp, char *name, int namelen, struct devfs_dire
de->de_dir = dd;
} else {
de->de_dir = dotdot;
+ sx_assert(&dmp->dm_lock, SX_XLOCKED);
TAILQ_INSERT_TAIL(&dotdot->de_dlist, dd, de_list);
dotdot->de_links++;
+ devfs_rules_apply(dmp, dd);
}
#ifdef MAC
diff --git a/sys/fs/devfs/devfs_rule.c b/sys/fs/devfs/devfs_rule.c
index d3a3ef3..d26f3504 100644
--- a/sys/fs/devfs/devfs_rule.c
+++ b/sys/fs/devfs/devfs_rule.c
@@ -139,6 +139,8 @@ devfs_rules_apply(struct devfs_mount *dm, struct devfs_dirent *de)
{
struct devfs_ruleset *ds;
+ sx_assert(&dm->dm_lock, SX_XLOCKED);
+
if (dm->dm_ruleset == 0)
return;
sx_slock(&sx_rules);
diff --git a/sys/fs/devfs/devfs_vnops.c b/sys/fs/devfs/devfs_vnops.c
index 5f1063d..c5f0dca 100644
--- a/sys/fs/devfs/devfs_vnops.c
+++ b/sys/fs/devfs/devfs_vnops.c
@@ -1589,6 +1589,7 @@ devfs_symlink(struct vop_symlink_args *ap)
de_dotdot = TAILQ_NEXT(de_dotdot, de_list); /* ".." */
TAILQ_INSERT_AFTER(&dd->de_dlist, de_dotdot, de, de_list);
devfs_dir_ref_de(dmp, dd);
+ devfs_rules_apply(dmp, de);
return (devfs_allocv(de, ap->a_dvp->v_mount, LK_EXCLUSIVE, ap->a_vpp));
}
OpenPOWER on IntegriCloud