#pragma option push -b -a8 -pc -A- -w-pun /*P_O_Push*/ /*++ BUILD Version: 0001 // Increment this if a change has global effects Copyright (c) Microsoft Corporation. All rights reserved. Module Name: batclass.h Abstract: Defines battery class driver interfaces. --*/ #include // // Battery device GUID // DEFINE_GUID (BATTERY_STATUS_WMI_GUID, 0xfc4670d1, 0xebbf, 0x416e, 0x87, 0xce, 0x37, 0x4a, 0x4e, 0xbc, 0x11, 0x1a); DEFINE_GUID (BATTERY_RUNTIME_WMI_GUID, 0x535a3767, 0x1ac2, 0x49bc, 0xa0, 0x77, 0x3f, 0x7a, 0x02, 0xe4, 0x0a, 0xec); DEFINE_GUID (BATTERY_TEMPERATURE_WMI_GUID, 0x1a52a14d, 0xadce, 0x4a44, 0x9a, 0x3e, 0xc8, 0xd8, 0xf1, 0x5f, 0xf2, 0xc2); DEFINE_GUID (BATTERY_FULL_CHARGED_CAPACITY_WMI_GUID, 0x40b40565, 0x96f7, 0x4435, 0x86, 0x94, 0x97, 0xe0, 0xe4, 0x39, 0x59, 0x05); DEFINE_GUID (BATTERY_CYCLE_COUNT_WMI_GUID, 0xef98db24, 0x0014, 0x4c25, 0xa5, 0x0b, 0xc7, 0x24, 0xae, 0x5c, 0xd3, 0x71); DEFINE_GUID (BATTERY_STATIC_DATA_WMI_GUID, 0x05e1e463, 0xe4e2, 0x4ea9, 0x80, 0xcb, 0x9b, 0xd4, 0xb3, 0xca, 0x06, 0x55); DEFINE_GUID (BATTERY_STATUS_CHANGE_WMI_GUID, 0xcddfa0c3, 0x7c5b, 0x4e43, 0xa0, 0x34, 0x05, 0x9f, 0xa5, 0xb8, 0x43, 0x64); DEFINE_GUID (BATTERY_TAG_CHANGE_WMI_GUID, 0x5e1f6e19, 0x8786, 0x4d23, 0x94, 0xfc, 0x9e, 0x74, 0x6b, 0xd5, 0xd8, 0x88); #ifndef _BATCLASS_ #define _BATCLASS_ #include #pragma region Desktop Family #if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) #if (NTDDI_VERSION < NTDDI_WINXP) // // Format of data returned when // BATTERY_INFORMATION_LEVEL = BatteryGranularityInformation // is an array of BATTERY_REPORTING_SCALE // #ifndef _NTPOAPI_ typedef struct { ULONG Granularity; ULONG Capacity; } BATTERY_REPORTING_SCALE, *PBATTERY_REPORTING_SCALE; #endif // _NTPOAPI_ #endif // (NTDDI_VERSION < NTDDI_WINXP) #ifndef _WINDOWS_ // // Battery Class-Miniport device driver interfaces // _Function_class_(BCLASS_QUERY_TAG_CALLBACK) _IRQL_requires_same_ _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ typedef NTSTATUS (BCLASS_QUERY_TAG_CALLBACK)( _In_ PVOID Context, _Out_ PULONG BatteryTag ); typedef BCLASS_QUERY_TAG_CALLBACK *PBCLASS_QUERY_TAG_CALLBACK; _Function_class_(BCLASS_QUERY_INFORMATION_CALLBACK) _IRQL_requires_same_ _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ typedef NTSTATUS (BCLASS_QUERY_INFORMATION_CALLBACK)( _In_ PVOID Context, _In_ ULONG BatteryTag, _In_ BATTERY_QUERY_INFORMATION_LEVEL Level, _In_ LONG AtRate, _Out_writes_bytes_to_(BufferLength, *ReturnedLength) PVOID Buffer, _In_ ULONG BufferLength, _Out_ PULONG ReturnedLength ); typedef BCLASS_QUERY_INFORMATION_CALLBACK *PBCLASS_QUERY_INFORMATION_CALLBACK; _Function_class_(BCLASS_QUERY_STATUS_CALLBACK) _IRQL_requires_same_ _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ typedef NTSTATUS (BCLASS_QUERY_STATUS_CALLBACK)( _In_ PVOID Context, _In_ ULONG BatteryTag, _Out_ PBATTERY_STATUS BatteryStatus ); typedef BCLASS_QUERY_STATUS_CALLBACK *PBCLASS_QUERY_STATUS_CALLBACK; typedef struct { ULONG PowerState; ULONG LowCapacity; ULONG HighCapacity; } BATTERY_NOTIFY, *PBATTERY_NOTIFY; _Function_class_(BCLASS_SET_STATUS_NOTIFY_CALLBACK) _IRQL_requires_same_ _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ typedef NTSTATUS (BCLASS_SET_STATUS_NOTIFY_CALLBACK)( _In_ PVOID Context, _In_ ULONG BatteryTag, _In_ PBATTERY_NOTIFY BatteryNotify ); typedef BCLASS_SET_STATUS_NOTIFY_CALLBACK *PBCLASS_SET_STATUS_NOTIFY_CALLBACK; _Function_class_(BCLASS_SET_INFORMATION_CALLBACK) _IRQL_requires_same_ _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ typedef NTSTATUS (BCLASS_SET_INFORMATION_CALLBACK)( _In_ PVOID Context, _In_ ULONG BatteryTag, _In_ BATTERY_SET_INFORMATION_LEVEL Level, _In_opt_ PVOID Buffer ); typedef BCLASS_SET_INFORMATION_CALLBACK *PBCLASS_SET_INFORMATION_CALLBACK; _Function_class_(BCLASS_DISABLE_STATUS_NOTIFY_CALLBACK) _IRQL_requires_same_ _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ typedef NTSTATUS (BCLASS_DISABLE_STATUS_NOTIFY_CALLBACK)( _In_ PVOID Context ); typedef BCLASS_DISABLE_STATUS_NOTIFY_CALLBACK *PBCLASS_DISABLE_STATUS_NOTIFY_CALLBACK; typedef PBCLASS_QUERY_TAG_CALLBACK BCLASS_QUERY_TAG; typedef PBCLASS_QUERY_INFORMATION_CALLBACK BCLASS_QUERY_INFORMATION; typedef PBCLASS_QUERY_STATUS_CALLBACK BCLASS_QUERY_STATUS; typedef PBCLASS_SET_STATUS_NOTIFY_CALLBACK BCLASS_SET_STATUS_NOTIFY; typedef PBCLASS_SET_INFORMATION_CALLBACK BCLASS_SET_INFORMATION; typedef PBCLASS_DISABLE_STATUS_NOTIFY_CALLBACK BCLASS_DISABLE_STATUS_NOTIFY; typedef struct { USHORT MajorVersion; USHORT MinorVersion; PVOID Context; // Miniport context BCLASS_QUERY_TAG QueryTag; BCLASS_QUERY_INFORMATION QueryInformation; BCLASS_SET_INFORMATION SetInformation; BCLASS_QUERY_STATUS QueryStatus; BCLASS_SET_STATUS_NOTIFY SetStatusNotify; BCLASS_DISABLE_STATUS_NOTIFY DisableStatusNotify; PDEVICE_OBJECT Pdo; PUNICODE_STRING DeviceName; } BATTERY_MINIPORT_INFO, *PBATTERY_MINIPORT_INFO; typedef struct { USHORT MajorVersion; USHORT MinorVersion; PVOID Context; // Miniport context BCLASS_QUERY_TAG QueryTag; BCLASS_QUERY_INFORMATION QueryInformation; BCLASS_SET_INFORMATION SetInformation; BCLASS_QUERY_STATUS QueryStatus; BCLASS_SET_STATUS_NOTIFY SetStatusNotify; BCLASS_DISABLE_STATUS_NOTIFY DisableStatusNotify; PDEVICE_OBJECT Pdo; PUNICODE_STRING DeviceName; PDEVICE_OBJECT Fdo; } BATTERY_MINIPORT_INFO_V1_1, *PBATTERY_MINIPORT_INFO_V1_1; #define BATTERY_CLASS_MAJOR_VERSION 0x0001 #define BATTERY_CLASS_MINOR_VERSION 0x0000 #define BATTERY_CLASS_MINOR_VERSION_1 0x0001 #if (NTDDI_VERSION >= NTDDI_WINXP) // // WMI data block structures // typedef struct _BATTERY_WMI_STATUS { ULONG Tag; ULONG RemainingCapacity; LONG ChargeRate; LONG DischargeRate; ULONG Voltage; BOOLEAN PowerOnline; BOOLEAN Charging; BOOLEAN Discharging; BOOLEAN Critical; } BATTERY_WMI_STATUS, *PBATTERY_WMI_STATUS; typedef struct _BATTERY_WMI_RUNTIME { ULONG Tag; ULONG EstimatedRuntime; } BATTERY_WMI_RUNTIME, *PBATTERY_WMI_RUNTIME; typedef struct _BATTERY_WMI_TEMPERATURE { ULONG Tag; ULONG Temperature; } BATTERY_WMI_TEMPERATURE, *PBATTERY_WMI_TEMPERATURE; typedef struct _BATTERY_WMI_FULL_CHARGED_CAPACITY { ULONG Tag; ULONG FullChargedCapacity; } BATTERY_WMI_FULL_CHARGED_CAPACITY, *PBATTERY_WMI_FULL_CHARGED_CAPACITY; typedef struct _BATTERY_WMI_CYCLE_COUNT { ULONG Tag; ULONG CycleCount; } BATTERY_WMI_CYCLE_COUNT, *PBATTERY_WMI_CYCLE_COUNT; typedef struct _BATTERY_WMI_STATIC_DATA { ULONG Tag; WCHAR ManufactureDate[25]; BATTERY_REPORTING_SCALE Granularity [4]; ULONG Capabilities; UCHAR Technology; ULONG Chemistry; ULONG DesignedCapacity; ULONG DefaultAlert1; ULONG DefaultAlert2; ULONG CriticalBias; WCHAR Strings[1]; // Four variable length string values are stored with the first USHORT // value containing the length of the string in bytes. // // Device Name // Manufacture Name // Serial Number // UniqueID // } BATTERY_WMI_STATIC_DATA, *PBATTERY_WMI_STATIC_DATA; typedef struct _BATTERY_WMI_STATUS_CHANGE { ULONG Tag; BOOLEAN PowerOnline; BOOLEAN Charging; BOOLEAN Discharging; BOOLEAN Critical; } BATTERY_WMI_STATUS_CHANGE, *PBATTERY_WMI_STATUS_CHANGE; typedef struct _BATTERY_TAG_CHANGE { ULONG Tag; } BATTERY_TAG_CHANGE, *PBATTERY_TAG_CHANGE; #endif // (NTDDI_VERSION >= NTDDI_WINXP) // // Battery class driver functions // #if !defined(BATTERYCLASS) #define BATTERYCLASSAPI DECLSPEC_IMPORT #else #define BATTERYCLASSAPI #endif _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ NTSTATUS BATTERYCLASSAPI BatteryClassInitializeDevice ( _In_ PBATTERY_MINIPORT_INFO MiniportInfo, _Out_ PVOID *ClassData ); _IRQL_requires_max_(PASSIVE_LEVEL) NTSTATUS BATTERYCLASSAPI BatteryClassUnload ( _In_ PVOID ClassData ); _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ NTSTATUS BATTERYCLASSAPI BatteryClassIoctl ( _In_ PVOID ClassData, _Inout_ PIRP Irp ); #if (NTDDI_VERSION >= NTDDI_WINXP) _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ NTSTATUS BATTERYCLASSAPI BatteryClassSystemControl ( _In_ PVOID ClassData, _In_ PVOID WmiLibContext, //PWMILIB_CONTEXT _In_ PDEVICE_OBJECT DeviceObject, _Inout_ PIRP Irp, _Out_ PVOID Disposition //PSYSCTL_IRP_DISPOSITION ); _IRQL_requires_max_(PASSIVE_LEVEL) _Check_return_ NTSTATUS BATTERYCLASSAPI BatteryClassQueryWmiDataBlock( _In_ PVOID ClassData, _Inout_ PDEVICE_OBJECT DeviceObject, _Inout_ PIRP Irp, _In_ ULONG GuidIndex, _Out_writes_(1) PULONG InstanceLengthArray, _In_ ULONG OutBufferSize, _Out_writes_bytes_opt_(OutBufferSize) PUCHAR Buffer ); #endif // (NTDDI_VERSION >= NTDDI_WINXP) _IRQL_requires_max_(DISPATCH_LEVEL) NTSTATUS BATTERYCLASSAPI BatteryClassStatusNotify ( _In_ PVOID ClassData ); #endif // _WINDOWS_ #endif /* WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) */ #pragma endregion #endif // _BATCLASS_ #pragma option pop /*P_O_Pop*/