Leaked source code of windows server 2003
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.

338 lines
6.7 KiB

  1. /*++
  2. Copyright (C) Microsoft Corporation, 1997 - 1999
  3. Module Name:
  4. partmgr.h
  5. Abstract:
  6. This file defines the internal data structure for the PARTMGR driver.
  7. Author:
  8. norbertk
  9. Revision History:
  10. --*/
  11. #include <partmgrp.h>
  12. #define DEVICENAME_MAXSTR 64 // used to storage device name for WMI
  13. #undef ExAllocatePool
  14. #define ExAllocatePool #
  15. #define PARTMGR_TAG_DEPENDANT_VOLUME_LIST 'vRcS' // ScRv
  16. #define PARTMGR_TAG_PARTITION_ENTRY 'pRcS' // ScRp
  17. #define PARTMGR_TAG_VOLUME_ENTRY 'VRcS' // ScRV
  18. #define PARTMGR_TAG_TABLE_ENTRY 'tRcS' // ScRt
  19. #define PARTMGR_TAG_POWER_WORK_ITEM 'wRcS' // ScRw
  20. #define PARTMGR_TAG_IOCTL_BUFFER 'iRcS' // ScRi
  21. #define PARTMGR_TAG_REMOVE_LOCK 'rRcS' // ScRr
  22. typedef struct _VOLMGR_LIST_ENTRY {
  23. LIST_ENTRY ListEntry;
  24. UNICODE_STRING VolumeManagerName;
  25. LONG RefCount;
  26. PDEVICE_OBJECT VolumeManager;
  27. PFILE_OBJECT VolumeManagerFileObject;
  28. } VOLMGR_LIST_ENTRY, *PVOLMGR_LIST_ENTRY;
  29. typedef struct _PARTITION_LIST_ENTRY {
  30. LIST_ENTRY ListEntry;
  31. PDEVICE_OBJECT TargetObject;
  32. PDEVICE_OBJECT WholeDiskPdo;
  33. PVOLMGR_LIST_ENTRY VolumeManagerEntry;
  34. } PARTITION_LIST_ENTRY, *PPARTITION_LIST_ENTRY;
  35. //
  36. // Allow usage of different clocks
  37. //
  38. #define USE_PERF_CTR // default to KeQueryPerformanceCounter
  39. #ifdef USE_PERF_CTR
  40. #define PmWmiGetClock(a, b) (a) = KeQueryPerformanceCounter((b))
  41. #else
  42. #define PmWmiGetClock(a, b) KeQuerySystemTime(&(a))
  43. #endif
  44. typedef
  45. VOID
  46. (*PPHYSICAL_DISK_IO_NOTIFY_ROUTINE)( // callout for disk I/O tracing
  47. IN ULONG DiskNumber,
  48. IN PIRP Irp,
  49. IN PDISK_PERFORMANCE PerfCounters
  50. );
  51. typedef struct _DO_EXTENSION {
  52. //
  53. // A pointer to the driver object.
  54. //
  55. PDRIVER_OBJECT DriverObject;
  56. //
  57. // A list of volume managers to pass partitions to. Protect with
  58. // 'Mutex'.
  59. //
  60. LIST_ENTRY VolumeManagerList;
  61. //
  62. // The list of device extensions in EpochNumber order (highest at the head).
  63. // Protect with 'Mutex'.
  64. //
  65. LIST_ENTRY DeviceExtensionList;
  66. //
  67. // The notification entry.
  68. //
  69. PVOID NotificationEntry;
  70. //
  71. // For synchronization.
  72. //
  73. KMUTEX Mutex;
  74. //
  75. // Am I past Driver Reinit?
  76. //
  77. LONG PastReinit;
  78. //
  79. // A table to keep track disk signatures which includes signatures
  80. // on MBR disks and squashed disk GUIDs on GPT disks.
  81. //
  82. RTL_GENERIC_TABLE SignatureTable;
  83. //
  84. // A table to keep track of GPT disk and partition GUIDs.
  85. //
  86. RTL_GENERIC_TABLE GuidTable;
  87. //
  88. // Registry Path.
  89. //
  90. UNICODE_STRING DiskPerfRegistryPath; // for WMI QueryRegInfo
  91. //
  92. // BootDiskSig for OEM pre-install.
  93. //
  94. ULONG BootDiskSig;
  95. //
  96. // BootPartitionGuid for OEM pre-install on GPT disks.
  97. //
  98. BOOLEAN BootPartitionGuidPresent;
  99. GUID BootPartitionGuid;
  100. //
  101. // The current Epoch Number. Protect with 'Mutex'.
  102. //
  103. ULONG CurrentEpochNumber;
  104. //
  105. // Queue of pending notifications for signature checks
  106. // Protect with 'Mutex'
  107. //
  108. LIST_ENTRY SignatureCheckNotificationIrpQueue;
  109. } DO_EXTENSION, *PDO_EXTENSION;
  110. typedef struct _DEVICE_EXTENSION {
  111. //
  112. // Indicates that a surprise remove has occurred.
  113. //
  114. BOOLEAN RemoveProcessed;
  115. //
  116. // Whether or not the counters are running.
  117. //
  118. BOOLEAN CountersEnabled;
  119. //
  120. // Indicates that this is a redundant path to a disk.
  121. //
  122. BOOLEAN IsRedundantPath;
  123. //
  124. // Indicates that the device is started. Protect with 'Mutex'.
  125. //
  126. BOOLEAN IsStarted;
  127. //
  128. // Indicates that signatures have not yet been checked.
  129. //
  130. BOOLEAN SignaturesNotChecked;
  131. //
  132. // A pointer to our own device object.
  133. //
  134. PDEVICE_OBJECT DeviceObject;
  135. //
  136. // A pointer to the driver extension.
  137. //
  138. PDO_EXTENSION DriverExtension;
  139. //
  140. // A pointer to the device object that we are layered above -- a whole
  141. // disk.
  142. //
  143. PDEVICE_OBJECT TargetObject;
  144. //
  145. // A pointer to the PDO.
  146. //
  147. PDEVICE_OBJECT Pdo;
  148. //
  149. // A list of partitions allocated from paged pool. Protect with
  150. // 'Mutex'.
  151. //
  152. LIST_ENTRY PartitionList;
  153. //
  154. // A list entry for the device extension list in the driver extension.
  155. //
  156. LIST_ENTRY ListEntry;
  157. //
  158. // For paging notifications
  159. //
  160. ULONG PagingPathCount;
  161. KEVENT PagingPathCountEvent;
  162. //
  163. // Remember the disk signature so that you can write it out later.
  164. //
  165. ULONG DiskSignature;
  166. //
  167. // Keep a list of Signatures used on this disk.
  168. //
  169. LIST_ENTRY SignatureList;
  170. //
  171. // Keep a list of GUIDs used on this disk.
  172. //
  173. LIST_ENTRY GuidList;
  174. //
  175. // Leave counters always enabled if we see IOCTL_DISK_PERFORMANCE
  176. //
  177. LONG EnableAlways;
  178. //
  179. // Disk Number.
  180. //
  181. ULONG DiskNumber;
  182. //
  183. // The Epoch Number for this disk. Protect with 'Root->Mutex'.
  184. //
  185. ULONG EpochNumber;
  186. //
  187. // Counter structure.
  188. //
  189. PVOID PmWmiCounterContext;
  190. //
  191. // Device Name
  192. //
  193. UNICODE_STRING PhysicalDeviceName;
  194. WCHAR PhysicalDeviceNameBuffer[DEVICENAME_MAXSTR];
  195. //
  196. // Routine to notify on IO completion.
  197. //
  198. PPHYSICAL_DISK_IO_NOTIFY_ROUTINE PhysicalDiskIoNotifyRoutine;
  199. //
  200. // Table of WmiLib Functions.
  201. //
  202. PWMILIB_CONTEXT WmilibContext;
  203. //
  204. // Work queue for power mgmt processing
  205. // Protected by "SpinLock"
  206. //
  207. LIST_ENTRY PowerQueue;
  208. //
  209. // Spinlock used to protect the power mgmt work queue
  210. //
  211. KSPIN_LOCK SpinLock;
  212. //
  213. // Lock structure used to block the device deletion
  214. // as a result of IRP_MN_REMOVE_DEVICE
  215. //
  216. IO_REMOVE_LOCK RemoveLock;
  217. } DEVICE_EXTENSION, *PDEVICE_EXTENSION;
  218. typedef struct _SIGNATURE_TABLE_ENTRY {
  219. LIST_ENTRY ListEntry;
  220. PDEVICE_EXTENSION Extension;
  221. ULONG Signature;
  222. } SIGNATURE_TABLE_ENTRY, *PSIGNATURE_TABLE_ENTRY;
  223. typedef struct _GUID_TABLE_ENTRY {
  224. LIST_ENTRY ListEntry;
  225. PDEVICE_EXTENSION Extension;
  226. GUID Guid;
  227. } GUID_TABLE_ENTRY, *PGUID_TABLE_ENTRY;
  228. //
  229. // Work item for PmPowerNotify
  230. //
  231. typedef struct _PM_POWER_WORK_ITEM {
  232. LIST_ENTRY ListEntry;
  233. DEVICE_POWER_STATE DevicePowerState;
  234. } PM_POWER_WORK_ITEM, *PPM_POWER_WORK_ITEM;