mirror of
https://git.openafs.org/openafs.git
synced 2025-01-21 00:10:15 +00:00
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 <jaltman@secure-endpoints.com> Tested-by: Jeffrey Altman <jaltman@secure-endpoints.com>
This commit is contained in:
parent
2982f8c5b1
commit
e53e189c3e
@ -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);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user