diff options
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2x00dev.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00dev.c | 55 |
1 files changed, 40 insertions, 15 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2x00dev.c b/drivers/net/wireless/rt2x00/rt2x00dev.c index 4f66adc5b09c..f8f7e6e47f80 100644 --- a/drivers/net/wireless/rt2x00/rt2x00dev.c +++ b/drivers/net/wireless/rt2x00/rt2x00dev.c | |||
@@ -40,7 +40,7 @@ | |||
40 | struct data_ring *rt2x00lib_get_ring(struct rt2x00_dev *rt2x00dev, | 40 | struct data_ring *rt2x00lib_get_ring(struct rt2x00_dev *rt2x00dev, |
41 | const unsigned int queue) | 41 | const unsigned int queue) |
42 | { | 42 | { |
43 | int beacon = test_bit(REQUIRE_BEACON_RING, &rt2x00dev->flags); | 43 | int beacon = test_bit(DRIVER_REQUIRE_BEACON_RING, &rt2x00dev->flags); |
44 | 44 | ||
45 | /* | 45 | /* |
46 | * Check if we are requesting a reqular TX ring, | 46 | * Check if we are requesting a reqular TX ring, |
@@ -102,7 +102,7 @@ int rt2x00lib_enable_radio(struct rt2x00_dev *rt2x00dev) | |||
102 | * And check if the hardware button has been disabled. | 102 | * And check if the hardware button has been disabled. |
103 | */ | 103 | */ |
104 | if (test_bit(DEVICE_ENABLED_RADIO, &rt2x00dev->flags) || | 104 | if (test_bit(DEVICE_ENABLED_RADIO, &rt2x00dev->flags) || |
105 | (test_bit(DEVICE_SUPPORT_HW_BUTTON, &rt2x00dev->flags) && | 105 | (test_bit(CONFIG_SUPPORT_HW_BUTTON, &rt2x00dev->flags) && |
106 | !test_bit(DEVICE_ENABLED_RADIO_HW, &rt2x00dev->flags))) | 106 | !test_bit(DEVICE_ENABLED_RADIO_HW, &rt2x00dev->flags))) |
107 | return 0; | 107 | return 0; |
108 | 108 | ||
@@ -162,6 +162,9 @@ void rt2x00lib_toggle_rx(struct rt2x00_dev *rt2x00dev, int enable) | |||
162 | { | 162 | { |
163 | enum dev_state state = enable ? STATE_RADIO_RX_ON : STATE_RADIO_RX_OFF; | 163 | enum dev_state state = enable ? STATE_RADIO_RX_ON : STATE_RADIO_RX_OFF; |
164 | 164 | ||
165 | if (!test_bit(DEVICE_ENABLED_RADIO, &rt2x00dev->flags)) | ||
166 | return; | ||
167 | |||
165 | /* | 168 | /* |
166 | * When we are disabling the RX, we should also stop the link tuner. | 169 | * When we are disabling the RX, we should also stop the link tuner. |
167 | */ | 170 | */ |
@@ -721,7 +724,7 @@ exit: | |||
721 | 724 | ||
722 | static void rt2x00lib_remove_hw(struct rt2x00_dev *rt2x00dev) | 725 | static void rt2x00lib_remove_hw(struct rt2x00_dev *rt2x00dev) |
723 | { | 726 | { |
724 | if (test_bit(DEVICE_INITIALIZED_HW, &rt2x00dev->flags)) | 727 | if (test_bit(DEVICE_REGISTERED_HW, &rt2x00dev->flags)) |
725 | ieee80211_unregister_hw(rt2x00dev->hw); | 728 | ieee80211_unregister_hw(rt2x00dev->hw); |
726 | 729 | ||
727 | if (likely(rt2x00dev->hwmodes)) { | 730 | if (likely(rt2x00dev->hwmodes)) { |
@@ -753,7 +756,7 @@ static int rt2x00lib_probe_hw(struct rt2x00_dev *rt2x00dev) | |||
753 | return status; | 756 | return status; |
754 | } | 757 | } |
755 | 758 | ||
756 | __set_bit(DEVICE_INITIALIZED_HW, &rt2x00dev->flags); | 759 | __set_bit(DEVICE_REGISTERED_HW, &rt2x00dev->flags); |
757 | 760 | ||
758 | return 0; | 761 | return 0; |
759 | } | 762 | } |
@@ -810,7 +813,7 @@ static int rt2x00lib_alloc_ring_entries(struct rt2x00_dev *rt2x00dev) | |||
810 | return -ENOMEM; | 813 | return -ENOMEM; |
811 | } | 814 | } |
812 | 815 | ||
813 | if (!test_bit(REQUIRE_BEACON_RING, &rt2x00dev->flags)) | 816 | if (!test_bit(DRIVER_REQUIRE_BEACON_RING, &rt2x00dev->flags)) |
814 | return 0; | 817 | return 0; |
815 | 818 | ||
816 | /* | 819 | /* |
@@ -919,7 +922,7 @@ static int rt2x00lib_alloc_rings(struct rt2x00_dev *rt2x00dev) | |||
919 | * Atim: 1 (if required) | 922 | * Atim: 1 (if required) |
920 | */ | 923 | */ |
921 | rt2x00dev->data_rings = 1 + rt2x00dev->hw->queues + | 924 | rt2x00dev->data_rings = 1 + rt2x00dev->hw->queues + |
922 | (2 * test_bit(REQUIRE_BEACON_RING, &rt2x00dev->flags)); | 925 | (2 * test_bit(DRIVER_REQUIRE_BEACON_RING, &rt2x00dev->flags)); |
923 | 926 | ||
924 | ring = kzalloc(rt2x00dev->data_rings * sizeof(*ring), GFP_KERNEL); | 927 | ring = kzalloc(rt2x00dev->data_rings * sizeof(*ring), GFP_KERNEL); |
925 | if (!ring) { | 928 | if (!ring) { |
@@ -932,7 +935,7 @@ static int rt2x00lib_alloc_rings(struct rt2x00_dev *rt2x00dev) | |||
932 | */ | 935 | */ |
933 | rt2x00dev->rx = ring; | 936 | rt2x00dev->rx = ring; |
934 | rt2x00dev->tx = &rt2x00dev->rx[1]; | 937 | rt2x00dev->tx = &rt2x00dev->rx[1]; |
935 | if (test_bit(REQUIRE_BEACON_RING, &rt2x00dev->flags)) | 938 | if (test_bit(DRIVER_REQUIRE_BEACON_RING, &rt2x00dev->flags)) |
936 | rt2x00dev->bcn = &rt2x00dev->tx[rt2x00dev->hw->queues]; | 939 | rt2x00dev->bcn = &rt2x00dev->tx[rt2x00dev->hw->queues]; |
937 | 940 | ||
938 | /* | 941 | /* |
@@ -1011,6 +1014,8 @@ int rt2x00lib_probe_dev(struct rt2x00_dev *rt2x00dev) | |||
1011 | */ | 1014 | */ |
1012 | rt2x00debug_register(rt2x00dev); | 1015 | rt2x00debug_register(rt2x00dev); |
1013 | 1016 | ||
1017 | __set_bit(DEVICE_PRESENT, &rt2x00dev->flags); | ||
1018 | |||
1014 | return 0; | 1019 | return 0; |
1015 | 1020 | ||
1016 | exit: | 1021 | exit: |
@@ -1022,6 +1027,8 @@ EXPORT_SYMBOL_GPL(rt2x00lib_probe_dev); | |||
1022 | 1027 | ||
1023 | void rt2x00lib_remove_dev(struct rt2x00_dev *rt2x00dev) | 1028 | void rt2x00lib_remove_dev(struct rt2x00_dev *rt2x00dev) |
1024 | { | 1029 | { |
1030 | __clear_bit(DEVICE_PRESENT, &rt2x00dev->flags); | ||
1031 | |||
1025 | /* | 1032 | /* |
1026 | * Disable radio. | 1033 | * Disable radio. |
1027 | */ | 1034 | */ |
@@ -1068,6 +1075,13 @@ int rt2x00lib_suspend(struct rt2x00_dev *rt2x00dev, pm_message_t state) | |||
1068 | int retval; | 1075 | int retval; |
1069 | 1076 | ||
1070 | NOTICE(rt2x00dev, "Going to sleep.\n"); | 1077 | NOTICE(rt2x00dev, "Going to sleep.\n"); |
1078 | __clear_bit(DEVICE_PRESENT, &rt2x00dev->flags); | ||
1079 | |||
1080 | /* | ||
1081 | * Only continue if mac80211 has open interfaces. | ||
1082 | */ | ||
1083 | if (!test_bit(DEVICE_STARTED, &rt2x00dev->flags)) | ||
1084 | goto exit; | ||
1071 | 1085 | ||
1072 | /* | 1086 | /* |
1073 | * Disable radio and unitialize all items | 1087 | * Disable radio and unitialize all items |
@@ -1077,6 +1091,7 @@ int rt2x00lib_suspend(struct rt2x00_dev *rt2x00dev, pm_message_t state) | |||
1077 | rt2x00lib_uninitialize(rt2x00dev); | 1091 | rt2x00lib_uninitialize(rt2x00dev); |
1078 | rt2x00debug_deregister(rt2x00dev); | 1092 | rt2x00debug_deregister(rt2x00dev); |
1079 | 1093 | ||
1094 | exit: | ||
1080 | /* | 1095 | /* |
1081 | * Set device mode to sleep for power management. | 1096 | * Set device mode to sleep for power management. |
1082 | */ | 1097 | */ |
@@ -1094,7 +1109,7 @@ int rt2x00lib_resume(struct rt2x00_dev *rt2x00dev) | |||
1094 | int retval; | 1109 | int retval; |
1095 | 1110 | ||
1096 | NOTICE(rt2x00dev, "Waking up.\n"); | 1111 | NOTICE(rt2x00dev, "Waking up.\n"); |
1097 | __set_bit(INTERFACE_RESUME, &rt2x00dev->flags); | 1112 | __set_bit(DEVICE_PRESENT, &rt2x00dev->flags); |
1098 | 1113 | ||
1099 | /* | 1114 | /* |
1100 | * Open the debugfs entry. | 1115 | * Open the debugfs entry. |
@@ -1102,6 +1117,12 @@ int rt2x00lib_resume(struct rt2x00_dev *rt2x00dev) | |||
1102 | rt2x00debug_register(rt2x00dev); | 1117 | rt2x00debug_register(rt2x00dev); |
1103 | 1118 | ||
1104 | /* | 1119 | /* |
1120 | * Only continue if mac80211 has open interfaces. | ||
1121 | */ | ||
1122 | if (!test_bit(DEVICE_STARTED, &rt2x00dev->flags)) | ||
1123 | return 0; | ||
1124 | |||
1125 | /* | ||
1105 | * Reinitialize device and all active interfaces. | 1126 | * Reinitialize device and all active interfaces. |
1106 | */ | 1127 | */ |
1107 | retval = rt2x00mac_start(rt2x00dev->hw); | 1128 | retval = rt2x00mac_start(rt2x00dev->hw); |
@@ -1111,15 +1132,23 @@ int rt2x00lib_resume(struct rt2x00_dev *rt2x00dev) | |||
1111 | /* | 1132 | /* |
1112 | * Reconfigure device. | 1133 | * Reconfigure device. |
1113 | */ | 1134 | */ |
1114 | retval = rt2x00mac_config(rt2x00dev->hw, &rt2x00dev->hw->conf); | 1135 | rt2x00lib_config(rt2x00dev, &rt2x00dev->hw->conf, 1); |
1115 | if (retval) | 1136 | if (!rt2x00dev->hw->conf.radio_enabled) |
1116 | goto exit; | 1137 | rt2x00lib_disable_radio(rt2x00dev); |
1117 | 1138 | ||
1118 | rt2x00lib_config_mac_addr(rt2x00dev, intf->mac); | 1139 | rt2x00lib_config_mac_addr(rt2x00dev, intf->mac); |
1119 | rt2x00lib_config_bssid(rt2x00dev, intf->bssid); | 1140 | rt2x00lib_config_bssid(rt2x00dev, intf->bssid); |
1120 | rt2x00lib_config_type(rt2x00dev, intf->type); | 1141 | rt2x00lib_config_type(rt2x00dev, intf->type); |
1121 | 1142 | ||
1122 | /* | 1143 | /* |
1144 | * It is possible that during that mac80211 has attempted | ||
1145 | * to send frames while we were suspending or resuming. | ||
1146 | * In that case we have disabled the TX queue and should | ||
1147 | * now enable it again | ||
1148 | */ | ||
1149 | ieee80211_start_queues(rt2x00dev->hw); | ||
1150 | |||
1151 | /* | ||
1123 | * When in Master or Ad-hoc mode, | 1152 | * When in Master or Ad-hoc mode, |
1124 | * restart Beacon transmitting by faking a beacondone event. | 1153 | * restart Beacon transmitting by faking a beacondone event. |
1125 | */ | 1154 | */ |
@@ -1127,8 +1156,6 @@ int rt2x00lib_resume(struct rt2x00_dev *rt2x00dev) | |||
1127 | intf->type == IEEE80211_IF_TYPE_IBSS) | 1156 | intf->type == IEEE80211_IF_TYPE_IBSS) |
1128 | rt2x00lib_beacondone(rt2x00dev); | 1157 | rt2x00lib_beacondone(rt2x00dev); |
1129 | 1158 | ||
1130 | __clear_bit(INTERFACE_RESUME, &rt2x00dev->flags); | ||
1131 | |||
1132 | return 0; | 1159 | return 0; |
1133 | 1160 | ||
1134 | exit: | 1161 | exit: |
@@ -1136,8 +1163,6 @@ exit: | |||
1136 | rt2x00lib_uninitialize(rt2x00dev); | 1163 | rt2x00lib_uninitialize(rt2x00dev); |
1137 | rt2x00debug_deregister(rt2x00dev); | 1164 | rt2x00debug_deregister(rt2x00dev); |
1138 | 1165 | ||
1139 | __clear_bit(INTERFACE_RESUME, &rt2x00dev->flags); | ||
1140 | |||
1141 | return retval; | 1166 | return retval; |
1142 | } | 1167 | } |
1143 | EXPORT_SYMBOL_GPL(rt2x00lib_resume); | 1168 | EXPORT_SYMBOL_GPL(rt2x00lib_resume); |