Lines Matching refs:asus
233 struct asus_laptop *asus; member
244 struct asus_laptop *asus; member
428 static bool asus_check_pega_lucid(struct asus_laptop *asus) in asus_check_pega_lucid() argument
430 return !strcmp(asus->name, DEVICE_NAME_PEGA) && in asus_check_pega_lucid()
431 !acpi_check_handle(asus->handle, METHOD_PEGA_ENABLE, NULL) && in asus_check_pega_lucid()
432 !acpi_check_handle(asus->handle, METHOD_PEGA_DISABLE, NULL) && in asus_check_pega_lucid()
433 !acpi_check_handle(asus->handle, METHOD_PEGA_READ, NULL); in asus_check_pega_lucid()
436 static int asus_pega_lucid_set(struct asus_laptop *asus, int unit, bool enable) in asus_pega_lucid_set() argument
439 return write_acpi_int(asus->handle, method, unit); in asus_pega_lucid_set()
442 static int pega_acc_axis(struct asus_laptop *asus, int curr, char *method) in pega_acc_axis() argument
447 acpi_evaluate_integer(asus->handle, method, NULL, &val); in pega_acc_axis()
465 struct asus_laptop *asus = dev_get_drvdata(parent); in pega_accel_poll() local
471 if (!asus->pega_acc_live) { in pega_accel_poll()
472 asus->pega_acc_live = true; in pega_accel_poll()
480 asus->pega_acc_x = pega_acc_axis(asus, asus->pega_acc_x, METHOD_XLRX); in pega_accel_poll()
481 asus->pega_acc_y = pega_acc_axis(asus, asus->pega_acc_y, METHOD_XLRY); in pega_accel_poll()
482 asus->pega_acc_z = pega_acc_axis(asus, asus->pega_acc_z, METHOD_XLRZ); in pega_accel_poll()
487 input_report_abs(ipd->input, ABS_X, -asus->pega_acc_x); in pega_accel_poll()
488 input_report_abs(ipd->input, ABS_Y, -asus->pega_acc_y); in pega_accel_poll()
489 input_report_abs(ipd->input, ABS_Z, asus->pega_acc_z); in pega_accel_poll()
493 static void pega_accel_exit(struct asus_laptop *asus) in pega_accel_exit() argument
495 if (asus->pega_accel_poll) { in pega_accel_exit()
496 input_unregister_polled_device(asus->pega_accel_poll); in pega_accel_exit()
497 input_free_polled_device(asus->pega_accel_poll); in pega_accel_exit()
499 asus->pega_accel_poll = NULL; in pega_accel_exit()
502 static int pega_accel_init(struct asus_laptop *asus) in pega_accel_init() argument
507 if (!asus->is_pega_lucid) in pega_accel_init()
510 if (acpi_check_handle(asus->handle, METHOD_XLRX, NULL) || in pega_accel_init()
511 acpi_check_handle(asus->handle, METHOD_XLRY, NULL) || in pega_accel_init()
512 acpi_check_handle(asus->handle, METHOD_XLRZ, NULL)) in pega_accel_init()
526 ipd->input->dev.parent = &asus->platform_device->dev; in pega_accel_init()
541 asus->pega_accel_poll = ipd; in pega_accel_init()
550 static int asus_led_set(struct asus_laptop *asus, const char *method, in asus_led_set() argument
560 return write_acpi_int(asus->handle, method, value); in asus_led_set()
571 struct asus_laptop *asus = led->asus; in asus_led_cdev_set() local
574 queue_work(asus->led_workqueue, &led->work); in asus_led_cdev_set()
580 struct asus_laptop *asus = led->asus; in asus_led_cdev_update() local
582 asus_led_set(asus, led->method, led->wk); in asus_led_cdev_update()
593 static int asus_kled_lvl(struct asus_laptop *asus) in asus_kled_lvl() argument
605 rv = acpi_evaluate_integer(asus->handle, METHOD_KBD_LIGHT_GET, in asus_kled_lvl()
614 static int asus_kled_set(struct asus_laptop *asus, int kblv) in asus_kled_set() argument
621 if (write_acpi_int(asus->handle, METHOD_KBD_LIGHT_SET, kblv)) { in asus_kled_set()
632 struct asus_laptop *asus = led->asus; in asus_kled_cdev_set() local
635 queue_work(asus->led_workqueue, &led->work); in asus_kled_cdev_set()
641 struct asus_laptop *asus = led->asus; in asus_kled_cdev_update() local
643 asus_kled_set(asus, led->wk); in asus_kled_cdev_update()
649 struct asus_laptop *asus = led->asus; in asus_kled_cdev_get() local
651 return asus_kled_lvl(asus); in asus_kled_cdev_get()
654 static void asus_led_exit(struct asus_laptop *asus) in asus_led_exit() argument
656 if (!IS_ERR_OR_NULL(asus->wled.led.dev)) in asus_led_exit()
657 led_classdev_unregister(&asus->wled.led); in asus_led_exit()
658 if (!IS_ERR_OR_NULL(asus->bled.led.dev)) in asus_led_exit()
659 led_classdev_unregister(&asus->bled.led); in asus_led_exit()
660 if (!IS_ERR_OR_NULL(asus->mled.led.dev)) in asus_led_exit()
661 led_classdev_unregister(&asus->mled.led); in asus_led_exit()
662 if (!IS_ERR_OR_NULL(asus->tled.led.dev)) in asus_led_exit()
663 led_classdev_unregister(&asus->tled.led); in asus_led_exit()
664 if (!IS_ERR_OR_NULL(asus->pled.led.dev)) in asus_led_exit()
665 led_classdev_unregister(&asus->pled.led); in asus_led_exit()
666 if (!IS_ERR_OR_NULL(asus->rled.led.dev)) in asus_led_exit()
667 led_classdev_unregister(&asus->rled.led); in asus_led_exit()
668 if (!IS_ERR_OR_NULL(asus->gled.led.dev)) in asus_led_exit()
669 led_classdev_unregister(&asus->gled.led); in asus_led_exit()
670 if (!IS_ERR_OR_NULL(asus->kled.led.dev)) in asus_led_exit()
671 led_classdev_unregister(&asus->kled.led); in asus_led_exit()
672 if (asus->led_workqueue) { in asus_led_exit()
673 destroy_workqueue(asus->led_workqueue); in asus_led_exit()
674 asus->led_workqueue = NULL; in asus_led_exit()
679 static int asus_led_register(struct asus_laptop *asus, in asus_led_register() argument
685 if (!method || acpi_check_handle(asus->handle, method, NULL)) in asus_led_register()
688 led->asus = asus; in asus_led_register()
696 return led_classdev_register(&asus->platform_device->dev, led_cdev); in asus_led_register()
699 static int asus_led_init(struct asus_laptop *asus) in asus_led_init() argument
707 if (asus->is_pega_lucid) in asus_led_init()
716 asus->led_workqueue = create_singlethread_workqueue("led_workqueue"); in asus_led_init()
717 if (!asus->led_workqueue) in asus_led_init()
720 if (asus->wled_type == TYPE_LED) in asus_led_init()
721 r = asus_led_register(asus, &asus->wled, "asus::wlan", in asus_led_init()
725 if (asus->bled_type == TYPE_LED) in asus_led_init()
726 r = asus_led_register(asus, &asus->bled, "asus::bluetooth", in asus_led_init()
730 r = asus_led_register(asus, &asus->mled, "asus::mail", METHOD_MLED); in asus_led_init()
733 r = asus_led_register(asus, &asus->tled, "asus::touchpad", METHOD_TLED); in asus_led_init()
736 r = asus_led_register(asus, &asus->rled, "asus::record", METHOD_RLED); in asus_led_init()
739 r = asus_led_register(asus, &asus->pled, "asus::phone", METHOD_PLED); in asus_led_init()
742 r = asus_led_register(asus, &asus->gled, "asus::gaming", METHOD_GLED); in asus_led_init()
745 if (!acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_SET, NULL) && in asus_led_init()
746 !acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_GET, NULL)) { in asus_led_init()
747 struct asus_led *led = &asus->kled; in asus_led_init()
750 led->asus = asus; in asus_led_init()
757 r = led_classdev_register(&asus->platform_device->dev, cdev); in asus_led_init()
761 asus_led_exit(asus); in asus_led_init()
770 struct asus_laptop *asus = bl_get_data(bd); in asus_read_brightness() local
774 rv = acpi_evaluate_integer(asus->handle, METHOD_BRIGHTNESS_GET, in asus_read_brightness()
784 struct asus_laptop *asus = bl_get_data(bd); in asus_set_brightness() local
786 if (write_acpi_int(asus->handle, METHOD_BRIGHTNESS_SET, value)) { in asus_set_brightness()
805 static int asus_backlight_notify(struct asus_laptop *asus) in asus_backlight_notify() argument
807 struct backlight_device *bd = asus->backlight_device; in asus_backlight_notify()
815 static int asus_backlight_init(struct asus_laptop *asus) in asus_backlight_init() argument
820 if (acpi_check_handle(asus->handle, METHOD_BRIGHTNESS_GET, NULL) || in asus_backlight_init()
821 acpi_check_handle(asus->handle, METHOD_BRIGHTNESS_SET, NULL)) in asus_backlight_init()
829 &asus->platform_device->dev, asus, in asus_backlight_init()
833 asus->backlight_device = NULL; in asus_backlight_init()
837 asus->backlight_device = bd; in asus_backlight_init()
844 static void asus_backlight_exit(struct asus_laptop *asus) in asus_backlight_exit() argument
846 backlight_device_unregister(asus->backlight_device); in asus_backlight_exit()
847 asus->backlight_device = NULL; in asus_backlight_exit()
862 struct asus_laptop *asus = dev_get_drvdata(dev); in infos_show() local
874 len += sprintf(page + len, "Model reference : %s\n", asus->name); in infos_show()
881 rv = acpi_evaluate_integer(asus->handle, "SFUN", NULL, &temp); in infos_show()
893 rv = acpi_evaluate_integer(asus->handle, "HWRS", NULL, &temp); in infos_show()
904 rv = acpi_evaluate_integer(asus->handle, "ASYM", NULL, &temp); in infos_show()
908 if (asus->dsdt_info) { in infos_show()
909 snprintf(buf, 16, "%d", asus->dsdt_info->length); in infos_show()
911 snprintf(buf, 16, "%d", asus->dsdt_info->checksum); in infos_show()
913 snprintf(buf, 16, "%d", asus->dsdt_info->revision); in infos_show()
915 snprintf(buf, 7, "%s", asus->dsdt_info->oem_id); in infos_show()
917 snprintf(buf, 9, "%s", asus->dsdt_info->oem_table_id); in infos_show()
919 snprintf(buf, 16, "%x", asus->dsdt_info->oem_revision); in infos_show()
921 snprintf(buf, 5, "%s", asus->dsdt_info->asl_compiler_id); in infos_show()
923 snprintf(buf, 16, "%x", asus->dsdt_info->asl_compiler_revision); in infos_show()
942 static ssize_t sysfs_acpi_set(struct asus_laptop *asus, in sysfs_acpi_set() argument
953 if (write_acpi_int(asus->handle, method, value)) in sysfs_acpi_set()
964 struct asus_laptop *asus = dev_get_drvdata(dev); in ledd_show() local
966 return sprintf(buf, "0x%08x\n", asus->ledd_status); in ledd_show()
972 struct asus_laptop *asus = dev_get_drvdata(dev); in ledd_store() local
977 if (write_acpi_int(asus->handle, METHOD_LEDD, value)) { in ledd_store()
981 asus->ledd_status = (u32) value; in ledd_store()
990 static int asus_wireless_status(struct asus_laptop *asus, int mask) in asus_wireless_status() argument
995 if (!asus->have_rsts) in asus_wireless_status()
996 return (asus->wireless_status & mask) ? 1 : 0; in asus_wireless_status()
998 rv = acpi_evaluate_integer(asus->handle, METHOD_WL_STATUS, in asus_wireless_status()
1010 static int asus_wlan_set(struct asus_laptop *asus, int status) in asus_wlan_set() argument
1012 if (write_acpi_int(asus->handle, METHOD_WLAN, !!status)) { in asus_wlan_set()
1022 struct asus_laptop *asus = dev_get_drvdata(dev); in wlan_show() local
1024 return sprintf(buf, "%d\n", asus_wireless_status(asus, WL_RSTS)); in wlan_show()
1030 struct asus_laptop *asus = dev_get_drvdata(dev); in wlan_store() local
1032 return sysfs_acpi_set(asus, buf, count, METHOD_WLAN); in wlan_store()
1039 static int asus_bluetooth_set(struct asus_laptop *asus, int status) in asus_bluetooth_set() argument
1041 if (write_acpi_int(asus->handle, METHOD_BLUETOOTH, !!status)) { in asus_bluetooth_set()
1051 struct asus_laptop *asus = dev_get_drvdata(dev); in bluetooth_show() local
1053 return sprintf(buf, "%d\n", asus_wireless_status(asus, BT_RSTS)); in bluetooth_show()
1060 struct asus_laptop *asus = dev_get_drvdata(dev); in bluetooth_store() local
1062 return sysfs_acpi_set(asus, buf, count, METHOD_BLUETOOTH); in bluetooth_store()
1069 static int asus_wimax_set(struct asus_laptop *asus, int status) in asus_wimax_set() argument
1071 if (write_acpi_int(asus->handle, METHOD_WIMAX, !!status)) { in asus_wimax_set()
1081 struct asus_laptop *asus = dev_get_drvdata(dev); in wimax_show() local
1083 return sprintf(buf, "%d\n", asus_wireless_status(asus, WM_RSTS)); in wimax_show()
1089 struct asus_laptop *asus = dev_get_drvdata(dev); in wimax_store() local
1091 return sysfs_acpi_set(asus, buf, count, METHOD_WIMAX); in wimax_store()
1098 static int asus_wwan_set(struct asus_laptop *asus, int status) in asus_wwan_set() argument
1100 if (write_acpi_int(asus->handle, METHOD_WWAN, !!status)) { in asus_wwan_set()
1110 struct asus_laptop *asus = dev_get_drvdata(dev); in wwan_show() local
1112 return sprintf(buf, "%d\n", asus_wireless_status(asus, WW_RSTS)); in wwan_show()
1118 struct asus_laptop *asus = dev_get_drvdata(dev); in wwan_store() local
1120 return sysfs_acpi_set(asus, buf, count, METHOD_WWAN); in wwan_store()
1127 static void asus_set_display(struct asus_laptop *asus, int value) in asus_set_display() argument
1130 if (write_acpi_int(asus->handle, METHOD_SWITCH_DISPLAY, value)) in asus_set_display()
1145 struct asus_laptop *asus = dev_get_drvdata(dev); in display_store() local
1150 asus_set_display(asus, value); in display_store()
1158 static void asus_als_switch(struct asus_laptop *asus, int value) in asus_als_switch() argument
1162 if (asus->is_pega_lucid) { in asus_als_switch()
1163 ret = asus_pega_lucid_set(asus, PEGA_ALS, value); in asus_als_switch()
1165 ret = asus_pega_lucid_set(asus, PEGA_ALS_POWER, value); in asus_als_switch()
1167 ret = write_acpi_int(asus->handle, METHOD_ALS_CONTROL, value); in asus_als_switch()
1172 asus->light_switch = value; in asus_als_switch()
1178 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_switch_show() local
1180 return sprintf(buf, "%d\n", asus->light_switch); in ls_switch_show()
1187 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_switch_store() local
1192 asus_als_switch(asus, value ? 1 : 0); in ls_switch_store()
1198 static void asus_als_level(struct asus_laptop *asus, int value) in asus_als_level() argument
1200 if (write_acpi_int(asus->handle, METHOD_ALS_LEVEL, value)) in asus_als_level()
1202 asus->light_level = value; in asus_als_level()
1208 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_level_show() local
1210 return sprintf(buf, "%d\n", asus->light_level); in ls_level_show()
1216 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_level_store() local
1223 asus_als_level(asus, value); in ls_level_store()
1230 static int pega_int_read(struct asus_laptop *asus, int arg, int *result) in pega_int_read() argument
1233 int err = write_acpi_int_ret(asus->handle, METHOD_PEGA_READ, arg, in pega_int_read()
1248 struct asus_laptop *asus = dev_get_drvdata(dev); in ls_value_show() local
1251 err = pega_int_read(asus, PEGA_READ_ALS_H, &hi); in ls_value_show()
1253 err = pega_int_read(asus, PEGA_READ_ALS_L, &lo); in ls_value_show()
1263 static int asus_gps_status(struct asus_laptop *asus) in asus_gps_status() argument
1268 rv = acpi_evaluate_integer(asus->handle, METHOD_GPS_STATUS, in asus_gps_status()
1277 static int asus_gps_switch(struct asus_laptop *asus, int status) in asus_gps_switch() argument
1281 if (write_acpi_int(asus->handle, meth, 0x02)) in asus_gps_switch()
1289 struct asus_laptop *asus = dev_get_drvdata(dev); in gps_show() local
1291 return sprintf(buf, "%d\n", asus_gps_status(asus)); in gps_show()
1297 struct asus_laptop *asus = dev_get_drvdata(dev); in gps_store() local
1304 ret = asus_gps_switch(asus, !!value); in gps_store()
1307 rfkill_set_sw_state(asus->gps.rfkill, !value); in gps_store()
1317 struct asus_laptop *asus = data; in asus_gps_rfkill_set() local
1319 return asus_gps_switch(asus, !blocked); in asus_gps_rfkill_set()
1329 struct asus_laptop *asus = rfk->asus; in asus_rfkill_set() local
1332 return asus_wlan_set(asus, !blocked); in asus_rfkill_set()
1334 return asus_bluetooth_set(asus, !blocked); in asus_rfkill_set()
1336 return asus_wimax_set(asus, !blocked); in asus_rfkill_set()
1338 return asus_wwan_set(asus, !blocked); in asus_rfkill_set()
1357 static void asus_rfkill_exit(struct asus_laptop *asus) in asus_rfkill_exit() argument
1359 asus_rfkill_terminate(&asus->wwan); in asus_rfkill_exit()
1360 asus_rfkill_terminate(&asus->bluetooth); in asus_rfkill_exit()
1361 asus_rfkill_terminate(&asus->wlan); in asus_rfkill_exit()
1362 asus_rfkill_terminate(&asus->gps); in asus_rfkill_exit()
1365 static int asus_rfkill_setup(struct asus_laptop *asus, struct asus_rfkill *rfk, in asus_rfkill_setup() argument
1372 rfk->asus = asus; in asus_rfkill_setup()
1373 rfk->rfkill = rfkill_alloc(name, &asus->platform_device->dev, in asus_rfkill_setup()
1387 static int asus_rfkill_init(struct asus_laptop *asus) in asus_rfkill_init() argument
1391 if (asus->is_pega_lucid) in asus_rfkill_init()
1394 if (!acpi_check_handle(asus->handle, METHOD_GPS_ON, NULL) && in asus_rfkill_init()
1395 !acpi_check_handle(asus->handle, METHOD_GPS_OFF, NULL) && in asus_rfkill_init()
1396 !acpi_check_handle(asus->handle, METHOD_GPS_STATUS, NULL)) in asus_rfkill_init()
1397 result = asus_rfkill_setup(asus, &asus->gps, "asus-gps", in asus_rfkill_init()
1404 if (!acpi_check_handle(asus->handle, METHOD_WLAN, NULL) && in asus_rfkill_init()
1405 asus->wled_type == TYPE_RFKILL) in asus_rfkill_init()
1406 result = asus_rfkill_setup(asus, &asus->wlan, "asus-wlan", in asus_rfkill_init()
1412 if (!acpi_check_handle(asus->handle, METHOD_BLUETOOTH, NULL) && in asus_rfkill_init()
1413 asus->bled_type == TYPE_RFKILL) in asus_rfkill_init()
1414 result = asus_rfkill_setup(asus, &asus->bluetooth, in asus_rfkill_init()
1421 if (!acpi_check_handle(asus->handle, METHOD_WWAN, NULL)) in asus_rfkill_init()
1422 result = asus_rfkill_setup(asus, &asus->wwan, "asus-wwan", in asus_rfkill_init()
1428 if (!acpi_check_handle(asus->handle, METHOD_WIMAX, NULL)) in asus_rfkill_init()
1429 result = asus_rfkill_setup(asus, &asus->wimax, "asus-wimax", in asus_rfkill_init()
1437 asus_rfkill_exit(asus); in asus_rfkill_init()
1446 int ret = asus_pega_lucid_set(rfk->asus, rfk->control_id, !blocked); in pega_rfkill_set()
1454 static int pega_rfkill_setup(struct asus_laptop *asus, struct asus_rfkill *rfk, in pega_rfkill_setup() argument
1457 return asus_rfkill_setup(asus, rfk, name, controlid, rfkill_type, in pega_rfkill_setup()
1461 static int pega_rfkill_init(struct asus_laptop *asus) in pega_rfkill_init() argument
1465 if(!asus->is_pega_lucid) in pega_rfkill_init()
1468 ret = pega_rfkill_setup(asus, &asus->wlan, "pega-wlan", in pega_rfkill_init()
1473 ret = pega_rfkill_setup(asus, &asus->bluetooth, "pega-bt", in pega_rfkill_init()
1478 ret = pega_rfkill_setup(asus, &asus->wwan, "pega-wwan", in pega_rfkill_init()
1483 asus_rfkill_exit(asus); in pega_rfkill_init()
1491 static void asus_input_notify(struct asus_laptop *asus, int event) in asus_input_notify() argument
1493 if (!asus->inputdev) in asus_input_notify()
1495 if (!sparse_keymap_report_event(asus->inputdev, event, 1, true)) in asus_input_notify()
1499 static int asus_input_init(struct asus_laptop *asus) in asus_input_init() argument
1511 input->dev.parent = &asus->platform_device->dev; in asus_input_init()
1524 asus->inputdev = input; in asus_input_init()
1534 static void asus_input_exit(struct asus_laptop *asus) in asus_input_exit() argument
1536 if (asus->inputdev) { in asus_input_exit()
1537 sparse_keymap_free(asus->inputdev); in asus_input_exit()
1538 input_unregister_device(asus->inputdev); in asus_input_exit()
1540 asus->inputdev = NULL; in asus_input_exit()
1548 struct asus_laptop *asus = acpi_driver_data(device); in asus_acpi_notify() local
1552 count = asus->event_count[event % 128]++; in asus_acpi_notify()
1553 acpi_bus_generate_netlink_event(asus->device->pnp.device_class, in asus_acpi_notify()
1554 dev_name(&asus->device->dev), event, in asus_acpi_notify()
1565 if (asus->backlight_device != NULL) { in asus_acpi_notify()
1567 asus_backlight_notify(asus); in asus_acpi_notify()
1573 if (asus->pega_accel_poll && event == 0xEA) { in asus_acpi_notify()
1574 kobject_uevent(&asus->pega_accel_poll->input->dev.kobj, in asus_acpi_notify()
1579 asus_input_notify(asus, event); in asus_acpi_notify()
1603 struct asus_laptop *asus = platform_get_drvdata(pdev); in asus_sysfs_is_visible() local
1604 acpi_handle handle = asus->handle; in asus_sysfs_is_visible()
1607 if (asus->is_pega_lucid) { in asus_sysfs_is_visible()
1631 !acpi_check_handle(asus->handle, METHOD_WIMAX, NULL); in asus_sysfs_is_visible()
1634 supported = !acpi_check_handle(asus->handle, METHOD_WWAN, NULL); in asus_sysfs_is_visible()
1644 supported = asus->is_pega_lucid; in asus_sysfs_is_visible()
1662 static int asus_platform_init(struct asus_laptop *asus) in asus_platform_init() argument
1666 asus->platform_device = platform_device_alloc(ASUS_LAPTOP_FILE, -1); in asus_platform_init()
1667 if (!asus->platform_device) in asus_platform_init()
1669 platform_set_drvdata(asus->platform_device, asus); in asus_platform_init()
1671 result = platform_device_add(asus->platform_device); in asus_platform_init()
1675 result = sysfs_create_group(&asus->platform_device->dev.kobj, in asus_platform_init()
1683 platform_device_del(asus->platform_device); in asus_platform_init()
1685 platform_device_put(asus->platform_device); in asus_platform_init()
1689 static void asus_platform_exit(struct asus_laptop *asus) in asus_platform_exit() argument
1691 sysfs_remove_group(&asus->platform_device->dev.kobj, &asus_attr_group); in asus_platform_exit()
1692 platform_device_unregister(asus->platform_device); in asus_platform_exit()
1706 static int asus_laptop_get_info(struct asus_laptop *asus) in asus_laptop_get_info() argument
1721 status = acpi_get_table(ACPI_SIG_DSDT, 1, &asus->dsdt_info); in asus_laptop_get_info()
1726 if (write_acpi_int_ret(asus->handle, "INIT", 0, &buffer)) { in asus_laptop_get_info()
1733 acpi_evaluate_integer(asus->handle, "BSTS", NULL, &bsts_result); in asus_laptop_get_info()
1741 if (write_acpi_int(asus->handle, "CWAP", wapf)) in asus_laptop_get_info()
1763 asus->name = kstrdup(string, GFP_KERNEL); in asus_laptop_get_info()
1764 if (!asus->name) { in asus_laptop_get_info()
1772 if (!acpi_check_handle(asus->handle, METHOD_WL_STATUS, NULL)) in asus_laptop_get_info()
1773 asus->have_rsts = true; in asus_laptop_get_info()
1780 static int asus_acpi_init(struct asus_laptop *asus) in asus_acpi_init() argument
1784 result = acpi_bus_get_status(asus->device); in asus_acpi_init()
1787 if (!asus->device->status.present) { in asus_acpi_init()
1792 result = asus_laptop_get_info(asus); in asus_acpi_init()
1797 asus->bled_type = TYPE_LED; in asus_acpi_init()
1799 asus->bled_type = TYPE_RFKILL; in asus_acpi_init()
1802 asus->wled_type = TYPE_LED; in asus_acpi_init()
1804 asus->wled_type = TYPE_RFKILL; in asus_acpi_init()
1807 asus_bluetooth_set(asus, !!bluetooth_status); in asus_acpi_init()
1810 asus_wlan_set(asus, !!wlan_status); in asus_acpi_init()
1813 asus_wimax_set(asus, !!wimax_status); in asus_acpi_init()
1816 asus_wwan_set(asus, !!wwan_status); in asus_acpi_init()
1819 if (!acpi_check_handle(asus->handle, METHOD_KBD_LIGHT_SET, NULL)) in asus_acpi_init()
1820 asus_kled_set(asus, 1); in asus_acpi_init()
1823 asus->ledd_status = 0xFFF; in asus_acpi_init()
1826 asus->light_switch = !!als_status; in asus_acpi_init()
1827 asus->light_level = 5; /* level 5 for sensor sensitivity */ in asus_acpi_init()
1829 if (asus->is_pega_lucid) { in asus_acpi_init()
1830 asus_als_switch(asus, asus->light_switch); in asus_acpi_init()
1831 } else if (!acpi_check_handle(asus->handle, METHOD_ALS_CONTROL, NULL) && in asus_acpi_init()
1832 !acpi_check_handle(asus->handle, METHOD_ALS_LEVEL, NULL)) { in asus_acpi_init()
1833 asus_als_switch(asus, asus->light_switch); in asus_acpi_init()
1834 asus_als_level(asus, asus->light_level); in asus_acpi_init()
1858 struct asus_laptop *asus; in asus_acpi_add() local
1863 asus = kzalloc(sizeof(struct asus_laptop), GFP_KERNEL); in asus_acpi_add()
1864 if (!asus) in asus_acpi_add()
1866 asus->handle = device->handle; in asus_acpi_add()
1869 device->driver_data = asus; in asus_acpi_add()
1870 asus->device = device; in asus_acpi_add()
1874 result = asus_acpi_init(asus); in asus_acpi_add()
1882 asus->is_pega_lucid = asus_check_pega_lucid(asus); in asus_acpi_add()
1883 result = asus_platform_init(asus); in asus_acpi_add()
1888 result = asus_backlight_init(asus); in asus_acpi_add()
1894 result = asus_input_init(asus); in asus_acpi_add()
1898 result = asus_led_init(asus); in asus_acpi_add()
1902 result = asus_rfkill_init(asus); in asus_acpi_add()
1906 result = pega_accel_init(asus); in asus_acpi_add()
1910 result = pega_rfkill_init(asus); in asus_acpi_add()
1918 pega_accel_exit(asus); in asus_acpi_add()
1920 asus_rfkill_exit(asus); in asus_acpi_add()
1922 asus_led_exit(asus); in asus_acpi_add()
1924 asus_input_exit(asus); in asus_acpi_add()
1926 asus_backlight_exit(asus); in asus_acpi_add()
1928 asus_platform_exit(asus); in asus_acpi_add()
1930 kfree(asus); in asus_acpi_add()
1937 struct asus_laptop *asus = acpi_driver_data(device); in asus_acpi_remove() local
1939 asus_backlight_exit(asus); in asus_acpi_remove()
1940 asus_rfkill_exit(asus); in asus_acpi_remove()
1941 asus_led_exit(asus); in asus_acpi_remove()
1942 asus_input_exit(asus); in asus_acpi_remove()
1943 pega_accel_exit(asus); in asus_acpi_remove()
1944 asus_platform_exit(asus); in asus_acpi_remove()
1946 kfree(asus->name); in asus_acpi_remove()
1947 kfree(asus); in asus_acpi_remove()