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