2 * acpi_battery.c - ACPI Battery Driver ($Revision: 37 $)
4 * Copyright (C) 2001, 2002 Andy Grover <andrew.grover@intel.com>
5 * Copyright (C) 2001, 2002 Paul Diefenbaugh <paul.s.diefenbaugh@intel.com>
7 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or (at
12 * your option) any later version.
14 * This program is distributed in the hope that it will be useful, but
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * General Public License for more details.
19 * You should have received a copy of the GNU General Public License along
20 * with this program; if not, write to the Free Software Foundation, Inc.,
21 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
23 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
26 #include <linux/kernel.h>
27 #include <linux/module.h>
28 #include <linux/init.h>
29 #include <linux/types.h>
30 #include <linux/proc_fs.h>
31 #include <linux/seq_file.h>
32 #include <asm/uaccess.h>
34 #include <acpi/acpi_bus.h>
35 #include <acpi/acpi_drivers.h>
37 #define ACPI_BATTERY_VALUE_UNKNOWN 0xFFFFFFFF
39 #define ACPI_BATTERY_FORMAT_BIF "NNNNNNNNNSSSS"
40 #define ACPI_BATTERY_FORMAT_BST "NNNN"
42 #define ACPI_BATTERY_COMPONENT 0x00040000
43 #define ACPI_BATTERY_CLASS "battery"
44 #define ACPI_BATTERY_HID "PNP0C0A"
45 #define ACPI_BATTERY_DEVICE_NAME "Battery"
46 #define ACPI_BATTERY_FILE_INFO "info"
47 #define ACPI_BATTERY_FILE_STATE "state"
48 #define ACPI_BATTERY_FILE_ALARM "alarm"
49 #define ACPI_BATTERY_NOTIFY_STATUS 0x80
50 #define ACPI_BATTERY_NOTIFY_INFO 0x81
51 #define ACPI_BATTERY_UNITS_WATTS "mW"
52 #define ACPI_BATTERY_UNITS_AMPS "mA"
54 #define _COMPONENT ACPI_BATTERY_COMPONENT
56 #define ACPI_BATTERY_UPDATE_TIME 0
58 #define ACPI_BATTERY_NONE_UPDATE 0
59 #define ACPI_BATTERY_EASY_UPDATE 1
60 #define ACPI_BATTERY_INIT_UPDATE 2
62 ACPI_MODULE_NAME("battery");
64 MODULE_AUTHOR("Paul Diefenbaugh");
65 MODULE_DESCRIPTION("ACPI Battery Driver");
66 MODULE_LICENSE("GPL");
68 static unsigned int update_time = ACPI_BATTERY_UPDATE_TIME;
70 /* 0 - every time, > 0 - by update_time */
71 module_param(update_time, uint, 0644);
73 extern struct proc_dir_entry *acpi_lock_battery_dir(void);
74 extern void *acpi_unlock_battery_dir(struct proc_dir_entry *acpi_battery_dir);
76 static int acpi_battery_add(struct acpi_device *device);
77 static int acpi_battery_remove(struct acpi_device *device, int type);
78 static int acpi_battery_resume(struct acpi_device *device);
80 static struct acpi_driver acpi_battery_driver = {
82 .class = ACPI_BATTERY_CLASS,
83 .ids = ACPI_BATTERY_HID,
85 .add = acpi_battery_add,
86 .resume = acpi_battery_resume,
87 .remove = acpi_battery_remove,
91 struct acpi_battery_state {
93 acpi_integer present_rate;
94 acpi_integer remaining_capacity;
95 acpi_integer present_voltage;
98 struct acpi_battery_info {
99 acpi_integer power_unit;
100 acpi_integer design_capacity;
101 acpi_integer last_full_capacity;
102 acpi_integer battery_technology;
103 acpi_integer design_voltage;
104 acpi_integer design_capacity_warning;
105 acpi_integer design_capacity_low;
106 acpi_integer battery_capacity_granularity_1;
107 acpi_integer battery_capacity_granularity_2;
108 acpi_string model_number;
109 acpi_string serial_number;
110 acpi_string battery_type;
111 acpi_string oem_info;
114 struct acpi_battery_flags {
115 u8 battery_present_prev;
124 struct acpi_battery {
126 struct acpi_device * device;
127 struct acpi_battery_flags flags;
128 struct acpi_buffer bif_data;
129 struct acpi_buffer bst_data;
131 unsigned long info_update_time;
132 unsigned long state_update_time;
133 unsigned long alarm_update_time;
136 #define acpi_battery_present(battery) battery->device->status.battery_present
137 #define acpi_battery_present_prev(battery) battery->flags.battery_present_prev
138 #define acpi_battery_alarm_present(battery) battery->flags.alarm_present
139 #define acpi_battery_init_update_flag(battery) battery->flags.init_update
140 #define acpi_battery_info_update_flag(battery) battery->flags.info_update
141 #define acpi_battery_state_update_flag(battery) battery->flags.state_update
142 #define acpi_battery_alarm_update_flag(battery) battery->flags.alarm_update
143 #define acpi_battery_power_units(battery) battery->flags.power_unit ? \
144 ACPI_BATTERY_UNITS_AMPS : ACPI_BATTERY_UNITS_WATTS
145 #define acpi_battery_handle(battery) battery->device->handle
146 #define acpi_battery_inserted(battery) (!acpi_battery_present_prev(battery) & acpi_battery_present(battery))
147 #define acpi_battery_removed(battery) (acpi_battery_present_prev(battery) & !acpi_battery_present(battery))
148 #define acpi_battery_bid(battery) acpi_device_bid(battery->device)
149 #define acpi_battery_status_str(battery) acpi_battery_present(battery) ? "present" : "absent"
151 /* --------------------------------------------------------------------------
153 -------------------------------------------------------------------------- */
155 static void acpi_battery_mutex_lock(struct acpi_battery *battery)
157 mutex_lock(&battery->mutex);
160 static void acpi_battery_mutex_unlock(struct acpi_battery *battery)
162 mutex_unlock(&battery->mutex);
165 static void acpi_battery_check_result(struct acpi_battery *battery, int result)
171 acpi_battery_init_update_flag(battery) = 1;
175 static int acpi_battery_extract_package(struct acpi_battery *battery,
176 union acpi_object *package,
177 struct acpi_buffer *format,
178 struct acpi_buffer *data,
181 acpi_status status = AE_OK;
182 struct acpi_buffer data_null = { 0, NULL };
184 status = acpi_extract_package(package, format, &data_null);
185 if (status != AE_BUFFER_OVERFLOW) {
186 ACPI_EXCEPTION((AE_INFO, status, "Extracting size %s",
191 if (data_null.length != data->length) {
193 kfree(data->pointer);
195 data->pointer = kzalloc(data_null.length, GFP_KERNEL);
196 if (!data->pointer) {
197 ACPI_EXCEPTION((AE_INFO, AE_NO_MEMORY, "kzalloc()"));
200 data->length = data_null.length;
203 status = acpi_extract_package(package, format, data);
204 if (ACPI_FAILURE(status)) {
205 ACPI_EXCEPTION((AE_INFO, status, "Extracting %s",
213 static int acpi_battery_get_status(struct acpi_battery *battery)
217 result = acpi_bus_get_status(battery->device);
219 ACPI_EXCEPTION((AE_INFO, AE_ERROR, "Evaluating _STA"));
225 static int acpi_battery_get_info(struct acpi_battery *battery)
228 acpi_status status = 0;
229 struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL };
230 struct acpi_buffer format = { sizeof(ACPI_BATTERY_FORMAT_BIF),
231 ACPI_BATTERY_FORMAT_BIF
233 union acpi_object *package = NULL;
234 struct acpi_buffer *data = NULL;
235 struct acpi_battery_info *bif = NULL;
237 battery->info_update_time = get_seconds();
239 if (!acpi_battery_present(battery))
244 status = acpi_evaluate_object(acpi_battery_handle(battery), "_BIF", NULL, &buffer);
245 if (ACPI_FAILURE(status)) {
246 ACPI_EXCEPTION((AE_INFO, status, "Evaluating _BIF"));
250 package = buffer.pointer;
252 data = &battery->bif_data;
254 /* Extract Package Data */
256 result = acpi_battery_extract_package(battery, package, &format, data, "_BIF");
262 if (buffer.pointer) {
263 kfree(buffer.pointer);
268 battery->flags.power_unit = bif->power_unit;
274 static int acpi_battery_get_state(struct acpi_battery *battery)
277 acpi_status status = 0;
278 struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL };
279 struct acpi_buffer format = { sizeof(ACPI_BATTERY_FORMAT_BST),
280 ACPI_BATTERY_FORMAT_BST
282 union acpi_object *package = NULL;
283 struct acpi_buffer *data = NULL;
285 battery->state_update_time = get_seconds();
287 if (!acpi_battery_present(battery))
292 status = acpi_evaluate_object(acpi_battery_handle(battery), "_BST", NULL, &buffer);
293 if (ACPI_FAILURE(status)) {
294 ACPI_EXCEPTION((AE_INFO, status, "Evaluating _BST"));
298 package = buffer.pointer;
300 data = &battery->bst_data;
302 /* Extract Package Data */
304 result = acpi_battery_extract_package(battery, package, &format, data, "_BST");
309 if (buffer.pointer) {
310 kfree(buffer.pointer);
316 static int acpi_battery_get_alarm(struct acpi_battery *battery)
318 battery->alarm_update_time = get_seconds();
323 static int acpi_battery_set_alarm(struct acpi_battery *battery, unsigned long alarm)
325 acpi_status status = 0;
326 union acpi_object arg0 = { ACPI_TYPE_INTEGER };
327 struct acpi_object_list arg_list = { 1, &arg0 };
329 battery->alarm_update_time = get_seconds();
331 if (!acpi_battery_present(battery))
334 if (!acpi_battery_alarm_present(battery))
337 arg0.integer.value = alarm;
339 status = acpi_evaluate_object(acpi_battery_handle(battery), "_BTP", &arg_list, NULL);
340 if (ACPI_FAILURE(status))
343 ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Alarm set to %d\n", (u32) alarm));
345 battery->alarm = alarm;
350 static int acpi_battery_init_alarm(struct acpi_battery *battery)
353 acpi_status status = AE_OK;
354 acpi_handle handle = NULL;
355 struct acpi_battery_info *bif = battery->bif_data.pointer;
356 unsigned long alarm = battery->alarm;
358 /* See if alarms are supported, and if so, set default */
360 status = acpi_get_handle(acpi_battery_handle(battery), "_BTP", &handle);
361 if (ACPI_SUCCESS(status)) {
362 acpi_battery_alarm_present(battery) = 1;
364 alarm = bif->design_capacity_warning;
366 result = acpi_battery_set_alarm(battery, alarm);
370 acpi_battery_alarm_present(battery) = 0;
378 static int acpi_battery_init_update(struct acpi_battery *battery)
382 result = acpi_battery_get_status(battery);
386 acpi_battery_present_prev(battery) = acpi_battery_present(battery);
388 if (acpi_battery_present(battery)) {
389 result = acpi_battery_get_info(battery);
392 result = acpi_battery_get_state(battery);
396 acpi_battery_init_alarm(battery);
402 static int acpi_battery_update(struct acpi_battery *battery,
403 int update, int *update_result_ptr)
406 int update_result = ACPI_BATTERY_NONE_UPDATE;
408 if (!acpi_battery_present(battery)) {
412 if (acpi_battery_init_update_flag(battery)) {
413 result = acpi_battery_init_update(battery);
416 update_result = ACPI_BATTERY_INIT_UPDATE;
418 result = acpi_battery_get_status(battery);
421 if (acpi_battery_inserted(battery) || acpi_battery_removed(battery)) {
422 result = acpi_battery_init_update(battery);
425 update_result = ACPI_BATTERY_INIT_UPDATE;
427 update_result = ACPI_BATTERY_EASY_UPDATE;
433 acpi_battery_init_update_flag(battery) = (result != 0);
435 *update_result_ptr = update_result;
440 static void acpi_battery_notify_update(struct acpi_battery *battery)
442 acpi_battery_get_status(battery);
444 if (acpi_battery_init_update_flag(battery)) {
448 if (acpi_battery_inserted(battery) || acpi_battery_removed(battery)) {
449 acpi_battery_init_update_flag(battery) = 1;
451 acpi_battery_info_update_flag(battery) = 1;
452 acpi_battery_state_update_flag(battery) = 1;
453 acpi_battery_alarm_update_flag(battery) = 1;
457 /* --------------------------------------------------------------------------
459 -------------------------------------------------------------------------- */
461 static struct proc_dir_entry *acpi_battery_dir;
463 static int acpi_battery_read_info_print(struct seq_file *seq, int result)
465 struct acpi_battery *battery = seq->private;
466 struct acpi_battery_info *bif = NULL;
472 if (acpi_battery_present(battery))
473 seq_printf(seq, "present: yes\n");
475 seq_printf(seq, "present: no\n");
479 bif = battery->bif_data.pointer;
481 ACPI_EXCEPTION((AE_INFO, AE_ERROR, "BIF buffer is NULL"));
488 units = acpi_battery_power_units(battery);
490 if (bif->design_capacity == ACPI_BATTERY_VALUE_UNKNOWN)
491 seq_printf(seq, "design capacity: unknown\n");
493 seq_printf(seq, "design capacity: %d %sh\n",
494 (u32) bif->design_capacity, units);
496 if (bif->last_full_capacity == ACPI_BATTERY_VALUE_UNKNOWN)
497 seq_printf(seq, "last full capacity: unknown\n");
499 seq_printf(seq, "last full capacity: %d %sh\n",
500 (u32) bif->last_full_capacity, units);
502 switch ((u32) bif->battery_technology) {
504 seq_printf(seq, "battery technology: non-rechargeable\n");
507 seq_printf(seq, "battery technology: rechargeable\n");
510 seq_printf(seq, "battery technology: unknown\n");
514 if (bif->design_voltage == ACPI_BATTERY_VALUE_UNKNOWN)
515 seq_printf(seq, "design voltage: unknown\n");
517 seq_printf(seq, "design voltage: %d mV\n",
518 (u32) bif->design_voltage);
519 seq_printf(seq, "design capacity warning: %d %sh\n",
520 (u32) bif->design_capacity_warning, units);
521 seq_printf(seq, "design capacity low: %d %sh\n",
522 (u32) bif->design_capacity_low, units);
523 seq_printf(seq, "capacity granularity 1: %d %sh\n",
524 (u32) bif->battery_capacity_granularity_1, units);
525 seq_printf(seq, "capacity granularity 2: %d %sh\n",
526 (u32) bif->battery_capacity_granularity_2, units);
527 seq_printf(seq, "model number: %s\n", bif->model_number);
528 seq_printf(seq, "serial number: %s\n", bif->serial_number);
529 seq_printf(seq, "battery type: %s\n", bif->battery_type);
530 seq_printf(seq, "OEM info: %s\n", bif->oem_info);
535 seq_printf(seq, "ERROR: Unable to read battery info\n");
540 static int acpi_battery_read_info(struct seq_file *seq, void *offset)
542 struct acpi_battery *battery = seq->private;
544 int update_result = ACPI_BATTERY_NONE_UPDATE;
547 acpi_battery_mutex_lock(battery);
549 update = (get_seconds() - battery->info_update_time >= update_time);
550 update = (update | acpi_battery_info_update_flag(battery));
552 result = acpi_battery_update(battery, update, &update_result);
556 /* Battery Info (_BIF) */
558 if (update_result == ACPI_BATTERY_EASY_UPDATE) {
559 result = acpi_battery_get_info(battery);
566 result = acpi_battery_read_info_print(seq, result);
568 acpi_battery_check_result(battery, result);
570 acpi_battery_info_update_flag(battery) = result;
572 acpi_battery_mutex_unlock(battery);
577 static int acpi_battery_info_open_fs(struct inode *inode, struct file *file)
579 return single_open(file, acpi_battery_read_info, PDE(inode)->data);
582 static int acpi_battery_read_state_print(struct seq_file *seq, int result)
584 struct acpi_battery *battery = seq->private;
585 struct acpi_battery_state *bst = NULL;
591 if (acpi_battery_present(battery))
592 seq_printf(seq, "present: yes\n");
594 seq_printf(seq, "present: no\n");
598 bst = battery->bst_data.pointer;
600 ACPI_EXCEPTION((AE_INFO, AE_ERROR, "BST buffer is NULL"));
607 units = acpi_battery_power_units(battery);
609 if (!(bst->state & 0x04))
610 seq_printf(seq, "capacity state: ok\n");
612 seq_printf(seq, "capacity state: critical\n");
614 if ((bst->state & 0x01) && (bst->state & 0x02)) {
616 "charging state: charging/discharging\n");
617 } else if (bst->state & 0x01)
618 seq_printf(seq, "charging state: discharging\n");
619 else if (bst->state & 0x02)
620 seq_printf(seq, "charging state: charging\n");
622 seq_printf(seq, "charging state: charged\n");
625 if (bst->present_rate == ACPI_BATTERY_VALUE_UNKNOWN)
626 seq_printf(seq, "present rate: unknown\n");
628 seq_printf(seq, "present rate: %d %s\n",
629 (u32) bst->present_rate, units);
631 if (bst->remaining_capacity == ACPI_BATTERY_VALUE_UNKNOWN)
632 seq_printf(seq, "remaining capacity: unknown\n");
634 seq_printf(seq, "remaining capacity: %d %sh\n",
635 (u32) bst->remaining_capacity, units);
637 if (bst->present_voltage == ACPI_BATTERY_VALUE_UNKNOWN)
638 seq_printf(seq, "present voltage: unknown\n");
640 seq_printf(seq, "present voltage: %d mV\n",
641 (u32) bst->present_voltage);
646 seq_printf(seq, "ERROR: Unable to read battery state\n");
652 static int acpi_battery_read_state(struct seq_file *seq, void *offset)
654 struct acpi_battery *battery = seq->private;
656 int update_result = ACPI_BATTERY_NONE_UPDATE;
659 acpi_battery_mutex_lock(battery);
661 update = (get_seconds() - battery->state_update_time >= update_time);
662 update = (update | acpi_battery_state_update_flag(battery));
664 result = acpi_battery_update(battery, update, &update_result);
668 /* Battery State (_BST) */
670 if (update_result == ACPI_BATTERY_EASY_UPDATE) {
671 result = acpi_battery_get_state(battery);
678 result = acpi_battery_read_state_print(seq, result);
680 acpi_battery_check_result(battery, result);
682 acpi_battery_state_update_flag(battery) = result;
684 acpi_battery_mutex_unlock(battery);
689 static int acpi_battery_state_open_fs(struct inode *inode, struct file *file)
691 return single_open(file, acpi_battery_read_state, PDE(inode)->data);
694 static int acpi_battery_read_alarm_print(struct seq_file *seq, int result)
696 struct acpi_battery *battery = seq->private;
702 if (!acpi_battery_present(battery)) {
703 seq_printf(seq, "present: no\n");
709 units = acpi_battery_power_units(battery);
711 seq_printf(seq, "alarm: ");
713 seq_printf(seq, "unsupported\n");
715 seq_printf(seq, "%lu %sh\n", battery->alarm, units);
720 seq_printf(seq, "ERROR: Unable to read battery alarm\n");
725 static int acpi_battery_read_alarm(struct seq_file *seq, void *offset)
727 struct acpi_battery *battery = seq->private;
729 int update_result = ACPI_BATTERY_NONE_UPDATE;
732 acpi_battery_mutex_lock(battery);
734 update = (get_seconds() - battery->alarm_update_time >= update_time);
735 update = (update | acpi_battery_alarm_update_flag(battery));
737 result = acpi_battery_update(battery, update, &update_result);
743 if (update_result == ACPI_BATTERY_EASY_UPDATE) {
744 result = acpi_battery_get_alarm(battery);
751 result = acpi_battery_read_alarm_print(seq, result);
753 acpi_battery_check_result(battery, result);
755 acpi_battery_alarm_update_flag(battery) = result;
757 acpi_battery_mutex_unlock(battery);
763 acpi_battery_write_alarm(struct file *file,
764 const char __user * buffer,
765 size_t count, loff_t * ppos)
768 char alarm_string[12] = { '\0' };
769 struct seq_file *m = file->private_data;
770 struct acpi_battery *battery = m->private;
771 int update_result = ACPI_BATTERY_NONE_UPDATE;
774 if (!battery || (count > sizeof(alarm_string) - 1))
777 acpi_battery_mutex_lock(battery);
779 result = acpi_battery_update(battery, 1, &update_result);
785 if (!acpi_battery_present(battery)) {
790 if (copy_from_user(alarm_string, buffer, count)) {
795 alarm_string[count] = '\0';
797 result = acpi_battery_set_alarm(battery,
798 simple_strtoul(alarm_string, NULL, 0));
804 acpi_battery_check_result(battery, result);
809 acpi_battery_mutex_unlock(battery);
814 static int acpi_battery_alarm_open_fs(struct inode *inode, struct file *file)
816 return single_open(file, acpi_battery_read_alarm, PDE(inode)->data);
819 static const struct file_operations acpi_battery_info_ops = {
820 .open = acpi_battery_info_open_fs,
823 .release = single_release,
824 .owner = THIS_MODULE,
827 static const struct file_operations acpi_battery_state_ops = {
828 .open = acpi_battery_state_open_fs,
831 .release = single_release,
832 .owner = THIS_MODULE,
835 static const struct file_operations acpi_battery_alarm_ops = {
836 .open = acpi_battery_alarm_open_fs,
838 .write = acpi_battery_write_alarm,
840 .release = single_release,
841 .owner = THIS_MODULE,
844 static int acpi_battery_add_fs(struct acpi_device *device)
846 struct proc_dir_entry *entry = NULL;
849 if (!acpi_device_dir(device)) {
850 acpi_device_dir(device) = proc_mkdir(acpi_device_bid(device),
852 if (!acpi_device_dir(device))
854 acpi_device_dir(device)->owner = THIS_MODULE;
858 entry = create_proc_entry(ACPI_BATTERY_FILE_INFO,
859 S_IRUGO, acpi_device_dir(device));
863 entry->proc_fops = &acpi_battery_info_ops;
864 entry->data = acpi_driver_data(device);
865 entry->owner = THIS_MODULE;
869 entry = create_proc_entry(ACPI_BATTERY_FILE_STATE,
870 S_IRUGO, acpi_device_dir(device));
874 entry->proc_fops = &acpi_battery_state_ops;
875 entry->data = acpi_driver_data(device);
876 entry->owner = THIS_MODULE;
880 entry = create_proc_entry(ACPI_BATTERY_FILE_ALARM,
881 S_IFREG | S_IRUGO | S_IWUSR,
882 acpi_device_dir(device));
886 entry->proc_fops = &acpi_battery_alarm_ops;
887 entry->data = acpi_driver_data(device);
888 entry->owner = THIS_MODULE;
894 static int acpi_battery_remove_fs(struct acpi_device *device)
896 if (acpi_device_dir(device)) {
897 remove_proc_entry(ACPI_BATTERY_FILE_ALARM,
898 acpi_device_dir(device));
899 remove_proc_entry(ACPI_BATTERY_FILE_STATE,
900 acpi_device_dir(device));
901 remove_proc_entry(ACPI_BATTERY_FILE_INFO,
902 acpi_device_dir(device));
904 remove_proc_entry(acpi_device_bid(device), acpi_battery_dir);
905 acpi_device_dir(device) = NULL;
911 /* --------------------------------------------------------------------------
913 -------------------------------------------------------------------------- */
915 static void acpi_battery_notify(acpi_handle handle, u32 event, void *data)
917 struct acpi_battery *battery = data;
918 struct acpi_device *device = NULL;
924 device = battery->device;
927 case ACPI_BATTERY_NOTIFY_STATUS:
928 case ACPI_BATTERY_NOTIFY_INFO:
929 case ACPI_NOTIFY_BUS_CHECK:
930 case ACPI_NOTIFY_DEVICE_CHECK:
931 acpi_battery_mutex_lock(battery);
932 device = battery->device;
933 acpi_battery_notify_update(battery);
934 acpi_battery_mutex_unlock(battery);
935 acpi_bus_generate_event(device, event, acpi_battery_present(battery));
938 ACPI_DEBUG_PRINT((ACPI_DB_INFO,
939 "Unsupported event [0x%x]\n", event));
946 static int acpi_battery_add(struct acpi_device *device)
949 acpi_status status = 0;
950 struct acpi_battery *battery = NULL;
955 battery = kzalloc(sizeof(struct acpi_battery), GFP_KERNEL);
959 mutex_init(&battery->mutex);
961 acpi_battery_mutex_lock(battery);
963 battery->device = device;
964 strcpy(acpi_device_name(device), ACPI_BATTERY_DEVICE_NAME);
965 strcpy(acpi_device_class(device), ACPI_BATTERY_CLASS);
966 acpi_driver_data(device) = battery;
968 result = acpi_battery_get_status(battery);
972 acpi_battery_init_update_flag(battery) = 1;
974 result = acpi_battery_add_fs(device);
978 status = acpi_install_notify_handler(device->handle,
980 acpi_battery_notify, battery);
981 if (ACPI_FAILURE(status)) {
982 ACPI_EXCEPTION((AE_INFO, status, "Installing notify handler"));
987 printk(KERN_INFO PREFIX "%s Slot [%s] (battery %s)\n",
988 ACPI_BATTERY_DEVICE_NAME, acpi_device_bid(device),
989 device->status.battery_present ? "present" : "absent");
994 acpi_battery_remove_fs(device);
998 acpi_battery_mutex_unlock(battery);
1003 static int acpi_battery_remove(struct acpi_device *device, int type)
1005 acpi_status status = 0;
1006 struct acpi_battery *battery = NULL;
1008 if (!device || !acpi_driver_data(device))
1011 battery = acpi_driver_data(device);
1013 acpi_battery_mutex_lock(battery);
1015 status = acpi_remove_notify_handler(device->handle,
1017 acpi_battery_notify);
1019 acpi_battery_remove_fs(device);
1021 if (battery->bif_data.pointer)
1022 kfree(battery->bif_data.pointer);
1024 if (battery->bst_data.pointer)
1025 kfree(battery->bst_data.pointer);
1027 acpi_battery_mutex_unlock(battery);
1029 mutex_destroy(&battery->mutex);
1036 /* this is needed to learn about changes made in suspended state */
1037 static int acpi_battery_resume(struct acpi_device *device)
1039 struct acpi_battery *battery;
1044 battery = device->driver_data;
1046 acpi_battery_init_update_flag(battery) = 1;
1051 static int __init acpi_battery_init(void)
1058 acpi_battery_dir = acpi_lock_battery_dir();
1059 if (!acpi_battery_dir)
1062 result = acpi_bus_register_driver(&acpi_battery_driver);
1064 acpi_unlock_battery_dir(acpi_battery_dir);
1071 static void __exit acpi_battery_exit(void)
1073 acpi_bus_unregister_driver(&acpi_battery_driver);
1075 acpi_unlock_battery_dir(acpi_battery_dir);
1080 module_init(acpi_battery_init);
1081 module_exit(acpi_battery_exit);