extern NPAGED_LOOKASIDE_LIST iBcbLookasideList;
+/* Counters:
+ * - Number of calls to CcMapData that could wait
+ * - Number of calls to CcMapData that couldn't wait
+ * - Number of calls to CcPinRead that could wait
+ * - Number of calls to CcPinRead that couldn't wait
+ */
+ULONG CcMapDataWait = 0;
+ULONG CcMapDataNoWait = 0;
+ULONG CcPinReadWait = 0;
+ULONG CcPinReadNoWait = 0;
+
/* FUNCTIONS *****************************************************************/
/*
" pBcb 0x%p, pBuffer 0x%p)\n", FileObject, FileOffset->QuadPart,
Length, Flags, pBcb, pBuffer);
+ if (Flags & MAP_WAIT)
+ {
+ ++CcMapDataWait;
+ }
+ else
+ {
+ ++CcMapDataNoWait;
+ }
+
ReadOffset = FileOffset->QuadPart;
ASSERT(FileObject);
IN ULONG Flags,
OUT PVOID * Bcb)
{
+ PINTERNAL_BCB iBcb;
PROS_SHARED_CACHE_MAP SharedCacheMap;
CCTRACE(CC_API_DEBUG, "FileOffset=%p FileOffset=%p Length=%lu Flags=0x%lx\n",
ASSERT(SharedCacheMap);
ASSERT(SharedCacheMap->PinAccess);
- /* no-op for current implementation. */
+ iBcb = *Bcb;
+ ASSERT(iBcb->Pinned == FALSE);
+
+ iBcb->Pinned = TRUE;
+ iBcb->Vacb->PinCount++;
+
+ if (Flags & PIN_EXCLUSIVE)
+ {
+ ExAcquireResourceExclusiveLite(&iBcb->Lock, TRUE);
+ }
+ else
+ {
+ ExAcquireResourceSharedLite(&iBcb->Lock, TRUE);
+ }
+
return TRUE;
}
OUT PVOID * Bcb,
OUT PVOID * Buffer)
{
- PINTERNAL_BCB iBcb;
-
CCTRACE(CC_API_DEBUG, "FileOffset=%p FileOffset=%p Length=%lu Flags=0x%lx\n",
FileObject, FileOffset, Length, Flags);
- if (CcMapData(FileObject, FileOffset, Length, Flags, Bcb, Buffer))
+ if (Flags & PIN_WAIT)
{
- if (CcPinMappedData(FileObject, FileOffset, Length, Flags, Bcb))
- {
- iBcb = *Bcb;
-
- ASSERT(iBcb->Pinned == FALSE);
-
- iBcb->Pinned = TRUE;
- iBcb->Vacb->PinCount++;
- CcRosReleaseVacbLock(iBcb->Vacb);
+ ++CcPinReadWait;
+ }
+ else
+ {
+ ++CcPinReadNoWait;
+ }
- if (Flags & PIN_EXCLUSIVE)
- {
- ExAcquireResourceExclusiveLite(&iBcb->Lock, TRUE);
- }
- else
- {
- ExAcquireResourceSharedLite(&iBcb->Lock, TRUE);
- }
+ /* Map first */
+ if (!CcMapData(FileObject, FileOffset, Length, Flags, Bcb, Buffer))
+ {
+ return FALSE;
+ }
- return TRUE;
- }
- else
- CcUnpinData(*Bcb);
+ /* Pin then */
+ if (!CcPinMappedData(FileObject, FileOffset, Length, Flags, Bcb))
+ {
+ CcUnpinData(*Bcb);
+ return FALSE;
}
- return FALSE;
+
+ return TRUE;
}
/*
Bcb, Lsn);
iBcb->Dirty = TRUE;
- CcRosMarkDirtyVacb(iBcb->Vacb);
+ if (!iBcb->Vacb->Dirty)
+ {
+ CcRosMarkDirtyVacb(iBcb->Vacb);
+ }
}
{
ExReleaseResourceForThreadLite(&iBcb->Lock, ResourceThreadId);
iBcb->Pinned = FALSE;
- CcRosAcquireVacbLock(iBcb->Vacb, NULL);
iBcb->Vacb->PinCount--;
}
- CcRosReleaseVacb(iBcb->Vacb->SharedCacheMap,
- iBcb->Vacb,
- TRUE,
- iBcb->Dirty,
- FALSE);
-
if (--iBcb->RefCount == 0)
{
+ CcRosReleaseVacb(iBcb->Vacb->SharedCacheMap,
+ iBcb->Vacb,
+ TRUE,
+ iBcb->Dirty,
+ FALSE);
+
ExDeleteResourceLite(&iBcb->Lock);
ExFreeToNPagedLookasideList(&iBcbLookasideList, iBcb);
}
IoStatus->Information = 0;
if (WriteThrough)
{
- CcRosAcquireVacbLock(iBcb->Vacb, NULL);
if (iBcb->Vacb->Dirty)
{
IoStatus->Status = CcRosFlushVacb(iBcb->Vacb);
{
IoStatus->Status = STATUS_SUCCESS;
}
- CcRosReleaseVacbLock(iBcb->Vacb);
}
else
{
{
ExReleaseResourceLite(&iBcb->Lock);
iBcb->Pinned = FALSE;
- CcRosAcquireVacbLock(iBcb->Vacb, NULL);
iBcb->Vacb->PinCount--;
+ ASSERT(iBcb->Vacb->PinCount == 0);
}
+
+ CcRosReleaseVacb(iBcb->Vacb->SharedCacheMap,
+ iBcb->Vacb,
+ TRUE,
+ iBcb->Dirty,
+ FALSE);
+
ExDeleteResourceLite(&iBcb->Lock);
ExFreeToNPagedLookasideList(&iBcbLookasideList, iBcb);
}