xref: /reactos/ntoskrnl/include/internal/po.h (revision 5100859e)
1 /*
2 * PROJECT:         ReactOS Kernel
3 * LICENSE:         GPL - See COPYING in the top level directory
4 * FILE:            ntoskrnl/include/internal/po.h
5 * PURPOSE:         Internal header for the Power Manager
6 * PROGRAMMERS:     Alex Ionescu (alex.ionescu@reactos.org)
7 */
8 
9 #include <guiddef.h>
10 #include <poclass.h>
11 
12 //
13 // Define this if you want debugging support
14 //
15 #define _PO_DEBUG_                                      0x00
16 
17 //
18 // These define the Debug Masks Supported
19 //
20 #define PO_STATE_DEBUG                                  0x01
21 
22 //
23 // Debug/Tracing support
24 //
25 #if _PO_DEBUG_
26 #ifdef NEW_DEBUG_SYSTEM_IMPLEMENTED // enable when Debug Filters are implemented
27 #define POTRACE DbgPrintEx
28 #else
29 #define POTRACE(x, ...)                                 \
30     if (x & PopTraceLevel) DbgPrint(__VA_ARGS__)
31 #endif
32 #else
33 #define POTRACE(x, fmt, ...) DPRINT(fmt, ##__VA_ARGS__)
34 #endif
35 
36 typedef struct _PO_HIBER_PERF
37 {
38     ULONGLONG IoTicks;
39     ULONGLONG InitTicks;
40     ULONGLONG CopyTicks;
41     ULONGLONG StartCount;
42     ULONG ElapsedTime;
43     ULONG IoTime;
44     ULONG CopyTime;
45     ULONG InitTime;
46     ULONG PagesWritten;
47     ULONG PagesProcessed;
48     ULONG BytesCopied;
49     ULONG DumpCount;
50     ULONG FileRuns;
51 } PO_HIBER_PERF, *PPO_HIBER_PERF;
52 
53 typedef struct _PO_MEMORY_IMAGE
54 {
55     ULONG Signature;
56     ULONG Version;
57     ULONG CheckSum;
58     ULONG LengthSelf;
59     PFN_NUMBER PageSelf;
60     ULONG PageSize;
61     ULONG ImageType;
62     LARGE_INTEGER SystemTime;
63     ULONGLONG InterruptTime;
64     ULONG FeatureFlags;
65     UCHAR HiberFlags;
66     UCHAR spare[3];
67     ULONG NoHiberPtes;
68     ULONG_PTR HiberVa;
69     PHYSICAL_ADDRESS HiberPte;
70     ULONG NoFreePages;
71     ULONG FreeMapCheck;
72     ULONG WakeCheck;
73     PFN_NUMBER TotalPages;
74     PFN_NUMBER FirstTablePage;
75     PFN_NUMBER LastFilePage;
76     PO_HIBER_PERF PerfInfo;
77 } PO_MEMORY_IMAGE, *PPO_MEMORY_IMAGE;
78 
79 typedef struct _PO_MEMORY_RANGE_ARRAY_RANGE
80 {
81     PFN_NUMBER PageNo;
82     PFN_NUMBER StartPage;
83     PFN_NUMBER EndPage;
84     ULONG CheckSum;
85 } PO_MEMORY_RANGE_ARRAY_RANGE;
86 
87 typedef struct _PO_MEMORY_RANGE_ARRAY_LINK
88 {
89     struct _PO_MEMORY_RANGE_ARRAY *Next;
90     PFN_NUMBER NextTable;
91     ULONG CheckSum;
92     ULONG EntryCount;
93 } PO_MEMORY_RANGE_ARRAY_LINK;
94 
95 typedef struct _PO_MEMORY_RANGE_ARRAY
96 {
97     union
98     {
99         PO_MEMORY_RANGE_ARRAY_RANGE Range;
100         PO_MEMORY_RANGE_ARRAY_LINK Link;
101     };
102 } PO_MEMORY_RANGE_ARRAY, *PPO_MEMORY_RANGE_ARRAY;
103 
104 typedef struct _POP_HIBER_CONTEXT
105 {
106     BOOLEAN WriteToFile;
107     BOOLEAN ReserveLoaderMemory;
108     BOOLEAN ReserveFreeMemory;
109     BOOLEAN VerifyOnWake;
110     BOOLEAN Reset;
111     UCHAR HiberFlags;
112     BOOLEAN LinkFile;
113     HANDLE LinkFileHandle;
114     PKSPIN_LOCK Lock;
115     BOOLEAN MapFrozen;
116     RTL_BITMAP MemoryMap;
117     LIST_ENTRY ClonedRanges;
118     ULONG ClonedRangeCount;
119     PLIST_ENTRY NextCloneRange;
120     PFN_NUMBER NextPreserve;
121     PMDL LoaderMdl;
122     PMDL Clones;
123     PUCHAR NextClone;
124     ULONG NoClones;
125     PMDL Spares;
126     ULONGLONG PagesOut;
127     PVOID IoPage;
128     PVOID CurrentMcb;
129     PVOID DumpStack;
130     PKPROCESSOR_STATE WakeState;
131     ULONG NoRanges;
132     ULONG_PTR HiberVa;
133     PHYSICAL_ADDRESS HiberPte;
134     NTSTATUS Status;
135     PPO_MEMORY_IMAGE MemoryImage;
136     PPO_MEMORY_RANGE_ARRAY TableHead;
137     PVOID CompressionWorkspace;
138     PUCHAR CompressedWriteBuffer;
139     PULONG PerformanceStats;
140     PVOID CompressionBlock;
141     PVOID DmaIO;
142     PVOID TemporaryHeap;
143     PO_HIBER_PERF PerfInfo;
144 } POP_HIBER_CONTEXT, *PPOP_HIBER_CONTEXT;
145 
146 typedef struct _PO_NOTIFY_ORDER_LEVEL
147 {
148     KEVENT LevelReady;
149     ULONG DeviceCount;
150     ULONG ActiveCount;
151     LIST_ENTRY WaitSleep;
152     LIST_ENTRY ReadySleep;
153     LIST_ENTRY Pending;
154     LIST_ENTRY Complete;
155     LIST_ENTRY ReadyS0;
156     LIST_ENTRY WaitS0;
157 } PO_NOTIFY_ORDER_LEVEL, *PPO_NOTIFY_ORDER_LEVEL;
158 
159 typedef struct _POP_SHUTDOWN_BUG_CHECK
160 {
161     HANDLE ThreadHandle;
162     HANDLE ThreadId;
163     HANDLE ProcessId;
164     ULONG Code;
165     ULONG_PTR Parameter1;
166     ULONG_PTR Parameter2;
167     ULONG_PTR Parameter3;
168     ULONG_PTR Parameter4;
169 } POP_SHUTDOWN_BUG_CHECK, *PPOP_SHUTDOWN_BUG_CHECK;
170 
171 typedef struct _POP_DEVICE_POWER_IRP
172 {
173     SINGLE_LIST_ENTRY Free;
174     PIRP Irp;
175     PPO_DEVICE_NOTIFY Notify;
176     LIST_ENTRY Pending;
177     LIST_ENTRY Complete;
178     LIST_ENTRY Abort;
179     LIST_ENTRY Failed;
180 } POP_DEVICE_POWER_IRP, *PPOP_DEVICE_POWER_IRP;
181 
182 typedef struct _PO_DEVICE_NOTIFY_ORDER
183 {
184     ULONG DevNodeSequence;
185     PDEVICE_OBJECT *WarmEjectPdoPointer;
186     PO_NOTIFY_ORDER_LEVEL OrderLevel[8];
187 } PO_DEVICE_NOTIFY_ORDER, *PPO_DEVICE_NOTIFY_ORDER;
188 
189 typedef struct _POP_DEVICE_SYS_STATE
190 {
191     UCHAR IrpMinor;
192     SYSTEM_POWER_STATE SystemState;
193     PKEVENT Event;
194     KSPIN_LOCK SpinLock;
195     PKTHREAD Thread;
196     BOOLEAN GetNewDeviceList;
197     PO_DEVICE_NOTIFY_ORDER Order;
198     NTSTATUS Status;
199     PDEVICE_OBJECT FailedDevice;
200     BOOLEAN Waking;
201     BOOLEAN Cancelled;
202     BOOLEAN IgnoreErrors;
203     BOOLEAN IgnoreNotImplemented;
204     BOOLEAN _WaitAny;
205     BOOLEAN _WaitAll;
206     LIST_ENTRY PresentIrpQueue;
207     POP_DEVICE_POWER_IRP Head;
208     POP_DEVICE_POWER_IRP PowerIrpState[20];
209 } POP_DEVICE_SYS_STATE, *PPOP_DEVICE_SYS_STATE;
210 
211 typedef struct _POP_POWER_ACTION
212 {
213     UCHAR Updates;
214     UCHAR State;
215     BOOLEAN Shutdown;
216     POWER_ACTION Action;
217     SYSTEM_POWER_STATE LightestState;
218     ULONG Flags;
219     NTSTATUS Status;
220     UCHAR IrpMinor;
221     SYSTEM_POWER_STATE SystemState;
222     SYSTEM_POWER_STATE NextSystemState;
223     PPOP_SHUTDOWN_BUG_CHECK ShutdownBugCode;
224     PPOP_DEVICE_SYS_STATE DevState;
225     PPOP_HIBER_CONTEXT HiberContext;
226     ULONGLONG WakeTime;
227     ULONGLONG SleepTime;
228 } POP_POWER_ACTION, *PPOP_POWER_ACTION;
229 
230 typedef enum _POP_DEVICE_IDLE_TYPE
231 {
232     DeviceIdleNormal,
233     DeviceIdleDisk,
234 } POP_DEVICE_IDLE_TYPE, *PPOP_DEVICE_IDLE_TYPE;
235 
236 typedef struct _POWER_CHANNEL_SUMMARY
237 {
238     ULONG Signature;
239     ULONG TotalCount;
240     ULONG D0Count;
241     LIST_ENTRY NotifyList;
242 } POWER_CHANNEL_SUMMARY, *PPOWER_CHANNEL_SUMMARY;
243 
244 typedef struct  _DEVICE_OBJECT_POWER_EXTENSION
245 {
246     ULONG IdleCount;
247     ULONG ConservationIdleTime;
248     ULONG PerformanceIdleTime;
249     PDEVICE_OBJECT DeviceObject;
250     LIST_ENTRY IdleList;
251     DEVICE_POWER_STATE State;
252     LIST_ENTRY NotifySourceList;
253     LIST_ENTRY NotifyTargetList;
254     POWER_CHANNEL_SUMMARY PowerChannelSummary;
255     LIST_ENTRY Volume;
256 } DEVICE_OBJECT_POWER_EXTENSION, *PDEVICE_OBJECT_POWER_EXTENSION;
257 
258 typedef struct _POP_SHUTDOWN_WAIT_ENTRY
259 {
260     struct _POP_SHUTDOWN_WAIT_ENTRY *NextEntry;
261     PETHREAD Thread;
262 } POP_SHUTDOWN_WAIT_ENTRY, *PPOP_SHUTDOWN_WAIT_ENTRY;
263 
264 //
265 // Initialization routines
266 //
267 BOOLEAN
268 NTAPI
269 PoInitSystem(
270     IN ULONG BootPhase
271 );
272 
273 VOID
274 NTAPI
275 PoInitializePrcb(
276     IN PKPRCB Prcb
277 );
278 
279 VOID
280 NTAPI
281 PopInitShutdownList(
282     VOID
283 );
284 
285 //
286 // I/O Routines
287 //
288 VOID
289 NTAPI
290 PoInitializeDeviceObject(
291     IN OUT PDEVOBJ_EXTENSION DeviceObjectExtension
292 );
293 
294 VOID
295 NTAPI
296 PoVolumeDevice(
297     IN PDEVICE_OBJECT DeviceObject
298 );
299 
300 VOID
301 NTAPI
302 PoRemoveVolumeDevice(
303     IN PDEVICE_OBJECT DeviceObject);
304 
305 //
306 // Power State routines
307 //
308 NTSTATUS
309 NTAPI
310 PopSetSystemPowerState(
311     SYSTEM_POWER_STATE PowerState,
312     POWER_ACTION PowerAction
313 );
314 
315 VOID
316 NTAPI
317 PopCleanupPowerState(
318     IN PPOWER_STATE PowerState
319 );
320 
321 NTSTATUS
322 NTAPI
323 PopAddRemoveSysCapsCallback(
324     IN PVOID NotificationStructure,
325     IN PVOID Context
326 );
327 
328 //
329 // Notifications
330 //
331 VOID
332 NTAPI
333 PoNotifySystemTimeSet(
334     VOID
335 );
336 
337 //
338 // Shutdown routines
339 //
340 VOID
341 NTAPI
342 PopReadShutdownPolicy(
343     VOID
344 );
345 
346 VOID
347 NTAPI
348 PopGracefulShutdown(
349     IN PVOID Context
350 );
351 
352 VOID
353 NTAPI
354 PopFlushVolumes(
355     IN BOOLEAN ShuttingDown
356 );
357 
358 //
359 // Global data inside the Power Manager
360 //
361 extern PDEVICE_NODE PopSystemPowerDeviceNode;
362 extern KGUARDED_MUTEX PopVolumeLock;
363 extern LIST_ENTRY PopVolumeDevices;
364 extern KSPIN_LOCK PopDopeGlobalLock;
365 extern POP_POWER_ACTION PopAction;
366 
367