windows-nt/Source/XPSP1/NT/base/busdrv/acpi/cmbatt/cmbattp.h
2020-09-26 16:20:57 +08:00

552 lines
15 KiB
C

/*++
Copyright (c) 1990 Microsoft Corporation
Module Name:
CmBattp.h
Abstract:
Control Method Battery Miniport Driver
Author:
Ron Mosgrove (Intel)
Environment:
Kernel mode
Revision History:
--*/
#ifndef FAR
#define FAR
#endif
#include <wdm.h>
#include <wmilib.h>
#include <batclass.h>
#include <devioctl.h>
#include <acpiioct.h>
#define DIRECT_ACCESS DBG
#if DIRECT_ACCESS
#define CMB_DIRECT_IOCTL_ONLY 1
#include "cmbdrect.h"
#endif
//
// Debug
//
#define DEBUG DBG
#if DEBUG
extern ULONG CmBattDebug;
#define CmBattPrint(l,m) if(l & CmBattDebug) DbgPrint m
#else
#define CmBattPrint(l,m)
#endif
#define CMBATT_LOW 0x00000001
#define CMBATT_NOTE 0x00000002
#define CMBATT_WARN 0x00000004
#define CMBATT_ERROR_ONLY 0x00000008
#define CMBATT_ERROR (CMBATT_ERROR_ONLY | CMBATT_WARN)
#define CMBATT_POWER 0x00000010
#define CMBATT_PNP 0x00000020
#define CMBATT_CM_EXE 0x00000040
#define CMBATT_DATA 0x00000100
#define CMBATT_TRACE 0x00000200
#define CMBATT_BIOS 0x00000400 // Show message to verify BIOS/HW functionality
#define CMBATT_MINI 0x00000800 // Show message to verify miniport retun data
extern UNICODE_STRING GlobalRegistryPath;
extern PDEVICE_OBJECT AcAdapterPdo;
extern KDPC CmBattWakeDpcObject;
extern KTIMER CmBattWakeDpcTimerObject;
//
// Delay before notifications on wake = 0 seconds * 10,000,000 (100-ns/s)
//
#define WAKE_DPC_DELAY {0,0}
//
// Delay on switch to DC before showing estimated time.
// 15 seconds * 10,000,000 (100-ns/s)
//
#define CM_ESTIMATED_TIME_DELAY 150000000
extern LARGE_INTEGER CmBattWakeDpcDelay;
#define MAX_DEVICE_NAME_LENGTH 100
//
// WaitWake registry key
//
extern PCWSTR WaitWakeEnableKey;
//
// Host Controller Device object extenstion
//
#define CM_MAX_DATA_SIZE 64
#define CM_MAX_STRING_LENGTH 256
//
// Control Methods defined for the Control Method Batteries
//
#define CM_BIF_METHOD (ULONG) ('FIB_')
#define CM_BST_METHOD (ULONG) ('TSB_')
#define CM_BTP_METHOD (ULONG) ('PTB_')
#define CM_PCL_METHOD (ULONG) ('LCP_')
#define CM_PSR_METHOD (ULONG) ('RSP_')
#define CM_STA_METHOD (ULONG) ('ATS_')
#define CM_UID_METHOD (ULONG) ('DIU_')
#define CM_OP_TYPE_READ 0
#define CM_OP_TYPE_WRITE 1
#define NUMBER_OF_BIF_ELEMENTS 13
#define NUMBER_OF_BST_ELEMENTS 4
//
// Value to send to _BTP to clear the trip point.
//
#define CM_BATT_CLEAR_TRIP_POINT 0x00000000
//
// Special values retuned from control methods.
//
#define CM_UNKNOWN_VALUE 0xffffffff
#define CM_MAX_VALUE 0x7fffffff
//
// STA control method return values
//
#define STA_DEVICE_PRESENT 0x10
#define STA_DEVICE_FUNCTIONAL 0x80
//
// Control method battery device notification values
//
#define BATTERY_DEVICE_CHECK 0x00
#define BATTERY_EJECT 0x01
#define BATTERY_STATUS_CHANGE 0x80
#define BATTERY_INFO_CHANGE 0x81
//
// This is the static data defined by the ACPI spec for the control method battery
// It is returned by the _BIF control method
//
typedef struct {
ULONG PowerUnit; // units used by interface 0:mWh or 1:mAh
ULONG DesignCapacity; // Nominal capacity of a new battery
ULONG LastFullChargeCapacity; // Predicted capacity when fully charged
ULONG BatteryTechnology; // 0:Primary (not rechargable), 1:Secondary (rechargable)
ULONG DesignVoltage; // Nominal voltage of a new battery
ULONG DesignCapacityOfWarning; // OEM-designed battery warning capacity
ULONG DesignCapacityOfLow; // OEM-designed battery low capacity
ULONG BatteryCapacityGran_1; // capacity granularity between low and warning
ULONG BatteryCapacityGran_2; // capacity granularity between warning and full
UCHAR ModelNumber[CM_MAX_STRING_LENGTH];
UCHAR SerialNumber[CM_MAX_STRING_LENGTH];
UCHAR BatteryType[CM_MAX_STRING_LENGTH];
UCHAR OEMInformation[CM_MAX_STRING_LENGTH];
} CM_BIF_BAT_INFO, *PCM_BIF_BAT_INFO;
//
// Definitions for the PowerUnit field of CM_BIF_BAT_INFO
//
#define CM_BIF_UNITS_WATTS 0 // All units are in mWh
#define CM_BIF_UNITS_AMPS 1 // All units are in mAh
//
// This is the battery status data defined by the ACPI spec for a control method battery
// It is returned by the _BST control method
//
typedef struct {
ULONG BatteryState; // Charging/Discharging/Critical
ULONG PresentRate; // Present draw rate in units defined by PowerUnit
// Unsigned value, direction is determined by BatteryState
ULONG RemainingCapacity; // Estimated remaining capacity, units defined by PowerUnit
ULONG PresentVoltage; // Present voltage across the battery terminals
} CM_BST_BAT_INFO, *PCM_BST_BAT_INFO;
//
// Bit definitions for the BatteryState field of CM_BST_BAT_INFO
//
#define CM_BST_STATE_DISCHARGING 0x00000001 // Battery is discharging
#define CM_BST_STATE_CHARGING 0x00000002 // Battery is charging
#define CM_BST_STATE_CRITICAL 0x00000004 // Battery is critical
//
// Cached battery info
//
typedef struct {
ULONG Tag; // Unique tag for this battery,
ULONG ModelNumLen; // Length of ModelNumber string in StringBuffer
PUCHAR ModelNum; // Ptr to ModelNumber in StringBuffer
ULONG SerialNumLen; // Length of SerialNumber string in StringBuffer
PUCHAR SerialNum; // Ptr to SerialNumber in StringBuffer
ULONG OEMInfoLen; // Length of OEMInformation string in StringBuffer
PUCHAR OEMInfo; // Ptr to OEMInformation in StringBuffer
CM_BST_BAT_INFO Status; // Last Status read from battery
CM_BIF_BAT_INFO StaticData; // Last valid data
ULONG StaticDataTag; // Tag when static data was last read
BATTERY_STATUS ApiStatus; // Status info, class driver structure
BATTERY_INFORMATION ApiInfo; // Battery info, class driver structure
ULONG ApiGranularity_1;
ULONG ApiGranularity_2;
BOOLEAN BtpExists; // Remeber if _BTP method exists
} STATIC_BAT_INFO, *PSTATIC_BAT_INFO;
typedef struct {
ULONG Granularity;
ULONG Capacity;
} BATTERY_REMAINING_SCALE, *PBATTERY_REMAINING_SCALE;
typedef struct {
ULONG Setting; // The alarm value
BOOLEAN Supported; // Set to false when _BTP fails
// don't bother calling _BTP again
} BAT_ALARM_INFO, *PBAT_ALARM_INFO;
#define CM_ALARM_INVALID 0xffffffff;
//
// Types for the different FDOs created by this driver.
//
#define AC_ADAPTER_TYPE 0x00
#define CM_BATTERY_TYPE 0x01
//
// Pagable device extension for control method battery
//
typedef struct _CM_BATT {
ULONG Type; // Battery or AC Adapter
PDEVICE_OBJECT DeviceObject; // Battery device object
PDEVICE_OBJECT Fdo; // Functional Device Object
PDEVICE_OBJECT Pdo; // Physical Device Object
PDEVICE_OBJECT LowerDeviceObject; // Detected at AddDevice time
FAST_MUTEX OpenCloseMutex;
ULONG OpenCount; // Count open file handles to device
PIRP WaitWakeIrp; // Pointer to Wait Wake Irp
POWER_STATE WakeSupportedState;
WMILIB_CONTEXT WmiLibContext;
BOOLEAN WakeEnabled;
BOOLEAN WantToRemove; // Syncronize device removal
LONG InUseCount;
KEVENT ReadyToRemove;
ULONG DeviceNumber;
PUNICODE_STRING DeviceName;
ACPI_INTERFACE_STANDARD AcpiInterfaces;
BOOLEAN Sleeping;
UCHAR ActionRequired;
//
// All fields before this point are common between _CM_BATT and _AC_ADAPTER
//
PVOID Class; // Battery Class handle
BOOLEAN IsStarted; // if non zero, the device is started
BOOLEAN ReCheckSta;
LONG CacheState; // 0 = invalid
// 1 = updating values
// 2 = valid
//
// Battery
//
ULONG TagCount; // Tag for next battery
STATIC_BAT_INFO Info;
BAT_ALARM_INFO Alarm;
ULONGLONG DischargeTime; // Time battery started discharging.
} CM_BATT, *PCM_BATT;
//
// Pagable device extension for AC Adapter
//
typedef struct _AC_ADAPTER {
ULONG Type; // Battery or AC Adapter
PDEVICE_OBJECT DeviceObject; // Battery device object
PDEVICE_OBJECT Fdo; // Functional Device Object
PDEVICE_OBJECT Pdo; // Physical Device Object
PDEVICE_OBJECT LowerDeviceObject; // Detected at AddDevice time
FAST_MUTEX OpenCloseMutex;
ULONG OpenCount; // Count open file handles to device
PIRP WaitWakeIrp; // Pointer to Wait Wake Irp
POWER_STATE WakeSupportedState;
WMILIB_CONTEXT WmiLibContext;
BOOLEAN WakeEnabled;
BOOLEAN WantToRemove; // Syncronize device removal
LONG InUseCount;
KEVENT ReadyToRemove;
ULONG DeviceNumber;
PUNICODE_STRING DeviceName;
ACPI_INTERFACE_STANDARD AcpiInterfaces;
BOOLEAN Sleeping;
UCHAR ActionRequired;
} AC_ADAPTER, *PAC_ADAPTER;
// Action required (AR) flags
#define CMBATT_AR_NO_ACTION 0
#define CMBATT_AR_NOTIFY 1
#define CMBATT_AR_INVALIDATE_CACHE 2
#define CMBATT_AR_INVALIDATE_TAG 4
//
// Use the IoSkipCurrentIrpStackLocation routine because the we
// don't need to change arguments, or a completion routine
//
#define CmBattCallLowerDriver(Status, DeviceObject, Irp) { \
IoSkipCurrentIrpStackLocation(Irp); \
Status = IoCallDriver(DeviceObject,Irp); \
}
#define GetTid() PsGetCurrentThread()
//
// Prototypes
//
VOID
CmBattAlarm (
IN PVOID Context,
IN UCHAR Address,
IN USHORT Data
);
NTSTATUS
CmBattVerifyStaticInfo (
IN PCM_BATT CmBatt,
IN ULONG BatteryTag
);
NTSTATUS
CmBattPnpDispatch(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
CmBattPowerDispatch(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
CmBattSystemControl(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
CmBattForwardRequest(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
);
NTSTATUS
CmBattAddDevice(
IN PDRIVER_OBJECT DriverObject,
IN PDEVICE_OBJECT Pdo
);
NTSTATUS
CmBattQueryTag (
IN PVOID Context,
OUT PULONG BatteryTag
);
NTSTATUS
CmBattSetStatusNotify (
IN PVOID Context,
IN ULONG BatteryTag,
IN PBATTERY_NOTIFY BatteryNotify
);
NTSTATUS
CmBattDisableStatusNotify (
IN PVOID Context
);
NTSTATUS
CmBattQueryStatus (
IN PVOID Context,
IN ULONG BatteryTag,
OUT PBATTERY_STATUS BatteryStatus
);
NTSTATUS
CmBattGetBifData(
IN PCM_BATT CmBatt,
OUT PCM_BIF_BAT_INFO BifBuf
);
NTSTATUS
CmBattGetUniqueId(
IN PDEVICE_OBJECT Pdo,
OUT PULONG UniqueId
);
NTSTATUS
CmBattGetStaData(
IN PDEVICE_OBJECT Pdo,
OUT PULONG ReturnStatus
);
NTSTATUS
CmBattGetPsrData(
IN PDEVICE_OBJECT Pdo,
OUT PULONG ReturnStatus
);
NTSTATUS
CmBattIoCompletion(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PKEVENT pdoIoCompletedEvent
);
NTSTATUS
CmBattSetTripPpoint(
IN PCM_BATT CmBatt,
IN ULONG TripPoint
);
NTSTATUS
CmBattGetBstData(
IN PCM_BATT CmBatt,
OUT PCM_BST_BAT_INFO BstBuf
);
NTSTATUS
GetDwordElement (
IN PACPI_METHOD_ARGUMENT Argument,
OUT PULONG PDword
);
NTSTATUS
GetStringElement (
IN PACPI_METHOD_ARGUMENT Argument,
OUT PUCHAR PBuffer
);
VOID
CmBattPowerCallBack(
IN PVOID CallBackContext,
IN PVOID Argument1,
IN PVOID Argument2
);
VOID
CmBattWakeDpc (
IN PKDPC Dpc,
IN PVOID DefferedContext,
IN PVOID SystemArgument1,
IN PVOID SystemArgument2
);
VOID
CmBattNotifyHandler (
IN PVOID Context,
IN ULONG NotifyValue
);
NTSTATUS
CmBattQueryInformation (
IN PVOID Context,
IN ULONG BatteryTag,
IN BATTERY_QUERY_INFORMATION_LEVEL Level,
IN LONG AtRate OPTIONAL,
OUT PVOID Buffer,
IN ULONG BufferLength,
OUT PULONG ReturnedLength
);
NTSTATUS
CmBattSendDownStreamIrp(
IN PDEVICE_OBJECT Pdo,
IN ULONG Ioctl,
IN PVOID InputBuffer,
IN ULONG InputSize,
IN PVOID OutputBuffer,
IN ULONG OutputSize
);
NTSTATUS
CmBattWaitWakeLoop(
IN PDEVICE_OBJECT DeviceObject,
IN UCHAR MinorFunction,
IN POWER_STATE PowerState,
IN PVOID Context,
IN PIO_STATUS_BLOCK IoStatus
);
NTSTATUS
CmBattWmiRegistration(
PCM_BATT CmBatt
);
NTSTATUS
CmBattWmiDeRegistration(
PCM_BATT CmBatt
);
#ifndef _WIN32_WINNT
VOID
CmBattNotifyVPOWERDOfPowerChange (
IN ULONG PowerSourceChange
);
#endif