xref: /reactos/sdk/include/psdk/batclass.h (revision 02032b71)
1 /*
2  * batclass.h
3  *
4  * Battery class driver interface
5  *
6  * This file is part of the w32api package.
7  *
8  * Contributors:
9  *   Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
10  *
11  * THIS SOFTWARE IS NOT COPYRIGHTED
12  *
13  * This source code is offered for use in the public domain. You may
14  * use, modify or distribute it freely.
15  *
16  * This code is distributed in the hope that it will be useful but
17  * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
18  * DISCLAIMED. This includes but is not limited to warranties of
19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
20  *
21  */
22 
23 #pragma once
24 
25 #ifdef __cplusplus
26 extern "C" {
27 #endif
28 
29 /* Battery device GUIDs */
30 
31 DEFINE_GUID(GUID_DEVICE_BATTERY,
32   0x72631e54L, 0x78A4, 0x11d0, 0xbc, 0xf7, 0x00, 0xaa, 0x00, 0xb7, 0xb3, 0x2a);
33 
34 #if (NTDDI_VERSION >= NTDDI_WINXP)
35 DEFINE_GUID(BATTERY_STATUS_WMI_GUID,
36   0xfc4670d1, 0xebbf, 0x416e, 0x87, 0xce, 0x37, 0x4a, 0x4e, 0xbc, 0x11, 0x1a);
37 DEFINE_GUID(BATTERY_RUNTIME_WMI_GUID,
38   0x535a3767, 0x1ac2, 0x49bc, 0xa0, 0x77, 0x3f, 0x7a, 0x02, 0xe4, 0x0a, 0xec);
39 DEFINE_GUID(BATTERY_TEMPERATURE_WMI_GUID,
40   0x1a52a14d, 0xadce, 0x4a44, 0x9a, 0x3e, 0xc8, 0xd8, 0xf1, 0x5f, 0xf2, 0xc2);
41 DEFINE_GUID(BATTERY_FULL_CHARGED_CAPACITY_WMI_GUID,
42   0x40b40565, 0x96f7, 0x4435, 0x86, 0x94, 0x97, 0xe0, 0xe4, 0x39, 0x59, 0x05);
43 DEFINE_GUID(BATTERY_CYCLE_COUNT_WMI_GUID,
44   0xef98db24, 0x0014, 0x4c25, 0xa5, 0x0b, 0xc7, 0x24, 0xae, 0x5c, 0xd3, 0x71);
45 DEFINE_GUID(BATTERY_STATIC_DATA_WMI_GUID,
46   0x05e1e463, 0xe4e2, 0x4ea9, 0x80, 0xcb, 0x9b, 0xd4, 0xb3, 0xca, 0x06, 0x55);
47 DEFINE_GUID(BATTERY_STATUS_CHANGE_WMI_GUID,
48   0xcddfa0c3, 0x7c5b, 0x4e43, 0xa0, 0x34, 0x05, 0x9f, 0xa5, 0xb8, 0x43, 0x64);
49 DEFINE_GUID(BATTERY_TAG_CHANGE_WMI_GUID,
50   0x5e1f6e19, 0x8786, 0x4d23, 0x94, 0xfc, 0x9e, 0x74, 0x6b, 0xd5, 0xd8, 0x88);
51 #endif /* (NTDDI_VERSION >= NTDDI_WINXP) */
52 
53 #ifndef _BATCLASS_
54 #define _BATCLASS_
55 
56 /* BATTERY_INFORMATION.Capabilities constants */
57 #define BATTERY_SET_CHARGE_SUPPORTED      0x00000001
58 #define BATTERY_SET_DISCHARGE_SUPPORTED   0x00000002
59 #define BATTERY_SET_RESUME_SUPPORTED      0x00000004
60 #define BATTERY_IS_SHORT_TERM             0x20000000
61 #define BATTERY_CAPACITY_RELATIVE         0x40000000
62 #define BATTERY_SYSTEM_BATTERY            0x80000000
63 
64 /* BATTERY_INFORMATION.Capacity constants */
65 #define BATTERY_UNKNOWN_CAPACITY          0xFFFFFFFF
66 
67 /* BatteryEstimatedTime constant */
68 #define BATTERY_UNKNOWN_TIME              0xFFFFFFFF
69 
70 #define MAX_BATTERY_STRING_SIZE           128
71 
72 /* BATTERY_STATUS.PowerState flags */
73 #define BATTERY_POWER_ON_LINE             0x00000001
74 #define BATTERY_DISCHARGING               0x00000002
75 #define BATTERY_CHARGING                  0x00000004
76 #define BATTERY_CRITICAL                  0x00000008
77 
78 /* BATTERY_STATUS.Voltage constant */
79 #define BATTERY_UNKNOWN_VOLTAGE           0xFFFFFFFF
80 
81 /* BATTERY_STATUS.Rate constant */
82 #define BATTERY_UNKNOWN_RATE              0x80000000
83 
84 #define IOCTL_BATTERY_QUERY_TAG \
85   CTL_CODE(FILE_DEVICE_BATTERY, 0x10, METHOD_BUFFERED, FILE_READ_ACCESS)
86 #define IOCTL_BATTERY_QUERY_INFORMATION \
87   CTL_CODE(FILE_DEVICE_BATTERY, 0x11, METHOD_BUFFERED, FILE_READ_ACCESS)
88 #define IOCTL_BATTERY_SET_INFORMATION \
89   CTL_CODE(FILE_DEVICE_BATTERY, 0x12, METHOD_BUFFERED, FILE_WRITE_ACCESS)
90 #define IOCTL_BATTERY_QUERY_STATUS \
91   CTL_CODE(FILE_DEVICE_BATTERY, 0x13, METHOD_BUFFERED, FILE_READ_ACCESS)
92 
93 /* NTSTATUS possibly returned by BCLASS_QUERY_STATUS */
94 #define BATTERY_TAG_INVALID 0
95 
96 typedef enum _BATTERY_QUERY_INFORMATION_LEVEL {
97   BatteryInformation = 0,
98   BatteryGranularityInformation,
99   BatteryTemperature,
100   BatteryEstimatedTime,
101   BatteryDeviceName,
102   BatteryManufactureDate,
103   BatteryManufactureName,
104   BatteryUniqueID,
105   BatterySerialNumber
106 } BATTERY_QUERY_INFORMATION_LEVEL;
107 
108 typedef struct _BATTERY_QUERY_INFORMATION {
109   ULONG BatteryTag;
110   BATTERY_QUERY_INFORMATION_LEVEL InformationLevel;
111   LONG AtRate;
112 } BATTERY_QUERY_INFORMATION, *PBATTERY_QUERY_INFORMATION;
113 
114 typedef struct _BATTERY_INFORMATION {
115   ULONG Capabilities;
116   UCHAR Technology;
117   UCHAR Reserved[3];
118   UCHAR Chemistry[4];
119   ULONG DesignedCapacity;
120   ULONG FullChargedCapacity;
121   ULONG DefaultAlert1;
122   ULONG DefaultAlert2;
123   ULONG CriticalBias;
124   ULONG CycleCount;
125 } BATTERY_INFORMATION, *PBATTERY_INFORMATION;
126 
127 typedef struct _BATTERY_MANUFACTURE_DATE {
128   UCHAR Day;
129   UCHAR Month;
130   USHORT Year;
131 } BATTERY_MANUFACTURE_DATE, *PBATTERY_MANUFACTURE_DATE;
132 
133 typedef enum _BATTERY_SET_INFORMATION_LEVEL {
134   BatteryCriticalBias = 0,
135   BatteryCharge,
136   BatteryDischarge
137 } BATTERY_SET_INFORMATION_LEVEL;
138 
139 typedef struct _BATTERY_SET_INFORMATION {
140   ULONG BatteryTag;
141   BATTERY_SET_INFORMATION_LEVEL InformationLevel;
142   UCHAR Buffer[1];
143 } BATTERY_SET_INFORMATION, *PBATTERY_SET_INFORMATION;
144 
145 typedef struct _BATTERY_WAIT_STATUS {
146   ULONG BatteryTag;
147   ULONG Timeout;
148   ULONG PowerState;
149   ULONG LowCapacity;
150   ULONG HighCapacity;
151 } BATTERY_WAIT_STATUS, *PBATTERY_WAIT_STATUS;
152 
153 typedef struct _BATTERY_STATUS {
154   ULONG PowerState;
155   ULONG Capacity;
156   ULONG Voltage;
157   LONG Rate;
158 } BATTERY_STATUS, *PBATTERY_STATUS;
159 
160 #ifndef _WINDOWS_H
161 
162 /* BATTERY_MINIPORT_INFO.XxxVersion */
163 #define BATTERY_CLASS_MAJOR_VERSION       0x0001
164 #define BATTERY_CLASS_MINOR_VERSION       0x0000
165 
166 _Function_class_(BCLASS_QUERY_TAG_CALLBACK)
167 _IRQL_requires_same_
168 _IRQL_requires_max_(PASSIVE_LEVEL)
169 _Check_return_
170 typedef NTSTATUS
171 (NTAPI BCLASS_QUERY_TAG_CALLBACK)(
172   _In_ PVOID Context,
173   _Out_ PULONG BatteryTag);
174 typedef BCLASS_QUERY_TAG_CALLBACK *PBCLASS_QUERY_TAG_CALLBACK;
175 
176 _Function_class_(BCLASS_QUERY_INFORMATION_CALLBACK)
177 _IRQL_requires_same_
178 _IRQL_requires_max_(PASSIVE_LEVEL)
179 _Check_return_
180 typedef NTSTATUS
181 (NTAPI BCLASS_QUERY_INFORMATION_CALLBACK)(
182   _In_ PVOID Context,
183   _In_ ULONG BatteryTag,
184   _In_ BATTERY_QUERY_INFORMATION_LEVEL Level,
185   _In_ LONG AtRate,
186   _Out_writes_bytes_to_(BufferLength, *ReturnedLength) PVOID Buffer,
187   _In_ ULONG BufferLength,
188   _Out_ PULONG ReturnedLength);
189 typedef BCLASS_QUERY_INFORMATION_CALLBACK *PBCLASS_QUERY_INFORMATION_CALLBACK;
190 
191 _Function_class_(BCLASS_QUERY_STATUS_CALLBACK)
192 _IRQL_requires_same_
193 _IRQL_requires_max_(PASSIVE_LEVEL)
194 _Check_return_
195 typedef NTSTATUS
196 (NTAPI BCLASS_QUERY_STATUS_CALLBACK)(
197   _In_ PVOID Context,
198   _In_ ULONG BatteryTag,
199   _Out_ PBATTERY_STATUS BatteryStatus);
200 typedef BCLASS_QUERY_STATUS_CALLBACK *PBCLASS_QUERY_STATUS_CALLBACK;
201 
202 typedef struct _BATTERY_NOTIFY {
203   ULONG PowerState;
204   ULONG LowCapacity;
205   ULONG HighCapacity;
206 } BATTERY_NOTIFY, *PBATTERY_NOTIFY;
207 
208 _Function_class_(BCLASS_SET_STATUS_NOTIFY_CALLBACK)
209 _IRQL_requires_same_
210 _IRQL_requires_max_(PASSIVE_LEVEL)
211 _Check_return_
212 typedef NTSTATUS
213 (NTAPI BCLASS_SET_STATUS_NOTIFY_CALLBACK)(
214   _In_ PVOID Context,
215   _In_ ULONG BatteryTag,
216   _In_ PBATTERY_NOTIFY BatteryNotify);
217 typedef BCLASS_SET_STATUS_NOTIFY_CALLBACK *PBCLASS_SET_STATUS_NOTIFY_CALLBACK;
218 
219 _Function_class_(BCLASS_SET_INFORMATION_CALLBACK)
220 _IRQL_requires_same_
221 _IRQL_requires_max_(PASSIVE_LEVEL)
222 _Check_return_
223 typedef NTSTATUS
224 (NTAPI BCLASS_SET_INFORMATION_CALLBACK)(
225   _In_ PVOID Context,
226   _In_ ULONG BatteryTag,
227   _In_ BATTERY_SET_INFORMATION_LEVEL Level,
228   _In_opt_ PVOID Buffer);
229 typedef BCLASS_SET_INFORMATION_CALLBACK *PBCLASS_SET_INFORMATION_CALLBACK;
230 
231 _Function_class_(BCLASS_DISABLE_STATUS_NOTIFY_CALLBACK)
232 _IRQL_requires_same_
233 _IRQL_requires_max_(PASSIVE_LEVEL)
234 _Check_return_
235 typedef NTSTATUS
236 (NTAPI BCLASS_DISABLE_STATUS_NOTIFY_CALLBACK)(
237   _In_ PVOID Context);
238 typedef BCLASS_DISABLE_STATUS_NOTIFY_CALLBACK *PBCLASS_DISABLE_STATUS_NOTIFY_CALLBACK;
239 
240 typedef PBCLASS_QUERY_TAG_CALLBACK BCLASS_QUERY_TAG;
241 typedef PBCLASS_QUERY_INFORMATION_CALLBACK BCLASS_QUERY_INFORMATION;
242 typedef PBCLASS_QUERY_STATUS_CALLBACK BCLASS_QUERY_STATUS;
243 typedef PBCLASS_SET_STATUS_NOTIFY_CALLBACK BCLASS_SET_STATUS_NOTIFY;
244 typedef PBCLASS_SET_INFORMATION_CALLBACK BCLASS_SET_INFORMATION;
245 typedef PBCLASS_DISABLE_STATUS_NOTIFY_CALLBACK BCLASS_DISABLE_STATUS_NOTIFY;
246 
247 typedef struct _BATTERY_MINIPORT_INFO {
248   USHORT MajorVersion;
249   USHORT MinorVersion;
250   PVOID Context;
251   BCLASS_QUERY_TAG QueryTag;
252   BCLASS_QUERY_INFORMATION QueryInformation;
253   BCLASS_SET_INFORMATION SetInformation;
254   BCLASS_QUERY_STATUS QueryStatus;
255   BCLASS_SET_STATUS_NOTIFY SetStatusNotify;
256   BCLASS_DISABLE_STATUS_NOTIFY DisableStatusNotify;
257   PDEVICE_OBJECT Pdo;
258   PUNICODE_STRING DeviceName;
259 } BATTERY_MINIPORT_INFO, *PBATTERY_MINIPORT_INFO;
260 
261 #if (NTDDI_VERSION >= NTDDI_WINXP)
262 
263 typedef struct _BATTERY_WMI_STATUS {
264   ULONG Tag;
265   ULONG RemainingCapacity;
266   LONG ChargeRate;
267   LONG DischargeRate;
268   ULONG Voltage;
269   BOOLEAN PowerOnline;
270   BOOLEAN Charging;
271   BOOLEAN Discharging;
272   BOOLEAN Critical;
273 } BATTERY_WMI_STATUS, *PBATTERY_WMI_STATUS;
274 
275 typedef struct _BATTERY_WMI_RUNTIME {
276   ULONG Tag;
277   ULONG EstimatedRuntime;
278 } BATTERY_WMI_RUNTIME, *PBATTERY_WMI_RUNTIME;
279 
280 typedef struct _BATTERY_WMI_TEMPERATURE {
281   ULONG Tag;
282   ULONG Temperature;
283 } BATTERY_WMI_TEMPERATURE, *PBATTERY_WMI_TEMPERATURE;
284 
285 typedef struct _BATTERY_WMI_FULL_CHARGED_CAPACITY {
286   ULONG Tag;
287   ULONG FullChargedCapacity;
288 } BATTERY_WMI_FULL_CHARGED_CAPACITY, *PBATTERY_WMI_FULL_CHARGED_CAPACITY;
289 
290 typedef struct _BATTERY_WMI_CYCLE_COUNT {
291   ULONG Tag;
292   ULONG CycleCount;
293 } BATTERY_WMI_CYCLE_COUNT, *PBATTERY_WMI_CYCLE_COUNT;
294 
295 typedef struct _BATTERY_WMI_STATIC_DATA {
296   ULONG Tag;
297   WCHAR ManufactureDate[25];
298   BATTERY_REPORTING_SCALE Granularity [4];
299   ULONG Capabilities;
300   UCHAR Technology;
301   ULONG Chemistry;
302   ULONG DesignedCapacity;
303   ULONG DefaultAlert1;
304   ULONG DefaultAlert2;
305   ULONG CriticalBias;
306   WCHAR Strings[1];
307 } BATTERY_WMI_STATIC_DATA, *PBATTERY_WMI_STATIC_DATA;
308 
309 typedef struct _BATTERY_WMI_STATUS_CHANGE {
310   ULONG Tag;
311   BOOLEAN PowerOnline;
312   BOOLEAN Charging;
313   BOOLEAN Discharging;
314   BOOLEAN Critical;
315 } BATTERY_WMI_STATUS_CHANGE, *PBATTERY_WMI_STATUS_CHANGE;
316 
317 typedef struct _BATTERY_TAG_CHANGE {
318   ULONG Tag;
319 } BATTERY_TAG_CHANGE, *PBATTERY_TAG_CHANGE;
320 
321 #endif /* (NTDDI_VERSION >= NTDDI_WINXP) */
322 
323 #if defined(_BATTERYCLASS_)
324 #define BCLASSAPI
325 #else
326 #define BCLASSAPI DECLSPEC_IMPORT
327 #endif
328 
329 _IRQL_requires_max_(PASSIVE_LEVEL)
330 _Check_return_
331 BCLASSAPI
332 NTSTATUS
333 NTAPI
334 BatteryClassInitializeDevice(
335   _In_ PBATTERY_MINIPORT_INFO MiniportInfo,
336   _Out_ PVOID *ClassData);
337 
338 _IRQL_requires_max_(PASSIVE_LEVEL)
339 _Check_return_
340 BCLASSAPI
341 NTSTATUS
342 NTAPI
343 BatteryClassIoctl(
344   _In_ PVOID ClassData,
345   _Inout_ PIRP Irp);
346 
347 _IRQL_requires_max_(DISPATCH_LEVEL)
348 BCLASSAPI
349 NTSTATUS
350 NTAPI
351 BatteryClassStatusNotify(
352   _In_ PVOID ClassData);
353 
354 #if (NTDDI_VERSION >= NTDDI_WINXP)
355 
356 _IRQL_requires_max_(PASSIVE_LEVEL)
357 _Check_return_
358 BCLASSAPI
359 NTSTATUS
360 NTAPI
361 BatteryClassQueryWmiDataBlock(
362   _In_ PVOID ClassData,
363   _Inout_ PDEVICE_OBJECT DeviceObject,
364   _Inout_ PIRP Irp,
365   _In_ ULONG GuidIndex,
366   _Out_writes_(1) PULONG InstanceLengthArray,
367   _In_ ULONG OutBufferSize,
368   _Out_writes_bytes_opt_(OutBufferSize) PUCHAR Buffer);
369 
370 _IRQL_requires_max_(PASSIVE_LEVEL)
371 _Check_return_
372 BCLASSAPI
373 NTSTATUS
374 NTAPI
375 BatteryClassSystemControl(
376   _In_ PVOID ClassData,
377   _In_ PVOID WmiLibContext, /* PWMILIB_CONTEXT */
378   _In_ PDEVICE_OBJECT DeviceObject,
379   _Inout_ PIRP Irp,
380   _Out_ PVOID Disposition); /* PSYSCTL_IRP_DISPOSITION */
381 
382 #endif /* (NTDDI_VERSION >= NTDDI_WINXP) */
383 
384 _IRQL_requires_max_(PASSIVE_LEVEL)
385 BCLASSAPI
386 NTSTATUS
387 NTAPI
388 BatteryClassUnload(
389   _In_ PVOID ClassData);
390 
391 #endif /* _WINDOWS_H */
392 
393 #endif /* _BATCLASS_ */
394 
395 #ifdef __cplusplus
396 }
397 #endif
398