Lines Matching full:asus
3 * asus-laptop.c - Asus Laptop Support
44 #define ASUS_LAPTOP_NAME "Asus Laptop Support"
112 * Some events we use, same for all Asus
217 struct asus_laptop *asus; member
228 struct asus_laptop *asus; member
413 static bool asus_check_pega_lucid(struct asus_laptop *asus) in asus_check_pega_lucid() argument
415 return !strcmp(asus->name, DEVICE_NAME_PEGA) && in asus_check_pega_lucid()
416 !acpi_check_handle(asus->handle, METHOD_PEGA_ENABLE, NULL) && in asus_check_pega_lucid()
417 !acpi_check_handle(asus->handle, METHOD_PEGA_DISABLE, NULL) && in asus_check_pega_lucid()
418 !acpi_check_handle(asus->handle, METHOD_PEGA_READ, NULL); in asus_check_pega_lucid()
421 static int asus_pega_lucid_set(struct asus_laptop *asus, int unit, bool enable) in asus_pega_lucid_set() argument
424 return write_acpi_int(asus->handle, method, unit); in asus_pega_lucid_set()
427 static int pega_acc_axis(struct asus_laptop *asus, int curr, char *method) in pega_acc_axis() argument
434 status = acpi_evaluate_integer(asus->handle, method, NULL, &val); in pega_acc_axis()
453 struct asus_laptop *asus = dev_get_drvdata(parent); in pega_accel_poll() local
459 if (!asus->pega_acc_live) { in pega_accel_poll()
460 asus->pega_acc_live = true; in pega_accel_poll()
468 asus->pega_acc_x = pega_acc_axis(asus, asus->pega_acc_x, METHOD_XLRX); in pega_accel_poll()
469 asus->pega_acc_y = pega_acc_axis(asus, asus->pega_acc_y, METHOD_XLRY); in pega_accel_poll()
470 asus->pega_acc_z = pega_acc_axis(asus, asus->pega_acc_z, METHOD_XLRZ); in pega_accel_poll()
475 input_report_abs(input, ABS_X, -asus->pega_acc_x); in pega_accel_poll()
476 input_report_abs(input, ABS_Y, -asus->pega_acc_y); in pega_accel_poll()
477 input_report_abs(input, ABS_Z, asus->pega_acc_z); in pega_accel_poll()
481 static void pega_accel_exit(struct asus_laptop *asus) in pega_accel_exit() argument
483 if (asus->pega_accel_poll) { in pega_accel_exit()
484 input_unregister_device(asus->pega_accel_poll); in pega_accel_exit()
485 asus->pega_accel_poll = NULL; in pega_accel_exit()
489 static int pega_accel_init(struct asus_laptop *asus) in pega_accel_init() argument
494 if (!asus->is_pega_lucid) in pega_accel_init()
497 if (acpi_check_handle(asus->handle, METHOD_XLRX, NULL) || in pega_accel_init()
498 acpi_check_handle(asus->handle, METHOD_XLRY, NULL) || in pega_accel_init()
499 acpi_check_handle(asus->handle, METHOD_XLRZ, NULL)) in pega_accel_init()
508 input->dev.parent = &asus->platform_device->dev; in pega_accel_init()
530 asus->pega_accel_poll = input; in pega_accel_init()
539 static int asus_led_set(struct asus_laptop *asus, const char *method, in asus_led_set() argument
549 return write_acpi_int(asus->handle, method, value); in asus_led_set()
560 struct asus_laptop *asus = led->asus; in asus_led_cdev_set() local
563 queue_work(asus->led_workqueue, &led->work); in asus_led_cdev_set()
569 struct asus_laptop *asus = led->asus; in asus_led_cdev_update() local
571 asus_led_set(asus, led->method, led->wk); in asus_led_cdev_update()
582 static int asus_kled_lvl(struct asus_laptop *asus) in asus_kled_lvl() argument
594 rv = acpi_evaluate_integer(asus->handle, METHOD_KBD_LIGHT_GET, in asus_kled_lvl()
603 static int asus_kled_set(struct asus_laptop *asus, int kblv) in asus_kled_set() argument
610 if (write_acpi_int(asus->handle, METHOD_KBD_LIGHT_SET, kblv)) { in asus_kled_set()
621 struct asus_laptop *asus = led->asus; in asus_kled_cdev_set() local
624 queue_work(asus->led_workqueue, &led->work); in asus_kled_cdev_set()
630 struct asus_laptop *asus = led->asus; in asus_kled_cdev_update() local
632 asus_kled_set(asus, led->wk); in asus_kled_cdev_update()
638 struct asus_laptop *asus = led->asus; in asus_kled_cdev_get() local
640 return asus_kled_lvl(asus); in asus_kled_cdev_get()
643 static void asus_led_exit(struct asus_laptop *asus) in asus_led_exit() argument
645 led_classdev_unregister(&asus->wled.led); in asus_led_exit()
646 led_classdev_unregister(&asus->bled.led); in asus_led_exit()
647 led_classdev_unregister(&asus->mled.led); in asus_led_exit()
648 led_classdev_unregister(&asus->tled.led); in asus_led_exit()
649 led_classdev_unregister(&asus->pled.led); in asus_led_exit()
650 led_classdev_unregister(&asus->rled.led); in asus_led_exit()
651 led_classdev_unregister(&asus->gled.led); in asus_led_exit()
652 led_classdev_unregister(&asus->kled.led); in asus_led_exit()
654 if (asus->led_workqueue) { in asus_led_exit()
655 destroy_workqueue(asus->led_workqueue); in asus_led_exit()
656 asus->led_workqueue = NULL; in asus_led_exit()
661 static int asus_led_register(struct asus_laptop *asus, in asus_led_register() argument
667 if (!method || acpi_check_handle(asus->handle, method, NULL)) in asus_led_register()
670 led->asus = asus; in asus_led_register()
678 return led_classdev_register(&asus->platform_device->dev, led_cdev); in asus_led_register()
681 static int asus_led_init(struct asus_laptop *asus) in asus_led_init() argument
689 if (asus->is_pega_lucid) in asus_led_init()
695 * subsystem asks, we avoid messing with the Asus ACPI stuff during a in asus_led_init()
698 asus->led_workqueue = create_singlethread_workqueue("led_workqueue"); in asus_led_init()
699 if (!asus->led_workqueue) in asus_led_init()
702 if (asus->wled_type == TYPE_LED) in asus_led_init()
703 r = asus_led_register(asus, &asus->wled, "asus::wlan", in asus_led_init()
707 if (asus->bled_type == TYPE_LED) in asus_led_init()
708 r = asus_led_register(asus, &asus->bled, "asus::bluetooth", in asus_led_init()
712 r = asus_led_register(asus, &asus->mled, "asus::mail", METHOD_MLED); in asus_led_init()
715 r = asus_led_register(asus, &asus->tled, "asus::touchpad", METHOD_TLED); in asus_led_init()
718 r = asus_led_register(asus, &asus->rled, "asus::record", METHOD_RLED); in asus_led_init()
721 r = asus_led_register(asus, &asus->pled, "asus::phone", METHOD_PLED); in asus_led_init()
724 r = asus_led_register(asus, &asus->gled, "asus::gaming", METHOD_GLED); in asus_led_init()
727 if (!acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_SET, NULL) && in asus_led_init()
728 !acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_GET, NULL)) { in asus_led_init()
729 struct asus_led *led = &asus->kled; in asus_led_init()
732 led->asus = asus; in asus_led_init()
735 cdev->name = "asus::kbd_backlight"; in asus_led_init()
739 r = led_classdev_register(&asus->platform_device->dev, cdev); in asus_led_init()
743 asus_led_exit(asus); in asus_led_init()
752 struct asus_laptop *asus = bl_get_data(bd); in asus_read_brightness() local
756 rv = acpi_evaluate_integer(asus->handle, METHOD_BRIGHTNESS_GET, in asus_read_brightness()
768 struct asus_laptop *asus = bl_get_data(bd); in asus_set_brightness() local
770 if (write_acpi_int(asus->handle, METHOD_BRIGHTNESS_SET, value)) { in asus_set_brightness()
789 static int asus_backlight_notify(struct asus_laptop *asus) in asus_backlight_notify() argument
791 struct backlight_device *bd = asus->backlight_device; in asus_backlight_notify()
799 static int asus_backlight_init(struct asus_laptop *asus) in asus_backlight_init() argument
804 if (acpi_check_handle(asus->handle, METHOD_BRIGHTNESS_GET, NULL) || in asus_backlight_init()
805 acpi_check_handle(asus->handle, METHOD_BRIGHTNESS_SET, NULL)) in asus_backlight_init()
813 &asus->platform_device->dev, asus, in asus_backlight_init()
816 pr_err("Could not register asus backlight device\n"); in asus_backlight_init()
817 asus->backlight_device = NULL; in asus_backlight_init()
821 asus->backlight_device = bd; in asus_backlight_init()
828 static void asus_backlight_exit(struct asus_laptop *asus) in asus_backlight_exit() argument
830 backlight_device_unregister(asus->backlight_device); in asus_backlight_exit()
831 asus->backlight_device = NULL; in asus_backlight_exit()
846 struct asus_laptop *asus = dev_get_drvdata(dev); in infos_show() local
858 len += sysfs_emit_at(page, len, "Model reference : %s\n", asus->name); in infos_show()
865 rv = acpi_evaluate_integer(asus->handle, "SFUN", NULL, &temp); in infos_show()
877 rv = acpi_evaluate_integer(asus->handle, "HWRS", NULL, &temp); in infos_show()
888 rv = acpi_evaluate_integer(asus->handle, "ASYM", NULL, &temp); in infos_show()
892 if (asus->dsdt_info) { in infos_show()
893 snprintf(buf, 16, "%d", asus->dsdt_info->length); in infos_show()
895 snprintf(buf, 16, "%d", asus->dsdt_info->checksum); in infos_show()
897 snprintf(buf, 16, "%d", asus->dsdt_info->revision); in infos_show()
899 snprintf(buf, 7, "%s", asus->dsdt_info->oem_id); in infos_show()
901 snprintf(buf, 9, "%s", asus->dsdt_info->oem_table_id); in infos_show()
903 snprintf(buf, 16, "%x", asus->dsdt_info->oem_revision); in infos_show()
905 snprintf(buf, 5, "%s", asus->dsdt_info->asl_compiler_id); in infos_show()
907 snprintf(buf, 16, "%x", asus->dsdt_info->asl_compiler_revision); in infos_show()
915 static ssize_t sysfs_acpi_set(struct asus_laptop *asus, in sysfs_acpi_set() argument
925 if (write_acpi_int(asus->handle, method, value)) in sysfs_acpi_set()
936 struct asus_laptop *asus = dev_get_drvdata(dev); in ledd_show() local
938 return sysfs_emit(buf, "0x%08x\n", asus->ledd_status); in ledd_show()
944 struct asus_laptop *asus = dev_get_drvdata(dev); in ledd_store() local
951 if (write_acpi_int(asus->handle, METHOD_LEDD, value)) { in ledd_store()
956 asus->ledd_status = (u32) value; in ledd_store()
964 static int asus_wireless_status(struct asus_laptop *asus, int mask) in asus_wireless_status() argument
969 if (!asus->have_rsts) in asus_wireless_status()
970 return (asus->wireless_status & mask) ? 1 : 0; in asus_wireless_status()
972 rv = acpi_evaluate_integer(asus->handle, METHOD_WL_STATUS, in asus_wireless_status()
984 static int asus_wlan_set(struct asus_laptop *asus, int status) in asus_wlan_set() argument
986 if (write_acpi_int(asus->handle, METHOD_WLAN, !!status)) { in asus_wlan_set()
996 struct asus_laptop *asus = dev_get_drvdata(dev); in wlan_show() local
998 return sysfs_emit(buf, "%d\n", asus_wireless_status(asus, WL_RSTS)); in wlan_show()
1004 struct asus_laptop *asus = dev_get_drvdata(dev); in wlan_store() local
1006 return sysfs_acpi_set(asus, buf, count, METHOD_WLAN); in wlan_store()
1013 static int asus_bluetooth_set(struct asus_laptop *asus, int status) in asus_bluetooth_set() argument
1015 if (write_acpi_int(asus->handle, METHOD_BLUETOOTH, !!status)) { in asus_bluetooth_set()
1025 struct asus_laptop *asus = dev_get_drvdata(dev); in bluetooth_show() local
1027 return sysfs_emit(buf, "%d\n", asus_wireless_status(asus, BT_RSTS)); in bluetooth_show()
1034 struct asus_laptop *asus = dev_get_drvdata(dev); in bluetooth_store() local
1036 return sysfs_acpi_set(asus, buf, count, METHOD_BLUETOOTH); in bluetooth_store()
1043 static int asus_wimax_set(struct asus_laptop *asus, int status) in asus_wimax_set() argument
1045 if (write_acpi_int(asus->handle, METHOD_WIMAX, !!status)) { in asus_wimax_set()
1055 struct asus_laptop *asus = dev_get_drvdata(dev); in wimax_show() local
1057 return sysfs_emit(buf, "%d\n", asus_wireless_status(asus, WM_RSTS)); in wimax_show()
1063 struct asus_laptop *asus = dev_get_drvdata(dev); in wimax_store() local
1065 return sysfs_acpi_set(asus, buf, count, METHOD_WIMAX); in wimax_store()
1072 static int asus_wwan_set(struct asus_laptop *asus, int status) in asus_wwan_set() argument
1074 if (write_acpi_int(asus->handle, METHOD_WWAN, !!status)) { in asus_wwan_set()
1084 struct asus_laptop *asus = dev_get_drvdata(dev); in wwan_show() local
1086 return sysfs_emit(buf, "%d\n", asus_wireless_status(asus, WW_RSTS)); in wwan_show()
1092 struct asus_laptop *asus = dev_get_drvdata(dev); in wwan_store() local
1094 return sysfs_acpi_set(asus, buf, count, METHOD_WWAN); in wwan_store()
1101 static void asus_set_display(struct asus_laptop *asus, int value) in asus_set_display() argument
1104 if (write_acpi_int(asus->handle, METHOD_SWITCH_DISPLAY, value)) in asus_set_display()
1119 struct asus_laptop *asus = dev_get_drvdata(dev); in display_store() local
1126 asus_set_display(asus, value); in display_store()
1134 static void asus_als_switch(struct asus_laptop *asus, int value) in asus_als_switch() argument
1138 if (asus->is_pega_lucid) { in asus_als_switch()
1139 ret = asus_pega_lucid_set(asus, PEGA_ALS, value); in asus_als_switch()
1141 ret = asus_pega_lucid_set(asus, PEGA_ALS_POWER, value); in asus_als_switch()
1143 ret = write_acpi_int(asus->handle, METHOD_ALS_CONTROL, value); in asus_als_switch()
1148 asus->light_switch = value; in asus_als_switch()
1154 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_switch_show() local
1156 return sysfs_emit(buf, "%d\n", asus->light_switch); in ls_switch_show()
1163 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_switch_store() local
1170 asus_als_switch(asus, value ? 1 : 0); in ls_switch_store()
1175 static void asus_als_level(struct asus_laptop *asus, int value) in asus_als_level() argument
1177 if (write_acpi_int(asus->handle, METHOD_ALS_LEVEL, value)) in asus_als_level()
1179 asus->light_level = value; in asus_als_level()
1185 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_level_show() local
1187 return sysfs_emit(buf, "%d\n", asus->light_level); in ls_level_show()
1193 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_level_store() local
1202 asus_als_level(asus, value); in ls_level_store()
1208 static int pega_int_read(struct asus_laptop *asus, int arg, int *result) in pega_int_read() argument
1211 int err = write_acpi_int_ret(asus->handle, METHOD_PEGA_READ, arg, in pega_int_read()
1226 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_value_show() local
1229 err = pega_int_read(asus, PEGA_READ_ALS_H, &hi); in ls_value_show()
1231 err = pega_int_read(asus, PEGA_READ_ALS_L, &lo); in ls_value_show()
1241 static int asus_gps_status(struct asus_laptop *asus) in asus_gps_status() argument
1246 rv = acpi_evaluate_integer(asus->handle, METHOD_GPS_STATUS, in asus_gps_status()
1255 static int asus_gps_switch(struct asus_laptop *asus, int status) in asus_gps_switch() argument
1259 if (write_acpi_int(asus->handle, meth, 0x02)) in asus_gps_switch()
1267 struct asus_laptop *asus = dev_get_drvdata(dev); in gps_show() local
1269 return sysfs_emit(buf, "%d\n", asus_gps_status(asus)); in gps_show()
1275 struct asus_laptop *asus = dev_get_drvdata(dev); in gps_store() local
1282 ret = asus_gps_switch(asus, !!value); in gps_store()
1285 rfkill_set_sw_state(asus->gps.rfkill, !value); in gps_store()
1295 struct asus_laptop *asus = data; in asus_gps_rfkill_set() local
1297 return asus_gps_switch(asus, !blocked); in asus_gps_rfkill_set()
1307 struct asus_laptop *asus = rfk->asus; in asus_rfkill_set() local
1310 return asus_wlan_set(asus, !blocked); in asus_rfkill_set()
1312 return asus_bluetooth_set(asus, !blocked); in asus_rfkill_set()
1314 return asus_wimax_set(asus, !blocked); in asus_rfkill_set()
1316 return asus_wwan_set(asus, !blocked); in asus_rfkill_set()
1335 static void asus_rfkill_exit(struct asus_laptop *asus) in asus_rfkill_exit() argument
1337 asus_rfkill_terminate(&asus->wwan); in asus_rfkill_exit()
1338 asus_rfkill_terminate(&asus->bluetooth); in asus_rfkill_exit()
1339 asus_rfkill_terminate(&asus->wlan); in asus_rfkill_exit()
1340 asus_rfkill_terminate(&asus->gps); in asus_rfkill_exit()
1343 static int asus_rfkill_setup(struct asus_laptop *asus, struct asus_rfkill *rfk, in asus_rfkill_setup() argument
1350 rfk->asus = asus; in asus_rfkill_setup()
1351 rfk->rfkill = rfkill_alloc(name, &asus->platform_device->dev, in asus_rfkill_setup()
1365 static int asus_rfkill_init(struct asus_laptop *asus) in asus_rfkill_init() argument
1369 if (asus->is_pega_lucid) in asus_rfkill_init()
1372 if (!acpi_check_handle(asus->handle, METHOD_GPS_ON, NULL) && in asus_rfkill_init()
1373 !acpi_check_handle(asus->handle, METHOD_GPS_OFF, NULL) && in asus_rfkill_init()
1374 !acpi_check_handle(asus->handle, METHOD_GPS_STATUS, NULL)) in asus_rfkill_init()
1375 result = asus_rfkill_setup(asus, &asus->gps, "asus-gps", in asus_rfkill_init()
1382 if (!acpi_check_handle(asus->handle, METHOD_WLAN, NULL) && in asus_rfkill_init()
1383 asus->wled_type == TYPE_RFKILL) in asus_rfkill_init()
1384 result = asus_rfkill_setup(asus, &asus->wlan, "asus-wlan", in asus_rfkill_init()
1390 if (!acpi_check_handle(asus->handle, METHOD_BLUETOOTH, NULL) && in asus_rfkill_init()
1391 asus->bled_type == TYPE_RFKILL) in asus_rfkill_init()
1392 result = asus_rfkill_setup(asus, &asus->bluetooth, in asus_rfkill_init()
1393 "asus-bluetooth", BT_RSTS, in asus_rfkill_init()
1399 if (!acpi_check_handle(asus->handle, METHOD_WWAN, NULL)) in asus_rfkill_init()
1400 result = asus_rfkill_setup(asus, &asus->wwan, "asus-wwan", in asus_rfkill_init()
1406 if (!acpi_check_handle(asus->handle, METHOD_WIMAX, NULL)) in asus_rfkill_init()
1407 result = asus_rfkill_setup(asus, &asus->wimax, "asus-wimax", in asus_rfkill_init()
1415 asus_rfkill_exit(asus); in asus_rfkill_init()
1424 int ret = asus_pega_lucid_set(rfk->asus, rfk->control_id, !blocked); in pega_rfkill_set()
1432 static int pega_rfkill_setup(struct asus_laptop *asus, struct asus_rfkill *rfk, in pega_rfkill_setup() argument
1435 return asus_rfkill_setup(asus, rfk, name, controlid, rfkill_type, in pega_rfkill_setup()
1439 static int pega_rfkill_init(struct asus_laptop *asus) in pega_rfkill_init() argument
1443 if(!asus->is_pega_lucid) in pega_rfkill_init()
1446 ret = pega_rfkill_setup(asus, &asus->wlan, "pega-wlan", in pega_rfkill_init()
1451 ret = pega_rfkill_setup(asus, &asus->bluetooth, "pega-bt", in pega_rfkill_init()
1456 ret = pega_rfkill_setup(asus, &asus->wwan, "pega-wwan", in pega_rfkill_init()
1461 asus_rfkill_exit(asus); in pega_rfkill_init()
1469 static void asus_input_notify(struct asus_laptop *asus, int event) in asus_input_notify() argument
1471 if (!asus->inputdev) in asus_input_notify()
1473 if (!sparse_keymap_report_event(asus->inputdev, event, 1, true)) in asus_input_notify()
1477 static int asus_input_init(struct asus_laptop *asus) in asus_input_init() argument
1486 input->name = "Asus Laptop extra buttons"; in asus_input_init()
1489 input->dev.parent = &asus->platform_device->dev; in asus_input_init()
1502 asus->inputdev = input; in asus_input_init()
1510 static void asus_input_exit(struct asus_laptop *asus) in asus_input_exit() argument
1512 if (asus->inputdev) in asus_input_exit()
1513 input_unregister_device(asus->inputdev); in asus_input_exit()
1514 asus->inputdev = NULL; in asus_input_exit()
1522 struct asus_laptop *asus = acpi_driver_data(device); in asus_acpi_notify() local
1526 count = asus->event_count[event % 128]++; in asus_acpi_notify()
1527 acpi_bus_generate_netlink_event(asus->device->pnp.device_class, in asus_acpi_notify()
1528 dev_name(&asus->device->dev), event, in asus_acpi_notify()
1539 if (asus->backlight_device != NULL) { in asus_acpi_notify()
1541 asus_backlight_notify(asus); in asus_acpi_notify()
1547 if (asus->pega_accel_poll && event == 0xEA) { in asus_acpi_notify()
1548 kobject_uevent(&asus->pega_accel_poll->dev.kobj, KOBJ_CHANGE); in asus_acpi_notify()
1552 asus_input_notify(asus, event); in asus_acpi_notify()
1575 struct asus_laptop *asus = dev_get_drvdata(dev); in asus_sysfs_is_visible() local
1576 acpi_handle handle = asus->handle; in asus_sysfs_is_visible()
1579 if (asus->is_pega_lucid) { in asus_sysfs_is_visible()
1603 !acpi_check_handle(asus->handle, METHOD_WIMAX, NULL); in asus_sysfs_is_visible()
1606 supported = !acpi_check_handle(asus->handle, METHOD_WWAN, NULL); in asus_sysfs_is_visible()
1616 supported = asus->is_pega_lucid; in asus_sysfs_is_visible()
1634 static int asus_platform_init(struct asus_laptop *asus) in asus_platform_init() argument
1638 asus->platform_device = platform_device_alloc(ASUS_LAPTOP_FILE, PLATFORM_DEVID_NONE); in asus_platform_init()
1639 if (!asus->platform_device) in asus_platform_init()
1641 platform_set_drvdata(asus->platform_device, asus); in asus_platform_init()
1643 result = platform_device_add(asus->platform_device); in asus_platform_init()
1647 result = sysfs_create_group(&asus->platform_device->dev.kobj, in asus_platform_init()
1655 platform_device_del(asus->platform_device); in asus_platform_init()
1657 platform_device_put(asus->platform_device); in asus_platform_init()
1661 static void asus_platform_exit(struct asus_laptop *asus) in asus_platform_exit() argument
1663 sysfs_remove_group(&asus->platform_device->dev.kobj, &asus_attr_group); in asus_platform_exit()
1664 platform_device_unregister(asus->platform_device); in asus_platform_exit()
1678 static int asus_laptop_get_info(struct asus_laptop *asus) in asus_laptop_get_info() argument
1693 status = acpi_get_table(ACPI_SIG_DSDT, 1, &asus->dsdt_info); in asus_laptop_get_info()
1697 /* We have to write 0 on init this far for all ASUS models */ in asus_laptop_get_info()
1698 if (write_acpi_int_ret(asus->handle, "INIT", 0, &buffer)) { in asus_laptop_get_info()
1705 acpi_evaluate_integer(asus->handle, "BSTS", NULL, &bsts_result); in asus_laptop_get_info()
1713 if (write_acpi_int(asus->handle, "CWAP", wapf)) in asus_laptop_get_info()
1735 asus->name = kstrdup(string, GFP_KERNEL); in asus_laptop_get_info()
1736 if (!asus->name) { in asus_laptop_get_info()
1744 if (!acpi_check_handle(asus->handle, METHOD_WL_STATUS, NULL)) in asus_laptop_get_info()
1745 asus->have_rsts = true; in asus_laptop_get_info()
1752 static int asus_acpi_init(struct asus_laptop *asus) in asus_acpi_init() argument
1756 result = acpi_bus_get_status(asus->device); in asus_acpi_init()
1759 if (!asus->device->status.present) { in asus_acpi_init()
1764 result = asus_laptop_get_info(asus); in asus_acpi_init()
1769 asus->bled_type = TYPE_LED; in asus_acpi_init()
1771 asus->bled_type = TYPE_RFKILL; in asus_acpi_init()
1774 asus->wled_type = TYPE_LED; in asus_acpi_init()
1776 asus->wled_type = TYPE_RFKILL; in asus_acpi_init()
1779 asus_bluetooth_set(asus, !!bluetooth_status); in asus_acpi_init()
1782 asus_wlan_set(asus, !!wlan_status); in asus_acpi_init()
1785 asus_wimax_set(asus, !!wimax_status); in asus_acpi_init()
1788 asus_wwan_set(asus, !!wwan_status); in asus_acpi_init()
1791 if (!acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_SET, NULL)) in asus_acpi_init()
1792 asus_kled_set(asus, 1); in asus_acpi_init()
1795 asus->ledd_status = 0xFFF; in asus_acpi_init()
1798 asus->light_switch = !!als_status; in asus_acpi_init()
1799 asus->light_level = 5; /* level 5 for sensor sensitivity */ in asus_acpi_init()
1801 if (asus->is_pega_lucid) { in asus_acpi_init()
1802 asus_als_switch(asus, asus->light_switch); in asus_acpi_init()
1803 } else if (!acpi_check_handle(asus->handle, METHOD_ALS_CONTROL, NULL) && in asus_acpi_init()
1804 !acpi_check_handle(asus->handle, METHOD_ALS_LEVEL, NULL)) { in asus_acpi_init()
1805 asus_als_switch(asus, asus->light_switch); in asus_acpi_init()
1806 asus_als_level(asus, asus->light_level); in asus_acpi_init()
1829 struct asus_laptop *asus; in asus_acpi_add() local
1832 pr_notice("Asus Laptop Support version %s\n", in asus_acpi_add()
1834 asus = kzalloc(sizeof(struct asus_laptop), GFP_KERNEL); in asus_acpi_add()
1835 if (!asus) in asus_acpi_add()
1837 asus->handle = device->handle; in asus_acpi_add()
1840 device->driver_data = asus; in asus_acpi_add()
1841 asus->device = device; in asus_acpi_add()
1845 result = asus_acpi_init(asus); in asus_acpi_add()
1853 asus->is_pega_lucid = asus_check_pega_lucid(asus); in asus_acpi_add()
1854 result = asus_platform_init(asus); in asus_acpi_add()
1859 result = asus_backlight_init(asus); in asus_acpi_add()
1864 result = asus_input_init(asus); in asus_acpi_add()
1868 result = asus_led_init(asus); in asus_acpi_add()
1872 result = asus_rfkill_init(asus); in asus_acpi_add()
1876 result = pega_accel_init(asus); in asus_acpi_add()
1880 result = pega_rfkill_init(asus); in asus_acpi_add()
1888 pega_accel_exit(asus); in asus_acpi_add()
1890 asus_rfkill_exit(asus); in asus_acpi_add()
1892 asus_led_exit(asus); in asus_acpi_add()
1894 asus_input_exit(asus); in asus_acpi_add()
1896 asus_backlight_exit(asus); in asus_acpi_add()
1898 asus_platform_exit(asus); in asus_acpi_add()
1900 kfree(asus); in asus_acpi_add()
1907 struct asus_laptop *asus = acpi_driver_data(device); in asus_acpi_remove() local
1909 asus_backlight_exit(asus); in asus_acpi_remove()
1910 asus_rfkill_exit(asus); in asus_acpi_remove()
1911 asus_led_exit(asus); in asus_acpi_remove()
1912 asus_input_exit(asus); in asus_acpi_remove()
1913 pega_accel_exit(asus); in asus_acpi_remove()
1914 asus_platform_exit(asus); in asus_acpi_remove()
1916 kfree(asus->name); in asus_acpi_remove()
1917 kfree(asus); in asus_acpi_remove()