Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

524 lines
24 KiB

  1. /****************************************************************************************************************
  2. FILENAME: DfrgEngn.h
  3. COPYRIGHT 2001 Microsoft Corporation and Executive Software International, Inc.
  4. DESCRIPTION:
  5. This contains the definitions for the common global data as used in
  6. both the FAT and NTFS defragmentation engines.
  7. /***************************************************************************************************************
  8. Structures
  9. ***************************************************************************************************************/
  10. #ifndef _DFRGENGN_H_
  11. #define _DFRGENGN_H_
  12. #include "VString.hpp"
  13. #include "alloc.h"
  14. //The size of the extent buffer in bytes.
  15. #define EXTENT_BUFFER_LENGTH 65536
  16. //The number of milliseconds to set the timer for updating the DiskView class.
  17. #define DISKVIEWUPDATEINTERVAL 1000
  18. //The number of milliseconds to wait for the DiskView mutex before erroring out.
  19. #define DISKVIEWMUTEXWAITINTERVAL 20000
  20. //The number of milliseconds between pings.
  21. #define PINGTIMER 5000
  22. //The prescan reads in chunks of the MFT directly from disk. This is the size of the chunks.
  23. #define MFT_BUFFER_SIZE 65536
  24. //Defines for whether the current pass moves these types of files.
  25. #define MOVE_FRAGMENTED 0x00000001
  26. #define MOVE_CONTIGUOUS 0x00000002
  27. //Defines the type of file system this engine is running on.
  28. #define FS_NONE 0
  29. #define FS_FAT 1
  30. #define FS_NTFS 2
  31. #define FS_FAT32 3
  32. //For use to determine whether we're moveing through the files forward or backward on a volume.
  33. #define FORWARD 0
  34. #define BACKWARD 1
  35. //The different combinations of bits that can be set to determine which type of free space to look for in
  36. //defragmenting a file.
  37. #define FIRST_FIT 0x001
  38. #define BEST_FIT 0x002
  39. #define LAST_FIT 0x004
  40. #define EARLIER 0x008
  41. #define FIND_FIRST 0x010
  42. #define FIND_LAST 0x020
  43. #define FIND_LARGEST 0x040
  44. #define AT_END 0x080
  45. #define COUNT_FREE_SPACES 0x100
  46. //The status's after attempting to defrag a file.
  47. #define NEXT_FILE 0x10 //Go on to the next file (successfully defragged, or can't defrag at all).
  48. #define NEXT_ALGO_STEP 0x20 //Try the next method of defragmenting this file (last one failed).
  49. #define NEXT_PASS 0x30 //Done with this pass, or major error, bomb out of this pass.
  50. #define TERMINATE_ENGINE 0x40 //Fatal error. Die a miserable death (gracefully).
  51. //The status of the engine.
  52. #define RUNNING 0x01 //The engine is running.
  53. #define PAUSED 0x02 //The engine is paused.
  54. #define TERMINATE 0x03 //The engine needs to terminate.
  55. //There will be a buffer for reading in chunks of the MFT. Make it nice and big so we aren't doing zillions of I/O's.
  56. #define MFT_BUFFER_BYTES 65536
  57. //#define AT_END 0x080
  58. //#define COUNT_FREE_SPACES 0x100
  59. //This goes at the beginning of an extent list before the series of streams to identify the streams that follow.
  60. typedef struct {
  61. LONGLONG FileRecordNumber; //The FRS of the file that owns the following streams.
  62. DWORD NumberOfStreams; //The number of streams that follow.
  63. DWORD TotalNumberOfStreams; //The total number of streams in the file including resident ones.
  64. LONGLONG ExcessExtents; //The number of excess extents in all the streams that follow.
  65. } FILE_EXTENT_HEADER, *PFILE_EXTENT_HEADER;
  66. //This goes into extent lists before each series of extents to identify the extents that follow within a stream.
  67. typedef struct {
  68. DWORD StreamNumber; //The number of this stream..
  69. LONGLONG ExtentCount; //The number of extents that follow.
  70. LONGLONG ExcessExtents; //The number of excess extents in the stream.
  71. LONGLONG AllocatedLength; //The allocated length for this stream.
  72. LONGLONG FileSize; //The size of data in this stream.
  73. } STREAM_EXTENT_HEADER, *PSTREAM_EXTENT_HEADER;
  74. //The extent list for files has a series of these structures, one for each extent.
  75. typedef struct {
  76. LONGLONG StartingLcn; //The Lcn this extent starts on.
  77. LONGLONG ClusterCount; //The count of clusters in this extent.
  78. #ifdef OFFLINEDK
  79. LONGLONG Frn; //The FileRecordNumber we got this from.
  80. LONGLONG OriginalLcn; //The Lcn this extent got moved from.
  81. DWORD AttributeNumber; //Which attribute in that FRS this is from.
  82. #endif
  83. } EXTENT_LIST, *PEXTENT_LIST;
  84. //We will have a buffer for holding extent lists of individual files. Allocate a nice big buffer initially to avoid frequent reallocs.
  85. #define INITIAL_EXTENT_LIST_BYTES (4096 * sizeof(EXTENT_LIST))
  86. //This is a file list entry.
  87. typedef struct _FILE_LIST_ENTRY {
  88. LONGLONG StartingLcn;
  89. LONGLONG FileRecordNumber;
  90. LONGLONG ClusterCount;
  91. ULONG ExcessExtentCount;
  92. BYTE Flags;
  93. BYTE Reserved[3];
  94. } FILE_LIST_ENTRY;
  95. typedef struct _FREE_SPACE_ENTRY {
  96. LONGLONG StartingLcn;
  97. LONGLONG ClusterCount;
  98. BOOL SortBySize;
  99. DWORD Reserved;
  100. } FREE_SPACE_ENTRY;
  101. typedef struct _FILE_LIST_ENTRY *PFILE_LIST_ENTRY;
  102. typedef struct _FREE_SPACE_ENTRY *PFREE_SPACE_ENTRY;
  103. //FLE stands for FILE_LIST_EXTRY. These masks are the bitmasks to the Flags member of FILE_LIST_EXTRY.
  104. #define FLE_DISABLED 0x01 //This bit identifies whether the file is not to be defragmented on any further pass.
  105. #define FLE_NEXT_PASS 0x02 //This bit identifies whether the file is not to be defragmented again this pass.
  106. #define FLE_FRAGMENTED 0x04 //This bit identifies whether the file is fragmented or not.
  107. #define FLE_DIRECTORY 0x08 //This bit identifies whether the file is a directory or not.
  108. #define FLE_BOOTOPTIMISE 0x10 //This bit identifies whether the file is to be boot-optimised
  109. ////Same as extent list except this is the format we use in the file lists. It only holds 32-bit values
  110. ////to save space in the file lists.
  111. //typedef struct{
  112. // ULONG StartingLcn;
  113. // ULONG ClusterCount;
  114. //} FILE_LIST_EXTENT;
  115. //
  116. ////This goes into the file lists before each series of extents to identify the extents that follow.
  117. ////Notice it has the same exact structure size as FILE_LIST_EXTENT so allocs can use one or the other without trouble.
  118. //typedef struct{
  119. // ULONG FileRecordNumber; //The FRS of the file that owns the following extents.
  120. // ULONG ExtentCount; //The number of extents that follow.
  121. //} FILE_LIST_HEADER;
  122. //This contains the various pointers necessary to hold an extent list and pass it around among the extent functions.
  123. typedef struct{
  124. HANDLE hExtents; //Handle to the memory for the extent list.
  125. UCHAR* pExtents; //Pointer to the memory for the extent list.
  126. DWORD ExtentListAlloced; //The number of bytes allocated in memory for the extent list.
  127. DWORD ExtentListSize; //The number of bytes actually used by the extent list in the alloced memory.
  128. FILE_EXTENT_HEADER* pFileExtentHeader; //The file extent header for this file's extent list.
  129. STREAM_EXTENT_HEADER* pStreamExtentHeader; //The stream extent header for any given stream in this file's extent list.
  130. DWORD dwEnabledStreams; //Determines which types of streams to look for.
  131. LONGLONG BytesRead; //The number of bytes read to the current stream.
  132. LONGLONG TotalClusters; //The number of clusters in all the streams of the file.
  133. LONGLONG TotalRealClusters; //The number of real clusters in all the streams of the file.
  134. } EXTENT_LIST_DATA;
  135. #define DEFAULT_STREAMS 0 //$DATA and $INDEX_ALLOCATION
  136. #define ALL_STREAMS 1 //$DATA, $INDEX_ALLOCATION, and $BITMAP
  137. //Used to access a LONGLONG as two discrete DWORDs
  138. typedef union _DWORD_AND_LONGLONG
  139. {
  140. struct {
  141. DWORD Low;
  142. DWORD High;
  143. } Dword;
  144. LONGLONG LongLong;
  145. } DWORD_AND_LONGLONG;
  146. // number of passes in the defrag alogrithm
  147. #define PASS_COUNT 7
  148. typedef struct {
  149. LONGLONG BitmapSize; //Total bits in bitmap buffer (padded fort 32 bit scans)
  150. LONGLONG BytesPerSector; //Number of bytes in one sector
  151. LONGLONG BytesPerCluster; //Number of bytes in one cluster
  152. LONGLONG SectorsPerCluster; //Number of sector in one cluster
  153. LONGLONG TotalSectors; //Number of sectors in this volume
  154. LONGLONG TotalClusters; //Number of clusters in this volume
  155. LONGLONG UsedClusters; //Number of used clusters on the drive
  156. LONGLONG UsedSpace; //Number of used bytes on the drive
  157. LONGLONG FreeSpace; //Number of free bytes on the drive
  158. LONGLONG UsableFreeSpace; //Number of usable free bytes on the drive
  159. LONGLONG NumFreeSpaces; //The number of free spaces on the volume.
  160. LONGLONG SmallestFreeSpaceClusters;//The size of the smallest free space in clusters.
  161. LONGLONG LargestFreeSpaceClusters;//The size of the largest free space in clusters.
  162. LONGLONG AveFreeSpaceClusters; //The average size of the free spaces in clusters.
  163. LONGLONG ExtentListAlloced; //The size in bytes of the allocated memory for the extent list.
  164. LONGLONG ExtentListSize;
  165. LONGLONG FileRecordNumber; //File record number of current file in this volume
  166. //(for NTFS it may be less than FreeSpace)
  167. LONGLONG StartingLcn; //The Lcn to consider as the earliest on the disk for the current file (not necessarily the earliest in actuality).
  168. // LONGLONG NumberOfExtents; //Number of extents in current file
  169. LONGLONG NumberOfFragments; //Number of fragments in current file
  170. LONGLONG NumberOfClusters; //Number of clusters in current file
  171. LONGLONG NumberOfRealClusters; //Number of real clusters in current file
  172. LONGLONG NumberOfFileRecords; //Number of File Records holding this file's extents
  173. LONGLONG FileSize; //Number of bytes in current file
  174. LONGLONG AllocatedLength; //Number of bytes allocated to the current file on disk.
  175. LONGLONG MftStartOffset; //Byte offset to the Mft
  176. LONGLONG MftStartLcn; //First cluster of the Mft
  177. LONGLONG Mft2StartLcn; //First cluster of the Mirror Mft
  178. LONGLONG MftZoneStart; //First cluster of the Mft zone.
  179. LONGLONG MftZoneEnd; //Last cluster of the Mft zone.
  180. LONGLONG BytesPerFRS; //Number of bytes in one file record segment
  181. LONGLONG ClustersPerFRS; //Number of clusters in one file record segment
  182. LONGLONG TotalFileRecords; //Number of file records in this volume
  183. LONGLONG InUseFileRecords; //How many file records are in use in the MFT.
  184. LONGLONG LastStartingLcn; //The LCN referring to the last file we said to defrag so we know where to pick up again when looking for the next file in the file lists to defrag.
  185. LONGLONG FatOffset; //The offset from the beginning of the disk to the active fat in clusters.
  186. LONGLONG FatMirrOffset; //The offset from the beginning of the disk to the mirror fat in clusters (or 0 if it doesn't exist).
  187. LONGLONG FoundLcn; //The Lcn of the free space found to move this file into.
  188. LONGLONG FoundLen; //The length of the free space.
  189. LONGLONG FilesMoved; //The number of files moved in the last pass.
  190. LONGLONG FreeSpaces; //The number of free spaces on the disk.
  191. LONGLONG CenterOfDisk; //The center cluster number on the disk.
  192. LONGLONG TotalFiles; //The total number of large files on the disk. (Not size, see the types of files that can exist on NTFS: small, large, huge, extremely huge)
  193. LONGLONG NumFraggedFiles; //The number of fragmented files on the disk.
  194. LONGLONG NumExcessFrags; //The number of frags over and above the 1 per file (i.e. frags that degrade performance.)
  195. LONGLONG TotalDirs; //The total number of directories on the disk.
  196. LONGLONG TotalSmallDirs; //Total number of Small Directories on the disk.
  197. // LONGLONG TotalDirExtents; //The total number of extents in all directories on the disk.
  198. LONGLONG NumFraggedDirs; //The total number of fragmented directories on the disk.
  199. LONGLONG NumExcessDirFrags; //The total number of excess frags in directories.
  200. LONGLONG NumFilesInMftZone; //acs//The total number of files in the Mft Zone
  201. LONGLONG AveFileSize; //The average size of the files on this disk in bytes.
  202. LONGLONG FraggedSpace; //The continuous counter of how many bytes on the disk are occupied by fragmented files.
  203. LONGLONG PercentDiskFragged; //What percent of the disk is fragmented.
  204. LONGLONG AveFragsPerFile; //The average number of fragments per file.
  205. LONGLONG TotalFileBytes; //The total number of bytes in all the files on the disk.
  206. LONGLONG TotalFileSpace; //The continuous counter of how many bytes all the files found on a scan take up.
  207. // LONGLONG TotalDirSpace; //The continuous counter of how many bytes all the directories found on a scan take up.
  208. LONGLONG CurrentFile; //The continuous counter of how many files have been found on a scan.
  209. // LONGLONG CurrentDirectory; //The continuous counter of how many directories have been found on a scan.
  210. LONGLONG MftSize; //The size of the Mft in bytes.
  211. LONGLONG MftNumberOfExtents; //Number of extents in the Mft
  212. LONGLONG PagefileSize; //The size of the pagefile in bytes.
  213. LONGLONG PagefileFrags; //The number of fragments in the pagefile.
  214. LONGLONG NumPagefiles; //The number of active pagefiles on this drive.
  215. LONGLONG LeastFragged; //The number of fragments in the least fragmented file in the most fragmented file list.
  216. LONGLONG LastPathFrs; //The frs of the directory the last file was in.
  217. LONGLONG MasterLcn; //The starting lcn of the directory that contains the entry for this file.
  218. LONGLONG FreeExtents; //The number of free extents in the free extents list (partial defrag).
  219. LONGLONG InitialFraggedClusters; //The total number of fragmented clusters after the analyse
  220. LONGLONG InitialContiguousClusters; // The total number of contiguous clusters after the analyse
  221. LONGLONG FraggedClustersDone; // Number of clusters we have finished defragmenting
  222. LONGLONG BootOptimizeBeginClusterExclude; //the cluster number where we exclude moving files
  223. LONGLONG BootOptimizeEndClusterExclude; //the cluster number where we exclude moving files
  224. LONGLONG BootOptimiseFileListTotalSize;
  225. LONGLONG BootOptimiseFilesAlreadyInZoneSize;
  226. PFILE_LIST_ENTRY pFileListEntry;
  227. PFREE_SPACE_ENTRY pFreeSpaceEntry;
  228. PLONGLONG pBootOptimiseFrnList;
  229. struct _SA_CONTEXT SaFreeSpaceContext;
  230. struct _SA_CONTEXT SaFileEntryContext;
  231. struct _SA_CONTEXT SaBootOptimiseFilesContext;
  232. RTL_GENERIC_TABLE FragmentedFileTable;
  233. RTL_GENERIC_TABLE ContiguousFileTable;
  234. RTL_GENERIC_TABLE NonMovableFileTable;
  235. RTL_GENERIC_TABLE FreeSpaceTable;
  236. RTL_GENERIC_TABLE BootOptimiseFileTable;
  237. RTL_GENERIC_TABLE FilesInBootExcludeZoneTable;
  238. RTL_GENERIC_TABLE MultipleFreeSpaceTrees[10];
  239. PTCHAR pNameList; //Pointer to the name list.
  240. UCHAR* pExtentList; //Pointer to the extent list.
  241. FILE_RECORD_SEGMENT_HEADER* pMftBuffer; //Pointer to that buffer.
  242. EXTENT_LIST* pMftExtentList; //The pointer to the Mft's extent list.
  243. PVOID pFileRecord; //Pointer to the Frs.
  244. VString vFileName; //The name of the current file
  245. TCHAR
  246. NodeName[MAX_COMPUTERNAME_LENGTH+1]; //The name of the node this engine is running on.
  247. SYSTEMTIME StartTime; //The time the engine started.
  248. SYSTEMTIME EndTime; //The time the engine finished action (not terminated).
  249. FILE_LIST_ENTRY* pSysList; //Pointer to the system file list.
  250. DWORD FileSystem; //This volume's file system (FS_NTFS, FS_FAT, FS_NONE)
  251. DWORD EngineState; //Whether the engine is paused, runnning or should terminate.
  252. DWORD FirstDataOffset; //On FAT and FAT32 drives, it specifies the byte offset for the first cluster on the disk (not zero). On NTFS - zero.
  253. DWORD Status; //During defrag this contains the status -- whether to go on to the next file, end pass, etc.
  254. DWORD Pass; //The current pass number. (prescan is 0, scan is 1, defrag passes start at 2)
  255. // The following fields are relevant only for the FAT engine
  256. HANDLE hMoveableFileList; //Handle to the moveable file list.
  257. DWORD ProcessFilesDirection; //Which direction we're traversing the disk. FORWARD or BACKWARD
  258. LONGLONG SourceStartLcn; //The first LCN in the region to move files from in the current pass.
  259. LONGLONG SourceEndLcn; //The last LCN in the region to move files from in the current pass.
  260. FILE_LIST_ENTRY* pMoveableFileList; //Pointer to the moveable file list
  261. ULONG MoveableFileListSize; //The size of the moveable file list in bytes.
  262. ULONG MoveableFileListEntries;//The number of entries (FILE_LIST_ENTRY size structures) in the moveable list.
  263. ULONG MoveableFileListIndex; //The current index into the moveable file list (in FILE_LIST_ENTRY size increments).
  264. FILE_LIST_ENTRY* pPagefileList; //Pointer to the page file list.
  265. ULONG PagefileListSize; //The size of the pagefile list in bytes.
  266. ULONG PagefileListEntries; //The number of entries (FILE_LIST_ENTRY size structures) in the pagefile file list.
  267. ULONG PagefileListIndex; //The current index into the page file list (in FILE_LIST_ENTRY size increments).
  268. DWORD Pass6Rep; //How many repetitions have occurred on pass 6. Used to limit the number of repetitions.
  269. LONGLONG FilesMovedInLastPass; //How many files were moved in the last pass.
  270. LONGLONG DestStartLcn; //The first LCN in the region to move files to in the current pass.
  271. LONGLONG DestEndLcn; //The last LCN in the region to move files to in the current pass.
  272. LONGLONG LargestFound; //The largest space found to move a file into in clusters.
  273. ULONG SysListSize; //The size of the system file list in bytes.
  274. // end FAT specific
  275. ULONG NameListSize; //The size of the name list in bytes.
  276. ULONG NameListIndex; //The current index into the name list (in bytes).
  277. ULONG VolumeBufferFlushes[PASS_COUNT]; // number of file flushes during each pass
  278. ULONG FragmentedFileMovesAttempted[PASS_COUNT]; //number of times a defragment attempt was made
  279. ULONG FragmentedFileMovesSucceeded[PASS_COUNT]; //number of times a defragment attempt succeeded
  280. ULONG FragmentedFileMovesFailed[PASS_COUNT]; //number of times a defragment attempt failed
  281. ULONG ContiguousFileMovesAttempted[PASS_COUNT]; //number of times a move attempt was made
  282. ULONG ContiguousFileMovesSucceeded[PASS_COUNT]; //number of times a move attempt succeeded
  283. ULONG ContiguousFileMovesFailed[PASS_COUNT]; //number of times a move attempt failed
  284. WORD FatVersion; //The version number of the FAT or FAT32 volume.
  285. HANDLE hVolume; //Handle to this volume
  286. HANDLE hVolumeBitmap; //Handle to volume's free space bitmap
  287. HANDLE hExtentList; //Handle to the current file's extent list
  288. HANDLE hMftBuffer; //Handle to the buffer for reading in chunks of the MFT.
  289. HANDLE hMftBitmap; //Handle to this volume's Mft bitmap
  290. HANDLE hMftExtentList; //Handle to this volume's Mft extent list
  291. HANDLE hFileRecord; //Handle for the Frs for the current file.
  292. HANDLE hExcludeList; //Handle to the exclusion list.
  293. HANDLE hFile; //Handle to the current file
  294. HANDLE hFreeExtents; //The handle to the free extents found to move this file into.
  295. HANDLE hSysList; //Handle to the system file list.
  296. HANDLE hPagefileList; //Handle to the page file list.
  297. HANDLE hNameList; //Handle to the name list which is used only for FAT and holds the names of every file in all the lists.
  298. HANDLE hBootOptimiseFrnList;
  299. TCHAR cDrive; //Drive letter of this volume (eg. C:)
  300. TCHAR cVolumeName[GUID_LENGTH];//The name of the volume (GUID or UNC)
  301. TCHAR cVolumeTag[GUID_LENGTH];//Used to concat onto strings to make unique IDs
  302. TCHAR cVolumeLabel[100]; //The volume label
  303. TCHAR cDisplayLabel[100]; //String used when printing to screen or logfile
  304. BOOL bCompressed; //If current file is compressed
  305. BOOL bDirectory; //If current file is a directory (index)
  306. BOOL bPageFile; //If current file is a PageFile
  307. BOOL bFragmented; //If current file is fragmented
  308. BOOL bSmallFile; //If current file is a small-file
  309. BOOL bLargeFile; //If current file is a large file
  310. BOOL bHugeFile; //If current file is a huge file
  311. BOOL bExtremelyHugeFile; //If current file is an extremely huge file
  312. BOOL bMFTCorrupt; //If the MFT contains corrupt records
  313. BOOL bInBootExcludeZone; //If current file has an extent in the region reserved for boot-optimisation
  314. BOOL bBootOptimiseFile; //If current file needs to be boot-optimised
  315. } VOL_DATA, *PVOL_DATA;
  316. //***************************************************************************************************************
  317. //
  318. // Global variables
  319. //
  320. //***************************************************************************************************************/
  321. //VolData contains all kinds of data!
  322. #ifndef GLOBAL_DATAHOME
  323. extern
  324. #endif
  325. VOL_DATA VolData;
  326. /* NO GLOBALS!! - MWP 12/3/98
  327. //Stores the instance of the resource DLL that we use to hold all resources. This is obtained by LoadLibrary and
  328. //is used to get any resources from the resource DLL.
  329. #ifndef GLOBAL_DATAHOME
  330. extern
  331. #endif
  332. HINSTANCE hInst
  333. #ifdef GLOBAL_DATAHOME
  334. = NULL
  335. #endif
  336. ;
  337. */
  338. //Tells whether were supposed to to an analyze or an analyze and a defrag.
  339. #ifndef GLOBAL_DATAHOME
  340. extern
  341. #endif
  342. DWORD AnalyzeOrDefrag
  343. #ifdef GLOBAL_DATAHOME
  344. = ANALYZE
  345. #endif
  346. ;
  347. //Stores the priority for the engine.
  348. #ifndef GLOBAL_DATAHOME
  349. extern
  350. #endif
  351. TCHAR cPriority[300];
  352. //Holds the handle to the main window for the Dfrg engine.
  353. #ifndef GLOBAL_DATAHOME
  354. extern
  355. #endif
  356. HWND hwndMain
  357. #ifdef GLOBAL_DATAHOME
  358. = NULL
  359. #endif
  360. ;
  361. //This is the buffer into which a file record is written after calling ESDeviceIoControl to get a file record.
  362. #ifndef GLOBAL_DATAHOME
  363. extern
  364. #endif
  365. UCHAR FileRecordOutputBuffer[(4096+32+16) * 10];
  366. //Handle to the memory which holds the name of the active pagefiles on the current drive.
  367. #ifndef GLOBAL_DATAHOME
  368. extern
  369. #endif
  370. HANDLE hPageFileNames
  371. #ifdef GLOBAL_DATAHOME
  372. = NULL
  373. #endif
  374. ;
  375. //The pointer for hPageFileNames
  376. #ifndef GLOBAL_DATAHOME
  377. extern
  378. #endif
  379. TCHAR* pPageFileNames
  380. #ifdef GLOBAL_DATAHOME
  381. = NULL
  382. #endif
  383. ;
  384. //The handle for the worker thread that carries out either Analyzing or Defragging.
  385. #ifndef GLOBAL_DATAHOME
  386. extern
  387. #endif
  388. HANDLE hThread
  389. #ifdef GLOBAL_DATAHOME
  390. = NULL
  391. #endif
  392. ;
  393. //The MFT is read in in chunks. This records the file record number of the lowest file record of the chunk that's currently loaded.
  394. #ifndef GLOBAL_DATAHOME
  395. extern
  396. #endif
  397. LONGLONG FileRecordLow
  398. #ifdef GLOBAL_DATAHOME
  399. = 0
  400. #endif
  401. ;
  402. //The MFT is read in in chunks. This records the file record number of the highest file record of the chunk that's currently loaded.
  403. #ifndef GLOBAL_DATAHOME
  404. extern
  405. #endif
  406. LONGLONG FileRecordHi
  407. #ifdef GLOBAL_DATAHOME
  408. = 0
  409. #endif
  410. ;
  411. //This table allows the number of set bits in a byte to be counted by using the
  412. //byte as an index into this table. FAST bit count. (do it twice for a word, etc)
  413. #ifndef GLOBAL_DATAHOME
  414. extern
  415. #endif
  416. BYTE CountBitsArray[256]
  417. #ifdef GLOBAL_DATAHOME
  418. = {
  419. // 0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f
  420. 0,1,1,2,1,2,2,3,1,2,2,3,2,3,3,4, // 0
  421. 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5, // 1
  422. 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5, // 2
  423. 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6, // 3
  424. 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5, // 4
  425. 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6, // 5
  426. 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6, // 6
  427. 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7, // 7
  428. 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5, // 8
  429. 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6, // 9
  430. 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6, // a
  431. 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7, // b
  432. 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6, // c
  433. 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7, // d
  434. 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7, // e
  435. 4,5,5,6,5,6,6,7,5,6,6,7,6,7,7,8 // f
  436. };
  437. #endif
  438. ;
  439. #endif //#ifndef _DFRGENGN_H_