xref: /reactos/sdk/include/xdk/potypes.h (revision d01518da)
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 */
17 typedef 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 
30 typedef 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 
130 typedef enum {
131   PowerActionNone = 0,
132   PowerActionReserved,
133   PowerActionSleep,
134   PowerActionHibernate,
135   PowerActionShutdown,
136   PowerActionShutdownReset,
137   PowerActionShutdownOff,
138   PowerActionWarmEject
139 } POWER_ACTION, *PPOWER_ACTION;
140 
141 typedef 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 
150 typedef enum _MONITOR_DISPLAY_STATE {
151   PowerMonitorOff = 0,
152   PowerMonitorOn,
153   PowerMonitorDim
154 } MONITOR_DISPLAY_STATE, *PMONITOR_DISPLAY_STATE;
155 
156 typedef union _POWER_STATE {
157   SYSTEM_POWER_STATE SystemState;
158   DEVICE_POWER_STATE DeviceState;
159 } POWER_STATE, *PPOWER_STATE;
160 
161 typedef enum _POWER_STATE_TYPE {
162   SystemPowerState = 0,
163   DevicePowerState
164 } POWER_STATE_TYPE, *PPOWER_STATE_TYPE;
165 
166 #if (NTDDI_VERSION >= NTDDI_VISTA)
167 typedef 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)
184 typedef 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 
213 typedef ULONG EXECUTION_STATE, *PEXECUTION_STATE;
214 
215 typedef 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 
234 typedef 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 
252 typedef 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 
265 typedef enum _SYSTEM_POWER_CONDITION {
266   PoAc,
267   PoDc,
268   PoHot,
269   PoConditionMaximum
270 } SYSTEM_POWER_CONDITION;
271 
272 typedef 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 
282 typedef struct _NOTIFY_USER_POWER_SETTING {
283   GUID Guid;
284 } NOTIFY_USER_POWER_SETTING, *PNOTIFY_USER_POWER_SETTING;
285 
286 typedef struct _APPLICATIONLAUNCH_SETTING_VALUE {
287   LARGE_INTEGER ActivationTime;
288   ULONG Flags;
289   ULONG ButtonInstanceID;
290 } APPLICATIONLAUNCH_SETTING_VALUE, *PAPPLICATIONLAUNCH_SETTING_VALUE;
291 
292 typedef 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 
319 typedef struct _POWER_PLATFORM_INFORMATION
320 {
321   BOOLEAN AoAc;
322 } POWER_PLATFORM_INFORMATION, *PPOWER_PLATFORM_INFORMATION;
323 
324 #if (NTDDI_VERSION >= NTDDI_WINXP) || !defined(_BATCLASS_)
325 typedef 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_GUID(GUID_MAX_POWER_SAVINGS, 0xA1841308, 0x3541, 0x4FAB, 0xBC, 0x81, 0xF7, 0x15, 0x56, 0xF2, 0x0B, 0x4A);
339 DEFINE_GUID(GUID_MIN_POWER_SAVINGS, 0x8C5E7FDA, 0xE8BF, 0x4A96, 0x9A, 0x85, 0xA6, 0xE2, 0x3A, 0x8C, 0x63, 0x5C);
340 DEFINE_GUID(GUID_TYPICAL_POWER_SAVINGS, 0x381B4222, 0xF694, 0x41F0, 0x96, 0x85, 0xFF, 0x5B, 0xB2, 0x60, 0xDF, 0x2E);
341 DEFINE_GUID(NO_SUBGROUP_GUID, 0xFEA3413E, 0x7E05, 0x4911, 0x9A, 0x71, 0x70, 0x03, 0x31, 0xF1, 0xC2, 0x94);
342 DEFINE_GUID(ALL_POWERSCHEMES_GUID, 0x68A1E95E, 0x13EA, 0x41E1, 0x80, 0x11, 0x0C, 0x49, 0x6C, 0xA4, 0x90, 0xB0);
343 DEFINE_GUID(GUID_POWERSCHEME_PERSONALITY, 0x245D8541, 0x3943, 0x4422, 0xB0, 0x25, 0x13, 0xA7, 0x84, 0xF6, 0x79, 0xB7);
344 DEFINE_GUID(GUID_ACTIVE_POWERSCHEME, 0x31F9F286, 0x5084, 0x42FE, 0xB7, 0x20, 0x2B, 0x02, 0x64, 0x99, 0x37, 0x63);
345 DEFINE_GUID(GUID_VIDEO_SUBGROUP, 0x7516B95F, 0xF776, 0x4464, 0x8C, 0x53, 0x06, 0x16, 0x7F, 0x40, 0xCC, 0x99);
346 DEFINE_GUID(GUID_VIDEO_POWERDOWN_TIMEOUT, 0x3C0BC021, 0xC8A8, 0x4E07, 0xA9, 0x73, 0x6B, 0x14, 0xCB, 0xCB, 0x2B, 0x7E);
347 DEFINE_GUID(GUID_VIDEO_ANNOYANCE_TIMEOUT, 0x82DBCF2D, 0xCD67, 0x40C5, 0xBF, 0xDC, 0x9F, 0x1A, 0x5C, 0xCD, 0x46, 0x63);
348 DEFINE_GUID(GUID_VIDEO_ADAPTIVE_PERCENT_INCREASE, 0xEED904DF, 0xB142, 0x4183, 0xB1, 0x0B, 0x5A, 0x11, 0x97, 0xA3, 0x78, 0x64);
349 DEFINE_GUID(GUID_VIDEO_DIM_TIMEOUT, 0x17aaa29b, 0x8b43, 0x4b94, 0xaa, 0xfe, 0x35, 0xf6, 0x4d, 0xaa, 0xf1, 0xee);
350 DEFINE_GUID(GUID_VIDEO_ADAPTIVE_POWERDOWN, 0x90959D22, 0xD6A1, 0x49B9, 0xAF, 0x93, 0xBC, 0xE8, 0x85, 0xAD, 0x33, 0x5B);
351 DEFINE_GUID(GUID_MONITOR_POWER_ON, 0x02731015, 0x4510, 0x4526, 0x99, 0xE6, 0xE5, 0xA1, 0x7E, 0xBD, 0x1A, 0xEA);
352 DEFINE_GUID(GUID_DEVICE_POWER_POLICY_VIDEO_BRIGHTNESS, 0xaded5e82L, 0xb909, 0x4619, 0x99, 0x49, 0xf5, 0xd7, 0x1d, 0xac, 0x0b, 0xcb);
353 DEFINE_GUID(GUID_DEVICE_POWER_POLICY_VIDEO_DIM_BRIGHTNESS, 0xf1fbfde2, 0xa960, 0x4165, 0x9f, 0x88, 0x50, 0x66, 0x79, 0x11, 0xce, 0x96);
354 DEFINE_GUID(GUID_VIDEO_CURRENT_MONITOR_BRIGHTNESS, 0x8ffee2c6, 0x2d01, 0x46be, 0xad, 0xb9, 0x39, 0x8a, 0xdd, 0xc5, 0xb4, 0xff);
355 DEFINE_GUID(GUID_VIDEO_ADAPTIVE_DISPLAY_BRIGHTNESS, 0xFBD9AA66, 0x9553, 0x4097, 0xBA, 0x44, 0xED, 0x6E, 0x9D, 0x65, 0xEA, 0xB8);
356 DEFINE_GUID(GUID_SESSION_DISPLAY_STATE, 0x73A5E93A, 0x5BB1, 0x4F93, 0x89, 0x5B, 0xDB, 0xD0, 0xDA, 0x85, 0x59, 0x67);
357 DEFINE_GUID(GUID_CONSOLE_DISPLAY_STATE, 0x6fe69556, 0x704a, 0x47a0, 0x8f, 0x24, 0xc2, 0x8d, 0x93, 0x6f, 0xda, 0x47);
358 DEFINE_GUID(GUID_ALLOW_DISPLAY_REQUIRED, 0xA9CEB8DA, 0xCD46, 0x44FB, 0xA9, 0x8B, 0x02, 0xAF, 0x69, 0xDE, 0x46, 0x23);
359 DEFINE_GUID(GUID_DISK_SUBGROUP, 0x0012EE47, 0x9041, 0x4B5D, 0x9B, 0x77, 0x53, 0x5F, 0xBA, 0x8B, 0x14, 0x42);
360 DEFINE_GUID(GUID_DISK_POWERDOWN_TIMEOUT, 0x6738E2C4, 0xE8A5, 0x4A42, 0xB1, 0x6A, 0xE0, 0x40, 0xE7, 0x69, 0x75, 0x6E);
361 DEFINE_GUID(GUID_DISK_IDLE_TIMEOUT, 0x58E39BA8, 0xB8E6, 0x4EF6, 0x90, 0xD0, 0x89, 0xAE, 0x32, 0xB2, 0x58, 0xD6);
362 DEFINE_GUID(GUID_DISK_BURST_IGNORE_THRESHOLD, 0x80e3c60e, 0xbb94, 0x4ad8, 0xbb, 0xe0, 0x0d, 0x31, 0x95, 0xef, 0xc6, 0x63);
363 DEFINE_GUID(GUID_DISK_ADAPTIVE_POWERDOWN, 0x396A32E1, 0x499A, 0x40B2, 0x91, 0x24, 0xA9, 0x6A, 0xFE, 0x70, 0x76, 0x67);
364 DEFINE_GUID(GUID_SLEEP_SUBGROUP, 0x238C9FA8, 0x0AAD, 0x41ED, 0x83, 0xF4, 0x97, 0xBE, 0x24, 0x2C, 0x8F, 0x20);
365 DEFINE_GUID(GUID_SLEEP_IDLE_THRESHOLD, 0x81cd32e0, 0x7833, 0x44f3, 0x87, 0x37, 0x70, 0x81, 0xf3, 0x8d, 0x1f, 0x70);
366 DEFINE_GUID(GUID_STANDBY_TIMEOUT, 0x29F6C1DB, 0x86DA, 0x48C5, 0x9F, 0xDB, 0xF2, 0xB6, 0x7B, 0x1F, 0x44, 0xDA);
367 DEFINE_GUID(GUID_UNATTEND_SLEEP_TIMEOUT, 0x7bc4a2f9, 0xd8fc, 0x4469, 0xb0, 0x7b, 0x33, 0xeb, 0x78, 0x5a, 0xac, 0xa0);
368 DEFINE_GUID(GUID_HIBERNATE_TIMEOUT, 0x9D7815A6, 0x7EE4, 0x497E, 0x88, 0x88, 0x51, 0x5A, 0x05, 0xF0, 0x23, 0x64);
369 DEFINE_GUID(GUID_HIBERNATE_FASTS4_POLICY, 0x94AC6D29, 0x73CE, 0x41A6, 0x80, 0x9F, 0x63, 0x63, 0xBA, 0x21, 0xB4, 0x7E);
370 DEFINE_GUID(GUID_CRITICAL_POWER_TRANSITION,  0xB7A27025, 0xE569, 0x46c2, 0xA5, 0x04, 0x2B, 0x96, 0xCA, 0xD2, 0x25, 0xA1);
371 DEFINE_GUID(GUID_SYSTEM_AWAYMODE, 0x98A7F580, 0x01F7, 0x48AA, 0x9C, 0x0F, 0x44, 0x35, 0x2C, 0x29, 0xE5, 0xC0);
372 DEFINE_GUID(GUID_ALLOW_AWAYMODE, 0x25dfa149, 0x5dd1, 0x4736, 0xb5, 0xab, 0xe8, 0xa3, 0x7b, 0x5b, 0x81, 0x87);
373 DEFINE_GUID(GUID_ALLOW_STANDBY_STATES, 0xabfc2519, 0x3608, 0x4c2a, 0x94, 0xea, 0x17, 0x1b, 0x0e, 0xd5, 0x46, 0xab);
374 DEFINE_GUID(GUID_ALLOW_RTC_WAKE, 0xBD3B718A, 0x0680, 0x4D9D, 0x8A, 0xB2, 0xE1, 0xD2, 0xB4, 0xAC, 0x80, 0x6D);
375 DEFINE_GUID(GUID_ALLOW_SYSTEM_REQUIRED, 0xA4B195F5, 0x8225, 0x47D8, 0x80, 0x12, 0x9D, 0x41, 0x36, 0x97, 0x86, 0xE2);
376 DEFINE_GUID(GUID_SYSTEM_BUTTON_SUBGROUP, 0x4F971E89, 0xEEBD, 0x4455, 0xA8, 0xDE, 0x9E, 0x59, 0x04, 0x0E, 0x73, 0x47);
377 DEFINE_GUID(GUID_POWERBUTTON_ACTION, 0x7648EFA3, 0xDD9C, 0x4E3E, 0xB5, 0x66, 0x50, 0xF9, 0x29, 0x38, 0x62, 0x80);
378 DEFINE_GUID(GUID_POWERBUTTON_ACTION_FLAGS, 0x857E7FAC, 0x034B, 0x4704, 0xAB, 0xB1, 0xBC, 0xA5, 0x4A, 0xA3, 0x14, 0x78);
379 DEFINE_GUID(GUID_SLEEPBUTTON_ACTION, 0x96996BC0, 0xAD50, 0x47EC, 0x92, 0x3B, 0x6F, 0x41, 0x87, 0x4D, 0xD9, 0xEB);
380 DEFINE_GUID(GUID_SLEEPBUTTON_ACTION_FLAGS, 0x2A160AB1, 0xB69D, 0x4743, 0xB7, 0x18, 0xBF, 0x14, 0x41, 0xD5, 0xE4, 0x93);
381 DEFINE_GUID(GUID_USERINTERFACEBUTTON_ACTION, 0xA7066653, 0x8D6C, 0x40A8, 0x91, 0x0E, 0xA1, 0xF5, 0x4B, 0x84, 0xC7, 0xE5);
382 DEFINE_GUID(GUID_LIDCLOSE_ACTION, 0x5CA83367, 0x6E45, 0x459F, 0xA2, 0x7B, 0x47, 0x6B, 0x1D, 0x01, 0xC9, 0x36);
383 DEFINE_GUID(GUID_LIDCLOSE_ACTION_FLAGS, 0x97E969AC, 0x0D6C, 0x4D08, 0x92, 0x7C, 0xD7, 0xBD, 0x7A, 0xD7, 0x85, 0x7B);
384 DEFINE_GUID(GUID_LIDOPEN_POWERSTATE, 0x99FF10E7, 0x23B1, 0x4C07, 0xA9, 0xD1, 0x5C, 0x32, 0x06, 0xD7, 0x41, 0xB4);
385 DEFINE_GUID(GUID_BATTERY_SUBGROUP, 0xE73A048D, 0xBF27, 0x4F12, 0x97, 0x31, 0x8B, 0x20, 0x76, 0xE8, 0x89, 0x1F);
386 DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_0, 0x637EA02F, 0xBBCB, 0x4015, 0x8E, 0x2C, 0xA1, 0xC7, 0xB9, 0xC0, 0xB5, 0x46);
387 DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_0, 0x9A66D8D7, 0x4FF7, 0x4EF9, 0xB5, 0xA2, 0x5A, 0x32, 0x6C, 0xA2, 0xA4, 0x69);
388 DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_0, 0x5dbb7c9f, 0x38e9, 0x40d2, 0x97, 0x49, 0x4f, 0x8a, 0x0e, 0x9f, 0x64, 0x0f);
389 DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_1, 0xD8742DCB, 0x3E6A, 0x4B3C, 0xB3, 0xFE, 0x37, 0x46, 0x23, 0xCD, 0xCF, 0x06);
390 DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_1, 0x8183BA9A, 0xE910, 0x48DA, 0x87, 0x69, 0x14, 0xAE, 0x6D, 0xC1, 0x17, 0x0A);
391 DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_1, 0xbcded951, 0x187b, 0x4d05, 0xbc, 0xcc, 0xf7, 0xe5, 0x19, 0x60, 0xc2, 0x58);
392 DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_2, 0x421CBA38, 0x1A8E, 0x4881, 0xAC, 0x89, 0xE3, 0x3A, 0x8B, 0x04, 0xEC, 0xE4);
393 DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_2, 0x07A07CA2, 0xADAF, 0x40D7, 0xB0, 0x77, 0x53, 0x3A, 0xAD, 0xED, 0x1B, 0xFA);
394 DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_2, 0x7fd2f0c4, 0xfeb7, 0x4da3, 0x81, 0x17, 0xe3, 0xfb, 0xed, 0xc4, 0x65, 0x82);
395 DEFINE_GUID(GUID_BATTERY_DISCHARGE_ACTION_3, 0x80472613, 0x9780, 0x455E, 0xB3, 0x08, 0x72, 0xD3, 0x00, 0x3C, 0xF2, 0xF8);
396 DEFINE_GUID(GUID_BATTERY_DISCHARGE_LEVEL_3, 0x58AFD5A6, 0xC2DD, 0x47D2, 0x9F, 0xBF, 0xEF, 0x70, 0xCC, 0x5C, 0x59, 0x65);
397 DEFINE_GUID(GUID_BATTERY_DISCHARGE_FLAGS_3, 0x73613ccf, 0xdbfa, 0x4279, 0x83, 0x56, 0x49, 0x35, 0xf6, 0xbf, 0x62, 0xf3);
398 DEFINE_GUID(GUID_PROCESSOR_SETTINGS_SUBGROUP, 0x54533251, 0x82BE, 0x4824, 0x96, 0xC1, 0x47, 0xB6, 0x0B, 0x74, 0x0D, 0x00);
399 DEFINE_GUID(GUID_PROCESSOR_THROTTLE_POLICY, 0x57027304, 0x4AF6, 0x4104, 0x92, 0x60, 0xE3, 0xD9, 0x52, 0x48, 0xFC, 0x36);
400 DEFINE_GUID(GUID_PROCESSOR_THROTTLE_MAXIMUM, 0xBC5038F7, 0x23E0, 0x4960, 0x96, 0xDA, 0x33, 0xAB, 0xAF, 0x59, 0x35, 0xEC);
401 DEFINE_GUID(GUID_PROCESSOR_THROTTLE_MINIMUM, 0x893DEE8E, 0x2BEF, 0x41E0, 0x89, 0xC6, 0xB5, 0x5D, 0x09, 0x29, 0x96, 0x4C);
402 DEFINE_GUID(GUID_PROCESSOR_ALLOW_THROTTLING, 0x3b04d4fd, 0x1cc7, 0x4f23, 0xab, 0x1c, 0xd1, 0x33, 0x78, 0x19, 0xc4, 0xbb);
403 DEFINE_GUID(GUID_PROCESSOR_IDLESTATE_POLICY, 0x68f262a7, 0xf621, 0x4069, 0xb9, 0xa5, 0x48, 0x74, 0x16, 0x9b, 0xe2, 0x3c);
404 DEFINE_GUID(GUID_PROCESSOR_PERFSTATE_POLICY, 0xBBDC3814, 0x18E9, 0x4463, 0x8A, 0x55, 0xD1, 0x97, 0x32, 0x7C, 0x45, 0xC0);
405 DEFINE_GUID(GUID_PROCESSOR_PERF_INCREASE_THRESHOLD, 0x06cadf0e, 0x64ed, 0x448a, 0x89, 0x27, 0xce, 0x7b, 0xf9, 0x0e, 0xb3, 0x5d);
406 DEFINE_GUID(GUID_PROCESSOR_PERF_DECREASE_THRESHOLD, 0x12a0ab44, 0xfe28, 0x4fa9, 0xb3, 0xbd, 0x4b, 0x64, 0xf4, 0x49, 0x60, 0xa6);
407 DEFINE_GUID(GUID_PROCESSOR_PERF_INCREASE_POLICY, 0x465e1f50, 0xb610, 0x473a, 0xab, 0x58, 0x0, 0xd1, 0x7, 0x7d, 0xc4, 0x18);
408 DEFINE_GUID(GUID_PROCESSOR_PERF_DECREASE_POLICY, 0x40fbefc7, 0x2e9d, 0x4d25, 0xa1, 0x85, 0xc, 0xfd, 0x85, 0x74, 0xba, 0xc6);
409 DEFINE_GUID(GUID_PROCESSOR_PERF_INCREASE_TIME, 0x984cf492, 0x3bed, 0x4488, 0xa8, 0xf9, 0x42, 0x86, 0xc9, 0x7b, 0xf5, 0xaa);
410 DEFINE_GUID(GUID_PROCESSOR_PERF_DECREASE_TIME, 0xd8edeb9b, 0x95cf, 0x4f95, 0xa7, 0x3c, 0xb0, 0x61, 0x97, 0x36, 0x93, 0xc8);
411 DEFINE_GUID(GUID_PROCESSOR_PERF_TIME_CHECK, 0x4d2b0152, 0x7d5c, 0x498b, 0x88, 0xe2, 0x34, 0x34, 0x53, 0x92, 0xa2, 0xc5);
412 DEFINE_GUID(GUID_PROCESSOR_PERF_BOOST_POLICY, 0x45bcc044, 0xd885, 0x43e2, 0x86, 0x5, 0xee, 0xe, 0xc6, 0xe9, 0x6b, 0x59);
413 DEFINE_GUID(GUID_PROCESSOR_IDLE_ALLOW_SCALING, 0x6c2993b0, 0x8f48, 0x481f, 0xbc, 0xc6, 0x0, 0xdd, 0x27, 0x42, 0xaa, 0x6);
414 DEFINE_GUID(GUID_PROCESSOR_IDLE_DISABLE, 0x5d76a2ca, 0xe8c0, 0x402f, 0xa1, 0x33, 0x21, 0x58, 0x49, 0x2d, 0x58, 0xad);
415 DEFINE_GUID(GUID_PROCESSOR_IDLE_TIME_CHECK, 0xc4581c31, 0x89ab, 0x4597, 0x8e, 0x2b, 0x9c, 0x9c, 0xab, 0x44, 0xe, 0x6b);
416 DEFINE_GUID(GUID_PROCESSOR_IDLE_DEMOTE_THRESHOLD, 0x4b92d758, 0x5a24, 0x4851, 0xa4, 0x70, 0x81, 0x5d, 0x78, 0xae, 0xe1, 0x19);
417 DEFINE_GUID(GUID_PROCESSOR_IDLE_PROMOTE_THRESHOLD, 0x7b224883, 0xb3cc, 0x4d79, 0x81, 0x9f, 0x83, 0x74, 0x15, 0x2c, 0xbe, 0x7c);
418 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_INCREASE_THRESHOLD, 0xdf142941, 0x20f3, 0x4edf, 0x9a, 0x4a, 0x9c, 0x83, 0xd3, 0xd7, 0x17, 0xd1);
419 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_DECREASE_THRESHOLD, 0x68dd2f27, 0xa4ce, 0x4e11, 0x84, 0x87, 0x37, 0x94, 0xe4, 0x13, 0x5d, 0xfa);
420 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_INCREASE_POLICY, 0xc7be0679, 0x2817, 0x4d69, 0x9d, 0x02, 0x51, 0x9a, 0x53, 0x7e, 0xd0, 0xc6);
421 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_DECREASE_POLICY, 0x71021b41, 0xc749, 0x4d21, 0xbe, 0x74, 0xa0, 0x0f, 0x33, 0x5d, 0x58, 0x2b);
422 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_MAX_CORES, 0xea062031, 0x0e34, 0x4ff1, 0x9b, 0x6d, 0xeb, 0x10, 0x59, 0x33, 0x40, 0x28);
423 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_MIN_CORES, 0x0cc5b647, 0xc1df, 0x4637, 0x89, 0x1a, 0xde, 0xc3, 0x5c, 0x31, 0x85, 0x83);
424 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_INCREASE_TIME, 0x2ddd5a84, 0x5a71, 0x437e, 0x91, 0x2a, 0xdb, 0x0b, 0x8c, 0x78, 0x87, 0x32);
425 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_DECREASE_TIME, 0xdfd10d17, 0xd5eb, 0x45dd, 0x87, 0x7a, 0x9a, 0x34, 0xdd, 0xd1, 0x5c, 0x82);
426 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_AFFINITY_HISTORY_DECREASE_FACTOR, 0x8f7b45e3, 0xc393, 0x480a, 0x87, 0x8c, 0xf6, 0x7a, 0xc3, 0xd0, 0x70, 0x82);
427 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_AFFINITY_HISTORY_THRESHOLD, 0x5b33697b, 0xe89d, 0x4d38, 0xaa, 0x46, 0x9e, 0x7d, 0xfb, 0x7c, 0xd2, 0xf9);
428 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_AFFINITY_WEIGHTING, 0xe70867f1, 0xfa2f, 0x4f4e, 0xae, 0xa1, 0x4d, 0x8a, 0x0b, 0xa2, 0x3b, 0x20);
429 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_HISTORY_DECREASE_FACTOR, 0x1299023c, 0xbc28, 0x4f0a, 0x81, 0xec, 0xd3, 0x29, 0x5a, 0x8d, 0x81, 0x5d);
430 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_HISTORY_THRESHOLD, 0x9ac18e92, 0xaa3c, 0x4e27, 0xb3, 0x07, 0x01, 0xae, 0x37, 0x30, 0x71, 0x29);
431 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_WEIGHTING, 0x8809c2d8, 0xb155, 0x42d4, 0xbc, 0xda, 0x0d, 0x34, 0x56, 0x51, 0xb1, 0xdb);
432 DEFINE_GUID(GUID_PROCESSOR_CORE_PARKING_OVER_UTILIZATION_THRESHOLD, 0x943c8cb6, 0x6f93, 0x4227, 0xad, 0x87, 0xe9, 0xa3, 0xfe, 0xec, 0x08, 0xd1);
433 DEFINE_GUID(GUID_PROCESSOR_PARKING_CORE_OVERRIDE, 0xa55612aa, 0xf624, 0x42c6, 0xa4, 0x43, 0x73, 0x97, 0xd0, 0x64, 0xc0, 0x4f);
434 DEFINE_GUID(GUID_PROCESSOR_PARKING_PERF_STATE, 0x447235c7, 0x6a8d, 0x4cc0, 0x8e, 0x24, 0x9e, 0xaf, 0x70, 0xb9, 0x6e, 0x2b);
435 DEFINE_GUID(GUID_PROCESSOR_PERF_HISTORY, 0x7d24baa7, 0x0b84, 0x480f, 0x84, 0x0c, 0x1b, 0x07, 0x43, 0xc0, 0x0f, 0x5f);
436 DEFINE_GUID(GUID_SYSTEM_COOLING_POLICY, 0x94D3A615, 0xA899, 0x4AC5, 0xAE, 0x2B, 0xE4, 0xD8, 0xF6, 0x34, 0x36, 0x7F);
437 DEFINE_GUID(GUID_LOCK_CONSOLE_ON_WAKE, 0x0E796BDB, 0x100D, 0x47D6, 0xA2, 0xD5, 0xF7, 0xD2, 0xDA, 0xA5, 0x1F, 0x51);
438 DEFINE_GUID(GUID_DEVICE_IDLE_POLICY, 0x4faab71a, 0x92e5, 0x4726, 0xb5, 0x31, 0x22, 0x45, 0x59, 0x67, 0x2d, 0x19);
439 DEFINE_GUID(GUID_ACDC_POWER_SOURCE, 0x5D3E9A59, 0xE9D5, 0x4B00, 0xA6, 0xBD, 0xFF, 0x34, 0xFF, 0x51, 0x65, 0x48);
440 DEFINE_GUID(GUID_LIDSWITCH_STATE_CHANGE,  0xBA3E0F4D, 0xB817, 0x4094, 0xA2, 0xD1, 0xD5, 0x63, 0x79, 0xE6, 0xA0, 0xF3);
441 DEFINE_GUID(GUID_BATTERY_PERCENTAGE_REMAINING, 0xA7AD8041, 0xB45A, 0x4CAE, 0x87, 0xA3, 0xEE, 0xCB, 0xB4, 0x68, 0xA9, 0xE1);
442 DEFINE_GUID(GUID_IDLE_BACKGROUND_TASK, 0x515C31D8, 0xF734, 0x163D, 0xA0, 0xFD, 0x11, 0xA0, 0x8C, 0x91, 0xE8, 0xF1);
443 DEFINE_GUID(GUID_BACKGROUND_TASK_NOTIFICATION, 0xCF23F240, 0x2A54, 0x48D8, 0xB1, 0x14, 0xDE, 0x15, 0x18, 0xFF, 0x05, 0x2E);
444 DEFINE_GUID(GUID_APPLAUNCH_BUTTON, 0x1A689231, 0x7399, 0x4E9A, 0x8F, 0x99, 0xB7, 0x1F, 0x99, 0x9D, 0xB3, 0xFA);
445 DEFINE_GUID(GUID_PCIEXPRESS_SETTINGS_SUBGROUP, 0x501a4d13, 0x42af,0x4429, 0x9f, 0xd1, 0xa8, 0x21, 0x8c, 0x26, 0x8e, 0x20);
446 DEFINE_GUID(GUID_PCIEXPRESS_ASPM_POLICY, 0xee12f906, 0xd277, 0x404b, 0xb6, 0xda, 0xe5, 0xfa, 0x1a, 0x57, 0x6d, 0xf5);
447 DEFINE_GUID(GUID_ENABLE_SWITCH_FORCED_SHUTDOWN, 0x833a6b62, 0xdfa4, 0x46d1, 0x82, 0xf8, 0xe0, 0x9e, 0x34, 0xd0, 0x29, 0xd6);
448 
449 #define PERFSTATE_POLICY_CHANGE_IDEAL            0
450 #define PERFSTATE_POLICY_CHANGE_SINGLE           1
451 #define PERFSTATE_POLICY_CHANGE_ROCKET           2
452 #define PERFSTATE_POLICY_CHANGE_MAX              PERFSTATE_POLICY_CHANGE_ROCKET
453 
454 #define PROCESSOR_PERF_BOOST_POLICY_DISABLED     0
455 #define PROCESSOR_PERF_BOOST_POLICY_MAX          100
456 
457 #define POWER_DEVICE_IDLE_POLICY_PERFORMANCE     0
458 #define POWER_DEVICE_IDLE_POLICY_CONSERVATIVE    1
459 
460 _Function_class_(REQUEST_POWER_COMPLETE)
461 _IRQL_requires_same_
462 typedef VOID
463 (NTAPI REQUEST_POWER_COMPLETE)(
464   _In_ struct _DEVICE_OBJECT *DeviceObject,
465   _In_ UCHAR MinorFunction,
466   _In_ POWER_STATE PowerState,
467   _In_opt_ PVOID Context,
468   _In_ struct _IO_STATUS_BLOCK *IoStatus);
469 typedef REQUEST_POWER_COMPLETE *PREQUEST_POWER_COMPLETE;
470 
471 _Function_class_(POWER_SETTING_CALLBACK)
472 _IRQL_requires_same_
473 typedef NTSTATUS
474 (NTAPI POWER_SETTING_CALLBACK)(
475   _In_ LPCGUID SettingGuid,
476   _In_reads_bytes_(ValueLength) PVOID Value,
477   _In_ ULONG ValueLength,
478   _Inout_opt_ PVOID Context);
479 typedef POWER_SETTING_CALLBACK *PPOWER_SETTING_CALLBACK;
480 
481 #if (NTDDI_VERSION >= NTDDI_WIN8)
482 
483 #define PO_FX_VERSION_V1 0x00000001
484 #define PO_FX_VERSION_V2 0x00000002
485 #define PO_FX_VERSION_V3 0x00000003
486 #define PO_FX_VERSION PO_FX_VERSION_V1
487 
488 DECLARE_HANDLE(POHANDLE);
489 
490 typedef
491 _Function_class_(PO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK)
492 _IRQL_requires_max_(DISPATCH_LEVEL)
493 VOID
494 PO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK(
495   _In_ PVOID Context,
496   _In_ ULONG Component);
497 
498 typedef PO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK *PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK;
499 
500 typedef
501 _Function_class_(PO_FX_COMPONENT_IDLE_CONDITION_CALLBACK)
502 _IRQL_requires_max_(DISPATCH_LEVEL)
503 VOID
504 PO_FX_COMPONENT_IDLE_CONDITION_CALLBACK(
505   _In_ PVOID Context,
506   _In_ ULONG Component);
507 
508 typedef PO_FX_COMPONENT_IDLE_CONDITION_CALLBACK *PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK;
509 
510 typedef
511 _Function_class_(PO_FX_COMPONENT_IDLE_STATE_CALLBACK)
512 _IRQL_requires_max_(DISPATCH_LEVEL)
513 VOID
514 PO_FX_COMPONENT_IDLE_STATE_CALLBACK(
515   _In_ PVOID Context,
516   _In_ ULONG Component,
517   _In_ ULONG State);
518 
519 typedef PO_FX_COMPONENT_IDLE_STATE_CALLBACK *PPO_FX_COMPONENT_IDLE_STATE_CALLBACK;
520 
521 typedef
522 _Function_class_(PO_FX_DEVICE_POWER_REQUIRED_CALLBACK)
523 _IRQL_requires_max_(DISPATCH_LEVEL)
524 VOID
525 PO_FX_DEVICE_POWER_REQUIRED_CALLBACK(
526   _In_ PVOID Context);
527 
528 typedef PO_FX_DEVICE_POWER_REQUIRED_CALLBACK *PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK;
529 
530 typedef
531 _Function_class_(PO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK)
532 _IRQL_requires_max_(DISPATCH_LEVEL)
533 VOID
534 PO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK(
535   _In_ PVOID Context);
536 
537 typedef PO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK *PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK;
538 
539 typedef
540 _Function_class_(PO_FX_POWER_CONTROL_CALLBACK)
541 _IRQL_requires_max_(DISPATCH_LEVEL)
542 NTSTATUS
543 PO_FX_POWER_CONTROL_CALLBACK(
544   _In_ PVOID DeviceContext,
545   _In_ LPCGUID PowerControlCode,
546   _In_reads_bytes_opt_(InBufferSize) PVOID InBuffer,
547   _In_ SIZE_T InBufferSize,
548   _Out_writes_bytes_opt_(OutBufferSize) PVOID OutBuffer,
549   _In_ SIZE_T OutBufferSize,
550   _Out_opt_ PSIZE_T BytesReturned);
551 
552 typedef PO_FX_POWER_CONTROL_CALLBACK *PPO_FX_POWER_CONTROL_CALLBACK;
553 
554 typedef
555 _Function_class_(PO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK)
556 _IRQL_requires_max_(HIGH_LEVEL)
557 VOID
558 PO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK(
559   _In_ PVOID Context,
560   _In_ ULONG Component,
561   _In_ BOOLEAN Active);
562 
563 typedef PO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK *PPO_FX_COMPONENT_CRITICAL_TRANSITION_CALLBACK;
564 
565 typedef struct _PO_FX_COMPONENT_IDLE_STATE
566 {
567   ULONGLONG TransitionLatency;
568   ULONGLONG ResidencyRequirement;
569   ULONG NominalPower;
570 } PO_FX_COMPONENT_IDLE_STATE, *PPO_FX_COMPONENT_IDLE_STATE;
571 
572 typedef struct _PO_FX_COMPONENT_V1
573 {
574   GUID Id;
575   ULONG IdleStateCount;
576   ULONG DeepestWakeableIdleState;
577   _Field_size_full_(IdleStateCount) PPO_FX_COMPONENT_IDLE_STATE IdleStates;
578 } PO_FX_COMPONENT_V1, *PPO_FX_COMPONENT_V1;
579 
580 typedef struct _PO_FX_DEVICE_V1
581 {
582   ULONG Version;
583   ULONG ComponentCount;
584   PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK ComponentActiveConditionCallback;
585   PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK ComponentIdleConditionCallback;
586   PPO_FX_COMPONENT_IDLE_STATE_CALLBACK ComponentIdleStateCallback;
587   PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK DevicePowerRequiredCallback;
588   PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK DevicePowerNotRequiredCallback;
589   PPO_FX_POWER_CONTROL_CALLBACK PowerControlCallback;
590   PVOID DeviceContext;
591   _Field_size_full_(ComponentCount) PO_FX_COMPONENT_V1 Components[ANYSIZE_ARRAY];
592 } PO_FX_DEVICE_V1, *PPO_FX_DEVICE_V1;
593 
594 #define PO_FX_COMPONENT_FLAG_F0_ON_DX 0x0000000000000001
595 #define PO_FX_COMPONENT_FLAG_NO_DEBOUNCE 0x0000000000000002
596 
597 typedef struct _PO_FX_COMPONENT_V2
598 {
599   GUID Id;
600   ULONGLONG Flags;
601   ULONG DeepestWakeableIdleState;
602   ULONG IdleStateCount;
603   _Field_size_full_(IdleStateCount) PPO_FX_COMPONENT_IDLE_STATE IdleStates;
604   ULONG ProviderCount;
605   _Field_size_full_(ProviderCount) PULONG Providers;
606 } PO_FX_COMPONENT_V2, *PPO_FX_COMPONENT_V2;
607 
608 typedef struct _PO_FX_DEVICE_V2
609 {
610   ULONG Version;
611   ULONGLONG Flags;
612   PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK ComponentActiveConditionCallback;
613   PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK ComponentIdleConditionCallback;
614   PPO_FX_COMPONENT_IDLE_STATE_CALLBACK ComponentIdleStateCallback;
615   PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK DevicePowerRequiredCallback;
616   PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK DevicePowerNotRequiredCallback;
617   PPO_FX_POWER_CONTROL_CALLBACK PowerControlCallback;
618   PVOID DeviceContext;
619   ULONG ComponentCount;
620   _Field_size_full_(ComponentCount) PO_FX_COMPONENT_V2 Components[ANYSIZE_ARRAY];
621 } PO_FX_DEVICE_V2, *PPO_FX_DEVICE_V2;
622 
623 #define PO_FX_DEVICE_FLAG_RESERVED_1                   (0x0000000000000001ull)
624 #define PO_FX_DEVICE_FLAG_DFX_DIRECT_CHILDREN_OPTIONAL (0x0000000000000002ull)
625 #define PO_FX_DEVICE_FLAG_DFX_POWER_CHILDREN_OPTIONAL  (0x0000000000000004ull)
626 #define PO_FX_DEVICE_FLAG_DFX_CHILDREN_OPTIONAL \
627             (PO_FX_DEVICE_FLAG_DFX_DIRECT_CHILDREN_OPTIONAL | \
628              PO_FX_DEVICE_FLAG_DFX_POWER_CHILDREN_OPTIONAL)
629 
630 #define PO_FX_DIRECTED_FX_DEFAULT_IDLE_TIMEOUT    (0ul)
631 #define PO_FX_DIRECTED_FX_IMMEDIATE_IDLE_TIMEOUT  ((ULONG)-1)
632 #define PO_FX_DIRECTED_FX_MAX_IDLE_TIMEOUT        (10ul * 60)
633 
634 typedef
635 _Function_class_(PO_FX_DIRECTED_POWER_UP_CALLBACK)
636 _IRQL_requires_max_(DISPATCH_LEVEL)
637 _IRQL_requires_same_
638 VOID
639 PO_FX_DIRECTED_POWER_UP_CALLBACK(
640   _In_ PVOID Context,
641   _In_ ULONG Flags);
642 
643 typedef PO_FX_DIRECTED_POWER_UP_CALLBACK *PPO_FX_DIRECTED_POWER_UP_CALLBACK;
644 
645 typedef
646 _Function_class_(PO_FX_DIRECTED_POWER_DOWN_CALLBACK)
647 _IRQL_requires_max_(DISPATCH_LEVEL)
648 _IRQL_requires_same_
649 VOID
650 PO_FX_DIRECTED_POWER_DOWN_CALLBACK(
651   _In_ PVOID Context,
652   _In_ ULONG Flags);
653 
654 typedef PO_FX_DIRECTED_POWER_DOWN_CALLBACK *PPO_FX_DIRECTED_POWER_DOWN_CALLBACK;
655 
656 typedef struct _PO_FX_DEVICE_V3
657 {
658   ULONG Version;
659   ULONGLONG Flags;
660   PPO_FX_COMPONENT_ACTIVE_CONDITION_CALLBACK ComponentActiveConditionCallback;
661   PPO_FX_COMPONENT_IDLE_CONDITION_CALLBACK ComponentIdleConditionCallback;
662   PPO_FX_COMPONENT_IDLE_STATE_CALLBACK ComponentIdleStateCallback;
663   PPO_FX_DEVICE_POWER_REQUIRED_CALLBACK DevicePowerRequiredCallback;
664   PPO_FX_DEVICE_POWER_NOT_REQUIRED_CALLBACK DevicePowerNotRequiredCallback;
665   PPO_FX_POWER_CONTROL_CALLBACK PowerControlCallback;
666   PPO_FX_DIRECTED_POWER_UP_CALLBACK DirectedPowerUpCallback;
667   PPO_FX_DIRECTED_POWER_DOWN_CALLBACK DirectedPowerDownCallback;
668   ULONG DirectedFxTimeoutInSeconds;
669   PVOID DeviceContext;
670   ULONG ComponentCount;
671   _Field_size_full_(ComponentCount) PO_FX_COMPONENT_V2 Components[ANYSIZE_ARRAY];
672 } PO_FX_DEVICE_V3, *PPO_FX_DEVICE_V3;
673 
674 #if (PO_FX_VERSION == PO_FX_VERSION_V1)
675 typedef PO_FX_COMPONENT_V1 PO_FX_COMPONENT, *PPO_FX_COMPONENT;
676 typedef PO_FX_DEVICE_V1 PO_FX_DEVICE, *PPO_FX_DEVICE;
677 #elif (PO_FX_VERSION == PO_FX_VERSION_V2)
678 typedef PO_FX_COMPONENT_V2 PO_FX_COMPONENT, *PPO_FX_COMPONENT;
679 typedef PO_FX_DEVICE_V2 PO_FX_DEVICE, *PPO_FX_DEVICE;
680 #elif (PO_FX_VERSION == PO_FX_VERSION_V3)
681 typedef PO_FX_COMPONENT_V2 PO_FX_COMPONENT, *PPO_FX_COMPONENT;
682 typedef PO_FX_DEVICE_V3 PO_FX_DEVICE, *PPO_FX_DEVICE;
683 #else
684 #error PO_FX_VERSION undefined!
685 #endif
686 
687 #endif // NTDDI_WIN8
688 
689 $endif (_WDMDDK_)
690 $if (_NTIFS_)
691 
692 #define PO_CB_SYSTEM_POWER_POLICY       0
693 #define PO_CB_AC_STATUS                 1
694 #define PO_CB_BUTTON_COLLISION          2
695 #define PO_CB_SYSTEM_STATE_LOCK         3
696 #define PO_CB_LID_SWITCH_STATE          4
697 #define PO_CB_PROCESSOR_POWER_POLICY    5
698 $endif (_NTIFS_)
699