3 typedef struct _NOCC_BCB
8 struct _NOCC_CACHE_MAP
*Map
;
9 PROS_SECTION_OBJECT SectionObject
;
10 LARGE_INTEGER FileOffset
;
16 /* Reference counts */
19 LIST_ENTRY ThisFileList
;
22 ULONG ExclusiveWaiter
;
24 } NOCC_BCB
, *PNOCC_BCB
;
26 typedef struct _NOCC_CACHE_MAP
29 LIST_ENTRY AssociatedBcb
;
30 LIST_ENTRY PrivateCacheMaps
;
33 CC_FILE_SIZES FileSizes
;
34 CACHE_MANAGER_CALLBACKS Callbacks
;
37 PFLUSH_TO_LSN FlushToLsn
;
38 ULONG ReadAheadGranularity
;
39 } NOCC_CACHE_MAP
, *PNOCC_CACHE_MAP
;
44 CcPfInitializePrefetcher(VOID
);
48 CcMdlReadComplete2(IN PFILE_OBJECT FileObject
,
49 IN PMDL MemoryDescriptorList
);
53 CcMdlWriteComplete2(IN PFILE_OBJECT FileObject
,
54 IN PLARGE_INTEGER FileOffset
,
64 CcpUnpinData(PNOCC_BCB Bcb
,
65 BOOLEAN ActuallyRelease
);
70 CcInitializeCacheManager(VOID
);
74 CcShutdownSystem(VOID
);
78 CcInitCacheZeroPage(VOID
);
80 /* Called by section.c */
83 CcFlushImageSection(PSECTION_OBJECT_POINTERS SectionObjectPointer
,
84 MMFLUSH_TYPE FlushType
);
88 _CcpFlushCache(IN PNOCC_CACHE_MAP Map
,
89 IN OPTIONAL PLARGE_INTEGER FileOffset
,
91 OUT OPTIONAL PIO_STATUS_BLOCK IoStatus
,
96 #define CcpFlushCache(M,F,L,I,D) _CcpFlushCache(M,F,L,I,D,__FILE__,__LINE__)
100 CcGetFileSizes(PFILE_OBJECT FileObject
,
101 PCC_FILE_SIZES FileSizes
);
105 CcpCountCacheSections(PNOCC_CACHE_MAP Map
);
109 CcpAcquireFileLock(PNOCC_CACHE_MAP Map
);
113 CcpReleaseFileLock(PNOCC_CACHE_MAP Map
);
116 * Macro for generic cache manage bugchecking. Note that this macro assumes
117 * that the file name including extension is always longer than 4 characters.
119 #define KEBUGCHECKCC \
120 KEBUGCHECKEX(CACHE_MANAGER, \
121 (*(ULONG*)(__FILE__ + sizeof(__FILE__) - 4) << 16) | \
122 (__LINE__ & 0xFFFF), 0, 0, 0)
126 #define CACHE_SINGLE_FILE_MAX (16)
127 #define CACHE_OVERALL_SIZE (32 * 1024 * 1024)
128 #define CACHE_STRIPE VACB_MAPPING_GRANULARITY
129 #define CACHE_SHIFT 18
130 #define CACHE_NUM_SECTIONS (CACHE_OVERALL_SIZE / CACHE_STRIPE)
131 #define CACHE_ROUND_UP(x) (((x) + (CACHE_STRIPE-1)) & ~(CACHE_STRIPE-1))
132 #define CACHE_ROUND_DOWN(x) ((x) & ~(CACHE_STRIPE-1))
133 #define INVALID_CACHE ((ULONG)~0)
135 extern NOCC_BCB CcCacheSections
[CACHE_NUM_SECTIONS
];
136 extern PRTL_BITMAP CcCacheBitmap
;
137 extern FAST_MUTEX CcMutex
;
138 extern KEVENT CcDeleteEvent
;
139 extern ULONG CcCacheClockHand
;
140 extern LIST_ENTRY CcPendingUnmap
;
141 extern KEVENT CcpLazyWriteEvent
;
143 #define CcpLock() _CcpLock(__FILE__,__LINE__)
144 #define CcpUnlock() _CcpUnlock(__FILE__,__LINE__)
146 extern VOID
_CcpLock(const char *file
, int line
);
147 extern VOID
_CcpUnlock(const char *file
, int line
);
149 extern VOID
CcpReferenceCache(ULONG Sector
);
150 extern VOID
CcpDereferenceCache(ULONG Sector
, BOOLEAN Immediate
);
154 CcpMapData(IN PFILE_OBJECT FileObject
,
155 IN PLARGE_INTEGER FileOffset
,
158 OUT PVOID
*BcbResult
,
163 CcpPinMappedData(IN PNOCC_CACHE_MAP Map
,
164 IN PLARGE_INTEGER FileOffset
,