From e53e189c3e99e28d31e0e1d1b52041aadcbd3ffa Mon Sep 17 00:00:00 2001 From: Jeffrey Altman Date: Sun, 1 Apr 2012 23:09:32 -0400 Subject: [PATCH] Windows: Redirector Dir Enumeration Bug An enumerated directory was not validated properly if AFSValidateEntry() was called with PurgeData == FALSE even when a data version change was detected. Now it does. FIXES 130636 Change-Id: Ic5d2fd62b40fb16652fc09d459caf43905566d37 Reviewed-on: http://gerrit.openafs.org/7012 Reviewed-by: Jeffrey Altman Tested-by: Jeffrey Altman --- src/WINNT/afsrdr/kernel/lib/AFSGeneric.cpp | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/src/WINNT/afsrdr/kernel/lib/AFSGeneric.cpp b/src/WINNT/afsrdr/kernel/lib/AFSGeneric.cpp index dadc0878d6..721d5567dc 100644 --- a/src/WINNT/afsrdr/kernel/lib/AFSGeneric.cpp +++ b/src/WINNT/afsrdr/kernel/lib/AFSGeneric.cpp @@ -3704,12 +3704,14 @@ AFSValidateEntry( IN AFSDirectoryCB *DirEntry, AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING, AFS_TRACE_LEVEL_VERBOSE_2, - "AFSValidateEntry Validating entry %wZ FID %08lX-%08lX-%08lX-%08lX\n", + "AFSValidateEntry Validating entry %wZ FID %08lX-%08lX-%08lX-%08lX PurgeContent %u FastCall %u\n", &DirEntry->NameInformation.FileName, pObjectInfo->FileId.Cell, pObjectInfo->FileId.Volume, pObjectInfo->FileId.Vnode, - pObjectInfo->FileId.Unique); + pObjectInfo->FileId.Unique, + PurgeContent, + FastCall); // // If this is a fake node then bail since the service knows nothing about it @@ -3802,7 +3804,8 @@ AFSValidateEntry( IN AFSDirectoryCB *DirEntry, AFSDbgLogMsg( AFS_SUBSYSTEM_FILE_PROCESSING, AFS_TRACE_LEVEL_VERBOSE, - "AFSValidateEntry Validating entry FastCall %d %wZ FID %08lX-%08lX-%08lX-%08lX DV %I64X returned DV %I64X FT %d\n", + "AFSValidateEntry Validating entry Purge %d FastCall %d %wZ FID %08lX-%08lX-%08lX-%08lX DV %I64X returned DV %I64X FT %d\n", + PurgeContent, FastCall, &DirEntry->NameInformation.FileName, pObjectInfo->FileId.Cell, @@ -4026,8 +4029,7 @@ AFSValidateEntry( IN AFSDirectoryCB *DirEntry, AFSDirectoryCB *pCurrentDirEntry = NULL; - if( pCurrentFcb != NULL && - pObjectInfo->DataVersion.QuadPart != pDirEnumEntry->DataVersion.QuadPart) + if( pObjectInfo->DataVersion.QuadPart != pDirEnumEntry->DataVersion.QuadPart) { // @@ -4056,8 +4058,8 @@ AFSValidateEntry( IN AFSDirectoryCB *DirEntry, AFSAcquireExcl( pObjectInfo->Specific.Directory.DirectoryNodeHdr.TreeLock, TRUE); - AFSValidateDirectoryCache( pCurrentFcb->ObjectInformation, - AuthGroup); + ntStatus = AFSValidateDirectoryCache( pObjectInfo, + AuthGroup); AFSReleaseResource( pObjectInfo->Specific.Directory.DirectoryNodeHdr.TreeLock); }