17#define IOCTL_BATTERY_QUERY_UNIQUE_ID \
18 CTL_CODE(FILE_DEVICE_BATTERY, 0x101, METHOD_BUFFERED, FILE_READ_ACCESS)
20#define IOCTL_BATTERY_QUERY_STA \
21 CTL_CODE(FILE_DEVICE_BATTERY, 0x102, METHOD_BUFFERED, FILE_READ_ACCESS)
23#define IOCTL_BATTERY_QUERY_PSR \
24 CTL_CODE(FILE_DEVICE_BATTERY, 0x103, METHOD_BUFFERED, FILE_READ_ACCESS)
26#define IOCTL_BATTERY_SET_TRIP_POINT \
27 CTL_CODE(FILE_DEVICE_BATTERY, 0x104, METHOD_BUFFERED, FILE_READ_ACCESS)
29#define IOCTL_BATTERY_QUERY_BIF_BIX \
30 CTL_CODE(FILE_DEVICE_BATTERY, 0x105, METHOD_BUFFERED, FILE_READ_ACCESS)
32#define IOCTL_BATTERY_QUERY_BST \
33 CTL_CODE(FILE_DEVICE_BATTERY, 0x106, METHOD_BUFFERED, FILE_READ_ACCESS)
35#define CMBATT_GENERIC_STATUS 0x01
36#define CMBATT_GENERIC_INFO 0x02
37#define CMBATT_GENERIC_WARNING 0x04
38#define CMBATT_ACPI_WARNING 0x08
39#define CMBATT_POWER_INFO 0x10
40#define CMBATT_PNP_INFO 0x20
41#define CMBATT_ACPI_ENTRY_EXIT 0x40
42#define CMBATT_PNP_ENTRY_EXIT 0x200
43#define CMBATT_ACPI_ASSERT 0x400
49#define CMBATT_DISCHARGE_TIME 150000000
55#define CMBATT_CAPACITY_BOGUS 0x100000
63#define ACPI_BUS_CHECK 0x00
64#define ACPI_DEVICE_CHECK 0x01
66#define ACPI_STA_PRESENT 0x01
67#define ACPI_STA_ENABLED 0x02
68#define ACPI_STA_SHOW_UI 0x04
69#define ACPI_STA_FUNCTIONAL 0x08
70#define ACPI_STA_BATTERY_PRESENT 0x10
72#define ACPI_BATT_NOTIFY_STATUS 0x80
73#define ACPI_BATT_NOTIFY_INFO 0x81
75#define ACPI_BATT_STAT_DISCHARG 0x0001
76#define ACPI_BATT_STAT_CHARGING 0x0002
77#define ACPI_BATT_STAT_CRITICAL 0x0004
79#define CM_MAX_VALUE 0x7FFFFFFF
80#define CM_UNKNOWN_VALUE 0xFFFFFFFF
82#define CONVERT_MAH_TO_MWH(mA, Volts) (((mA) * (Volts) + 500) / 1000)
84#define CONVERT_BATT_INFO(Capacity, DesignVoltage) \
85 (((Capacity) != BATTERY_UNKNOWN_CAPACITY) \
86 ? CONVERT_MAH_TO_MWH((Capacity), (DesignVoltage)) \
87 : BATTERY_UNKNOWN_CAPACITY)
97#define ACPI_BATT_POWER_UNIT_WATTS 0x0
98#define ACPI_BATT_POWER_UNIT_AMPS 0x1
100#define ASCIIZ_MAX_LENGTH 256
151#define CMBATT_BATT_STATIC_INFO_TAG 'nItS'
153#define CMBATT_AR_NOTIFY 0x01
154#define CMBATT_AR_INSERT 0x02
155#define CMBATT_AR_REMOVE 0x04
_In_ ULONG _In_ BATTERY_QUERY_INFORMATION_LEVEL _In_ LONG _In_ ULONG _Out_ PULONG ReturnedLength
_In_ ULONG _In_ PBATTERY_NOTIFY BatteryNotify
_In_ ULONG _Out_ PBATTERY_STATUS BatteryStatus
_In_ ULONG _In_ BATTERY_QUERY_INFORMATION_LEVEL _In_ LONG AtRate
enum _BATTERY_QUERY_INFORMATION_LEVEL BATTERY_QUERY_INFORMATION_LEVEL
NTSTATUS NTAPI CmBattSetTripPpoint(PCMBATT_DEVICE_EXTENSION DeviceExtension, ULONG AlarmValue)
PDEVICE_OBJECT AcAdapterPdo
struct _ACPI_BST_DATA * PACPI_BST_DATA
NTSTATUS NTAPI CmBattGetStaData(PDEVICE_OBJECT DeviceObject, PULONG StaData)
NTSTATUS NTAPI CmBattGetPsrData(PDEVICE_OBJECT DeviceObject, PULONG PsrData)
struct _ACPI_BATT_STATIC_INFO * PACPI_BATT_STATIC_INFO
struct _ACPI_BATT_STATIC_INFO ACPI_BATT_STATIC_INFO
struct _ACPI_BIF_DATA ACPI_BIF_DATA
NTSTATUS NTAPI CmBattGetUniqueId(PDEVICE_OBJECT DeviceObject, PULONG UniqueId)
NTSTATUS NTAPI CmBattPowerDispatch(PDEVICE_OBJECT DeviceObject, PIRP Irp)
struct _ACPI_BIF_DATA * PACPI_BIF_DATA
NTSTATUS NTAPI CmBattGetBifData(PCMBATT_DEVICE_EXTENSION DeviceExtension, PACPI_BIF_DATA BifData)
NTSTATUS NTAPI CmBattGetBstData(PCMBATT_DEVICE_EXTENSION DeviceExtension, PACPI_BST_DATA BstData)
struct _CMBATT_DEVICE_EXTENSION * PCMBATT_DEVICE_EXTENSION
NTSTATUS NTAPI CmBattDisableStatusNotify(IN PCMBATT_DEVICE_EXTENSION DeviceExtension)
NTSTATUS NTAPI CmBattQueryStatus(IN PCMBATT_DEVICE_EXTENSION DeviceExtension, IN ULONG Tag, IN PBATTERY_STATUS BatteryStatus)
NTSTATUS NTAPI CmBattPnpDispatch(PDEVICE_OBJECT DeviceObject, PIRP Irp)
NTSTATUS NTAPI CmBattQueryInformation(IN PCMBATT_DEVICE_EXTENSION FdoExtension, IN ULONG Tag, IN BATTERY_QUERY_INFORMATION_LEVEL InfoLevel, IN OPTIONAL LONG AtRate, IN PVOID Buffer, IN ULONG BufferLength, OUT PULONG ReturnedLength)
struct _ACPI_BST_DATA ACPI_BST_DATA
NTSTATUS NTAPI CmBattGetBixData(_In_ PCMBATT_DEVICE_EXTENSION DeviceExtension, _Out_ PACPI_BIX_DATA BixData)
Retrieves the eXtended static battery information from the ACPI _BIX method.
VOID NTAPI CmBattNotifyHandler(IN PCMBATT_DEVICE_EXTENSION DeviceExtension, IN ULONG NotifyValue)
struct _ACPI_BIX_DATA ACPI_BIX_DATA
NTSTATUS NTAPI CmBattAddDevice(PDRIVER_OBJECT DriverObject, PDEVICE_OBJECT DeviceObject)
#define ASCIIZ_MAX_LENGTH
NTSTATUS NTAPI CmBattSystemControl(PDEVICE_OBJECT DeviceObject, PIRP Irp)
NTSTATUS NTAPI CmBattWmiRegistration(PCMBATT_DEVICE_EXTENSION DeviceExtension)
NTSTATUS NTAPI CmBattQueryTag(IN PCMBATT_DEVICE_EXTENSION DeviceExtension, OUT PULONG Tag)
NTSTATUS NTAPI CmBattWmiDeRegistration(PCMBATT_DEVICE_EXTENSION DeviceExtension)
struct _ACPI_BIX_DATA * PACPI_BIX_DATA
NTSTATUS NTAPI CmBattSetStatusNotify(IN PCMBATT_DEVICE_EXTENSION DeviceExtension, IN ULONG BatteryTag, IN PBATTERY_NOTIFY BatteryNotify)
struct _CMBATT_DEVICE_EXTENSION CMBATT_DEVICE_EXTENSION
enum _CMBATT_EXTENSION_TYPE CMBATT_EXTENSION_TYPE
PULONG MinorVersion OPTIONAL
CHAR SerialNumber[ASCIIZ_MAX_LENGTH]
CHAR BatteryType[ASCIIZ_MAX_LENGTH]
ULONG BatteryCapacityGranularity1
CHAR OemInfo[ASCIIZ_MAX_LENGTH]
ULONG DesignCapacityWarning
ULONG BatteryCapacityGranularity2
CHAR ModelNumber[ASCIIZ_MAX_LENGTH]
ULONG BatteryCapacityGranularity2
CHAR BatteryType[ASCIIZ_MAX_LENGTH]
CHAR ModelNumber[ASCIIZ_MAX_LENGTH]
CHAR SerialNumber[ASCIIZ_MAX_LENGTH]
ULONG BatteryCapacityGranularity1
ULONG DesignCapacityWarning
CHAR OemInfo[ASCIIZ_MAX_LENGTH]
PUNICODE_STRING DeviceName
CMBATT_EXTENSION_TYPE FdoType
ACPI_BATT_STATIC_INFO BattInfo
PDEVICE_OBJECT PdoDeviceObject
WMILIB_CONTEXT WmiLibInfo
PDEVICE_OBJECT FdoDeviceObject
PDEVICE_OBJECT DeviceObject
BOOLEAN DelayNotification
PDEVICE_OBJECT AttachedDevice
IO_REMOVE_LOCK RemoveLock
ULONG BatteryCapacityGranularity1
ULONG BatteryCapacityGranularity2
BATTERY_INFORMATION BatteryInformation
ACPI_INTERFACE_STANDARD AcpiInterface
_In_ PDEVICE_OBJECT DeviceObject
_Must_inspect_result_ _In_ WDFDEVICE _In_ BOOLEAN _In_opt_ PVOID Tag
_Must_inspect_result_ _In_ WDFDEVICE _In_ DEVICE_REGISTRY_PROPERTY _In_ ULONG BufferLength
_Must_inspect_result_ _In_ PDRIVER_OBJECT DriverObject