Lines Matching refs:asus
234 struct asus_laptop *asus; member
245 struct asus_laptop *asus; member
430 static bool asus_check_pega_lucid(struct asus_laptop *asus) in asus_check_pega_lucid() argument
432 return !strcmp(asus->name, DEVICE_NAME_PEGA) && in asus_check_pega_lucid()
433 !acpi_check_handle(asus->handle, METHOD_PEGA_ENABLE, NULL) && in asus_check_pega_lucid()
434 !acpi_check_handle(asus->handle, METHOD_PEGA_DISABLE, NULL) && in asus_check_pega_lucid()
435 !acpi_check_handle(asus->handle, METHOD_PEGA_READ, NULL); in asus_check_pega_lucid()
438 static int asus_pega_lucid_set(struct asus_laptop *asus, int unit, bool enable) in asus_pega_lucid_set() argument
441 return write_acpi_int(asus->handle, method, unit); in asus_pega_lucid_set()
444 static int pega_acc_axis(struct asus_laptop *asus, int curr, char *method) in pega_acc_axis() argument
449 acpi_evaluate_integer(asus->handle, method, NULL, &val); in pega_acc_axis()
467 struct asus_laptop *asus = dev_get_drvdata(parent); in pega_accel_poll() local
473 if (!asus->pega_acc_live) { in pega_accel_poll()
474 asus->pega_acc_live = true; in pega_accel_poll()
482 asus->pega_acc_x = pega_acc_axis(asus, asus->pega_acc_x, METHOD_XLRX); in pega_accel_poll()
483 asus->pega_acc_y = pega_acc_axis(asus, asus->pega_acc_y, METHOD_XLRY); in pega_accel_poll()
484 asus->pega_acc_z = pega_acc_axis(asus, asus->pega_acc_z, METHOD_XLRZ); in pega_accel_poll()
489 input_report_abs(ipd->input, ABS_X, -asus->pega_acc_x); in pega_accel_poll()
490 input_report_abs(ipd->input, ABS_Y, -asus->pega_acc_y); in pega_accel_poll()
491 input_report_abs(ipd->input, ABS_Z, asus->pega_acc_z); in pega_accel_poll()
495 static void pega_accel_exit(struct asus_laptop *asus) in pega_accel_exit() argument
497 if (asus->pega_accel_poll) { in pega_accel_exit()
498 input_unregister_polled_device(asus->pega_accel_poll); in pega_accel_exit()
499 input_free_polled_device(asus->pega_accel_poll); in pega_accel_exit()
501 asus->pega_accel_poll = NULL; in pega_accel_exit()
504 static int pega_accel_init(struct asus_laptop *asus) in pega_accel_init() argument
509 if (!asus->is_pega_lucid) in pega_accel_init()
512 if (acpi_check_handle(asus->handle, METHOD_XLRX, NULL) || in pega_accel_init()
513 acpi_check_handle(asus->handle, METHOD_XLRY, NULL) || in pega_accel_init()
514 acpi_check_handle(asus->handle, METHOD_XLRZ, NULL)) in pega_accel_init()
528 ipd->input->dev.parent = &asus->platform_device->dev; in pega_accel_init()
543 asus->pega_accel_poll = ipd; in pega_accel_init()
552 static int asus_led_set(struct asus_laptop *asus, const char *method, in asus_led_set() argument
562 return write_acpi_int(asus->handle, method, value); in asus_led_set()
573 struct asus_laptop *asus = led->asus; in asus_led_cdev_set() local
576 queue_work(asus->led_workqueue, &led->work); in asus_led_cdev_set()
582 struct asus_laptop *asus = led->asus; in asus_led_cdev_update() local
584 asus_led_set(asus, led->method, led->wk); in asus_led_cdev_update()
595 static int asus_kled_lvl(struct asus_laptop *asus) in asus_kled_lvl() argument
607 rv = acpi_evaluate_integer(asus->handle, METHOD_KBD_LIGHT_GET, in asus_kled_lvl()
616 static int asus_kled_set(struct asus_laptop *asus, int kblv) in asus_kled_set() argument
623 if (write_acpi_int(asus->handle, METHOD_KBD_LIGHT_SET, kblv)) { in asus_kled_set()
634 struct asus_laptop *asus = led->asus; in asus_kled_cdev_set() local
637 queue_work(asus->led_workqueue, &led->work); in asus_kled_cdev_set()
643 struct asus_laptop *asus = led->asus; in asus_kled_cdev_update() local
645 asus_kled_set(asus, led->wk); in asus_kled_cdev_update()
651 struct asus_laptop *asus = led->asus; in asus_kled_cdev_get() local
653 return asus_kled_lvl(asus); in asus_kled_cdev_get()
656 static void asus_led_exit(struct asus_laptop *asus) in asus_led_exit() argument
658 if (!IS_ERR_OR_NULL(asus->wled.led.dev)) in asus_led_exit()
659 led_classdev_unregister(&asus->wled.led); in asus_led_exit()
660 if (!IS_ERR_OR_NULL(asus->bled.led.dev)) in asus_led_exit()
661 led_classdev_unregister(&asus->bled.led); in asus_led_exit()
662 if (!IS_ERR_OR_NULL(asus->mled.led.dev)) in asus_led_exit()
663 led_classdev_unregister(&asus->mled.led); in asus_led_exit()
664 if (!IS_ERR_OR_NULL(asus->tled.led.dev)) in asus_led_exit()
665 led_classdev_unregister(&asus->tled.led); in asus_led_exit()
666 if (!IS_ERR_OR_NULL(asus->pled.led.dev)) in asus_led_exit()
667 led_classdev_unregister(&asus->pled.led); in asus_led_exit()
668 if (!IS_ERR_OR_NULL(asus->rled.led.dev)) in asus_led_exit()
669 led_classdev_unregister(&asus->rled.led); in asus_led_exit()
670 if (!IS_ERR_OR_NULL(asus->gled.led.dev)) in asus_led_exit()
671 led_classdev_unregister(&asus->gled.led); in asus_led_exit()
672 if (!IS_ERR_OR_NULL(asus->kled.led.dev)) in asus_led_exit()
673 led_classdev_unregister(&asus->kled.led); in asus_led_exit()
674 if (asus->led_workqueue) { in asus_led_exit()
675 destroy_workqueue(asus->led_workqueue); in asus_led_exit()
676 asus->led_workqueue = NULL; in asus_led_exit()
681 static int asus_led_register(struct asus_laptop *asus, in asus_led_register() argument
687 if (!method || acpi_check_handle(asus->handle, method, NULL)) in asus_led_register()
690 led->asus = asus; in asus_led_register()
698 return led_classdev_register(&asus->platform_device->dev, led_cdev); in asus_led_register()
701 static int asus_led_init(struct asus_laptop *asus) in asus_led_init() argument
709 if (asus->is_pega_lucid) in asus_led_init()
718 asus->led_workqueue = create_singlethread_workqueue("led_workqueue"); in asus_led_init()
719 if (!asus->led_workqueue) in asus_led_init()
722 if (asus->wled_type == TYPE_LED) in asus_led_init()
723 r = asus_led_register(asus, &asus->wled, "asus::wlan", in asus_led_init()
727 if (asus->bled_type == TYPE_LED) in asus_led_init()
728 r = asus_led_register(asus, &asus->bled, "asus::bluetooth", in asus_led_init()
732 r = asus_led_register(asus, &asus->mled, "asus::mail", METHOD_MLED); in asus_led_init()
735 r = asus_led_register(asus, &asus->tled, "asus::touchpad", METHOD_TLED); in asus_led_init()
738 r = asus_led_register(asus, &asus->rled, "asus::record", METHOD_RLED); in asus_led_init()
741 r = asus_led_register(asus, &asus->pled, "asus::phone", METHOD_PLED); in asus_led_init()
744 r = asus_led_register(asus, &asus->gled, "asus::gaming", METHOD_GLED); in asus_led_init()
747 if (!acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_SET, NULL) && in asus_led_init()
748 !acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_GET, NULL)) { in asus_led_init()
749 struct asus_led *led = &asus->kled; in asus_led_init()
752 led->asus = asus; in asus_led_init()
759 r = led_classdev_register(&asus->platform_device->dev, cdev); in asus_led_init()
763 asus_led_exit(asus); in asus_led_init()
772 struct asus_laptop *asus = bl_get_data(bd); in asus_read_brightness() local
776 rv = acpi_evaluate_integer(asus->handle, METHOD_BRIGHTNESS_GET, in asus_read_brightness()
786 struct asus_laptop *asus = bl_get_data(bd); in asus_set_brightness() local
788 if (write_acpi_int(asus->handle, METHOD_BRIGHTNESS_SET, value)) { in asus_set_brightness()
807 static int asus_backlight_notify(struct asus_laptop *asus) in asus_backlight_notify() argument
809 struct backlight_device *bd = asus->backlight_device; in asus_backlight_notify()
817 static int asus_backlight_init(struct asus_laptop *asus) in asus_backlight_init() argument
822 if (acpi_check_handle(asus->handle, METHOD_BRIGHTNESS_GET, NULL) || in asus_backlight_init()
823 acpi_check_handle(asus->handle, METHOD_BRIGHTNESS_SET, NULL)) in asus_backlight_init()
831 &asus->platform_device->dev, asus, in asus_backlight_init()
835 asus->backlight_device = NULL; in asus_backlight_init()
839 asus->backlight_device = bd; in asus_backlight_init()
846 static void asus_backlight_exit(struct asus_laptop *asus) in asus_backlight_exit() argument
848 backlight_device_unregister(asus->backlight_device); in asus_backlight_exit()
849 asus->backlight_device = NULL; in asus_backlight_exit()
864 struct asus_laptop *asus = dev_get_drvdata(dev); in infos_show() local
876 len += sprintf(page + len, "Model reference : %s\n", asus->name); in infos_show()
883 rv = acpi_evaluate_integer(asus->handle, "SFUN", NULL, &temp); in infos_show()
895 rv = acpi_evaluate_integer(asus->handle, "HWRS", NULL, &temp); in infos_show()
906 rv = acpi_evaluate_integer(asus->handle, "ASYM", NULL, &temp); in infos_show()
910 if (asus->dsdt_info) { in infos_show()
911 snprintf(buf, 16, "%d", asus->dsdt_info->length); in infos_show()
913 snprintf(buf, 16, "%d", asus->dsdt_info->checksum); in infos_show()
915 snprintf(buf, 16, "%d", asus->dsdt_info->revision); in infos_show()
917 snprintf(buf, 7, "%s", asus->dsdt_info->oem_id); in infos_show()
919 snprintf(buf, 9, "%s", asus->dsdt_info->oem_table_id); in infos_show()
921 snprintf(buf, 16, "%x", asus->dsdt_info->oem_revision); in infos_show()
923 snprintf(buf, 5, "%s", asus->dsdt_info->asl_compiler_id); in infos_show()
925 snprintf(buf, 16, "%x", asus->dsdt_info->asl_compiler_revision); in infos_show()
944 static ssize_t sysfs_acpi_set(struct asus_laptop *asus, in sysfs_acpi_set() argument
955 if (write_acpi_int(asus->handle, method, value)) in sysfs_acpi_set()
966 struct asus_laptop *asus = dev_get_drvdata(dev); in ledd_show() local
968 return sprintf(buf, "0x%08x\n", asus->ledd_status); in ledd_show()
974 struct asus_laptop *asus = dev_get_drvdata(dev); in ledd_store() local
979 if (write_acpi_int(asus->handle, METHOD_LEDD, value)) { in ledd_store()
983 asus->ledd_status = (u32) value; in ledd_store()
992 static int asus_wireless_status(struct asus_laptop *asus, int mask) in asus_wireless_status() argument
997 if (!asus->have_rsts) in asus_wireless_status()
998 return (asus->wireless_status & mask) ? 1 : 0; in asus_wireless_status()
1000 rv = acpi_evaluate_integer(asus->handle, METHOD_WL_STATUS, in asus_wireless_status()
1012 static int asus_wlan_set(struct asus_laptop *asus, int status) in asus_wlan_set() argument
1014 if (write_acpi_int(asus->handle, METHOD_WLAN, !!status)) { in asus_wlan_set()
1024 struct asus_laptop *asus = dev_get_drvdata(dev); in wlan_show() local
1026 return sprintf(buf, "%d\n", asus_wireless_status(asus, WL_RSTS)); in wlan_show()
1032 struct asus_laptop *asus = dev_get_drvdata(dev); in wlan_store() local
1034 return sysfs_acpi_set(asus, buf, count, METHOD_WLAN); in wlan_store()
1041 static int asus_bluetooth_set(struct asus_laptop *asus, int status) in asus_bluetooth_set() argument
1043 if (write_acpi_int(asus->handle, METHOD_BLUETOOTH, !!status)) { in asus_bluetooth_set()
1053 struct asus_laptop *asus = dev_get_drvdata(dev); in bluetooth_show() local
1055 return sprintf(buf, "%d\n", asus_wireless_status(asus, BT_RSTS)); in bluetooth_show()
1062 struct asus_laptop *asus = dev_get_drvdata(dev); in bluetooth_store() local
1064 return sysfs_acpi_set(asus, buf, count, METHOD_BLUETOOTH); in bluetooth_store()
1071 static int asus_wimax_set(struct asus_laptop *asus, int status) in asus_wimax_set() argument
1073 if (write_acpi_int(asus->handle, METHOD_WIMAX, !!status)) { in asus_wimax_set()
1083 struct asus_laptop *asus = dev_get_drvdata(dev); in wimax_show() local
1085 return sprintf(buf, "%d\n", asus_wireless_status(asus, WM_RSTS)); in wimax_show()
1091 struct asus_laptop *asus = dev_get_drvdata(dev); in wimax_store() local
1093 return sysfs_acpi_set(asus, buf, count, METHOD_WIMAX); in wimax_store()
1100 static int asus_wwan_set(struct asus_laptop *asus, int status) in asus_wwan_set() argument
1102 if (write_acpi_int(asus->handle, METHOD_WWAN, !!status)) { in asus_wwan_set()
1112 struct asus_laptop *asus = dev_get_drvdata(dev); in wwan_show() local
1114 return sprintf(buf, "%d\n", asus_wireless_status(asus, WW_RSTS)); in wwan_show()
1120 struct asus_laptop *asus = dev_get_drvdata(dev); in wwan_store() local
1122 return sysfs_acpi_set(asus, buf, count, METHOD_WWAN); in wwan_store()
1129 static void asus_set_display(struct asus_laptop *asus, int value) in asus_set_display() argument
1132 if (write_acpi_int(asus->handle, METHOD_SWITCH_DISPLAY, value)) in asus_set_display()
1147 struct asus_laptop *asus = dev_get_drvdata(dev); in display_store() local
1152 asus_set_display(asus, value); in display_store()
1160 static void asus_als_switch(struct asus_laptop *asus, int value) in asus_als_switch() argument
1164 if (asus->is_pega_lucid) { in asus_als_switch()
1165 ret = asus_pega_lucid_set(asus, PEGA_ALS, value); in asus_als_switch()
1167 ret = asus_pega_lucid_set(asus, PEGA_ALS_POWER, value); in asus_als_switch()
1169 ret = write_acpi_int(asus->handle, METHOD_ALS_CONTROL, value); in asus_als_switch()
1174 asus->light_switch = value; in asus_als_switch()
1180 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_switch_show() local
1182 return sprintf(buf, "%d\n", asus->light_switch); in ls_switch_show()
1189 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_switch_store() local
1194 asus_als_switch(asus, value ? 1 : 0); in ls_switch_store()
1200 static void asus_als_level(struct asus_laptop *asus, int value) in asus_als_level() argument
1202 if (write_acpi_int(asus->handle, METHOD_ALS_LEVEL, value)) in asus_als_level()
1204 asus->light_level = value; in asus_als_level()
1210 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_level_show() local
1212 return sprintf(buf, "%d\n", asus->light_level); in ls_level_show()
1218 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_level_store() local
1225 asus_als_level(asus, value); in ls_level_store()
1232 static int pega_int_read(struct asus_laptop *asus, int arg, int *result) in pega_int_read() argument
1235 int err = write_acpi_int_ret(asus->handle, METHOD_PEGA_READ, arg, in pega_int_read()
1250 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_value_show() local
1253 err = pega_int_read(asus, PEGA_READ_ALS_H, &hi); in ls_value_show()
1255 err = pega_int_read(asus, PEGA_READ_ALS_L, &lo); in ls_value_show()
1265 static int asus_gps_status(struct asus_laptop *asus) in asus_gps_status() argument
1270 rv = acpi_evaluate_integer(asus->handle, METHOD_GPS_STATUS, in asus_gps_status()
1279 static int asus_gps_switch(struct asus_laptop *asus, int status) in asus_gps_switch() argument
1283 if (write_acpi_int(asus->handle, meth, 0x02)) in asus_gps_switch()
1291 struct asus_laptop *asus = dev_get_drvdata(dev); in gps_show() local
1293 return sprintf(buf, "%d\n", asus_gps_status(asus)); in gps_show()
1299 struct asus_laptop *asus = dev_get_drvdata(dev); in gps_store() local
1306 ret = asus_gps_switch(asus, !!value); in gps_store()
1309 rfkill_set_sw_state(asus->gps.rfkill, !value); in gps_store()
1319 struct asus_laptop *asus = data; in asus_gps_rfkill_set() local
1321 return asus_gps_switch(asus, !blocked); in asus_gps_rfkill_set()
1331 struct asus_laptop *asus = rfk->asus; in asus_rfkill_set() local
1334 return asus_wlan_set(asus, !blocked); in asus_rfkill_set()
1336 return asus_bluetooth_set(asus, !blocked); in asus_rfkill_set()
1338 return asus_wimax_set(asus, !blocked); in asus_rfkill_set()
1340 return asus_wwan_set(asus, !blocked); in asus_rfkill_set()
1359 static void asus_rfkill_exit(struct asus_laptop *asus) in asus_rfkill_exit() argument
1361 asus_rfkill_terminate(&asus->wwan); in asus_rfkill_exit()
1362 asus_rfkill_terminate(&asus->bluetooth); in asus_rfkill_exit()
1363 asus_rfkill_terminate(&asus->wlan); in asus_rfkill_exit()
1364 asus_rfkill_terminate(&asus->gps); in asus_rfkill_exit()
1367 static int asus_rfkill_setup(struct asus_laptop *asus, struct asus_rfkill *rfk, in asus_rfkill_setup() argument
1374 rfk->asus = asus; in asus_rfkill_setup()
1375 rfk->rfkill = rfkill_alloc(name, &asus->platform_device->dev, in asus_rfkill_setup()
1389 static int asus_rfkill_init(struct asus_laptop *asus) in asus_rfkill_init() argument
1393 if (asus->is_pega_lucid) in asus_rfkill_init()
1396 if (!acpi_check_handle(asus->handle, METHOD_GPS_ON, NULL) && in asus_rfkill_init()
1397 !acpi_check_handle(asus->handle, METHOD_GPS_OFF, NULL) && in asus_rfkill_init()
1398 !acpi_check_handle(asus->handle, METHOD_GPS_STATUS, NULL)) in asus_rfkill_init()
1399 result = asus_rfkill_setup(asus, &asus->gps, "asus-gps", in asus_rfkill_init()
1406 if (!acpi_check_handle(asus->handle, METHOD_WLAN, NULL) && in asus_rfkill_init()
1407 asus->wled_type == TYPE_RFKILL) in asus_rfkill_init()
1408 result = asus_rfkill_setup(asus, &asus->wlan, "asus-wlan", in asus_rfkill_init()
1414 if (!acpi_check_handle(asus->handle, METHOD_BLUETOOTH, NULL) && in asus_rfkill_init()
1415 asus->bled_type == TYPE_RFKILL) in asus_rfkill_init()
1416 result = asus_rfkill_setup(asus, &asus->bluetooth, in asus_rfkill_init()
1423 if (!acpi_check_handle(asus->handle, METHOD_WWAN, NULL)) in asus_rfkill_init()
1424 result = asus_rfkill_setup(asus, &asus->wwan, "asus-wwan", in asus_rfkill_init()
1430 if (!acpi_check_handle(asus->handle, METHOD_WIMAX, NULL)) in asus_rfkill_init()
1431 result = asus_rfkill_setup(asus, &asus->wimax, "asus-wimax", in asus_rfkill_init()
1439 asus_rfkill_exit(asus); in asus_rfkill_init()
1448 int ret = asus_pega_lucid_set(rfk->asus, rfk->control_id, !blocked); in pega_rfkill_set()
1456 static int pega_rfkill_setup(struct asus_laptop *asus, struct asus_rfkill *rfk, in pega_rfkill_setup() argument
1459 return asus_rfkill_setup(asus, rfk, name, controlid, rfkill_type, in pega_rfkill_setup()
1463 static int pega_rfkill_init(struct asus_laptop *asus) in pega_rfkill_init() argument
1467 if(!asus->is_pega_lucid) in pega_rfkill_init()
1470 ret = pega_rfkill_setup(asus, &asus->wlan, "pega-wlan", in pega_rfkill_init()
1475 ret = pega_rfkill_setup(asus, &asus->bluetooth, "pega-bt", in pega_rfkill_init()
1480 ret = pega_rfkill_setup(asus, &asus->wwan, "pega-wwan", in pega_rfkill_init()
1485 asus_rfkill_exit(asus); in pega_rfkill_init()
1493 static void asus_input_notify(struct asus_laptop *asus, int event) in asus_input_notify() argument
1495 if (!asus->inputdev) in asus_input_notify()
1497 if (!sparse_keymap_report_event(asus->inputdev, event, 1, true)) in asus_input_notify()
1501 static int asus_input_init(struct asus_laptop *asus) in asus_input_init() argument
1513 input->dev.parent = &asus->platform_device->dev; in asus_input_init()
1526 asus->inputdev = input; in asus_input_init()
1536 static void asus_input_exit(struct asus_laptop *asus) in asus_input_exit() argument
1538 if (asus->inputdev) { in asus_input_exit()
1539 sparse_keymap_free(asus->inputdev); in asus_input_exit()
1540 input_unregister_device(asus->inputdev); in asus_input_exit()
1542 asus->inputdev = NULL; in asus_input_exit()
1550 struct asus_laptop *asus = acpi_driver_data(device); in asus_acpi_notify() local
1554 count = asus->event_count[event % 128]++; in asus_acpi_notify()
1555 acpi_bus_generate_netlink_event(asus->device->pnp.device_class, in asus_acpi_notify()
1556 dev_name(&asus->device->dev), event, in asus_acpi_notify()
1567 if (asus->backlight_device != NULL) { in asus_acpi_notify()
1569 asus_backlight_notify(asus); in asus_acpi_notify()
1575 if (asus->pega_accel_poll && event == 0xEA) { in asus_acpi_notify()
1576 kobject_uevent(&asus->pega_accel_poll->input->dev.kobj, in asus_acpi_notify()
1581 asus_input_notify(asus, event); in asus_acpi_notify()
1605 struct asus_laptop *asus = platform_get_drvdata(pdev); in asus_sysfs_is_visible() local
1606 acpi_handle handle = asus->handle; in asus_sysfs_is_visible()
1609 if (asus->is_pega_lucid) { in asus_sysfs_is_visible()
1633 !acpi_check_handle(asus->handle, METHOD_WIMAX, NULL); in asus_sysfs_is_visible()
1636 supported = !acpi_check_handle(asus->handle, METHOD_WWAN, NULL); in asus_sysfs_is_visible()
1646 supported = asus->is_pega_lucid; in asus_sysfs_is_visible()
1664 static int asus_platform_init(struct asus_laptop *asus) in asus_platform_init() argument
1668 asus->platform_device = platform_device_alloc(ASUS_LAPTOP_FILE, -1); in asus_platform_init()
1669 if (!asus->platform_device) in asus_platform_init()
1671 platform_set_drvdata(asus->platform_device, asus); in asus_platform_init()
1673 result = platform_device_add(asus->platform_device); in asus_platform_init()
1677 result = sysfs_create_group(&asus->platform_device->dev.kobj, in asus_platform_init()
1685 platform_device_del(asus->platform_device); in asus_platform_init()
1687 platform_device_put(asus->platform_device); in asus_platform_init()
1691 static void asus_platform_exit(struct asus_laptop *asus) in asus_platform_exit() argument
1693 sysfs_remove_group(&asus->platform_device->dev.kobj, &asus_attr_group); in asus_platform_exit()
1694 platform_device_unregister(asus->platform_device); in asus_platform_exit()
1708 static int asus_laptop_get_info(struct asus_laptop *asus) in asus_laptop_get_info() argument
1723 status = acpi_get_table(ACPI_SIG_DSDT, 1, &asus->dsdt_info); in asus_laptop_get_info()
1728 if (write_acpi_int_ret(asus->handle, "INIT", 0, &buffer)) { in asus_laptop_get_info()
1735 acpi_evaluate_integer(asus->handle, "BSTS", NULL, &bsts_result); in asus_laptop_get_info()
1743 if (write_acpi_int(asus->handle, "CWAP", wapf)) in asus_laptop_get_info()
1765 asus->name = kstrdup(string, GFP_KERNEL); in asus_laptop_get_info()
1766 if (!asus->name) { in asus_laptop_get_info()
1774 if (!acpi_check_handle(asus->handle, METHOD_WL_STATUS, NULL)) in asus_laptop_get_info()
1775 asus->have_rsts = true; in asus_laptop_get_info()
1782 static int asus_acpi_init(struct asus_laptop *asus) in asus_acpi_init() argument
1786 result = acpi_bus_get_status(asus->device); in asus_acpi_init()
1789 if (!asus->device->status.present) { in asus_acpi_init()
1794 result = asus_laptop_get_info(asus); in asus_acpi_init()
1799 asus->bled_type = TYPE_LED; in asus_acpi_init()
1801 asus->bled_type = TYPE_RFKILL; in asus_acpi_init()
1804 asus->wled_type = TYPE_LED; in asus_acpi_init()
1806 asus->wled_type = TYPE_RFKILL; in asus_acpi_init()
1809 asus_bluetooth_set(asus, !!bluetooth_status); in asus_acpi_init()
1812 asus_wlan_set(asus, !!wlan_status); in asus_acpi_init()
1815 asus_wimax_set(asus, !!wimax_status); in asus_acpi_init()
1818 asus_wwan_set(asus, !!wwan_status); in asus_acpi_init()
1821 if (!acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_SET, NULL)) in asus_acpi_init()
1822 asus_kled_set(asus, 1); in asus_acpi_init()
1825 asus->ledd_status = 0xFFF; in asus_acpi_init()
1828 asus->light_switch = !!als_status; in asus_acpi_init()
1829 asus->light_level = 5; /* level 5 for sensor sensitivity */ in asus_acpi_init()
1831 if (asus->is_pega_lucid) { in asus_acpi_init()
1832 asus_als_switch(asus, asus->light_switch); in asus_acpi_init()
1833 } else if (!acpi_check_handle(asus->handle, METHOD_ALS_CONTROL, NULL) && in asus_acpi_init()
1834 !acpi_check_handle(asus->handle, METHOD_ALS_LEVEL, NULL)) { in asus_acpi_init()
1835 asus_als_switch(asus, asus->light_switch); in asus_acpi_init()
1836 asus_als_level(asus, asus->light_level); in asus_acpi_init()
1860 struct asus_laptop *asus; in asus_acpi_add() local
1865 asus = kzalloc(sizeof(struct asus_laptop), GFP_KERNEL); in asus_acpi_add()
1866 if (!asus) in asus_acpi_add()
1868 asus->handle = device->handle; in asus_acpi_add()
1871 device->driver_data = asus; in asus_acpi_add()
1872 asus->device = device; in asus_acpi_add()
1876 result = asus_acpi_init(asus); in asus_acpi_add()
1884 asus->is_pega_lucid = asus_check_pega_lucid(asus); in asus_acpi_add()
1885 result = asus_platform_init(asus); in asus_acpi_add()
1890 result = asus_backlight_init(asus); in asus_acpi_add()
1895 result = asus_input_init(asus); in asus_acpi_add()
1899 result = asus_led_init(asus); in asus_acpi_add()
1903 result = asus_rfkill_init(asus); in asus_acpi_add()
1907 result = pega_accel_init(asus); in asus_acpi_add()
1911 result = pega_rfkill_init(asus); in asus_acpi_add()
1919 pega_accel_exit(asus); in asus_acpi_add()
1921 asus_rfkill_exit(asus); in asus_acpi_add()
1923 asus_led_exit(asus); in asus_acpi_add()
1925 asus_input_exit(asus); in asus_acpi_add()
1927 asus_backlight_exit(asus); in asus_acpi_add()
1929 asus_platform_exit(asus); in asus_acpi_add()
1931 kfree(asus); in asus_acpi_add()
1938 struct asus_laptop *asus = acpi_driver_data(device); in asus_acpi_remove() local
1940 asus_backlight_exit(asus); in asus_acpi_remove()
1941 asus_rfkill_exit(asus); in asus_acpi_remove()
1942 asus_led_exit(asus); in asus_acpi_remove()
1943 asus_input_exit(asus); in asus_acpi_remove()
1944 pega_accel_exit(asus); in asus_acpi_remove()
1945 asus_platform_exit(asus); in asus_acpi_remove()
1947 kfree(asus->name); in asus_acpi_remove()
1948 kfree(asus); in asus_acpi_remove()