aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/platform/x86/asus-wmi.c115
1 files changed, 59 insertions, 56 deletions
diff --git a/drivers/platform/x86/asus-wmi.c b/drivers/platform/x86/asus-wmi.c
index 4c3f68a495d7..d0f0931ea5eb 100644
--- a/drivers/platform/x86/asus-wmi.c
+++ b/drivers/platform/x86/asus-wmi.c
@@ -114,6 +114,12 @@ struct asus_wmi_debug {
114 u32 ctrl_param; 114 u32 ctrl_param;
115}; 115};
116 116
117struct asus_rfkill {
118 struct asus_wmi *asus;
119 struct rfkill *rfkill;
120 u32 dev_id;
121};
122
117struct asus_wmi { 123struct asus_wmi {
118 struct input_dev *inputdev; 124 struct input_dev *inputdev;
119 struct backlight_device *backlight_device; 125 struct backlight_device *backlight_device;
@@ -124,10 +130,10 @@ struct asus_wmi {
124 struct workqueue_struct *led_workqueue; 130 struct workqueue_struct *led_workqueue;
125 struct work_struct tpd_led_work; 131 struct work_struct tpd_led_work;
126 132
127 struct rfkill *wlan_rfkill; 133 struct asus_rfkill wlan;
128 struct rfkill *bluetooth_rfkill; 134 struct asus_rfkill bluetooth;
129 struct rfkill *wimax_rfkill; 135 struct asus_rfkill wimax;
130 struct rfkill *wwan3g_rfkill; 136 struct asus_rfkill wwan3g;
131 137
132 struct hotplug_slot *hotplug_slot; 138 struct hotplug_slot *hotplug_slot;
133 struct mutex hotplug_lock; 139 struct mutex hotplug_lock;
@@ -377,8 +383,8 @@ static void asus_rfkill_hotplug(struct asus_wmi *asus)
377 383
378 mutex_lock(&asus->hotplug_lock); 384 mutex_lock(&asus->hotplug_lock);
379 385
380 if (asus->wlan_rfkill) 386 if (asus->wlan.rfkill)
381 rfkill_set_sw_state(asus->wlan_rfkill, blocked); 387 rfkill_set_sw_state(asus->wlan.rfkill, blocked);
382 388
383 if (asus->hotplug_slot) { 389 if (asus->hotplug_slot) {
384 bus = pci_find_bus(0, 1); 390 bus = pci_find_bus(0, 1);
@@ -570,11 +576,11 @@ error_workqueue:
570 */ 576 */
571static int asus_rfkill_set(void *data, bool blocked) 577static int asus_rfkill_set(void *data, bool blocked)
572{ 578{
573 int dev_id = (unsigned long)data; 579 struct asus_rfkill *priv = data;
574 u32 ctrl_param = !blocked; 580 u32 ctrl_param = !blocked;
575 acpi_status status; 581 acpi_status status;
576 582
577 status = asus_wmi_set_devstate(dev_id, ctrl_param, NULL); 583 status = asus_wmi_set_devstate(priv->dev_id, ctrl_param, NULL);
578 584
579 if (ACPI_FAILURE(status)) 585 if (ACPI_FAILURE(status))
580 return -EIO; 586 return -EIO;
@@ -584,20 +590,21 @@ static int asus_rfkill_set(void *data, bool blocked)
584 590
585static void asus_rfkill_query(struct rfkill *rfkill, void *data) 591static void asus_rfkill_query(struct rfkill *rfkill, void *data)
586{ 592{
587 int dev_id = (unsigned long)data; 593 struct asus_rfkill *priv = data;
588 int result; 594 int result;
589 595
590 result = asus_wmi_get_devstate_simple(dev_id); 596 result = asus_wmi_get_devstate_simple(priv->dev_id);
591 597
592 if (result < 0) 598 if (result < 0)
593 return; 599 return;
594 600
595 rfkill_set_sw_state(rfkill, !result); 601 rfkill_set_sw_state(priv->rfkill, !result);
596} 602}
597 603
598static int asus_rfkill_wlan_set(void *data, bool blocked) 604static int asus_rfkill_wlan_set(void *data, bool blocked)
599{ 605{
600 struct asus_wmi *asus = data; 606 struct asus_rfkill *priv = data;
607 struct asus_wmi *asus = priv->asus;
601 int ret; 608 int ret;
602 609
603 /* 610 /*
@@ -608,19 +615,14 @@ static int asus_rfkill_wlan_set(void *data, bool blocked)
608 * any wmi method 615 * any wmi method
609 */ 616 */
610 mutex_lock(&asus->wmi_lock); 617 mutex_lock(&asus->wmi_lock);
611 ret = asus_rfkill_set((void *)(long)ASUS_WMI_DEVID_WLAN, blocked); 618 ret = asus_rfkill_set(data, blocked);
612 mutex_unlock(&asus->wmi_lock); 619 mutex_unlock(&asus->wmi_lock);
613 return ret; 620 return ret;
614} 621}
615 622
616static void asus_rfkill_wlan_query(struct rfkill *rfkill, void *data)
617{
618 asus_rfkill_query(rfkill, (void *)(long)ASUS_WMI_DEVID_WLAN);
619}
620
621static const struct rfkill_ops asus_rfkill_wlan_ops = { 623static const struct rfkill_ops asus_rfkill_wlan_ops = {
622 .set_block = asus_rfkill_wlan_set, 624 .set_block = asus_rfkill_wlan_set,
623 .query = asus_rfkill_wlan_query, 625 .query = asus_rfkill_query,
624}; 626};
625 627
626static const struct rfkill_ops asus_rfkill_ops = { 628static const struct rfkill_ops asus_rfkill_ops = {
@@ -629,20 +631,24 @@ static const struct rfkill_ops asus_rfkill_ops = {
629}; 631};
630 632
631static int asus_new_rfkill(struct asus_wmi *asus, 633static int asus_new_rfkill(struct asus_wmi *asus,
632 struct rfkill **rfkill, 634 struct asus_rfkill *arfkill,
633 const char *name, enum rfkill_type type, int dev_id) 635 const char *name, enum rfkill_type type, int dev_id)
634{ 636{
635 int result = asus_wmi_get_devstate_simple(dev_id); 637 int result = asus_wmi_get_devstate_simple(dev_id);
638 struct rfkill **rfkill = &arfkill->rfkill;
636 639
637 if (result < 0) 640 if (result < 0)
638 return result; 641 return result;
639 642
643 arfkill->dev_id = dev_id;
644 arfkill->asus = asus;
645
640 if (dev_id == ASUS_WMI_DEVID_WLAN && asus->driver->hotplug_wireless) 646 if (dev_id == ASUS_WMI_DEVID_WLAN && asus->driver->hotplug_wireless)
641 *rfkill = rfkill_alloc(name, &asus->platform_device->dev, type, 647 *rfkill = rfkill_alloc(name, &asus->platform_device->dev, type,
642 &asus_rfkill_wlan_ops, asus); 648 &asus_rfkill_wlan_ops, arfkill);
643 else 649 else
644 *rfkill = rfkill_alloc(name, &asus->platform_device->dev, type, 650 *rfkill = rfkill_alloc(name, &asus->platform_device->dev, type,
645 &asus_rfkill_ops, (void *)(long)dev_id); 651 &asus_rfkill_ops, arfkill);
646 652
647 if (!*rfkill) 653 if (!*rfkill)
648 return -EINVAL; 654 return -EINVAL;
@@ -662,10 +668,10 @@ static void asus_wmi_rfkill_exit(struct asus_wmi *asus)
662 asus_unregister_rfkill_notifier(asus, "\\_SB.PCI0.P0P5"); 668 asus_unregister_rfkill_notifier(asus, "\\_SB.PCI0.P0P5");
663 asus_unregister_rfkill_notifier(asus, "\\_SB.PCI0.P0P6"); 669 asus_unregister_rfkill_notifier(asus, "\\_SB.PCI0.P0P6");
664 asus_unregister_rfkill_notifier(asus, "\\_SB.PCI0.P0P7"); 670 asus_unregister_rfkill_notifier(asus, "\\_SB.PCI0.P0P7");
665 if (asus->wlan_rfkill) { 671 if (asus->wlan.rfkill) {
666 rfkill_unregister(asus->wlan_rfkill); 672 rfkill_unregister(asus->wlan.rfkill);
667 rfkill_destroy(asus->wlan_rfkill); 673 rfkill_destroy(asus->wlan.rfkill);
668 asus->wlan_rfkill = NULL; 674 asus->wlan.rfkill = NULL;
669 } 675 }
670 /* 676 /*
671 * Refresh pci hotplug in case the rfkill state was changed after 677 * Refresh pci hotplug in case the rfkill state was changed after
@@ -677,20 +683,20 @@ static void asus_wmi_rfkill_exit(struct asus_wmi *asus)
677 if (asus->hotplug_workqueue) 683 if (asus->hotplug_workqueue)
678 destroy_workqueue(asus->hotplug_workqueue); 684 destroy_workqueue(asus->hotplug_workqueue);
679 685
680 if (asus->bluetooth_rfkill) { 686 if (asus->bluetooth.rfkill) {
681 rfkill_unregister(asus->bluetooth_rfkill); 687 rfkill_unregister(asus->bluetooth.rfkill);
682 rfkill_destroy(asus->bluetooth_rfkill); 688 rfkill_destroy(asus->bluetooth.rfkill);
683 asus->bluetooth_rfkill = NULL; 689 asus->bluetooth.rfkill = NULL;
684 } 690 }
685 if (asus->wimax_rfkill) { 691 if (asus->wimax.rfkill) {
686 rfkill_unregister(asus->wimax_rfkill); 692 rfkill_unregister(asus->wimax.rfkill);
687 rfkill_destroy(asus->wimax_rfkill); 693 rfkill_destroy(asus->wimax.rfkill);
688 asus->wimax_rfkill = NULL; 694 asus->wimax.rfkill = NULL;
689 } 695 }
690 if (asus->wwan3g_rfkill) { 696 if (asus->wwan3g.rfkill) {
691 rfkill_unregister(asus->wwan3g_rfkill); 697 rfkill_unregister(asus->wwan3g.rfkill);
692 rfkill_destroy(asus->wwan3g_rfkill); 698 rfkill_destroy(asus->wwan3g.rfkill);
693 asus->wwan3g_rfkill = NULL; 699 asus->wwan3g.rfkill = NULL;
694 } 700 }
695} 701}
696 702
@@ -701,30 +707,27 @@ static int asus_wmi_rfkill_init(struct asus_wmi *asus)
701 mutex_init(&asus->hotplug_lock); 707 mutex_init(&asus->hotplug_lock);
702 mutex_init(&asus->wmi_lock); 708 mutex_init(&asus->wmi_lock);
703 709
704 result = asus_new_rfkill(asus, &asus->wlan_rfkill, 710 result = asus_new_rfkill(asus, &asus->wlan, "asus-wlan",
705 "asus-wlan", RFKILL_TYPE_WLAN, 711 RFKILL_TYPE_WLAN, ASUS_WMI_DEVID_WLAN);
706 ASUS_WMI_DEVID_WLAN);
707 712
708 if (result && result != -ENODEV) 713 if (result && result != -ENODEV)
709 goto exit; 714 goto exit;
710 715
711 result = asus_new_rfkill(asus, &asus->bluetooth_rfkill, 716 result = asus_new_rfkill(asus, &asus->bluetooth,
712 "asus-bluetooth", RFKILL_TYPE_BLUETOOTH, 717 "asus-bluetooth", RFKILL_TYPE_BLUETOOTH,
713 ASUS_WMI_DEVID_BLUETOOTH); 718 ASUS_WMI_DEVID_BLUETOOTH);
714 719
715 if (result && result != -ENODEV) 720 if (result && result != -ENODEV)
716 goto exit; 721 goto exit;
717 722
718 result = asus_new_rfkill(asus, &asus->wimax_rfkill, 723 result = asus_new_rfkill(asus, &asus->wimax, "asus-wimax",
719 "asus-wimax", RFKILL_TYPE_WIMAX, 724 RFKILL_TYPE_WIMAX, ASUS_WMI_DEVID_WIMAX);
720 ASUS_WMI_DEVID_WIMAX);
721 725
722 if (result && result != -ENODEV) 726 if (result && result != -ENODEV)
723 goto exit; 727 goto exit;
724 728
725 result = asus_new_rfkill(asus, &asus->wwan3g_rfkill, 729 result = asus_new_rfkill(asus, &asus->wwan3g, "asus-wwan3g",
726 "asus-wwan3g", RFKILL_TYPE_WWAN, 730 RFKILL_TYPE_WWAN, ASUS_WMI_DEVID_WWAN3G);
727 ASUS_WMI_DEVID_WWAN3G);
728 731
729 if (result && result != -ENODEV) 732 if (result && result != -ENODEV)
730 goto exit; 733 goto exit;
@@ -1277,7 +1280,7 @@ static int asus_hotk_thaw(struct device *device)
1277{ 1280{
1278 struct asus_wmi *asus = dev_get_drvdata(device); 1281 struct asus_wmi *asus = dev_get_drvdata(device);
1279 1282
1280 if (asus->wlan_rfkill) { 1283 if (asus->wlan.rfkill) {
1281 bool wlan; 1284 bool wlan;
1282 1285
1283 /* 1286 /*
@@ -1298,20 +1301,20 @@ static int asus_hotk_restore(struct device *device)
1298 int bl; 1301 int bl;
1299 1302
1300 /* Refresh both wlan rfkill state and pci hotplug */ 1303 /* Refresh both wlan rfkill state and pci hotplug */
1301 if (asus->wlan_rfkill) 1304 if (asus->wlan.rfkill)
1302 asus_rfkill_hotplug(asus); 1305 asus_rfkill_hotplug(asus);
1303 1306
1304 if (asus->bluetooth_rfkill) { 1307 if (asus->bluetooth.rfkill) {
1305 bl = !asus_wmi_get_devstate_simple(ASUS_WMI_DEVID_BLUETOOTH); 1308 bl = !asus_wmi_get_devstate_simple(ASUS_WMI_DEVID_BLUETOOTH);
1306 rfkill_set_sw_state(asus->bluetooth_rfkill, bl); 1309 rfkill_set_sw_state(asus->bluetooth.rfkill, bl);
1307 } 1310 }
1308 if (asus->wimax_rfkill) { 1311 if (asus->wimax.rfkill) {
1309 bl = !asus_wmi_get_devstate_simple(ASUS_WMI_DEVID_WIMAX); 1312 bl = !asus_wmi_get_devstate_simple(ASUS_WMI_DEVID_WIMAX);
1310 rfkill_set_sw_state(asus->wimax_rfkill, bl); 1313 rfkill_set_sw_state(asus->wimax.rfkill, bl);
1311 } 1314 }
1312 if (asus->wwan3g_rfkill) { 1315 if (asus->wwan3g.rfkill) {
1313 bl = !asus_wmi_get_devstate_simple(ASUS_WMI_DEVID_WWAN3G); 1316 bl = !asus_wmi_get_devstate_simple(ASUS_WMI_DEVID_WWAN3G);
1314 rfkill_set_sw_state(asus->wwan3g_rfkill, bl); 1317 rfkill_set_sw_state(asus->wwan3g.rfkill, bl);
1315 } 1318 }
1316 1319
1317 return 0; 1320 return 0;