mirror of
https://git.openafs.org/openafs.git
synced 2025-01-19 23:40:13 +00:00
Windows: cm_ShutdownSCache corrections
Obtain cm_scache.dirlock, cm_scache.rw and cm_scacheLock in the correct order. Do not release cm_scache.rw when it is not held. Since the cm_scacheLock is being dropped, preserve the value of scp->allNextp prior to dropping the lock. Change-Id: I025a8d76f3f7b94ae00bfd4e000750a90d38b343 Reviewed-on: http://gerrit.openafs.org/5279 Reviewed-by: Jeffrey Altman <jaltman@openafs.org> Tested-by: Jeffrey Altman <jaltman@openafs.org>
This commit is contained in:
parent
020b415be8
commit
c58ae34f72
@ -583,20 +583,24 @@ cm_SuspendSCache(void)
|
||||
long
|
||||
cm_ShutdownSCache(void)
|
||||
{
|
||||
cm_scache_t * scp;
|
||||
cm_scache_t * scp, * nextp;
|
||||
|
||||
cm_GiveUpAllCallbacksAllServersMulti(FALSE);
|
||||
|
||||
lock_ObtainWrite(&cm_scacheLock);
|
||||
|
||||
for ( scp = cm_data.allSCachesp; scp;
|
||||
scp = scp->allNextp ) {
|
||||
scp = nextp ) {
|
||||
nextp = scp->allNextp;
|
||||
lock_ReleaseWrite(&cm_scacheLock);
|
||||
#ifdef USE_BPLUS
|
||||
lock_ObtainWrite(&scp->dirlock);
|
||||
#endif
|
||||
lock_ObtainWrite(&scp->rw);
|
||||
lock_ObtainWrite(&cm_scacheLock);
|
||||
|
||||
if (scp->randomACLp) {
|
||||
lock_ReleaseWrite(&cm_scacheLock);
|
||||
lock_ObtainWrite(&scp->rw);
|
||||
lock_ObtainWrite(&cm_scacheLock);
|
||||
cm_FreeAllACLEnts(scp);
|
||||
lock_ReleaseWrite(&scp->rw);
|
||||
}
|
||||
|
||||
if (scp->cbServerp) {
|
||||
@ -612,6 +616,7 @@ cm_ShutdownSCache(void)
|
||||
freeBtree(scp->dirBplus);
|
||||
scp->dirBplus = NULL;
|
||||
scp->dirDataVersion = CM_SCACHE_VERSION_BAD;
|
||||
lock_ReleaseWrite(&scp->dirlock);
|
||||
lock_FinalizeRWLock(&scp->dirlock);
|
||||
#endif
|
||||
lock_FinalizeRWLock(&scp->rw);
|
||||
|
Loading…
Reference in New Issue
Block a user