Linux: drop GLOCK before calling dput

Holding the GLOCK when calling dput can result in a deadlock when
the kernel calls back into afs_dentry_iput.  It should be safe
to drop the lock here.

Change-Id: I8966aea7336b39b4c3ec265a53d820fc6135eeaf
Reviewed-on: http://gerrit.openafs.org/8046
Reviewed-by: Simon Wilkinson <simonxwilkinson@gmail.com>
Reviewed-by: Derrick Brashear <shadow@your-file-system.com>
Tested-by: Derrick Brashear <shadow@your-file-system.com>
This commit is contained in:
Marc Dionne 2012-09-05 20:25:55 -04:00 committed by Derrick Brashear
parent 777e03103f
commit 0dac4de8ee

View File

@ -1239,7 +1239,13 @@ afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg, int follow)
#endif /* AFS_NEED_CLIENTCONTEXT */ #endif /* AFS_NEED_CLIENTCONTEXT */
if (vp) { if (vp) {
#ifdef AFS_LINUX22_ENV #ifdef AFS_LINUX22_ENV
/*
* Holding the global lock when calling dput can cause a deadlock
* when the kernel calls back into afs_dentry_iput
*/
AFS_GUNLOCK();
dput(dp); dput(dp);
AFS_GLOCK();
#else #else
#if defined(AFS_FBSD80_ENV) #if defined(AFS_FBSD80_ENV)
if (VOP_ISLOCKED(vp)) if (VOP_ISLOCKED(vp))