Reactos
1$if (_WDMDDK_)
2/******************************************************************************
3 * Power Management Support Types *
4 ******************************************************************************/
5
6#ifndef _PO_DDK_
7#define _PO_DDK_
8
9#define PO_CB_SYSTEM_POWER_POLICY 0
10#define PO_CB_AC_STATUS 1
11#define PO_CB_BUTTON_COLLISION 2
12#define PO_CB_SYSTEM_STATE_LOCK 3
13#define PO_CB_LID_SWITCH_STATE 4
14#define PO_CB_PROCESSOR_POWER_POLICY 5
15
16/* Power States/Levels */
17typedef enum _SYSTEM_POWER_STATE {
18 PowerSystemUnspecified = 0,
19 PowerSystemWorking,
20 PowerSystemSleeping1,
21 PowerSystemSleeping2,
22 PowerSystemSleeping3,
23 PowerSystemHibernate,
24 PowerSystemShutdown,
25 PowerSystemMaximum
26} SYSTEM_POWER_STATE, *PSYSTEM_POWER_STATE;
27
28#define POWER_SYSTEM_MAXIMUM PowerSystemMaximum
29
30typedef enum _POWER_INFORMATION_LEVEL {
31 SystemPowerPolicyAc,
32 SystemPowerPolicyDc,
33 VerifySystemPolicyAc,
34 VerifySystemPolicyDc,
35 SystemPowerCapabilities,
36 SystemBatteryState,
37 SystemPowerStateHandler,
38 ProcessorStateHandler,
39 SystemPowerPolicyCurrent,
40 AdministratorPowerPolicy,
41 SystemReserveHiberFile,
42 ProcessorInformation,
43 SystemPowerInformation,
44 ProcessorStateHandler2,
45 LastWakeTime,
46 LastSleepTime,
47 SystemExecutionState,
48 SystemPowerStateNotifyHandler,
49 ProcessorPowerPolicyAc,
50 ProcessorPowerPolicyDc,
51 VerifyProcessorPowerPolicyAc,
52 VerifyProcessorPowerPolicyDc,
53 ProcessorPowerPolicyCurrent,
54 SystemPowerStateLogging,
55 SystemPowerLoggingEntry,
56 SetPowerSettingValue,
57 NotifyUserPowerSetting,
58 PowerInformationLevelUnused0,
59 SystemMonitorHiberBootPowerOff,
60 SystemVideoState,
61 TraceApplicationPowerMessage,
62 TraceApplicationPowerMessageEnd,
63 ProcessorPerfStates,
64 ProcessorIdleStates,
65 ProcessorCap,
66 SystemWakeSource,
67 SystemHiberFileInformation,
68 TraceServicePowerMessage,
69 ProcessorLoad,
70 PowerShutdownNotification,
71 MonitorCapabilities,
72 SessionPowerInit,
73 SessionDisplayState,
74 PowerRequestCreate,
75 PowerRequestAction,
76 GetPowerRequestList,
77 ProcessorInformationEx,
78 NotifyUserModeLegacyPowerEvent,
79 GroupPark,
80 ProcessorIdleDomains,
81 WakeTimerList,
82 SystemHiberFileSize,
83 ProcessorIdleStatesHv,
84 ProcessorPerfStatesHv,
85 ProcessorPerfCapHv,
86 ProcessorSetIdle,
87 LogicalProcessorIdling,
88 UserPresence,
89 PowerSettingNotificationName,
90 GetPowerSettingValue,
91 IdleResiliency,
92 SessionRITState,
93 SessionConnectNotification,
94 SessionPowerCleanup,
95 SessionLockState,
96 SystemHiberbootState,
97 PlatformInformation,
98 PdcInvocation,
99 MonitorInvocation,
100 FirmwareTableInformationRegistered,
101 SetShutdownSelectedTime,
102 SuspendResumeInvocation,
103 PlmPowerRequestCreate,
104 ScreenOff,
105 CsDeviceNotification,
106 PlatformRole,
107 LastResumePerformance,
108 DisplayBurst,
109 ExitLatencySamplingPercentage,
110 RegisterSpmPowerSettings,
111 PlatformIdleStates,
112 ProcessorIdleVeto, // deprecated
113 PlatformIdleVeto, // deprecated
114 SystemBatteryStatePrecise,
115 ThermalEvent,
116 PowerRequestActionInternal,
117 BatteryDeviceState,
118 PowerInformationInternal,
119 ThermalStandby,
120 SystemHiberFileType,
121 PhysicalPowerButtonPress,
122 QueryPotentialDripsConstraint,
123 EnergyTrackerCreate,
124 EnergyTrackerQuery,
125 UpdateBlackBoxRecorder,
126 SessionAllowExternalDmaDevices,
127 PowerInformationLevelMaximum
128} POWER_INFORMATION_LEVEL;
129
130typedef enum {
131 PowerActionNone = 0,
132 PowerActionReserved,
133 PowerActionSleep,
134 PowerActionHibernate,
135 PowerActionShutdown,
136 PowerActionShutdownReset,
137 PowerActionShutdownOff,
138 PowerActionWarmEject
139} POWER_ACTION, *PPOWER_ACTION;
140
141typedef enum _DEVICE_POWER_STATE {
142 PowerDeviceUnspecified = 0,
143 PowerDeviceD0,
144 PowerDeviceD1,
145 PowerDeviceD2,
146 PowerDeviceD3,
147 PowerDeviceMaximum
148} DEVICE_POWER_STATE, *PDEVICE_POWER_STATE;
149
150typedef enum _MONITOR_DISPLAY_STATE {
151 PowerMonitorOff = 0,
152 PowerMonitorOn,
153 PowerMonitorDim
154} MONITOR_DISPLAY_STATE, *PMONITOR_DISPLAY_STATE;
155
156typedef union _POWER_STATE {
157 SYSTEM_POWER_STATE SystemState;
158 DEVICE_POWER_STATE DeviceState;
159} POWER_STATE, *PPOWER_STATE;
160
161typedef enum _POWER_STATE_TYPE {
162 SystemPowerState = 0,
163 DevicePowerState
164} POWER_STATE_TYPE, *PPOWER_STATE_TYPE;
165
166#if (NTDDI_VERSION >= NTDDI_VISTA)
167typedef struct _SYSTEM_POWER_STATE_CONTEXT {
168 _ANONYMOUS_UNION union {
169 _ANONYMOUS_STRUCT struct {
170 ULONG Reserved1:8;
171 ULONG TargetSystemState:4;
172 ULONG EffectiveSystemState:4;
173 ULONG CurrentSystemState:4;
174 ULONG IgnoreHibernationPath:1;
175 ULONG PseudoTransition:1;
176 ULONG Reserved2:10;
177 } DUMMYSTRUCTNAME;
178 ULONG ContextAsUlong;
179 } DUMMYUNIONNAME;
180} SYSTEM_POWER_STATE_CONTEXT, *PSYSTEM_POWER_STATE_CONTEXT;
181#endif
182
183#if (NTDDI_VERSION >= NTDDI_WIN7)
184typedef struct _COUNTED_REASON_CONTEXT {
185 ULONG Version;
186 ULONG Flags;
187 _ANONYMOUS_UNION union {
188 _ANONYMOUS_STRUCT struct {
189 UNICODE_STRING ResourceFileName;
190 USHORT ResourceReasonId;
191 ULONG StringCount;
192 PUNICODE_STRING ReasonStrings;
193 } DUMMYSTRUCTNAME;
194 UNICODE_STRING SimpleString;
195 } DUMMYUNIONNAME;
196} COUNTED_REASON_CONTEXT, *PCOUNTED_REASON_CONTEXT;
197#endif
198
199#define IOCTL_QUERY_DEVICE_POWER_STATE \
200 CTL_CODE(FILE_DEVICE_BATTERY, 0x0, METHOD_BUFFERED, FILE_READ_ACCESS)
201
202#define IOCTL_SET_DEVICE_WAKE \
203 CTL_CODE(FILE_DEVICE_BATTERY, 0x1, METHOD_BUFFERED, FILE_WRITE_ACCESS)
204
205#define IOCTL_CANCEL_DEVICE_WAKE \
206 CTL_CODE(FILE_DEVICE_BATTERY, 0x2, METHOD_BUFFERED, FILE_WRITE_ACCESS)
207
208#define ES_SYSTEM_REQUIRED 0x00000001
209#define ES_DISPLAY_REQUIRED 0x00000002
210#define ES_USER_PRESENT 0x00000004
211#define ES_CONTINUOUS 0x80000000
212
213typedef ULONG EXECUTION_STATE, *PEXECUTION_STATE;
214
215typedef enum {
216 LT_DONT_CARE,
217 LT_LOWEST_LATENCY
218} LATENCY_TIME;
219
220#if (_WIN32_WINNT >= _WIN32_WINNT_WIN7)
221#define DIAGNOSTIC_REASON_VERSION 0
222#define DIAGNOSTIC_REASON_SIMPLE_STRING 0x00000001
223#define DIAGNOSTIC_REASON_DETAILED_STRING 0x00000002
224#define DIAGNOSTIC_REASON_NOT_SPECIFIED 0x80000000
225#define DIAGNOSTIC_REASON_INVALID_FLAGS (~0x80000003)
226#endif
227
228#define POWER_REQUEST_CONTEXT_VERSION 0
229#define POWER_REQUEST_CONTEXT_SIMPLE_STRING 0x00000001
230#define POWER_REQUEST_CONTEXT_DETAILED_STRING 0x00000002
231
232#define PowerRequestMaximum 3
233
234typedef enum _POWER_REQUEST_TYPE {
235 PowerRequestDisplayRequired,
236 PowerRequestSystemRequired,
237 PowerRequestAwayModeRequired
238} POWER_REQUEST_TYPE, *PPOWER_REQUEST_TYPE;
239
240#if (NTDDI_VERSION >= NTDDI_WINXP)
241
242#define PDCAP_D0_SUPPORTED 0x00000001
243#define PDCAP_D1_SUPPORTED 0x00000002
244#define PDCAP_D2_SUPPORTED 0x00000004
245#define PDCAP_D3_SUPPORTED 0x00000008
246#define PDCAP_WAKE_FROM_D0_SUPPORTED 0x00000010
247#define PDCAP_WAKE_FROM_D1_SUPPORTED 0x00000020
248#define PDCAP_WAKE_FROM_D2_SUPPORTED 0x00000040
249#define PDCAP_WAKE_FROM_D3_SUPPORTED 0x00000080
250#define PDCAP_WARM_EJECT_SUPPORTED 0x00000100
251
252typedef struct CM_Power_Data_s {
253 ULONG PD_Size;
254 DEVICE_POWER_STATE PD_MostRecentPowerState;
255 ULONG PD_Capabilities;
256 ULONG PD_D1Latency;
257 ULONG PD_D2Latency;
258 ULONG PD_D3Latency;
259 DEVICE_POWER_STATE PD_PowerStateMapping[PowerSystemMaximum];
260 SYSTEM_POWER_STATE PD_DeepestSystemWake;
261} CM_POWER_DATA, *PCM_POWER_DATA;
262
263#endif /* (NTDDI_VERSION >= NTDDI_WINXP) */
264
265typedef enum _SYSTEM_POWER_CONDITION {
266 PoAc,
267 PoDc,
268 PoHot,
269 PoConditionMaximum
270} SYSTEM_POWER_CONDITION;
271
272typedef struct _SET_POWER_SETTING_VALUE {
273 ULONG Version;
274 GUID Guid;
275 SYSTEM_POWER_CONDITION PowerCondition;
276 ULONG DataLength;
277 UCHAR Data[ANYSIZE_ARRAY];
278} SET_POWER_SETTING_VALUE, *PSET_POWER_SETTING_VALUE;
279
280#define POWER_SETTING_VALUE_VERSION (0x1)
281
282typedef struct _NOTIFY_USER_POWER_SETTING {
283 GUID Guid;
284} NOTIFY_USER_POWER_SETTING, *PNOTIFY_USER_POWER_SETTING;
285
286typedef struct _APPLICATIONLAUNCH_SETTING_VALUE {
287 LARGE_INTEGER ActivationTime;
288 ULONG Flags;
289 ULONG ButtonInstanceID;
290} APPLICATIONLAUNCH_SETTING_VALUE, *PAPPLICATIONLAUNCH_SETTING_VALUE;
291
292typedef enum _POWER_PLATFORM_ROLE {
293 PlatformRoleUnspecified = 0,
294 PlatformRoleDesktop,
295 PlatformRoleMobile,
296 PlatformRoleWorkstation,
297 PlatformRoleEnterpriseServer,
298 PlatformRoleSOHOServer,
299 PlatformRoleAppliancePC,
300 PlatformRolePerformanceServer,
301 PlatformRoleSlate,
302 PlatformRoleMaximum
303} POWER_PLATFORM_ROLE;
304
305#define POWER_PLATFORM_ROLE_V1 (0x00000001)
306#define POWER_PLATFORM_ROLE_V1_MAX (PlatformRolePerformanceServer + 1)
307
308#define POWER_PLATFORM_ROLE_V2 (0x00000002)
309#define POWER_PLATFORM_ROLE_V2_MAX (PlatformRoleSlate + 1)
310
311#if (NTDDI_VERSION >= NTDDI_WIN8)
312#define POWER_PLATFORM_ROLE_VERSION POWER_PLATFORM_ROLE_V2
313#define POWER_PLATFORM_ROLE_VERSION_MAX POWER_PLATFORM_ROLE_V2_MAX
314#else
315#define POWER_PLATFORM_ROLE_VERSION POWER_PLATFORM_ROLE_V1
316#define POWER_PLATFORM_ROLE_VERSION_MAX POWER_PLATFORM_ROLE_V1_MAX
317#endif
318
319typedef struct _POWER_PLATFORM_INFORMATION
320{
321 BOOLEAN AoAc;
322} POWER_PLATFORM_INFORMATION, *PPOWER_PLATFORM_INFORMATION;
323
324#if (NTDDI_VERSION >= NTDDI_WINXP) || !defined(_BATCLASS_)
325typedef struct {
326 ULONG Granularity;
327 ULONG Capacity;
328} BATTERY_REPORTING_SCALE, *PBATTERY_REPORTING_SCALE;
329#endif /* (NTDDI_VERSION >= NTDDI_WINXP) || !defined(_BATCLASS_) */
330
331#endif /* !_PO_DDK_ */
332
333#define CORE_PARKING_POLICY_CHANGE_IDEAL 0
334#define CORE_PARKING_POLICY_CHANGE_SINGLE 1
335#define CORE_PARKING_POLICY_CHANGE_ROCKET 2
336#define CORE_PARKING_POLICY_CHANGE_MAX CORE_PARKING_POLICY_CHANGE_ROCKET
337
338#define PERFSTATE_POLICY_CHANGE_IDEAL 0
339#define PERFSTATE_POLICY_CHANGE_SINGLE 1
340#define PERFSTATE_POLICY_CHANGE_ROCKET 2
341#define PERFSTATE_POLICY_CHANGE_MAX PERFSTATE_POLICY_CHANGE_ROCKET
342
343#define PROCESSOR_PERF_BOOST_POLICY_DISABLED 0
344#define PROCESSOR_PERF_BOOST_POLICY_MAX 100
345
346#define POWER_DEVICE_IDLE_POLICY_PERFORMANCE 0
347#define POWER_DEVICE_IDLE_POLICY_CONSERVATIVE 1
348
349//
350// Power setting GUIDs
351//
352DEFINE_GUID(GUID_MAX_POWER_SAVINGS, 0xA1841308, 0x3541, 0x4FAB, 0xBC, 0x81, 0xF7, 0x15, 0x56, 0xF2, 0x0B, 0x4A);
353DEFINE_GUID(GUID_MIN_POWER_SAVINGS, 0x8C5E7FDA, 0xE8BF, 0x4A96, 0x9A, 0x85, 0xA6, 0xE2, 0x3A, 0x8C, 0x63, 0x5C);
354DEFINE_GUID(GUID_TYPICAL_POWER_SAVINGS, 0x381B4222, 0xF694, 0x41F0, 0x96, 0x85, 0xFF, 0x5B, 0xB2, 0x60, 0xDF, 0x2E);
355DEFINE_GUID(NO_SUBGROUP_GUID, 0xFEA3413E, 0x7E05, 0x4911, 0x9A, 0x71, 0x70, 0x03, 0x31, 0xF1, 0xC2, 0x94);
356DEFINE_GUID(ALL_POWERSCHEMES_GUID, 0x68A1E95E, 0x13EA, 0x41E1, 0x80, 0x11, 0x0C, 0x49, 0x6C, 0xA4, 0x90, 0xB0);
357DEFINE_GUID(GUID_POWERSCHEME_PERSONALITY, 0x245D8541, 0x3943, 0x4422, 0xB0, 0x25, 0x13, 0xA7, 0x84, 0xF6, 0x79, 0xB7);
358DEFINE_GUID(GUID_ACTIVE_POWERSCHEME, 0x31F9F286, 0x5084, 0x42FE, 0xB7, 0x20, 0x2B, 0x02, 0x64, 0x99, 0x37, 0x63);
359DEFINE_GUID(GUID_VIDEO_SUBGROUP, 0x7516B95F, 0xF776, 0x4464, 0x8C, 0x53, 0x06, 0x16, 0x7F, 0x40, 0xCC, 0x99);
360DEFINE_GUID(GUID_VIDEO_POWERDOWN_TIMEOUT, 0x3C0BC021, 0xC8A8, 0x4E07, 0xA9, 0x73, 0x6B, 0x14, 0xCB, 0xCB, 0x2B, 0x7E);
361DEFINE_GUID(GUID_VIDEO_ANNOYANCE_TIMEOUT, 0x82DBCF2D, 0xCD67, 0x40C5, 0xBF, 0xDC, 0x9F, 0x1A, 0x5C, 0xCD, 0x46, 0x63);
362DEFINE_GUID(GUID_VIDEO_ADAPTIVE_PERCENT_INCREASE, 0xEED904DF, 0xB142, 0x4183, 0xB1, 0x0B, 0x5A, 0x11, 0x97, 0xA3, 0x78, 0x64);
363DEFINE_GUID(GUID_VIDEO_DIM_TIMEOUT, 0x17aaa29b, 0x8b43, 0x4b94, 0xaa, 0xfe, 0x35, 0xf6, 0x4d, 0xaa, 0xf1, 0xee);
364DEFINE_GUID(GUID_VIDEO_ADAPTIVE_POWERDOWN, 0x90959D22, 0xD6A1, 0x49B9, 0xAF, 0x93, 0xBC, 0xE8, 0x85, 0xAD, 0x33, 0x5B);
365DEFINE_GUID(GUID_MONITOR_POWER_ON, 0x02731015, 0x4510, 0x4526, 0x99, 0xE6, 0xE5, 0xA1, 0x7E, 0xBD, 0x1A, 0xEA);
366DEFINE_GUID(GUID_DEVICE_POWER_POLICY_VIDEO_BRIGHTNESS, 0xaded5e82L, 0xb909, 0x4619, 0x99, 0x49, 0xf5, 0xd7, 0x1d, 0xac, 0x0b, 0xcb);
367DEFINE_GUID(GUID_DEVICE_POWER_POLICY_VIDEO_DIM_BRIGHTNESS, 0xf1fbfde2, 0xa960, 0x4165, 0x9f, 0x88, 0x50, 0x66, 0x79, 0x11, 0xce, 0x96);
368DEFINE_GUID(GUID_VIDEO_CURRENT_MONITOR_BRIGHTNESS, 0x8ffee2c6, 0x2d01, 0x46be, 0xad, 0xb9, 0x39, 0x8a, 0xdd, 0xc5, 0xb4, 0xff);
369DEFINE_GUID(GUID_VIDEO_ADAPTIVE_DISPLAY_BRIGHTNESS, 0xFBD9AA66, 0x9553, 0x4097, 0xBA, 0x44, 0xED, 0x6E, 0x9D, 0x65, 0xEA, 0xB8);
370DEFINE_GUID(GUID_SESSION_DISPLAY_STATE, 0x73A5E93A, 0x5BB1, 0x4F93, 0x89, 0x5B, 0xDB, 0xD0, 0xDA, 0x85, 0x59, 0x67);
371DEFINE_GUID(GUID_CONSOLE_DISPLAY_STATE, 0x6fe69556, 0x704a, 0x47a0, 0x8f, 0x24, 0xc2, 0x8d, 0x93, 0x6f, 0xda, 0x47);
372DEFINE_GUID(GUID_ALLOW_DISPLAY_REQUIRED, 0xA9CEB8DA, 0xCD46, 0x44FB, 0xA9, 0x8B, 0x02, 0xAF, 0x69, 0xDE, 0x46, 0x23);
373DEFINE_GUID(GUID_DISK_SUBGROUP, 0x0012EE47, 0x9041, 0x4B5D, 0x9B, 0x77, 0x53, 0x5F, 0xBA, 0x8B, 0x14, 0x42);
374DEFINE_GUID(GUID_DISK_POWERDOWN_TIMEOUT, 0x6738E2C4, 0xE8A5, 0x4A42, 0xB1, 0x6A, 0xE0, 0x40, 0xE7, 0x69, 0x75, 0x6E);
375DEFINE_GUID(GUID_DISK_IDLE_TIMEOUT, 0x58E39BA8, 0xB8E6, 0x4EF6, 0x90, 0xD0, 0x89, 0xAE, 0x32, 0xB2, 0x58, 0xD6);
376DEFINE_GUID(GUID_DISK_BURST_IGNORE_THRESHOLD, 0x80e3c60e, 0xbb94, 0x4ad8, 0xbb, 0xe0, 0x0d, 0x31, 0x95, 0xef, 0xc6, 0x63);
377DEFINE_GUID(GUID_DISK_ADAPTIVE_POWERDOWN, 0x396A32E1, 0x499A, 0x40B2, 0x91, 0x24, 0xA9, 0x6A, 0xFE, 0x70, 0x76, 0x67);
378DEFINE_GUID(GUID_SLEEP_SUBGROUP, 0x238C9FA8, 0x0AAD, 0x41ED, 0x83, 0xF4, 0x97, 0xBE, 0x24, 0x2C, 0x8F, 0x20);
379DEFINE_GUID(GUID_SLEEP_IDLE_THRESHOLD, 0x81cd32e0, 0x7833, 0x44f3, 0x87, 0x37, 0x70, 0x81, 0xf3, 0x8d, 0x1f, 0x70);
380DEFINE_GUID(GUID_STANDBY_TIMEOUT, 0x29F6C1DB, 0x86DA, 0x48C5, 0x9F, 0xDB, 0xF2, 0xB6, 0x7B, 0x1F, 0x44, 0xDA);
381DEFINE_GUID(GUID_UNATTEND_SLEEP_TIMEOUT, 0x7bc4a2f9, 0xd8fc, 0x4469, 0xb0, 0x7b, 0x33, 0xeb, 0x78, 0x5a, 0xac, 0xa0);
382DEFINE_GUID(GUID_HIBERNATE_TIMEOUT, 0x9D7815A6, 0x7EE4, 0x497E, 0x88, 0x88, 0x51, 0x5A, 0x05, 0xF0, 0x23, 0x64);
383DEFINE_GUID(GUID_HIBERNATE_FASTS4_POLICY, 0x94AC6D29, 0x73CE, 0x41A6, 0x80, 0x9F, 0x63, 0x63, 0xBA, 0x21, 0xB4, 0x7E);
384DEFINE_GUID(GUID_CRITICAL_POWER_TRANSITION, 0xB7A27025, 0xE569, 0x46c2, 0xA5, 0x04, 0x2B, 0x96, 0xCA, 0xD2, 0x25, 0xA1);
385DEFINE_GUID(GUID_SYSTEM_AWAYMODE, 0x98A7F580, 0x01F7, 0x48AA, 0x9C, 0x0F, 0x44, 0x35, 0x2C, 0x29, 0xE5, 0xC0);
386DEFINE_GUID(GUID_ALLOW_AWAYMODE, 0x25dfa149, 0x5dd1, 0x4736, 0xb5, 0xab, 0xe8, 0xa3, 0x7b, 0x5b, 0x81, 0x87);
387DEFINE_GUID(GUID_ALLOW_STANDBY_STATES, 0xabfc2519, 0x3608, 0x4c2a, 0x94, 0xea, 0x17, 0x1b, 0x0e, 0xd5, 0x46, 0xab);
388DEFINE_GUID(GUID_ALLOW_RTC_WAKE, 0xBD3B718A, 0x0680, 0x4D9D, 0x8A, 0xB2, 0xE1, 0xD2, 0xB4, 0xAC, 0x80, 0x6D);
389DEFINE_GUID(GUID_ALLOW_SYSTEM_REQUIRED, 0xA4B195F5, 0x8225, 0x47D8, 0x80, 0x12, 0x9D, 0x41, 0x36, 0x97, 0x86, 0xE2);
390DEFINE_GUID(GUID_SYSTEM_BUTTON_SUBGROUP, 0x4F971E89, 0xEEBD, 0x4455, 0xA8, 0xDE, 0x9E, 0x59, 0x04, 0x0E, 0x73, 0x47);
391DEFINE_GUID(GUID_POWERBUTTON_ACTION, 0x7648EFA3, 0xDD9C, 0x4E3E, 0xB5, 0x66, 0x50, 0xF9, 0x29, 0x38, 0x62, 0x80);
392DEFINE_GUID(GUID_POWERBUTTON_ACTION_FLAGS, 0x857E7FAC, 0x034B, 0x4704, 0xAB, 0xB1, 0xBC, 0xA5, 0x4A, 0xA3, 0x14, 0x78);
393DEFINE_GUID(GUID_SLEEPBUTTON_ACTION, 0x96996BC0, 0xAD50, 0x47EC, 0x92, 0x3B, 0x6F, 0x41, 0x87, 0x4D, 0xD9, 0xEB);
394DEFINE_GUID(GUID_SLEEPBUTTON_ACTION_FLAGS, 0x2A160AB1, 0xB69D, 0x4743, 0xB7, 0x18, 0xBF, 0x14, 0x41, 0xD5, 0xE4, 0x93);
395DEFINE_GUID(GUID_USERINTERFACEBUTTON_ACTION, 0xA7066653, 0x8D6C, 0x40A8, 0x91, 0x0E, 0xA1, 0xF5, 0x4B, 0x84, 0xC7, 0xE5);
396DEFINE_GUID(GUID_LIDCLOSE_ACTION, 0x5CA83367, 0x6E45, 0x459F, 0xA2, 0x7B, 0x47, 0x6B, 0x1D, 0x01, 0xC9, 0x36);
397DEFINE_GUID(GUID_LIDCLOSE_ACTION_FLAGS, 0x97E969AC, 0x0D6C, 0x4D08, 0x92, 0x7C, 0xD7, 0xBD, 0x7A, 0xD7, 0x85, 0x7B);
398DEFINE_GUID(GUID_LIDOPEN_POWERSTATE, 0x99FF10E7, 0x23B1, 0x4C07, 0xA9, 0xD1, 0x5C, 0x32, 0x06, 0xD7, 0x41, 0xB4);
399DEFINE_GUID(GUID_BATTERY_SUBGROUP, 0xE73A048D, 0xBF27, 0x4F12, 0x97, 0x31, 0x8B, 0x20, 0x76, 0xE8, 0x89, 0x1F);
400DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_0, 0x637EA02F, 0xBBCB, 0x4015, 0x8E, 0x2C, 0xA1, 0xC7, 0xB9, 0xC0, 0xB5, 0x46);
401DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_0, 0x9A66D8D7, 0x4FF7, 0x4EF9, 0xB5, 0xA2, 0x5A, 0x32, 0x6C, 0xA2, 0xA4, 0x69);
402DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_0, 0x5dbb7c9f, 0x38e9, 0x40d2, 0x97, 0x49, 0x4f, 0x8a, 0x0e, 0x9f, 0x64, 0x0f);
403DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_1, 0xD8742DCB, 0x3E6A, 0x4B3C, 0xB3, 0xFE, 0x37, 0x46, 0x23, 0xCD, 0xCF, 0x06);
404DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_1, 0x8183BA9A, 0xE910, 0x48DA, 0x87, 0x69, 0x14, 0xAE, 0x6D, 0xC1, 0x17, 0x0A);
405DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_1, 0xbcded951, 0x187b, 0x4d05, 0xbc, 0xcc, 0xf7, 0xe5, 0x19, 0x60, 0xc2, 0x58);
406DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_2, 0x421CBA38, 0x1A8E, 0x4881, 0xAC, 0x89, 0xE3, 0x3A, 0x8B, 0x04, 0xEC, 0xE4);
407DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_2, 0x07A07CA2, 0xADAF, 0x40D7, 0xB0, 0x77, 0x53, 0x3A, 0xAD, 0xED, 0x1B, 0xFA);
408DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_2, 0x7fd2f0c4, 0xfeb7, 0x4da3, 0x81, 0x17, 0xe3, 0xfb, 0xed, 0xc4, 0x65, 0x82);
409DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_3, 0x80472613, 0x9780, 0x455E, 0xB3, 0x08, 0x72, 0xD3, 0x00, 0x3C, 0xF2, 0xF8);
410DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_3, 0x58AFD5A6, 0xC2DD, 0x47D2, 0x9F, 0xBF, 0xEF, 0x70, 0xCC, 0x5C, 0x59, 0x65);
411DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_3, 0x73613ccf, 0xdbfa, 0x4279, 0x83, 0x56, 0x49, 0x35, 0xf6, 0xbf, 0x62, 0xf3);
412DEFINE_GUID(GUID_PROCESSOR_SETTINGS_SUBGROUP, 0x54533251, 0x82BE, 0x4824, 0x96, 0xC1, 0x47, 0xB6, 0x0B, 0x74, 0x0D, 0x00);
413DEFINE_GUID(GUID_PROCESSOR_THROTTLE_POLICY, 0x57027304, 0x4AF6, 0x4104, 0x92, 0x60, 0xE3, 0xD9, 0x52, 0x48, 0xFC, 0x36);
414DEFINE_GUID(GUID_PROCESSOR_THROTTLE_MAXIMUM, 0xBC5038F7, 0x23E0, 0x4960, 0x96, 0xDA, 0x33, 0xAB, 0xAF, 0x59, 0x35, 0xEC);
415DEFINE_GUID(GUID_PROCESSOR_THROTTLE_MINIMUM, 0x893DEE8E, 0x2BEF, 0x41E0, 0x89, 0xC6, 0xB5, 0x5D, 0x09, 0x29, 0x96, 0x4C);
416DEFINE_GUID(GUID_PROCESSOR_ALLOW_THROTTLING, 0x3b04d4fd, 0x1cc7, 0x4f23, 0xab, 0x1c, 0xd1, 0x33, 0x78, 0x19, 0xc4, 0xbb);
417DEFINE_GUID(GUID_PROCESSOR_IDLESTATE_POLICY, 0x68f262a7, 0xf621, 0x4069, 0xb9, 0xa5, 0x48, 0x74, 0x16, 0x9b, 0xe2, 0x3c);
418DEFINE_GUID(GUID_PROCESSOR_PERFSTATE_POLICY, 0xBBDC3814, 0x18E9, 0x4463, 0x8A, 0x55, 0xD1, 0x97, 0x32, 0x7C, 0x45, 0xC0);
419DEFINE_GUID(GUID_PROCESSOR_PERF_INCREASE_THRESHOLD, 0x06cadf0e, 0x64ed, 0x448a, 0x89, 0x27, 0xce, 0x7b, 0xf9, 0x0e, 0xb3, 0x5d);
420DEFINE_GUID(GUID_PROCESSOR_PERF_DECREASE_THRESHOLD, 0x12a0ab44, 0xfe28, 0x4fa9, 0xb3, 0xbd, 0x4b, 0x64, 0xf4, 0x49, 0x60, 0xa6);
421DEFINE_GUID(GUID_PROCESSOR_PERF_INCREASE_POLICY, 0x465e1f50, 0xb610, 0x473a, 0xab, 0x58, 0x0, 0xd1, 0x7, 0x7d, 0xc4, 0x18);
422DEFINE_GUID(GUID_PROCESSOR_PERF_DECREASE_POLICY, 0x40fbefc7, 0x2e9d, 0x4d25, 0xa1, 0x85, 0xc, 0xfd, 0x85, 0x74, 0xba, 0xc6);
423DEFINE_GUID(GUID_PROCESSOR_PERF_INCREASE_TIME, 0x984cf492, 0x3bed, 0x4488, 0xa8, 0xf9, 0x42, 0x86, 0xc9, 0x7b, 0xf5, 0xaa);
424DEFINE_GUID(GUID_PROCESSOR_PERF_DECREASE_TIME, 0xd8edeb9b, 0x95cf, 0x4f95, 0xa7, 0x3c, 0xb0, 0x61, 0x97, 0x36, 0x93, 0xc8);
425DEFINE_GUID(GUID_PROCESSOR_PERF_TIME_CHECK, 0x4d2b0152, 0x7d5c, 0x498b, 0x88, 0xe2, 0x34, 0x34, 0x53, 0x92, 0xa2, 0xc5);
426DEFINE_GUID(GUID_PROCESSOR_PERF_BOOST_POLICY, 0x45bcc044, 0xd885, 0x43e2, 0x86, 0x5, 0xee, 0xe, 0xc6, 0xe9, 0x6b, 0x59);
427DEFINE_GUID(GUID_PROCESSOR_IDLE_ALLOW_SCALING, 0x6c2993b0, 0x8f48, 0x481f, 0xbc, 0xc6, 0x0, 0xdd, 0x27, 0x42, 0xaa, 0x6);
428DEFINE_GUID(GUID_PROCESSOR_IDLE_DISABLE, 0x5d76a2ca, 0xe8c0, 0x402f, 0xa1, 0x33, 0x21, 0x58, 0x49, 0x2d, 0x58, 0xad);
429DEFINE_GUID(GUID_PROCESSOR_IDLE_TIME_CHECK, 0xc4581c31, 0x89ab, 0x4597, 0x8e, 0x2b, 0x9c, 0x9c, 0xab, 0x44, 0xe, 0x6b);
430DEFINE_GUID(GUID_PROCESSOR_IDLE_DEMOTE_THRESHOLD, 0x4b92d758, 0x5a24, 0x4851, 0xa4, 0x70, 0x81, 0x5d, 0x78, 0xae, 0xe1, 0x19);
431DEFINE_GUID(GUID_PROCESSOR_IDLE_PROMOTE_THRESHOLD, 0x7b224883, 0xb3cc, 0x4d79, 0x81, 0x9f, 0x83, 0x74, 0x15, 0x2c, 0xbe, 0x7c);
432DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_INCREASE_THRESHOLD, 0xdf142941, 0x20f3, 0x4edf, 0x9a, 0x4a, 0x9c, 0x83, 0xd3, 0xd7, 0x17, 0xd1);
433DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_DECREASE_THRESHOLD, 0x68dd2f27, 0xa4ce, 0x4e11, 0x84, 0x87, 0x37, 0x94, 0xe4, 0x13, 0x5d, 0xfa);
434DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_INCREASE_POLICY, 0xc7be0679, 0x2817, 0x4d69, 0x9d, 0x02, 0x51, 0x9a, 0x53, 0x7e, 0xd0, 0xc6);
435DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_DECREASE_POLICY, 0x71021b41, 0xc749, 0x4d21, 0xbe, 0x74, 0xa0, 0x0f, 0x33, 0x5d, 0x58, 0x2b);
436DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_MAX_CORES, 0xea062031, 0x0e34, 0x4ff1, 0x9b, 0x6d, 0xeb, 0x10, 0x59, 0x33, 0x40, 0x28);
437DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_MIN_CORES, 0x0cc5b647, 0xc1df, 0x4637, 0x89, 0x1a, 0xde, 0xc3, 0x5c, 0x31, 0x85, 0x83);
438DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_INCREASE_TIME, 0x2ddd5a84, 0x5a71, 0x437e, 0x91, 0x2a, 0xdb, 0x0b, 0x8c, 0x78, 0x87, 0x32);
439DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_DECREASE_TIME, 0xdfd10d17, 0xd5eb, 0x45dd, 0x87, 0x7a, 0x9a, 0x34, 0xdd, 0xd1, 0x5c, 0x82);
440DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_AFFINITY_HISTORY_DECREASE_FACTOR, 0x8f7b45e3, 0xc393, 0x480a, 0x87, 0x8c, 0xf6, 0x7a, 0xc3, 0xd0, 0x70, 0x82);
441DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_AFFINITY_HISTORY_THRESHOLD, 0x5b33697b, 0xe89d, 0x4d38, 0xaa, 0x46, 0x9e, 0x7d, 0xfb, 0x7c, 0xd2, 0xf9);
442DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_AFFINITY_WEIGHTING, 0xe70867f1, 0xfa2f, 0x4f4e, 0xae, 0xa1, 0x4d, 0x8a, 0x0b, 0xa2, 0x3b, 0x20);
443DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_HISTORY_DECREASE_FACTOR, 0x1299023c, 0xbc28, 0x4f0a, 0x81, 0xec, 0xd3, 0x29, 0x5a, 0x8d, 0x81, 0x5d);
444DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_HISTORY_THRESHOLD, 0x9ac18e92, 0xaa3c, 0x4e27, 0xb3, 0x07, 0x01, 0xae, 0x37, 0x30, 0x71, 0x29);
445DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_WEIGHTING, 0x8809c2d8, 0xb155, 0x42d4, 0xbc, 0xda, 0x0d, 0x34, 0x56, 0x51, 0xb1, 0xdb);
446DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_THRESHOLD, 0x943c8cb6, 0x6f93, 0x4227, 0xad, 0x87, 0xe9, 0xa3, 0xfe, 0xec, 0x08, 0xd1);
447DEFINE_GUID(GUID_PROCESSOR_PARKING_CORE_OVERRIDE, 0xa55612aa, 0xf624, 0x42c6, 0xa4, 0x43, 0x73, 0x97, 0xd0, 0x64, 0xc0, 0x4f);
448DEFINE_GUID(GUID_PROCESSOR_PARKING_PERF_STATE, 0x447235c7, 0x6a8d, 0x4cc0, 0x8e, 0x24, 0x9e, 0xaf, 0x70, 0xb9, 0x6e, 0x2b);
449DEFINE_GUID(GUID_PROCESSOR_PERF_HISTORY, 0x7d24baa7, 0x0b84, 0x480f, 0x84, 0x0c, 0x1b, 0x07, 0x43, 0xc0, 0x0f, 0x5f);
450DEFINE_GUID(GUID_SYSTEM_COOLING_POLICY, 0x94D3A615, 0xA899, 0x4AC5, 0xAE, 0x2B, 0xE4, 0xD8, 0xF6, 0x34, 0x36, 0x7F);
451DEFINE_GUID(GUID_LOCK_CONSOLE_ON_WAKE, 0x0E796BDB, 0x100D, 0x47D6, 0xA2, 0xD5, 0xF7, 0xD2, 0xDA, 0xA5, 0x1F, 0x51);
452DEFINE_GUID(GUID_DEVICE_IDLE_POLICY, 0x4faab71a, 0x92e5, 0x4726, 0xb5, 0x31, 0x22, 0x45, 0x59, 0x67, 0x2d, 0x19);
453DEFINE_GUID(GUID_ACDC_POWER_SOURCE, 0x5D3E9A59, 0xE9D5, 0x4B00, 0xA6, 0xBD, 0xFF, 0x34, 0xFF, 0x51, 0x65, 0x48);
454DEFINE_GUID(GUID_LIDSWITCH_STATE_CHANGE, 0xBA3E0F4D, 0xB817, 0x4094, 0xA2, 0xD1, 0xD5, 0x63, 0x79, 0xE6, 0xA0, 0xF3);
455DEFINE_GUID(GUID_BATTERY_PERCENTAGE_REMAINING, 0xA7AD8041, 0xB45A, 0x4CAE, 0x87, 0xA3, 0xEE, 0xCB, 0xB4, 0x68, 0xA9, 0xE1);
456DEFINE_GUID(GUID_IDLE_BACKGROUND_TASK, 0x515C31D8, 0xF734, 0x163D, 0xA0, 0xFD, 0x11, 0xA0, 0x8C, 0x91, 0xE8, 0xF1);
457DEFINE_GUID(GUID_BACKGROUND_TASK_NOTIFICATION, 0xCF23F240, 0x2A54, 0x48D8, 0xB1, 0x14, 0xDE, 0x15, 0x18, 0xFF, 0x05, 0x2E);
458DEFINE_GUID(GUID_APPLAUNCH_BUTTON, 0x1A689231, 0x7399, 0x4E9A, 0x8F, 0x99, 0xB7, 0x1F, 0x99, 0x9D, 0xB3, 0xFA);
459DEFINE_GUID(GUID_PCIEXPRESS_SETTINGS_SUBGROUP, 0x501a4d13, 0x42af,0x4429, 0x9f, 0xd1, 0xa8, 0x21, 0x8c, 0x26, 0x8e, 0x20);
460DEFINE_GUID(GUID_PCIEXPRESS_ASPM_POLICY, 0xee12f906, 0xd277, 0x404b, 0xb6, 0xda, 0xe5, 0xfa, 0x1a, 0x57, 0x6d, 0xf5);
461DEFINE_GUID(GUID_ENABLE_SWITCH_FORCED_SHUTDOWN, 0x833a6b62, 0xdfa4, 0x46d1, 0x82, 0xf8, 0xe0, 0x9e, 0x34, 0xd0, 0x29, 0xd6);
462
463_Function_class_(REQUEST_POWER_COMPLETE)
464_IRQL_requires_same_
465typedef VOID
466(NTAPI REQUEST_POWER_COMPLETE)(
467 _In_ struct _DEVICE_OBJECT *DeviceObject,
468 _In_ UCHAR MinorFunction,
469 _In_ POWER_STATE PowerState,
470 _In_opt_ PVOID Context,
471 _In_ struct _IO_STATUS_BLOCK *IoStatus);
472typedef REQUEST_POWER_COMPLETE *PREQUEST_POWER_COMPLETE;
473
474_Function_class_(POWER_SETTING_CALLBACK)
475_IRQL_requires_same_
476typedef NTSTATUS
477(NTAPI POWER_SETTING_CALLBACK)(
478 _In_ LPCGUID SettingGuid,
479 _In_reads_bytes_(ValueLength) PVOID Value,
480 _In_ ULONG ValueLength,
481 _Inout_opt_ PVOID Context);
482typedef POWER_SETTING_CALLBACK *PPOWER_SETTING_CALLBACK;
483
484#if (NTDDI_VERSION >= NTDDI_WIN8)
485
486#define PO_FX_VERSION_V1 0x00000001
487#define PO_FX_VERSION_V2 0x00000002
488#define PO_FX_VERSION_V3 0x00000003
489#define PO_FX_VERSION PO_FX_VERSION_V1
490
491DECLARE_HANDLE(POHANDLE);
492
493typedef
494_Function_class_(PO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK)
495_IRQL_requires_max_(DISPATCH_LEVEL)
496VOID
497PO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK(
498 _In_ PVOID Context,
499 _In_ ULONG Component);
500
501typedef PO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK *PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK;
502
503typedef
504_Function_class_(PO_FX_COMPONENT_IDLE_CONDITION_CALLBACK)
505_IRQL_requires_max_(DISPATCH_LEVEL)
506VOID
507PO_FX_COMPONENT_IDLE_CONDITION_CALLBACK(
508 _In_ PVOID Context,
509 _In_ ULONG Component);
510
511typedef PO_FX_COMPONENT_IDLE_CONDITION_CALLBACK *PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK;
512
513typedef
514_Function_class_(PO_FX_COMPONENT_IDLE_STATE_CALLBACK)
515_IRQL_requires_max_(DISPATCH_LEVEL)
516VOID
517PO_FX_COMPONENT_IDLE_STATE_CALLBACK(
518 _In_ PVOID Context,
519 _In_ ULONG Component,
520 _In_ ULONG State);
521
522typedef PO_FX_COMPONENT_IDLE_STATE_CALLBACK *PPO_FX_COMPONENT_IDLE_STATE_CALLBACK;
523
524typedef
525_Function_class_(PO_FX_DEVICE_POWER_REQUIRED_CALLBACK)
526_IRQL_requires_max_(DISPATCH_LEVEL)
527VOID
528PO_FX_DEVICE_POWER_REQUIRED_CALLBACK(
529 _In_ PVOID Context);
530
531typedef PO_FX_DEVICE_POWER_REQUIRED_CALLBACK *PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK;
532
533typedef
534_Function_class_(PO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK)
535_IRQL_requires_max_(DISPATCH_LEVEL)
536VOID
537PO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK(
538 _In_ PVOID Context);
539
540typedef PO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK *PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK;
541
542typedef
543_Function_class_(PO_FX_POWER_CONTROL_CALLBACK)
544_IRQL_requires_max_(DISPATCH_LEVEL)
545NTSTATUS
546PO_FX_POWER_CONTROL_CALLBACK(
547 _In_ PVOID DeviceContext,
548 _In_ LPCGUID PowerControlCode,
549 _In_reads_bytes_opt_(InBufferSize) PVOID InBuffer,
550 _In_ SIZE_T InBufferSize,
551 _Out_writes_bytes_opt_(OutBufferSize) PVOID OutBuffer,
552 _In_ SIZE_T OutBufferSize,
553 _Out_opt_ PSIZE_T BytesReturned);
554
555typedef PO_FX_POWER_CONTROL_CALLBACK *PPO_FX_POWER_CONTROL_CALLBACK;
556
557typedef
558_Function_class_(PO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK)
559_IRQL_requires_max_(HIGH_LEVEL)
560VOID
561PO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK(
562 _In_ PVOID Context,
563 _In_ ULONG Component,
564 _In_ BOOLEAN Active);
565
566typedef PO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK *PPO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK;
567
568typedef struct _PO_FX_COMPONENT_IDLE_STATE
569{
570 ULONGLONG TransitionLatency;
571 ULONGLONG ResidencyRequirement;
572 ULONG NominalPower;
573} PO_FX_COMPONENT_IDLE_STATE, *PPO_FX_COMPONENT_IDLE_STATE;
574
575typedef struct _PO_FX_COMPONENT_V1
576{
577 GUID Id;
578 ULONG IdleStateCount;
579 ULONG DeepestWakeableIdleState;
580 _Field_size_full_(IdleStateCount) PPO_FX_COMPONENT_IDLE_STATE IdleStates;
581} PO_FX_COMPONENT_V1, *PPO_FX_COMPONENT_V1;
582
583typedef struct _PO_FX_DEVICE_V1
584{
585 ULONG Version;
586 ULONG ComponentCount;
587 PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK ComponentActiveConditionCallback;
588 PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK ComponentIdleConditionCallback;
589 PPO_FX_COMPONENT_IDLE_STATE_CALLBACK ComponentIdleStateCallback;
590 PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK DevicePowerRequiredCallback;
591 PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK DevicePowerNotRequiredCallback;
592 PPO_FX_POWER_CONTROL_CALLBACK PowerControlCallback;
593 PVOID DeviceContext;
594 _Field_size_full_(ComponentCount) PO_FX_COMPONENT_V1 Components[ANYSIZE_ARRAY];
595} PO_FX_DEVICE_V1, *PPO_FX_DEVICE_V1;
596
597#define PO_FX_COMPONENT_FLAG_F0_ON_DX 0x0000000000000001
598#define PO_FX_COMPONENT_FLAG_NO_DEBOUNCE 0x0000000000000002
599
600typedef struct _PO_FX_COMPONENT_V2
601{
602 GUID Id;
603 ULONGLONG Flags;
604 ULONG DeepestWakeableIdleState;
605 ULONG IdleStateCount;
606 _Field_size_full_(IdleStateCount) PPO_FX_COMPONENT_IDLE_STATE IdleStates;
607 ULONG ProviderCount;
608 _Field_size_full_(ProviderCount) PULONG Providers;
609} PO_FX_COMPONENT_V2, *PPO_FX_COMPONENT_V2;
610
611typedef struct _PO_FX_DEVICE_V2
612{
613 ULONG Version;
614 ULONGLONG Flags;
615 PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK ComponentActiveConditionCallback;
616 PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK ComponentIdleConditionCallback;
617 PPO_FX_COMPONENT_IDLE_STATE_CALLBACK ComponentIdleStateCallback;
618 PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK DevicePowerRequiredCallback;
619 PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK DevicePowerNotRequiredCallback;
620 PPO_FX_POWER_CONTROL_CALLBACK PowerControlCallback;
621 PVOID DeviceContext;
622 ULONG ComponentCount;
623 _Field_size_full_(ComponentCount) PO_FX_COMPONENT_V2 Components[ANYSIZE_ARRAY];
624} PO_FX_DEVICE_V2, *PPO_FX_DEVICE_V2;
625
626#define PO_FX_DEVICE_FLAG_RESERVED_1 (0x0000000000000001ull)
627#define PO_FX_DEVICE_FLAG_DFX_DIRECT_CHILDREN_OPTIONAL (0x0000000000000002ull)
628#define PO_FX_DEVICE_FLAG_DFX_POWER_CHILDREN_OPTIONAL (0x0000000000000004ull)
629#define PO_FX_DEVICE_FLAG_DFX_CHILDREN_OPTIONAL \
630 (PO_FX_DEVICE_FLAG_DFX_DIRECT_CHILDREN_OPTIONAL | \
631 PO_FX_DEVICE_FLAG_DFX_POWER_CHILDREN_OPTIONAL)
632
633#define PO_FX_DIRECTED_FX_DEFAULT_IDLE_TIMEOUT (0ul)
634#define PO_FX_DIRECTED_FX_IMMEDIATE_IDLE_TIMEOUT ((ULONG)-1)
635#define PO_FX_DIRECTED_FX_MAX_IDLE_TIMEOUT (10ul * 60)
636
637typedef
638_Function_class_(PO_FX_DIRECTED_POWER_UP_CALLBACK)
639_IRQL_requires_max_(DISPATCH_LEVEL)
640_IRQL_requires_same_
641VOID
642PO_FX_DIRECTED_POWER_UP_CALLBACK(
643 _In_ PVOID Context,
644 _In_ ULONG Flags);
645
646typedef PO_FX_DIRECTED_POWER_UP_CALLBACK *PPO_FX_DIRECTED_POWER_UP_CALLBACK;
647
648typedef
649_Function_class_(PO_FX_DIRECTED_POWER_DOWN_CALLBACK)
650_IRQL_requires_max_(DISPATCH_LEVEL)
651_IRQL_requires_same_
652VOID
653PO_FX_DIRECTED_POWER_DOWN_CALLBACK(
654 _In_ PVOID Context,
655 _In_ ULONG Flags);
656
657typedef PO_FX_DIRECTED_POWER_DOWN_CALLBACK *PPO_FX_DIRECTED_POWER_DOWN_CALLBACK;
658
659typedef struct _PO_FX_DEVICE_V3
660{
661 ULONG Version;
662 ULONGLONG Flags;
663 PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK ComponentActiveConditionCallback;
664 PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK ComponentIdleConditionCallback;
665 PPO_FX_COMPONENT_IDLE_STATE_CALLBACK ComponentIdleStateCallback;
666 PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK DevicePowerRequiredCallback;
667 PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK DevicePowerNotRequiredCallback;
668 PPO_FX_POWER_CONTROL_CALLBACK PowerControlCallback;
669 PPO_FX_DIRECTED_POWER_UP_CALLBACK DirectedPowerUpCallback;
670 PPO_FX_DIRECTED_POWER_DOWN_CALLBACK DirectedPowerDownCallback;
671 ULONG DirectedFxTimeoutInSeconds;
672 PVOID DeviceContext;
673 ULONG ComponentCount;
674 _Field_size_full_(ComponentCount) PO_FX_COMPONENT_V2 Components[ANYSIZE_ARRAY];
675} PO_FX_DEVICE_V3, *PPO_FX_DEVICE_V3;
676
677#if (PO_FX_VERSION == PO_FX_VERSION_V1)
678typedef PO_FX_COMPONENT_V1 PO_FX_COMPONENT, *PPO_FX_COMPONENT;
679typedef PO_FX_DEVICE_V1 PO_FX_DEVICE, *PPO_FX_DEVICE;
680#elif (PO_FX_VERSION == PO_FX_VERSION_V2)
681typedef PO_FX_COMPONENT_V2 PO_FX_COMPONENT, *PPO_FX_COMPONENT;
682typedef PO_FX_DEVICE_V2 PO_FX_DEVICE, *PPO_FX_DEVICE;
683#elif (PO_FX_VERSION == PO_FX_VERSION_V3)
684typedef PO_FX_COMPONENT_V2 PO_FX_COMPONENT, *PPO_FX_COMPONENT;
685typedef PO_FX_DEVICE_V3 PO_FX_DEVICE, *PPO_FX_DEVICE;
686#else
687#error PO_FX_VERSION undefined!
688#endif
689
690#define PO_FX_UNKNOWN_POWER 0xFFFFFFFF
691
692#endif // NTDDI_WIN8
693
694$endif (_WDMDDK_)
695$if (_NTIFS_)
696
697#define PO_CB_SYSTEM_POWER_POLICY 0
698#define PO_CB_AC_STATUS 1
699#define PO_CB_BUTTON_COLLISION 2
700#define PO_CB_SYSTEM_STATE_LOCK 3
701#define PO_CB_LID_SWITCH_STATE 4
702#define PO_CB_PROCESSOR_POWER_POLICY 5
703$endif (_NTIFS_)