diff options
-rw-r--r-- | drivers/net/wireless/rtlwifi/ps.c | 283 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/ps.h | 71 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8188ee/Makefile | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8188ee/hw.c | 17 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8188ee/pwrseq.h | 18 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.h | 4 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723ae/Makefile | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723ae/hw.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723be/Makefile | 1 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723be/hw.c | 15 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723be/pwrseqcmd.c | 1 |
13 files changed, 162 insertions, 253 deletions
diff --git a/drivers/net/wireless/rtlwifi/ps.c b/drivers/net/wireless/rtlwifi/ps.c index 50504942ded1..b69321d45f04 100644 --- a/drivers/net/wireless/rtlwifi/ps.c +++ b/drivers/net/wireless/rtlwifi/ps.c | |||
@@ -11,10 +11,6 @@ | |||
11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | 11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
12 | * more details. | 12 | * more details. |
13 | * | 13 | * |
14 | * You should have received a copy of the GNU General Public License along with | ||
15 | * this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA | ||
17 | * | ||
18 | * The full GNU General Public License is included in this distribution in the | 14 | * The full GNU General Public License is included in this distribution in the |
19 | * file called LICENSE. | 15 | * file called LICENSE. |
20 | * | 16 | * |
@@ -27,110 +23,11 @@ | |||
27 | * | 23 | * |
28 | *****************************************************************************/ | 24 | *****************************************************************************/ |
29 | 25 | ||
30 | #include <linux/export.h> | ||
31 | #include "wifi.h" | 26 | #include "wifi.h" |
32 | #include "base.h" | 27 | #include "base.h" |
33 | #include "ps.h" | 28 | #include "ps.h" |
34 | 29 | #include <linux/export.h> | |
35 | /* Description: | 30 | #include "btcoexist/rtl_btc.h" |
36 | * This routine deals with the Power Configuration CMD | ||
37 | * parsing for RTL8723/RTL8188E Series IC. | ||
38 | * Assumption: | ||
39 | * We should follow specific format that was released from HW SD. | ||
40 | */ | ||
41 | bool rtl_hal_pwrseqcmdparsing(struct rtl_priv *rtlpriv, u8 cut_version, | ||
42 | u8 faversion, u8 interface_type, | ||
43 | struct wlan_pwr_cfg pwrcfgcmd[]) | ||
44 | { | ||
45 | struct wlan_pwr_cfg cfg_cmd = {0}; | ||
46 | bool polling_bit = false; | ||
47 | u32 ary_idx = 0; | ||
48 | u8 value = 0; | ||
49 | u32 offset = 0; | ||
50 | u32 polling_count = 0; | ||
51 | u32 max_polling_cnt = 5000; | ||
52 | |||
53 | do { | ||
54 | cfg_cmd = pwrcfgcmd[ary_idx]; | ||
55 | RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE, | ||
56 | "rtl_hal_pwrseqcmdparsing(): offset(%#x),cut_msk(%#x), famsk(%#x)," | ||
57 | "interface_msk(%#x), base(%#x), cmd(%#x), msk(%#x), value(%#x)\n", | ||
58 | GET_PWR_CFG_OFFSET(cfg_cmd), | ||
59 | GET_PWR_CFG_CUT_MASK(cfg_cmd), | ||
60 | GET_PWR_CFG_FAB_MASK(cfg_cmd), | ||
61 | GET_PWR_CFG_INTF_MASK(cfg_cmd), | ||
62 | GET_PWR_CFG_BASE(cfg_cmd), GET_PWR_CFG_CMD(cfg_cmd), | ||
63 | GET_PWR_CFG_MASK(cfg_cmd), GET_PWR_CFG_VALUE(cfg_cmd)); | ||
64 | |||
65 | if ((GET_PWR_CFG_FAB_MASK(cfg_cmd)&faversion) && | ||
66 | (GET_PWR_CFG_CUT_MASK(cfg_cmd)&cut_version) && | ||
67 | (GET_PWR_CFG_INTF_MASK(cfg_cmd)&interface_type)) { | ||
68 | switch (GET_PWR_CFG_CMD(cfg_cmd)) { | ||
69 | case PWR_CMD_READ: | ||
70 | RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE, | ||
71 | "rtl_hal_pwrseqcmdparsing(): PWR_CMD_READ\n"); | ||
72 | break; | ||
73 | case PWR_CMD_WRITE: | ||
74 | RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE, | ||
75 | "rtl_hal_pwrseqcmdparsing(): PWR_CMD_WRITE\n"); | ||
76 | offset = GET_PWR_CFG_OFFSET(cfg_cmd); | ||
77 | |||
78 | /*Read the value from system register*/ | ||
79 | value = rtl_read_byte(rtlpriv, offset); | ||
80 | value &= (~(GET_PWR_CFG_MASK(cfg_cmd))); | ||
81 | value |= (GET_PWR_CFG_VALUE(cfg_cmd) & | ||
82 | GET_PWR_CFG_MASK(cfg_cmd)); | ||
83 | |||
84 | /*Write the value back to sytem register*/ | ||
85 | rtl_write_byte(rtlpriv, offset, value); | ||
86 | break; | ||
87 | case PWR_CMD_POLLING: | ||
88 | RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE, | ||
89 | "rtl_hal_pwrseqcmdparsing(): PWR_CMD_POLLING\n"); | ||
90 | polling_bit = false; | ||
91 | offset = GET_PWR_CFG_OFFSET(cfg_cmd); | ||
92 | |||
93 | do { | ||
94 | value = rtl_read_byte(rtlpriv, offset); | ||
95 | |||
96 | value &= GET_PWR_CFG_MASK(cfg_cmd); | ||
97 | if (value == | ||
98 | (GET_PWR_CFG_VALUE(cfg_cmd) | ||
99 | & GET_PWR_CFG_MASK(cfg_cmd))) | ||
100 | polling_bit = true; | ||
101 | else | ||
102 | udelay(10); | ||
103 | |||
104 | if (polling_count++ > max_polling_cnt) | ||
105 | return false; | ||
106 | } while (!polling_bit); | ||
107 | break; | ||
108 | case PWR_CMD_DELAY: | ||
109 | RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE, | ||
110 | "rtl_hal_pwrseqcmdparsing(): PWR_CMD_DELAY\n"); | ||
111 | if (GET_PWR_CFG_VALUE(cfg_cmd) == | ||
112 | PWRSEQ_DELAY_US) | ||
113 | udelay(GET_PWR_CFG_OFFSET(cfg_cmd)); | ||
114 | else | ||
115 | mdelay(GET_PWR_CFG_OFFSET(cfg_cmd)); | ||
116 | break; | ||
117 | case PWR_CMD_END: | ||
118 | RT_TRACE(rtlpriv, COMP_INIT, DBG_TRACE, | ||
119 | "rtl_hal_pwrseqcmdparsing(): PWR_CMD_END\n"); | ||
120 | return true; | ||
121 | default: | ||
122 | RT_ASSERT(false, | ||
123 | "rtl_hal_pwrseqcmdparsing(): Unknown CMD!!\n"); | ||
124 | break; | ||
125 | } | ||
126 | |||
127 | } | ||
128 | ary_idx++; | ||
129 | } while (1); | ||
130 | |||
131 | return true; | ||
132 | } | ||
133 | EXPORT_SYMBOL(rtl_hal_pwrseqcmdparsing); | ||
134 | 31 | ||
135 | bool rtl_ps_enable_nic(struct ieee80211_hw *hw) | 32 | bool rtl_ps_enable_nic(struct ieee80211_hw *hw) |
136 | { | 33 | { |
@@ -181,11 +78,49 @@ EXPORT_SYMBOL(rtl_ps_disable_nic); | |||
181 | 78 | ||
182 | bool rtl_ps_set_rf_state(struct ieee80211_hw *hw, | 79 | bool rtl_ps_set_rf_state(struct ieee80211_hw *hw, |
183 | enum rf_pwrstate state_toset, | 80 | enum rf_pwrstate state_toset, |
184 | u32 changesource) | 81 | u32 changesource, bool protect_or_not) |
185 | { | 82 | { |
186 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 83 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
187 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); | 84 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); |
85 | enum rf_pwrstate rtstate; | ||
188 | bool actionallowed = false; | 86 | bool actionallowed = false; |
87 | u16 rfwait_cnt = 0; | ||
88 | |||
89 | if (protect_or_not) | ||
90 | goto no_protect; | ||
91 | |||
92 | /*Only one thread can change | ||
93 | *the RF state at one time, and others | ||
94 | *should wait to be executed. | ||
95 | */ | ||
96 | while (true) { | ||
97 | spin_lock(&rtlpriv->locks.rf_ps_lock); | ||
98 | if (ppsc->rfchange_inprogress) { | ||
99 | spin_unlock(&rtlpriv->locks.rf_ps_lock); | ||
100 | |||
101 | RT_TRACE(rtlpriv, COMP_ERR, DBG_WARNING, | ||
102 | "RF Change in progress! Wait to set..state_toset(%d).\n", | ||
103 | state_toset); | ||
104 | |||
105 | /* Set RF after the previous action is done. */ | ||
106 | while (ppsc->rfchange_inprogress) { | ||
107 | rfwait_cnt++; | ||
108 | mdelay(1); | ||
109 | /*Wait too long, return false to avoid | ||
110 | *to be stuck here. | ||
111 | */ | ||
112 | if (rfwait_cnt > 100) | ||
113 | return false; | ||
114 | } | ||
115 | } else { | ||
116 | ppsc->rfchange_inprogress = true; | ||
117 | spin_unlock(&rtlpriv->locks.rf_ps_lock); | ||
118 | break; | ||
119 | } | ||
120 | } | ||
121 | |||
122 | no_protect: | ||
123 | rtstate = ppsc->rfpwr_state; | ||
189 | 124 | ||
190 | switch (state_toset) { | 125 | switch (state_toset) { |
191 | case ERFON: | 126 | case ERFON: |
@@ -227,6 +162,12 @@ bool rtl_ps_set_rf_state(struct ieee80211_hw *hw, | |||
227 | if (actionallowed) | 162 | if (actionallowed) |
228 | rtlpriv->cfg->ops->set_rf_power_state(hw, state_toset); | 163 | rtlpriv->cfg->ops->set_rf_power_state(hw, state_toset); |
229 | 164 | ||
165 | if (!protect_or_not) { | ||
166 | spin_lock(&rtlpriv->locks.rf_ps_lock); | ||
167 | ppsc->rfchange_inprogress = false; | ||
168 | spin_unlock(&rtlpriv->locks.rf_ps_lock); | ||
169 | } | ||
170 | |||
230 | return actionallowed; | 171 | return actionallowed; |
231 | } | 172 | } |
232 | EXPORT_SYMBOL(rtl_ps_set_rf_state); | 173 | EXPORT_SYMBOL(rtl_ps_set_rf_state); |
@@ -249,12 +190,13 @@ static void _rtl_ps_inactive_ps(struct ieee80211_hw *hw) | |||
249 | } | 190 | } |
250 | } | 191 | } |
251 | 192 | ||
252 | rtl_ps_set_rf_state(hw, ppsc->inactive_pwrstate, RF_CHANGE_BY_IPS); | 193 | rtl_ps_set_rf_state(hw, ppsc->inactive_pwrstate, |
194 | RF_CHANGE_BY_IPS, false); | ||
253 | 195 | ||
254 | if (ppsc->inactive_pwrstate == ERFOFF && | 196 | if (ppsc->inactive_pwrstate == ERFOFF && |
255 | rtlhal->interface == INTF_PCI) { | 197 | rtlhal->interface == INTF_PCI) { |
256 | if (ppsc->reg_rfps_level & RT_RF_OFF_LEVL_ASPM && | 198 | if (ppsc->reg_rfps_level & RT_RF_OFF_LEVL_ASPM && |
257 | !RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM)) { | 199 | !RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM)) { |
258 | rtlpriv->intf_ops->enable_aspm(hw); | 200 | rtlpriv->intf_ops->enable_aspm(hw); |
259 | RT_SET_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM); | 201 | RT_SET_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM); |
260 | } | 202 | } |
@@ -318,6 +260,11 @@ void rtl_ips_nic_off_wq_callback(void *data) | |||
318 | ppsc->inactive_pwrstate = ERFOFF; | 260 | ppsc->inactive_pwrstate = ERFOFF; |
319 | ppsc->in_powersavemode = true; | 261 | ppsc->in_powersavemode = true; |
320 | 262 | ||
263 | /* call before RF off */ | ||
264 | if (rtlpriv->cfg->ops->get_btc_status()) | ||
265 | rtlpriv->btcoexist.btc_ops->btc_ips_notify(rtlpriv, | ||
266 | ppsc->inactive_pwrstate); | ||
267 | |||
321 | /*rtl_pci_reset_trx_ring(hw); */ | 268 | /*rtl_pci_reset_trx_ring(hw); */ |
322 | _rtl_ps_inactive_ps(hw); | 269 | _rtl_ps_inactive_ps(hw); |
323 | } | 270 | } |
@@ -328,10 +275,9 @@ void rtl_ips_nic_off(struct ieee80211_hw *hw) | |||
328 | { | 275 | { |
329 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 276 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
330 | 277 | ||
331 | /* | 278 | /* because when link with ap, mac80211 will ask us |
332 | *because when link with ap, mac80211 will ask us | 279 | * to disable nic quickly after scan before linking, |
333 | *to disable nic quickly after scan before linking, | 280 | * this will cause link failed, so we delay 100ms here |
334 | *this will cause link failed, so we delay 100ms here | ||
335 | */ | 281 | */ |
336 | queue_delayed_work(rtlpriv->works.rtl_wq, | 282 | queue_delayed_work(rtlpriv->works.rtl_wq, |
337 | &rtlpriv->works.ips_nic_off_wq, MSECS(100)); | 283 | &rtlpriv->works.ips_nic_off_wq, MSECS(100)); |
@@ -343,16 +289,12 @@ void rtl_ips_nic_off(struct ieee80211_hw *hw) | |||
343 | void rtl_ips_nic_on(struct ieee80211_hw *hw) | 289 | void rtl_ips_nic_on(struct ieee80211_hw *hw) |
344 | { | 290 | { |
345 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 291 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
346 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); | ||
347 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); | 292 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); |
348 | enum rf_pwrstate rtstate; | 293 | enum rf_pwrstate rtstate; |
349 | unsigned long flags; | ||
350 | |||
351 | if (mac->opmode != NL80211_IFTYPE_STATION) | ||
352 | return; | ||
353 | 294 | ||
354 | spin_lock_irqsave(&rtlpriv->locks.ips_lock, flags); | 295 | cancel_delayed_work(&rtlpriv->works.ips_nic_off_wq); |
355 | 296 | ||
297 | spin_lock(&rtlpriv->locks.ips_lock); | ||
356 | if (ppsc->inactiveps) { | 298 | if (ppsc->inactiveps) { |
357 | rtstate = ppsc->rfpwr_state; | 299 | rtstate = ppsc->rfpwr_state; |
358 | 300 | ||
@@ -362,12 +304,14 @@ void rtl_ips_nic_on(struct ieee80211_hw *hw) | |||
362 | 304 | ||
363 | ppsc->inactive_pwrstate = ERFON; | 305 | ppsc->inactive_pwrstate = ERFON; |
364 | ppsc->in_powersavemode = false; | 306 | ppsc->in_powersavemode = false; |
365 | |||
366 | _rtl_ps_inactive_ps(hw); | 307 | _rtl_ps_inactive_ps(hw); |
308 | /* call after RF on */ | ||
309 | if (rtlpriv->cfg->ops->get_btc_status()) | ||
310 | rtlpriv->btcoexist.btc_ops->btc_ips_notify(rtlpriv, | ||
311 | ppsc->inactive_pwrstate); | ||
367 | } | 312 | } |
368 | } | 313 | } |
369 | 314 | spin_unlock(&rtlpriv->locks.ips_lock); | |
370 | spin_unlock_irqrestore(&rtlpriv->locks.ips_lock, flags); | ||
371 | } | 315 | } |
372 | EXPORT_SYMBOL_GPL(rtl_ips_nic_on); | 316 | EXPORT_SYMBOL_GPL(rtl_ips_nic_on); |
373 | 317 | ||
@@ -404,7 +348,7 @@ static bool rtl_get_fwlps_doze(struct ieee80211_hw *hw) | |||
404 | } | 348 | } |
405 | 349 | ||
406 | /* Change current and default preamble mode.*/ | 350 | /* Change current and default preamble mode.*/ |
407 | static void rtl_lps_set_psmode(struct ieee80211_hw *hw, u8 rt_psmode) | 351 | void rtl_lps_set_psmode(struct ieee80211_hw *hw, u8 rt_psmode) |
408 | { | 352 | { |
409 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 353 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
410 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); | 354 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); |
@@ -437,21 +381,24 @@ static void rtl_lps_set_psmode(struct ieee80211_hw *hw, u8 rt_psmode) | |||
437 | if (ppsc->dot11_psmode == EACTIVE) { | 381 | if (ppsc->dot11_psmode == EACTIVE) { |
438 | RT_TRACE(rtlpriv, COMP_RF, DBG_DMESG, | 382 | RT_TRACE(rtlpriv, COMP_RF, DBG_DMESG, |
439 | "FW LPS leave ps_mode:%x\n", | 383 | "FW LPS leave ps_mode:%x\n", |
440 | FW_PS_ACTIVE_MODE); | 384 | FW_PS_ACTIVE_MODE); |
441 | enter_fwlps = false; | 385 | enter_fwlps = false; |
442 | ppsc->pwr_mode = FW_PS_ACTIVE_MODE; | 386 | ppsc->pwr_mode = FW_PS_ACTIVE_MODE; |
443 | ppsc->smart_ps = 0; | 387 | ppsc->smart_ps = 0; |
444 | rtlpriv->cfg->ops->set_hw_reg(hw, | 388 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_FW_LPS_ACTION, |
445 | HW_VAR_FW_LPS_ACTION, | 389 | (u8 *)(&enter_fwlps)); |
446 | (u8 *)(&enter_fwlps)); | ||
447 | if (ppsc->p2p_ps_info.opp_ps) | 390 | if (ppsc->p2p_ps_info.opp_ps) |
448 | rtl_p2p_ps_cmd(hw, P2P_PS_ENABLE); | 391 | rtl_p2p_ps_cmd(hw , P2P_PS_ENABLE); |
449 | 392 | ||
393 | if (rtlpriv->cfg->ops->get_btc_status()) | ||
394 | rtlpriv->btcoexist.btc_ops->btc_lps_notify(rtlpriv, rt_psmode); | ||
450 | } else { | 395 | } else { |
451 | if (rtl_get_fwlps_doze(hw)) { | 396 | if (rtl_get_fwlps_doze(hw)) { |
452 | RT_TRACE(rtlpriv, COMP_RF, DBG_DMESG, | 397 | RT_TRACE(rtlpriv, COMP_RF, DBG_DMESG, |
453 | "FW LPS enter ps_mode:%x\n", | 398 | "FW LPS enter ps_mode:%x\n", |
454 | ppsc->fwctrl_psmode); | 399 | ppsc->fwctrl_psmode); |
400 | if (rtlpriv->cfg->ops->get_btc_status()) | ||
401 | rtlpriv->btcoexist.btc_ops->btc_lps_notify(rtlpriv, rt_psmode); | ||
455 | enter_fwlps = true; | 402 | enter_fwlps = true; |
456 | ppsc->pwr_mode = ppsc->fwctrl_psmode; | 403 | ppsc->pwr_mode = ppsc->fwctrl_psmode; |
457 | ppsc->smart_ps = 2; | 404 | ppsc->smart_ps = 2; |
@@ -473,6 +420,7 @@ void rtl_lps_enter(struct ieee80211_hw *hw) | |||
473 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); | 420 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); |
474 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); | 421 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); |
475 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 422 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
423 | unsigned long flag; | ||
476 | 424 | ||
477 | if (!ppsc->fwctrl_lps) | 425 | if (!ppsc->fwctrl_lps) |
478 | return; | 426 | return; |
@@ -493,7 +441,7 @@ void rtl_lps_enter(struct ieee80211_hw *hw) | |||
493 | if (mac->link_state != MAC80211_LINKED) | 441 | if (mac->link_state != MAC80211_LINKED) |
494 | return; | 442 | return; |
495 | 443 | ||
496 | mutex_lock(&rtlpriv->locks.ps_mutex); | 444 | spin_lock_irqsave(&rtlpriv->locks.lps_lock, flag); |
497 | 445 | ||
498 | /* Idle for a while if we connect to AP a while ago. */ | 446 | /* Idle for a while if we connect to AP a while ago. */ |
499 | if (mac->cnt_after_linked >= 2) { | 447 | if (mac->cnt_after_linked >= 2) { |
@@ -505,8 +453,9 @@ void rtl_lps_enter(struct ieee80211_hw *hw) | |||
505 | } | 453 | } |
506 | } | 454 | } |
507 | 455 | ||
508 | mutex_unlock(&rtlpriv->locks.ps_mutex); | 456 | spin_unlock_irqrestore(&rtlpriv->locks.lps_lock, flag); |
509 | } | 457 | } |
458 | EXPORT_SYMBOL(rtl_lps_enter); | ||
510 | 459 | ||
511 | /*Leave the leisure power save mode.*/ | 460 | /*Leave the leisure power save mode.*/ |
512 | void rtl_lps_leave(struct ieee80211_hw *hw) | 461 | void rtl_lps_leave(struct ieee80211_hw *hw) |
@@ -514,14 +463,15 @@ void rtl_lps_leave(struct ieee80211_hw *hw) | |||
514 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 463 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
515 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); | 464 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); |
516 | struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw)); | 465 | struct rtl_hal *rtlhal = rtl_hal(rtl_priv(hw)); |
466 | unsigned long flag; | ||
517 | 467 | ||
518 | mutex_lock(&rtlpriv->locks.ps_mutex); | 468 | spin_lock_irqsave(&rtlpriv->locks.lps_lock, flag); |
519 | 469 | ||
520 | if (ppsc->fwctrl_lps) { | 470 | if (ppsc->fwctrl_lps) { |
521 | if (ppsc->dot11_psmode != EACTIVE) { | 471 | if (ppsc->dot11_psmode != EACTIVE) { |
522 | 472 | ||
523 | /*FIX ME */ | 473 | /*FIX ME */ |
524 | rtlpriv->cfg->ops->enable_interrupt(hw); | 474 | /*rtlpriv->cfg->ops->enable_interrupt(hw); */ |
525 | 475 | ||
526 | if (ppsc->reg_rfps_level & RT_RF_LPS_LEVEL_ASPM && | 476 | if (ppsc->reg_rfps_level & RT_RF_LPS_LEVEL_ASPM && |
527 | RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM) && | 477 | RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM) && |
@@ -536,8 +486,9 @@ void rtl_lps_leave(struct ieee80211_hw *hw) | |||
536 | rtl_lps_set_psmode(hw, EACTIVE); | 486 | rtl_lps_set_psmode(hw, EACTIVE); |
537 | } | 487 | } |
538 | } | 488 | } |
539 | mutex_unlock(&rtlpriv->locks.ps_mutex); | 489 | spin_unlock_irqrestore(&rtlpriv->locks.lps_lock, flag); |
540 | } | 490 | } |
491 | EXPORT_SYMBOL(rtl_lps_leave); | ||
541 | 492 | ||
542 | /* For sw LPS*/ | 493 | /* For sw LPS*/ |
543 | void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len) | 494 | void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len) |
@@ -613,7 +564,7 @@ void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len) | |||
613 | /* back to low-power land. and delay is | 564 | /* back to low-power land. and delay is |
614 | * prevent null power save frame tx fail */ | 565 | * prevent null power save frame tx fail */ |
615 | queue_delayed_work(rtlpriv->works.rtl_wq, | 566 | queue_delayed_work(rtlpriv->works.rtl_wq, |
616 | &rtlpriv->works.ps_work, MSECS(5)); | 567 | &rtlpriv->works.ps_work, MSECS(5)); |
617 | } else { | 568 | } else { |
618 | RT_TRACE(rtlpriv, COMP_POWER, DBG_DMESG, | 569 | RT_TRACE(rtlpriv, COMP_POWER, DBG_DMESG, |
619 | "u_bufferd: %x, m_buffered: %x\n", u_buffed, m_buffed); | 570 | "u_bufferd: %x, m_buffered: %x\n", u_buffed, m_buffed); |
@@ -626,6 +577,7 @@ void rtl_swlps_rf_awake(struct ieee80211_hw *hw) | |||
626 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 577 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
627 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); | 578 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); |
628 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); | 579 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); |
580 | unsigned long flag; | ||
629 | 581 | ||
630 | if (!rtlpriv->psc.swctrl_lps) | 582 | if (!rtlpriv->psc.swctrl_lps) |
631 | return; | 583 | return; |
@@ -633,14 +585,14 @@ void rtl_swlps_rf_awake(struct ieee80211_hw *hw) | |||
633 | return; | 585 | return; |
634 | 586 | ||
635 | if (ppsc->reg_rfps_level & RT_RF_LPS_LEVEL_ASPM && | 587 | if (ppsc->reg_rfps_level & RT_RF_LPS_LEVEL_ASPM && |
636 | RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM)) { | 588 | RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM)) { |
637 | rtlpriv->intf_ops->disable_aspm(hw); | 589 | rtlpriv->intf_ops->disable_aspm(hw); |
638 | RT_CLEAR_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM); | 590 | RT_CLEAR_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM); |
639 | } | 591 | } |
640 | 592 | ||
641 | mutex_lock(&rtlpriv->locks.ps_mutex); | 593 | spin_lock_irqsave(&rtlpriv->locks.lps_lock, flag); |
642 | rtl_ps_set_rf_state(hw, ERFON, RF_CHANGE_BY_PS); | 594 | rtl_ps_set_rf_state(hw, ERFON, RF_CHANGE_BY_PS, false); |
643 | mutex_unlock(&rtlpriv->locks.ps_mutex); | 595 | spin_unlock_irqrestore(&rtlpriv->locks.lps_lock, flag); |
644 | } | 596 | } |
645 | 597 | ||
646 | void rtl_swlps_rfon_wq_callback(void *data) | 598 | void rtl_swlps_rfon_wq_callback(void *data) |
@@ -657,6 +609,7 @@ void rtl_swlps_rf_sleep(struct ieee80211_hw *hw) | |||
657 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 609 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
658 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); | 610 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); |
659 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); | 611 | struct rtl_ps_ctl *ppsc = rtl_psc(rtl_priv(hw)); |
612 | unsigned long flag; | ||
660 | u8 sleep_intv; | 613 | u8 sleep_intv; |
661 | 614 | ||
662 | if (!rtlpriv->psc.sw_ps_enabled) | 615 | if (!rtlpriv->psc.sw_ps_enabled) |
@@ -673,12 +626,19 @@ void rtl_swlps_rf_sleep(struct ieee80211_hw *hw) | |||
673 | if (rtlpriv->link_info.busytraffic) | 626 | if (rtlpriv->link_info.busytraffic) |
674 | return; | 627 | return; |
675 | 628 | ||
676 | mutex_lock(&rtlpriv->locks.ps_mutex); | 629 | spin_lock(&rtlpriv->locks.rf_ps_lock); |
677 | rtl_ps_set_rf_state(hw, ERFSLEEP, RF_CHANGE_BY_PS); | 630 | if (rtlpriv->psc.rfchange_inprogress) { |
678 | mutex_unlock(&rtlpriv->locks.ps_mutex); | 631 | spin_unlock(&rtlpriv->locks.rf_ps_lock); |
632 | return; | ||
633 | } | ||
634 | spin_unlock(&rtlpriv->locks.rf_ps_lock); | ||
635 | |||
636 | spin_lock_irqsave(&rtlpriv->locks.lps_lock, flag); | ||
637 | rtl_ps_set_rf_state(hw, ERFSLEEP, RF_CHANGE_BY_PS , false); | ||
638 | spin_unlock_irqrestore(&rtlpriv->locks.lps_lock, flag); | ||
679 | 639 | ||
680 | if (ppsc->reg_rfps_level & RT_RF_OFF_LEVL_ASPM && | 640 | if (ppsc->reg_rfps_level & RT_RF_OFF_LEVL_ASPM && |
681 | !RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM)) { | 641 | !RT_IN_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM)) { |
682 | rtlpriv->intf_ops->enable_aspm(hw); | 642 | rtlpriv->intf_ops->enable_aspm(hw); |
683 | RT_SET_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM); | 643 | RT_SET_PS_LEVEL(ppsc, RT_PS_LEVEL_ASPM); |
684 | } | 644 | } |
@@ -706,7 +666,7 @@ void rtl_swlps_rf_sleep(struct ieee80211_hw *hw) | |||
706 | * awake before every dtim */ | 666 | * awake before every dtim */ |
707 | RT_TRACE(rtlpriv, COMP_POWER, DBG_DMESG, | 667 | RT_TRACE(rtlpriv, COMP_POWER, DBG_DMESG, |
708 | "dtim_counter:%x will sleep :%d beacon_intv\n", | 668 | "dtim_counter:%x will sleep :%d beacon_intv\n", |
709 | rtlpriv->psc.dtim_counter, sleep_intv); | 669 | rtlpriv->psc.dtim_counter, sleep_intv); |
710 | 670 | ||
711 | /* we tested that 40ms is enough for sw & hw sw delay */ | 671 | /* we tested that 40ms is enough for sw & hw sw delay */ |
712 | queue_delayed_work(rtlpriv->works.rtl_wq, &rtlpriv->works.ps_rfon_wq, | 672 | queue_delayed_work(rtlpriv->works.rtl_wq, &rtlpriv->works.ps_rfon_wq, |
@@ -744,7 +704,7 @@ void rtl_swlps_wq_callback(void *data) | |||
744 | 704 | ||
745 | if (rtlpriv->psc.state && !ps) { | 705 | if (rtlpriv->psc.state && !ps) { |
746 | rtlpriv->psc.sleep_ms = jiffies_to_msecs(jiffies - | 706 | rtlpriv->psc.sleep_ms = jiffies_to_msecs(jiffies - |
747 | rtlpriv->psc.last_action); | 707 | rtlpriv->psc.last_action); |
748 | } | 708 | } |
749 | 709 | ||
750 | if (ps) | 710 | if (ps) |
@@ -764,7 +724,7 @@ static void rtl_p2p_noa_ie(struct ieee80211_hw *hw, void *data, | |||
764 | u8 *pos, *end, *ie; | 724 | u8 *pos, *end, *ie; |
765 | u16 noa_len; | 725 | u16 noa_len; |
766 | static u8 p2p_oui_ie_type[4] = {0x50, 0x6f, 0x9a, 0x09}; | 726 | static u8 p2p_oui_ie_type[4] = {0x50, 0x6f, 0x9a, 0x09}; |
767 | u8 noa_num, index, i, noa_index = 0; | 727 | u8 noa_num, index , i, noa_index = 0; |
768 | bool find_p2p_ie = false , find_p2p_ps_ie = false; | 728 | bool find_p2p_ie = false , find_p2p_ps_ie = false; |
769 | pos = (u8 *)mgmt->u.beacon.variable; | 729 | pos = (u8 *)mgmt->u.beacon.variable; |
770 | end = data + len; | 730 | end = data + len; |
@@ -814,7 +774,7 @@ static void rtl_p2p_noa_ie(struct ieee80211_hw *hw, void *data, | |||
814 | index = 5; | 774 | index = 5; |
815 | for (i = 0; i < noa_num; i++) { | 775 | for (i = 0; i < noa_num; i++) { |
816 | p2pinfo->noa_count_type[i] = | 776 | p2pinfo->noa_count_type[i] = |
817 | READEF1BYTE(ie+index); | 777 | READEF1BYTE(ie+index); |
818 | index += 1; | 778 | index += 1; |
819 | p2pinfo->noa_duration[i] = | 779 | p2pinfo->noa_duration[i] = |
820 | READEF4BYTE((__le32 *)ie+index); | 780 | READEF4BYTE((__le32 *)ie+index); |
@@ -842,7 +802,7 @@ static void rtl_p2p_noa_ie(struct ieee80211_hw *hw, void *data, | |||
842 | rtl_p2p_ps_cmd(hw, P2P_PS_DISABLE); | 802 | rtl_p2p_ps_cmd(hw, P2P_PS_DISABLE); |
843 | } | 803 | } |
844 | } | 804 | } |
845 | break; | 805 | break; |
846 | } | 806 | } |
847 | ie += 3 + noa_len; | 807 | ie += 3 + noa_len; |
848 | } | 808 | } |
@@ -860,7 +820,7 @@ static void rtl_p2p_action_ie(struct ieee80211_hw *hw, void *data, | |||
860 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 820 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
861 | struct ieee80211_mgmt *mgmt = data; | 821 | struct ieee80211_mgmt *mgmt = data; |
862 | struct rtl_p2p_ps_info *p2pinfo = &(rtlpriv->psc.p2p_ps_info); | 822 | struct rtl_p2p_ps_info *p2pinfo = &(rtlpriv->psc.p2p_ps_info); |
863 | u8 noa_num, index, i, noa_index = 0; | 823 | u8 noa_num, index , i , noa_index = 0; |
864 | u8 *pos, *end, *ie; | 824 | u8 *pos, *end, *ie; |
865 | u16 noa_len; | 825 | u16 noa_len; |
866 | static u8 p2p_oui_ie_type[4] = {0x50, 0x6f, 0x9a, 0x09}; | 826 | static u8 p2p_oui_ie_type[4] = {0x50, 0x6f, 0x9a, 0x09}; |
@@ -906,7 +866,7 @@ static void rtl_p2p_action_ie(struct ieee80211_hw *hw, void *data, | |||
906 | index = 5; | 866 | index = 5; |
907 | for (i = 0; i < noa_num; i++) { | 867 | for (i = 0; i < noa_num; i++) { |
908 | p2pinfo->noa_count_type[i] = | 868 | p2pinfo->noa_count_type[i] = |
909 | READEF1BYTE(ie+index); | 869 | READEF1BYTE(ie+index); |
910 | index += 1; | 870 | index += 1; |
911 | p2pinfo->noa_duration[i] = | 871 | p2pinfo->noa_duration[i] = |
912 | READEF4BYTE((__le32 *)ie+index); | 872 | READEF4BYTE((__le32 *)ie+index); |
@@ -934,37 +894,37 @@ static void rtl_p2p_action_ie(struct ieee80211_hw *hw, void *data, | |||
934 | rtl_p2p_ps_cmd(hw, P2P_PS_DISABLE); | 894 | rtl_p2p_ps_cmd(hw, P2P_PS_DISABLE); |
935 | } | 895 | } |
936 | } | 896 | } |
937 | break; | 897 | break; |
938 | } | 898 | } |
939 | ie += 3 + noa_len; | 899 | ie += 3 + noa_len; |
940 | } | 900 | } |
941 | } | 901 | } |
942 | 902 | ||
943 | void rtl_p2p_ps_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state) | 903 | void rtl_p2p_ps_cmd(struct ieee80211_hw *hw , u8 p2p_ps_state) |
944 | { | 904 | { |
945 | struct rtl_priv *rtlpriv = rtl_priv(hw); | 905 | struct rtl_priv *rtlpriv = rtl_priv(hw); |
946 | struct rtl_ps_ctl *rtlps = rtl_psc(rtl_priv(hw)); | 906 | struct rtl_ps_ctl *rtlps = rtl_psc(rtl_priv(hw)); |
947 | struct rtl_p2p_ps_info *p2pinfo = &(rtlpriv->psc.p2p_ps_info); | 907 | struct rtl_p2p_ps_info *p2pinfo = &(rtlpriv->psc.p2p_ps_info); |
948 | 908 | ||
949 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, " p2p state %x\n", p2p_ps_state); | 909 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, " p2p state %x\n" , p2p_ps_state); |
950 | switch (p2p_ps_state) { | 910 | switch (p2p_ps_state) { |
951 | case P2P_PS_DISABLE: | 911 | case P2P_PS_DISABLE: |
952 | p2pinfo->p2p_ps_state = p2p_ps_state; | 912 | p2pinfo->p2p_ps_state = p2p_ps_state; |
953 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, | 913 | rtlpriv->cfg->ops->set_hw_reg(hw, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, |
954 | &p2p_ps_state); | 914 | &p2p_ps_state); |
955 | |||
956 | p2pinfo->noa_index = 0; | 915 | p2pinfo->noa_index = 0; |
957 | p2pinfo->ctwindow = 0; | 916 | p2pinfo->ctwindow = 0; |
958 | p2pinfo->opp_ps = 0; | 917 | p2pinfo->opp_ps = 0; |
959 | p2pinfo->noa_num = 0; | 918 | p2pinfo->noa_num = 0; |
960 | p2pinfo->p2p_ps_mode = P2P_PS_NONE; | 919 | p2pinfo->p2p_ps_mode = P2P_PS_NONE; |
961 | if (rtlps->fw_current_inpsmode == true) { | 920 | if (rtlps->fw_current_inpsmode) { |
962 | if (rtlps->smart_ps == 0) { | 921 | if (rtlps->smart_ps == 0) { |
963 | rtlps->smart_ps = 2; | 922 | rtlps->smart_ps = 2; |
964 | rtlpriv->cfg->ops->set_hw_reg(hw, | 923 | rtlpriv->cfg->ops->set_hw_reg(hw, |
965 | HW_VAR_H2C_FW_PWRMODE, | 924 | HW_VAR_H2C_FW_PWRMODE, |
966 | &rtlps->pwr_mode); | 925 | &rtlps->pwr_mode); |
967 | } | 926 | } |
927 | |||
968 | } | 928 | } |
969 | break; | 929 | break; |
970 | case P2P_PS_ENABLE: | 930 | case P2P_PS_ENABLE: |
@@ -982,6 +942,7 @@ void rtl_p2p_ps_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state) | |||
982 | rtlpriv->cfg->ops->set_hw_reg(hw, | 942 | rtlpriv->cfg->ops->set_hw_reg(hw, |
983 | HW_VAR_H2C_FW_P2P_PS_OFFLOAD, | 943 | HW_VAR_H2C_FW_P2P_PS_OFFLOAD, |
984 | &p2p_ps_state); | 944 | &p2p_ps_state); |
945 | |||
985 | } | 946 | } |
986 | break; | 947 | break; |
987 | case P2P_PS_SCAN: | 948 | case P2P_PS_SCAN: |
@@ -998,12 +959,16 @@ void rtl_p2p_ps_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state) | |||
998 | break; | 959 | break; |
999 | } | 960 | } |
1000 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, | 961 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, |
1001 | "ctwindow %x oppps %x\n", p2pinfo->ctwindow, p2pinfo->opp_ps); | 962 | "ctwindow %x oppps %x\n", |
963 | p2pinfo->ctwindow , p2pinfo->opp_ps); | ||
1002 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, | 964 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, |
1003 | "count %x duration %x index %x interval %x start time %x noa num %x\n", | 965 | "count %x duration %x index %x interval %x start time %x noa num %x\n", |
1004 | p2pinfo->noa_count_type[0], p2pinfo->noa_duration[0], | 966 | p2pinfo->noa_count_type[0], |
1005 | p2pinfo->noa_index, p2pinfo->noa_interval[0], | 967 | p2pinfo->noa_duration[0], |
1006 | p2pinfo->noa_start_time[0], p2pinfo->noa_num); | 968 | p2pinfo->noa_index, |
969 | p2pinfo->noa_interval[0], | ||
970 | p2pinfo->noa_start_time[0], | ||
971 | p2pinfo->noa_num); | ||
1007 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, "end\n"); | 972 | RT_TRACE(rtlpriv, COMP_FW, DBG_LOUD, "end\n"); |
1008 | } | 973 | } |
1009 | 974 | ||
@@ -1032,8 +997,8 @@ void rtl_p2p_info(struct ieee80211_hw *hw, void *data, unsigned int len) | |||
1032 | return; | 997 | return; |
1033 | 998 | ||
1034 | if (ieee80211_is_action(hdr->frame_control)) | 999 | if (ieee80211_is_action(hdr->frame_control)) |
1035 | rtl_p2p_action_ie(hw, data, len - FCS_LEN); | 1000 | rtl_p2p_action_ie(hw , data , len - FCS_LEN); |
1036 | else | 1001 | else |
1037 | rtl_p2p_noa_ie(hw, data, len - FCS_LEN); | 1002 | rtl_p2p_noa_ie(hw , data , len - FCS_LEN); |
1038 | } | 1003 | } |
1039 | EXPORT_SYMBOL_GPL(rtl_p2p_info); | 1004 | EXPORT_SYMBOL_GPL(rtl_p2p_info); |
diff --git a/drivers/net/wireless/rtlwifi/ps.h b/drivers/net/wireless/rtlwifi/ps.h index 3bd41f958974..29dfc514212d 100644 --- a/drivers/net/wireless/rtlwifi/ps.h +++ b/drivers/net/wireless/rtlwifi/ps.h | |||
@@ -11,10 +11,6 @@ | |||
11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | 11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
12 | * more details. | 12 | * more details. |
13 | * | 13 | * |
14 | * You should have received a copy of the GNU General Public License along with | ||
15 | * this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA | ||
17 | * | ||
18 | * The full GNU General Public License is included in this distribution in the | 14 | * The full GNU General Public License is included in this distribution in the |
19 | * file called LICENSE. | 15 | * file called LICENSE. |
20 | * | 16 | * |
@@ -32,68 +28,9 @@ | |||
32 | 28 | ||
33 | #define MAX_SW_LPS_SLEEP_INTV 5 | 29 | #define MAX_SW_LPS_SLEEP_INTV 5 |
34 | 30 | ||
35 | /*--------------------------------------------- | ||
36 | * 3 The value of cmd: 4 bits | ||
37 | *--------------------------------------------- | ||
38 | */ | ||
39 | #define PWR_CMD_READ 0x00 | ||
40 | #define PWR_CMD_WRITE 0x01 | ||
41 | #define PWR_CMD_POLLING 0x02 | ||
42 | #define PWR_CMD_DELAY 0x03 | ||
43 | #define PWR_CMD_END 0x04 | ||
44 | |||
45 | /* define the base address of each block */ | ||
46 | #define PWR_BASEADDR_MAC 0x00 | ||
47 | #define PWR_BASEADDR_USB 0x01 | ||
48 | #define PWR_BASEADDR_PCIE 0x02 | ||
49 | #define PWR_BASEADDR_SDIO 0x03 | ||
50 | |||
51 | #define PWR_FAB_ALL_MSK (BIT(0)|BIT(1)|BIT(2)|BIT(3)) | ||
52 | #define PWR_CUT_TESTCHIP_MSK BIT(0) | ||
53 | #define PWR_CUT_A_MSK BIT(1) | ||
54 | #define PWR_CUT_B_MSK BIT(2) | ||
55 | #define PWR_CUT_C_MSK BIT(3) | ||
56 | #define PWR_CUT_D_MSK BIT(4) | ||
57 | #define PWR_CUT_E_MSK BIT(5) | ||
58 | #define PWR_CUT_F_MSK BIT(6) | ||
59 | #define PWR_CUT_G_MSK BIT(7) | ||
60 | #define PWR_CUT_ALL_MSK 0xFF | ||
61 | #define PWR_INTF_SDIO_MSK BIT(0) | ||
62 | #define PWR_INTF_USB_MSK BIT(1) | ||
63 | #define PWR_INTF_PCI_MSK BIT(2) | ||
64 | #define PWR_INTF_ALL_MSK (BIT(0)|BIT(1)|BIT(2)|BIT(3)) | ||
65 | |||
66 | enum pwrseq_delay_unit { | ||
67 | PWRSEQ_DELAY_US, | ||
68 | PWRSEQ_DELAY_MS, | ||
69 | }; | ||
70 | |||
71 | struct wlan_pwr_cfg { | ||
72 | u16 offset; | ||
73 | u8 cut_msk; | ||
74 | u8 fab_msk:4; | ||
75 | u8 interface_msk:4; | ||
76 | u8 base:4; | ||
77 | u8 cmd:4; | ||
78 | u8 msk; | ||
79 | u8 value; | ||
80 | }; | ||
81 | |||
82 | #define GET_PWR_CFG_OFFSET(__PWR_CMD) (__PWR_CMD.offset) | ||
83 | #define GET_PWR_CFG_CUT_MASK(__PWR_CMD) (__PWR_CMD.cut_msk) | ||
84 | #define GET_PWR_CFG_FAB_MASK(__PWR_CMD) (__PWR_CMD.fab_msk) | ||
85 | #define GET_PWR_CFG_INTF_MASK(__PWR_CMD) (__PWR_CMD.interface_msk) | ||
86 | #define GET_PWR_CFG_BASE(__PWR_CMD) (__PWR_CMD.base) | ||
87 | #define GET_PWR_CFG_CMD(__PWR_CMD) (__PWR_CMD.cmd) | ||
88 | #define GET_PWR_CFG_MASK(__PWR_CMD) (__PWR_CMD.msk) | ||
89 | #define GET_PWR_CFG_VALUE(__PWR_CMD) (__PWR_CMD.value) | ||
90 | |||
91 | bool rtl_hal_pwrseqcmdparsing(struct rtl_priv *rtlpriv, u8 cut_version, | ||
92 | u8 fab_version, u8 interface_type, | ||
93 | struct wlan_pwr_cfg pwrcfgcmd[]); | ||
94 | |||
95 | bool rtl_ps_set_rf_state(struct ieee80211_hw *hw, | 31 | bool rtl_ps_set_rf_state(struct ieee80211_hw *hw, |
96 | enum rf_pwrstate state_toset, u32 changesource); | 32 | enum rf_pwrstate state_toset, u32 changesource, |
33 | bool protect_or_not); | ||
97 | bool rtl_ps_enable_nic(struct ieee80211_hw *hw); | 34 | bool rtl_ps_enable_nic(struct ieee80211_hw *hw); |
98 | bool rtl_ps_disable_nic(struct ieee80211_hw *hw); | 35 | bool rtl_ps_disable_nic(struct ieee80211_hw *hw); |
99 | void rtl_ips_nic_off(struct ieee80211_hw *hw); | 36 | void rtl_ips_nic_off(struct ieee80211_hw *hw); |
@@ -102,12 +39,14 @@ void rtl_ips_nic_off_wq_callback(void *data); | |||
102 | void rtl_lps_enter(struct ieee80211_hw *hw); | 39 | void rtl_lps_enter(struct ieee80211_hw *hw); |
103 | void rtl_lps_leave(struct ieee80211_hw *hw); | 40 | void rtl_lps_leave(struct ieee80211_hw *hw); |
104 | 41 | ||
42 | void rtl_lps_set_psmode(struct ieee80211_hw *hw, u8 rt_psmode); | ||
43 | |||
105 | void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len); | 44 | void rtl_swlps_beacon(struct ieee80211_hw *hw, void *data, unsigned int len); |
106 | void rtl_swlps_wq_callback(void *data); | 45 | void rtl_swlps_wq_callback(void *data); |
107 | void rtl_swlps_rfon_wq_callback(void *data); | 46 | void rtl_swlps_rfon_wq_callback(void *data); |
108 | void rtl_swlps_rf_awake(struct ieee80211_hw *hw); | 47 | void rtl_swlps_rf_awake(struct ieee80211_hw *hw); |
109 | void rtl_swlps_rf_sleep(struct ieee80211_hw *hw); | 48 | void rtl_swlps_rf_sleep(struct ieee80211_hw *hw); |
110 | void rtl_p2p_ps_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state); | 49 | void rtl_p2p_ps_cmd(struct ieee80211_hw *hw , u8 p2p_ps_state); |
111 | void rtl_p2p_info(struct ieee80211_hw *hw, void *data, unsigned int len); | 50 | void rtl_p2p_info(struct ieee80211_hw *hw, void *data, unsigned int len); |
112 | void rtl_lps_change_work_callback(struct work_struct *work); | 51 | void rtl_lps_change_work_callback(struct work_struct *work); |
113 | 52 | ||
diff --git a/drivers/net/wireless/rtlwifi/rtl8188ee/Makefile b/drivers/net/wireless/rtlwifi/rtl8188ee/Makefile index a85419a37651..5b194e97f4b3 100644 --- a/drivers/net/wireless/rtlwifi/rtl8188ee/Makefile +++ b/drivers/net/wireless/rtlwifi/rtl8188ee/Makefile | |||
@@ -5,6 +5,7 @@ rtl8188ee-objs := \ | |||
5 | led.o \ | 5 | led.o \ |
6 | phy.o \ | 6 | phy.o \ |
7 | pwrseq.o \ | 7 | pwrseq.o \ |
8 | pwrseqcmd.o \ | ||
8 | rf.o \ | 9 | rf.o \ |
9 | sw.o \ | 10 | sw.o \ |
10 | table.o \ | 11 | table.o \ |
diff --git a/drivers/net/wireless/rtlwifi/rtl8188ee/hw.c b/drivers/net/wireless/rtlwifi/rtl8188ee/hw.c index d840ad7bdf65..ba639bb7457c 100644 --- a/drivers/net/wireless/rtlwifi/rtl8188ee/hw.c +++ b/drivers/net/wireless/rtlwifi/rtl8188ee/hw.c | |||
@@ -41,6 +41,7 @@ | |||
41 | #include "fw.h" | 41 | #include "fw.h" |
42 | #include "led.h" | 42 | #include "led.h" |
43 | #include "hw.h" | 43 | #include "hw.h" |
44 | #include "pwrseqcmd.h" | ||
44 | #include "pwrseq.h" | 45 | #include "pwrseq.h" |
45 | 46 | ||
46 | #define LLT_CONFIG 5 | 47 | #define LLT_CONFIG 5 |
@@ -809,9 +810,9 @@ static bool _rtl88ee_init_mac(struct ieee80211_hw *hw) | |||
809 | 810 | ||
810 | rtl_write_byte(rtlpriv, REG_RSV_CTRL, 0x00); | 811 | rtl_write_byte(rtlpriv, REG_RSV_CTRL, 0x00); |
811 | /* HW Power on sequence */ | 812 | /* HW Power on sequence */ |
812 | if (!rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, | 813 | if (!rtl88_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, |
813 | PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, | 814 | PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, |
814 | Rtl8188E_NIC_ENABLE_FLOW)) { | 815 | RTL8188E_NIC_ENABLE_FLOW)) { |
815 | RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, | 816 | RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, |
816 | "init MAC Fail as rtl_hal_pwrseqcmdparsing\n"); | 817 | "init MAC Fail as rtl_hal_pwrseqcmdparsing\n"); |
817 | return false; | 818 | return false; |
@@ -1352,9 +1353,9 @@ static void _rtl88ee_poweroff_adapter(struct ieee80211_hw *hw) | |||
1352 | } | 1353 | } |
1353 | rtl_write_byte(rtlpriv, REG_PCIE_CTRL_REG+1, 0xFF); | 1354 | rtl_write_byte(rtlpriv, REG_PCIE_CTRL_REG+1, 0xFF); |
1354 | 1355 | ||
1355 | rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, | 1356 | rtl88_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, |
1356 | PWR_INTF_PCI_MSK, | 1357 | PWR_INTF_PCI_MSK, |
1357 | Rtl8188E_NIC_LPS_ENTER_FLOW); | 1358 | RTL8188E_NIC_LPS_ENTER_FLOW); |
1358 | 1359 | ||
1359 | rtl_write_byte(rtlpriv, REG_RF_CTRL, 0x00); | 1360 | rtl_write_byte(rtlpriv, REG_RF_CTRL, 0x00); |
1360 | 1361 | ||
@@ -1368,8 +1369,8 @@ static void _rtl88ee_poweroff_adapter(struct ieee80211_hw *hw) | |||
1368 | u1b_tmp = rtl_read_byte(rtlpriv, REG_32K_CTRL); | 1369 | u1b_tmp = rtl_read_byte(rtlpriv, REG_32K_CTRL); |
1369 | rtl_write_byte(rtlpriv, REG_32K_CTRL, (u1b_tmp & (~BIT(0)))); | 1370 | rtl_write_byte(rtlpriv, REG_32K_CTRL, (u1b_tmp & (~BIT(0)))); |
1370 | 1371 | ||
1371 | rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, | 1372 | rtl88_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, |
1372 | PWR_INTF_PCI_MSK, Rtl8188E_NIC_DISABLE_FLOW); | 1373 | PWR_INTF_PCI_MSK, RTL8188E_NIC_DISABLE_FLOW); |
1373 | 1374 | ||
1374 | u1b_tmp = rtl_read_byte(rtlpriv, REG_RSV_CTRL+1); | 1375 | u1b_tmp = rtl_read_byte(rtlpriv, REG_RSV_CTRL+1); |
1375 | rtl_write_byte(rtlpriv, REG_RSV_CTRL+1, (u1b_tmp & (~BIT(3)))); | 1376 | rtl_write_byte(rtlpriv, REG_RSV_CTRL+1, (u1b_tmp & (~BIT(3)))); |
diff --git a/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseq.h b/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseq.h index 32e135ab9a63..45c7f4ada9fb 100644 --- a/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseq.h +++ b/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseq.h | |||
@@ -313,14 +313,14 @@ extern struct wlan_pwr_cfg rtl8188e_leave_lps_flow | |||
313 | RTL8188E_TRANS_END_STEPS]; | 313 | RTL8188E_TRANS_END_STEPS]; |
314 | 314 | ||
315 | /* RTL8723 Power Configuration CMDs for PCIe interface */ | 315 | /* RTL8723 Power Configuration CMDs for PCIe interface */ |
316 | #define Rtl8188E_NIC_PWR_ON_FLOW rtl8188e_power_on_flow | 316 | #define RTL8188E_NIC_PWR_ON_FLOW rtl8188e_power_on_flow |
317 | #define Rtl8188E_NIC_RF_OFF_FLOW rtl8188e_radio_off_flow | 317 | #define RTL8188E_NIC_RF_OFF_FLOW rtl8188e_radio_off_flow |
318 | #define Rtl8188E_NIC_DISABLE_FLOW rtl8188e_card_disable_flow | 318 | #define RTL8188E_NIC_DISABLE_FLOW rtl8188e_card_disable_flow |
319 | #define Rtl8188E_NIC_ENABLE_FLOW rtl8188e_card_enable_flow | 319 | #define RTL8188E_NIC_ENABLE_FLOW rtl8188e_card_enable_flow |
320 | #define Rtl8188E_NIC_SUSPEND_FLOW rtl8188e_suspend_flow | 320 | #define RTL8188E_NIC_SUSPEND_FLOW rtl8188e_suspend_flow |
321 | #define Rtl8188E_NIC_RESUME_FLOW rtl8188e_resume_flow | 321 | #define RTL8188E_NIC_RESUME_FLOW rtl8188e_resume_flow |
322 | #define Rtl8188E_NIC_PDN_FLOW rtl8188e_hwpdn_flow | 322 | #define RTL8188E_NIC_PDN_FLOW rtl8188e_hwpdn_flow |
323 | #define Rtl8188E_NIC_LPS_ENTER_FLOW rtl8188e_enter_lps_flow | 323 | #define RTL8188E_NIC_LPS_ENTER_FLOW rtl8188e_enter_lps_flow |
324 | #define Rtl8188E_NIC_LPS_LEAVE_FLOW rtl8188e_leave_lps_flow | 324 | #define RTL8188E_NIC_LPS_LEAVE_FLOW rtl8188e_leave_lps_flow |
325 | 325 | ||
326 | #endif | 326 | #endif |
diff --git a/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.c b/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.c index 0f9314205526..3a95ddb3257f 100644 --- a/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.c +++ b/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.c | |||
@@ -27,6 +27,7 @@ | |||
27 | * | 27 | * |
28 | *****************************************************************************/ | 28 | *****************************************************************************/ |
29 | 29 | ||
30 | #include "pwrseqcmd.h" | ||
30 | #include "pwrseq.h" | 31 | #include "pwrseq.h" |
31 | 32 | ||
32 | 33 | ||
diff --git a/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.h b/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.h index d9ae280bb1a2..a6cdb0d851a9 100644 --- a/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.h +++ b/drivers/net/wireless/rtlwifi/rtl8188ee/pwrseqcmd.h | |||
@@ -11,10 +11,6 @@ | |||
11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | 11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
12 | * more details. | 12 | * more details. |
13 | * | 13 | * |
14 | * You should have received a copy of the GNU General Public License along with | ||
15 | * this program; if not, write to the Free Software Foundation, Inc., | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA | ||
17 | * | ||
18 | * The full GNU General Public License is included in this distribution in the | 14 | * The full GNU General Public License is included in this distribution in the |
19 | * file called LICENSE. | 15 | * file called LICENSE. |
20 | * | 16 | * |
diff --git a/drivers/net/wireless/rtlwifi/rtl8723ae/Makefile b/drivers/net/wireless/rtlwifi/rtl8723ae/Makefile index 9c34a85fdb89..4ed731f09b1f 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723ae/Makefile +++ b/drivers/net/wireless/rtlwifi/rtl8723ae/Makefile | |||
@@ -10,6 +10,7 @@ rtl8723ae-objs := \ | |||
10 | led.o \ | 10 | led.o \ |
11 | phy.o \ | 11 | phy.o \ |
12 | pwrseq.o \ | 12 | pwrseq.o \ |
13 | pwrseqcmd.o \ | ||
13 | rf.o \ | 14 | rf.o \ |
14 | sw.o \ | 15 | sw.o \ |
15 | table.o \ | 16 | table.o \ |
diff --git a/drivers/net/wireless/rtlwifi/rtl8723ae/hw.c b/drivers/net/wireless/rtlwifi/rtl8723ae/hw.c index 662a079f76f3..dd8e76cb03aa 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723ae/hw.c +++ b/drivers/net/wireless/rtlwifi/rtl8723ae/hw.c | |||
@@ -43,6 +43,7 @@ | |||
43 | #include "../rtl8723com/fw_common.h" | 43 | #include "../rtl8723com/fw_common.h" |
44 | #include "led.h" | 44 | #include "led.h" |
45 | #include "hw.h" | 45 | #include "hw.h" |
46 | #include "pwrseqcmd.h" | ||
46 | #include "pwrseq.h" | 47 | #include "pwrseq.h" |
47 | #include "btc.h" | 48 | #include "btc.h" |
48 | 49 | ||
diff --git a/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.c b/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.c index 2044b5936b7f..239eb4473dd1 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.c +++ b/drivers/net/wireless/rtlwifi/rtl8723ae/pwrseqcmd.c | |||
@@ -27,6 +27,7 @@ | |||
27 | * | 27 | * |
28 | *****************************************************************************/ | 28 | *****************************************************************************/ |
29 | 29 | ||
30 | #include "pwrseqcmd.h" | ||
30 | #include "pwrseq.h" | 31 | #include "pwrseq.h" |
31 | 32 | ||
32 | /* Description: | 33 | /* Description: |
diff --git a/drivers/net/wireless/rtlwifi/rtl8723be/Makefile b/drivers/net/wireless/rtlwifi/rtl8723be/Makefile index 59e416abd93a..4a75aab0539a 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723be/Makefile +++ b/drivers/net/wireless/rtlwifi/rtl8723be/Makefile | |||
@@ -8,6 +8,7 @@ rtl8723be-objs := \ | |||
8 | led.o \ | 8 | led.o \ |
9 | phy.o \ | 9 | phy.o \ |
10 | pwrseq.o \ | 10 | pwrseq.o \ |
11 | pwrseqcmd.o \ | ||
11 | rf.o \ | 12 | rf.o \ |
12 | sw.o \ | 13 | sw.o \ |
13 | table.o \ | 14 | table.o \ |
diff --git a/drivers/net/wireless/rtlwifi/rtl8723be/hw.c b/drivers/net/wireless/rtlwifi/rtl8723be/hw.c index 3cd286930fe0..1b939183f39d 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723be/hw.c +++ b/drivers/net/wireless/rtlwifi/rtl8723be/hw.c | |||
@@ -39,6 +39,7 @@ | |||
39 | #include "../rtl8723com/fw_common.h" | 39 | #include "../rtl8723com/fw_common.h" |
40 | #include "led.h" | 40 | #include "led.h" |
41 | #include "hw.h" | 41 | #include "hw.h" |
42 | #include "pwrseqcmd.h" | ||
42 | #include "pwrseq.h" | 43 | #include "pwrseq.h" |
43 | #include "../btcoexist/rtl_btc.h" | 44 | #include "../btcoexist/rtl_btc.h" |
44 | 45 | ||
@@ -814,9 +815,9 @@ static bool _rtl8723be_init_mac(struct ieee80211_hw *hw) | |||
814 | mac_func_enable = false; | 815 | mac_func_enable = false; |
815 | 816 | ||
816 | /* HW Power on sequence */ | 817 | /* HW Power on sequence */ |
817 | if (!rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, | 818 | if (!rtlbe_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, |
818 | PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, | 819 | PWR_FAB_ALL_MSK, PWR_INTF_PCI_MSK, |
819 | RTL8723_NIC_ENABLE_FLOW)) { | 820 | RTL8723_NIC_ENABLE_FLOW)) { |
820 | RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, | 821 | RT_TRACE(rtlpriv, COMP_INIT, DBG_LOUD, |
821 | "init MAC Fail as power on failure\n"); | 822 | "init MAC Fail as power on failure\n"); |
822 | return false; | 823 | return false; |
@@ -1305,8 +1306,8 @@ static void _rtl8723be_poweroff_adapter(struct ieee80211_hw *hw) | |||
1305 | 1306 | ||
1306 | /* Combo (PCIe + USB) Card and PCIe-MF Card */ | 1307 | /* Combo (PCIe + USB) Card and PCIe-MF Card */ |
1307 | /* 1. Run LPS WL RFOFF flow */ | 1308 | /* 1. Run LPS WL RFOFF flow */ |
1308 | rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, | 1309 | rtlbe_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, |
1309 | PWR_INTF_PCI_MSK, RTL8723_NIC_LPS_ENTER_FLOW); | 1310 | PWR_INTF_PCI_MSK, RTL8723_NIC_LPS_ENTER_FLOW); |
1310 | 1311 | ||
1311 | /* 2. 0x1F[7:0] = 0 */ | 1312 | /* 2. 0x1F[7:0] = 0 */ |
1312 | /* turn off RF */ | 1313 | /* turn off RF */ |
@@ -1324,8 +1325,8 @@ static void _rtl8723be_poweroff_adapter(struct ieee80211_hw *hw) | |||
1324 | rtl_write_byte(rtlpriv, REG_MCUFWDL, 0x00); | 1325 | rtl_write_byte(rtlpriv, REG_MCUFWDL, 0x00); |
1325 | 1326 | ||
1326 | /* HW card disable configuration. */ | 1327 | /* HW card disable configuration. */ |
1327 | rtl_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, | 1328 | rtlbe_hal_pwrseqcmdparsing(rtlpriv, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, |
1328 | PWR_INTF_PCI_MSK, RTL8723_NIC_DISABLE_FLOW); | 1329 | PWR_INTF_PCI_MSK, RTL8723_NIC_DISABLE_FLOW); |
1329 | 1330 | ||
1330 | /* Reset MCU IO Wrapper */ | 1331 | /* Reset MCU IO Wrapper */ |
1331 | u1b_tmp = rtl_read_byte(rtlpriv, REG_RSV_CTRL + 1); | 1332 | u1b_tmp = rtl_read_byte(rtlpriv, REG_RSV_CTRL + 1); |
diff --git a/drivers/net/wireless/rtlwifi/rtl8723be/pwrseqcmd.c b/drivers/net/wireless/rtlwifi/rtl8723be/pwrseqcmd.c index 4573310c707f..cf57a4964ad3 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723be/pwrseqcmd.c +++ b/drivers/net/wireless/rtlwifi/rtl8723be/pwrseqcmd.c | |||
@@ -23,6 +23,7 @@ | |||
23 | * | 23 | * |
24 | *****************************************************************************/ | 24 | *****************************************************************************/ |
25 | 25 | ||
26 | #include "pwrseqcmd.h" | ||
26 | #include "pwrseq.h" | 27 | #include "pwrseq.h" |
27 | 28 | ||
28 | /* Description: | 29 | /* Description: |