2010-03-25 14:26:04 +00:00
|
|
|
/*
|
2024-12-14 20:36:09 +01:00
|
|
|
* PROJECT: ReactOS Composite Battery Driver
|
2024-12-14 22:59:38 +01:00
|
|
|
* LICENSE: MIT (https://spdx.org/licenses/MIT)
|
2024-12-14 20:36:09 +01:00
|
|
|
* PURPOSE: Composite battery main header file
|
2024-12-14 22:59:38 +01:00
|
|
|
* COPYRIGHT: Copyright 2010 ReactOS Portable Systems Group <ros.arm@reactos.org>
|
2024-12-14 20:36:09 +01:00
|
|
|
* Copyright 2024 George Bișoc <george.bisoc@reactos.org>
|
2010-03-25 14:26:04 +00:00
|
|
|
*/
|
|
|
|
|
2024-12-14 20:36:09 +01:00
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
|
2014-02-06 11:18:34 +00:00
|
|
|
#ifndef _COMPBATT_PCH_
|
|
|
|
#define _COMPBATT_PCH_
|
|
|
|
|
2014-01-27 23:11:48 +00:00
|
|
|
#include <wdm.h>
|
2010-03-25 14:26:04 +00:00
|
|
|
#include <batclass.h>
|
|
|
|
|
2024-12-14 20:36:09 +01:00
|
|
|
/* DEFINES ********************************************************************/
|
|
|
|
|
|
|
|
//
|
|
|
|
// I/O remove lock allocate tag
|
|
|
|
//
|
|
|
|
#define COMPBATT_TAG 'aBoC'
|
|
|
|
|
|
|
|
//
|
|
|
|
// Composite battery flags
|
|
|
|
//
|
2010-03-29 02:02:07 +00:00
|
|
|
#define COMPBATT_BATTERY_INFORMATION_PRESENT 0x04
|
2024-12-14 20:36:09 +01:00
|
|
|
#define COMPBATT_STATUS_NOTIFY_SET 0x10
|
2010-03-29 02:02:07 +00:00
|
|
|
#define COMPBATT_TAG_ASSIGNED 0x80
|
|
|
|
|
2024-12-14 20:36:09 +01:00
|
|
|
//
|
|
|
|
// IRP complete worker mode states
|
|
|
|
//
|
|
|
|
#define COMPBATT_QUERY_TAG 1
|
|
|
|
#define COMPBATT_READ_STATUS 2
|
|
|
|
|
|
|
|
//
|
|
|
|
// Low/High capacity wait constants
|
|
|
|
//
|
|
|
|
#define COMPBATT_WAIT_MIN_LOW_CAPACITY 0
|
|
|
|
#define COMPBATT_WAIT_MAX_HIGH_CAPACITY 0x7FFFFFFF
|
|
|
|
|
|
|
|
//
|
|
|
|
// One hour in seconds, used to calculate the total rate of each battery for time estimation
|
|
|
|
//
|
|
|
|
#define COMPBATT_ATRATE_HOUR_IN_SECS 3600
|
|
|
|
|
|
|
|
//
|
|
|
|
// Time constant of which the battery status data is considered fresh (50000000 * 100ns == 5s)
|
|
|
|
//
|
|
|
|
#define COMPBATT_FRESH_STATUS_TIME 50000000
|
|
|
|
|
|
|
|
//
|
|
|
|
// Macro that calculates the delta of a battery's capacity
|
|
|
|
//
|
|
|
|
#define COMPUTE_BATT_CAP_DELTA(LowDiff, Batt, TotalRate) \
|
|
|
|
((ULONG)(((LONGLONG)LowDiff * (Batt)->BatteryStatus.Rate) / TotalRate))
|
|
|
|
|
|
|
|
//
|
|
|
|
// Macro that calculates the "At Rate" time drain of the battery
|
|
|
|
//
|
|
|
|
#define COMPUTE_ATRATE_DRAIN(Batt, Time) \
|
|
|
|
((LONG)((Batt)->BatteryStatus.Capacity) * COMPBATT_ATRATE_HOUR_IN_SECS / Time)
|
|
|
|
|
|
|
|
//
|
|
|
|
// Composite battery debug levels
|
|
|
|
//
|
|
|
|
#define COMPBATT_DEBUG_INFO 0x1
|
|
|
|
#define COMPBATT_DEBUG_TRACE 0x2
|
|
|
|
#define COMPBATT_DEBUG_WARN 0x4
|
|
|
|
#define COMPBATT_DEBUG_ERR 0x10
|
|
|
|
#define COMPBATT_DEBUG_ALL_LEVELS (COMPBATT_DEBUG_INFO | COMPBATT_DEBUG_TRACE | COMPBATT_DEBUG_WARN | COMPBATT_DEBUG_ERR)
|
|
|
|
|
|
|
|
/* STRUCTURES *****************************************************************/
|
|
|
|
|
|
|
|
//
|
|
|
|
// Individual ACPI battery data
|
|
|
|
//
|
2010-03-29 00:02:05 +00:00
|
|
|
typedef struct _COMPBATT_BATTERY_DATA
|
2010-03-25 14:26:04 +00:00
|
|
|
{
|
|
|
|
LIST_ENTRY BatteryLink;
|
|
|
|
IO_REMOVE_LOCK RemoveLock;
|
|
|
|
PDEVICE_OBJECT DeviceObject;
|
|
|
|
PIRP Irp;
|
|
|
|
WORK_QUEUE_ITEM WorkItem;
|
2024-12-14 20:36:09 +01:00
|
|
|
UCHAR Mode;
|
2010-03-25 14:26:04 +00:00
|
|
|
BATTERY_WAIT_STATUS WaitStatus;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
BATTERY_WAIT_STATUS WorkerWaitStatus;
|
|
|
|
BATTERY_STATUS WorkerStatus;
|
2024-12-14 20:36:09 +01:00
|
|
|
ULONG WorkerTag;
|
|
|
|
} WorkerBuffer;
|
2010-03-25 14:26:04 +00:00
|
|
|
ULONG Tag;
|
|
|
|
ULONG Flags;
|
|
|
|
BATTERY_INFORMATION BatteryInformation;
|
|
|
|
BATTERY_STATUS BatteryStatus;
|
|
|
|
ULONGLONG InterruptTime;
|
|
|
|
UNICODE_STRING BatteryName;
|
2010-03-29 00:02:05 +00:00
|
|
|
} COMPBATT_BATTERY_DATA, *PCOMPBATT_BATTERY_DATA;
|
2010-03-25 14:26:04 +00:00
|
|
|
|
2024-12-14 20:36:09 +01:00
|
|
|
//
|
|
|
|
// Composite battery device extension data
|
|
|
|
//
|
2010-03-25 14:26:04 +00:00
|
|
|
typedef struct _COMPBATT_DEVICE_EXTENSION
|
|
|
|
{
|
|
|
|
PVOID ClassData;
|
|
|
|
ULONG NextTag;
|
|
|
|
LIST_ENTRY BatteryList;
|
|
|
|
FAST_MUTEX Lock;
|
|
|
|
ULONG Tag;
|
|
|
|
ULONG Flags;
|
|
|
|
BATTERY_INFORMATION BatteryInformation;
|
|
|
|
BATTERY_STATUS BatteryStatus;
|
2024-12-14 20:36:09 +01:00
|
|
|
BATTERY_WAIT_STATUS WaitNotifyStatus;
|
2010-03-25 14:26:04 +00:00
|
|
|
ULONGLONG InterruptTime;
|
|
|
|
PDEVICE_OBJECT AttachedDevice;
|
|
|
|
PDEVICE_OBJECT DeviceObject;
|
|
|
|
PVOID NotificationEntry;
|
|
|
|
} COMPBATT_DEVICE_EXTENSION, *PCOMPBATT_DEVICE_EXTENSION;
|
|
|
|
|
2024-12-14 20:36:09 +01:00
|
|
|
/* PROTOTYPES *****************************************************************/
|
|
|
|
|
2010-03-27 21:34:06 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattAddDevice(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PDRIVER_OBJECT DriverObject,
|
|
|
|
_In_ PDEVICE_OBJECT PdoDeviceObject
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattPowerDispatch(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PDEVICE_OBJECT DeviceObject,
|
|
|
|
_In_ PIRP Irp
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattPnpDispatch(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PDEVICE_OBJECT DeviceObject,
|
|
|
|
_In_ PIRP Irp
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattQueryInformation(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION FdoExtension,
|
|
|
|
_In_ ULONG Tag,
|
|
|
|
_In_ BATTERY_QUERY_INFORMATION_LEVEL InfoLevel,
|
|
|
|
_In_opt_ LONG AtRate,
|
|
|
|
_In_ PVOID Buffer,
|
|
|
|
_In_ ULONG BufferLength,
|
|
|
|
_Out_ PULONG ReturnedLength
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
2021-06-11 15:29:21 +03:00
|
|
|
|
2010-03-27 21:34:06 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattQueryStatus(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
_In_ ULONG Tag,
|
|
|
|
_Out_ PBATTERY_STATUS BatteryStatus
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattGetEstimatedTime(
|
|
|
|
_Out_ PULONG Time,
|
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION DeviceExtension
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattSetStatusNotify(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
_In_ ULONG BatteryTag,
|
|
|
|
_In_ PBATTERY_NOTIFY BatteryNotify
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattDisableStatusNotify(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION DeviceExtension
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattQueryTag(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION DeviceExtension,
|
|
|
|
_Out_ PULONG Tag
|
2010-03-27 21:34:06 +00:00
|
|
|
);
|
|
|
|
|
2010-03-29 00:02:05 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattMonitorIrpComplete(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PDEVICE_OBJECT DeviceObject,
|
|
|
|
_In_ PIRP Irp,
|
|
|
|
_In_ PVOID Context
|
2010-03-29 00:02:05 +00:00
|
|
|
);
|
|
|
|
|
2024-12-14 20:36:09 +01:00
|
|
|
VOID
|
2010-03-29 00:02:05 +00:00
|
|
|
NTAPI
|
|
|
|
CompBattMonitorIrpCompleteWorker(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PCOMPBATT_BATTERY_DATA BatteryData
|
2010-03-29 00:02:05 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattGetDeviceObjectPointer(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ PUNICODE_STRING DeviceName,
|
|
|
|
_In_ ACCESS_MASK DesiredAccess,
|
|
|
|
_Out_ PFILE_OBJECT *FileObject,
|
|
|
|
_Out_ PDEVICE_OBJECT *DeviceObject
|
2010-03-29 00:02:05 +00:00
|
|
|
);
|
2010-03-29 02:02:07 +00:00
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
BatteryIoctl(
|
2024-12-14 20:36:09 +01:00
|
|
|
_In_ ULONG IoControlCode,
|
|
|
|
_In_ PDEVICE_OBJECT DeviceObject,
|
|
|
|
_In_ PVOID InputBuffer,
|
|
|
|
_In_ ULONG InputBufferLength,
|
|
|
|
_Out_ PVOID OutputBuffer,
|
|
|
|
_Inout_ ULONG OutputBufferLength,
|
|
|
|
_In_ BOOLEAN InternalDeviceIoControl
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
CompBattRemoveBattery(
|
|
|
|
_In_ PUNICODE_STRING BatteryName,
|
|
|
|
_In_ PCOMPBATT_DEVICE_EXTENSION DeviceExtension
|
2010-03-29 02:02:07 +00:00
|
|
|
);
|
2014-02-06 11:18:34 +00:00
|
|
|
|
2010-03-27 21:34:06 +00:00
|
|
|
extern ULONG CompBattDebug;
|
2010-03-25 14:26:04 +00:00
|
|
|
|
2014-02-06 11:18:34 +00:00
|
|
|
#endif /* _COMPBATT_PCH_ */
|