diff options
author | jkoshy <jkoshy@FreeBSD.org> | 2009-12-29 02:35:50 +0000 |
---|---|---|
committer | jkoshy <jkoshy@FreeBSD.org> | 2009-12-29 02:35:50 +0000 |
commit | c2b52cffb792bd1447586fcead68ec527663b573 (patch) | |
tree | ccf5c60affee8f0a99b1305088f03865cc5f2750 /sys/dev/hwpmc | |
parent | 7236f425fcc7d93f3e40c7b625ded5a6aebdb638 (diff) | |
download | FreeBSD-src-c2b52cffb792bd1447586fcead68ec527663b573.zip FreeBSD-src-c2b52cffb792bd1447586fcead68ec527663b573.tar.gz |
Use VFS_{LOCK,UNLOCK}_GIANT() around the call to vrele().
Reviewed by: kib
Diffstat (limited to 'sys/dev/hwpmc')
-rw-r--r-- | sys/dev/hwpmc/hwpmc_mod.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/sys/dev/hwpmc/hwpmc_mod.c b/sys/dev/hwpmc/hwpmc_mod.c index 6c7c587..d331a85 100644 --- a/sys/dev/hwpmc/hwpmc_mod.c +++ b/sys/dev/hwpmc/hwpmc_mod.c @@ -41,6 +41,7 @@ __FBSDID("$FreeBSD$"); #include <sys/lock.h> #include <sys/malloc.h> #include <sys/module.h> +#include <sys/mount.h> #include <sys/mutex.h> #include <sys/pmc.h> #include <sys/pmckern.h> @@ -1625,6 +1626,7 @@ pmc_log_kernel_mappings(struct pmc *pm) static void pmc_log_process_mappings(struct pmc_owner *po, struct proc *p) { + int locked; vm_map_t map; struct vnode *vp; struct vmspace *vm; @@ -1733,7 +1735,11 @@ pmc_log_process_mappings(struct pmc_owner *po, struct proc *p) freepath = NULL; pmc_getfilename(vp, &fullpath, &freepath); last_vp = vp; + + locked = VFS_LOCK_GIANT(vp->v_mount); vrele(vp); + VFS_UNLOCK_GIANT(locked); + vp = NULL; pmclog_process_map_in(po, p->p_pid, start_addr, fullpath); if (freepath) |