diff options
Diffstat (limited to 'drivers/net/wireless/rtlwifi/rtl8192cu/dm.c')
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8192cu/dm.c | 113 |
1 files changed, 113 insertions, 0 deletions
diff --git a/drivers/net/wireless/rtlwifi/rtl8192cu/dm.c b/drivers/net/wireless/rtlwifi/rtl8192cu/dm.c new file mode 100644 index 000000000000..f311baee668d --- /dev/null +++ b/drivers/net/wireless/rtlwifi/rtl8192cu/dm.c | |||
@@ -0,0 +1,113 @@ | |||
1 | /****************************************************************************** | ||
2 | * | ||
3 | * Copyright(c) 2009-2010 Realtek Corporation. | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it | ||
6 | * under the terms of version 2 of the GNU General Public License as | ||
7 | * published by the Free Software Foundation. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, but WITHOUT | ||
10 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | ||
12 | * more details. | ||
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 | ||
19 | * file called LICENSE. | ||
20 | * | ||
21 | * Contact Information: | ||
22 | * wlanfae <wlanfae@realtek.com> | ||
23 | * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park, | ||
24 | * Hsinchu 300, Taiwan. | ||
25 | * | ||
26 | * Larry Finger <Larry.Finger@lwfinger.net> | ||
27 | * | ||
28 | *****************************************************************************/ | ||
29 | |||
30 | #include "../wifi.h" | ||
31 | #include "../base.h" | ||
32 | #include "reg.h" | ||
33 | #include "def.h" | ||
34 | #include "phy.h" | ||
35 | #include "dm.h" | ||
36 | |||
37 | void rtl92cu_dm_dynamic_txpower(struct ieee80211_hw *hw) | ||
38 | { | ||
39 | struct rtl_priv *rtlpriv = rtl_priv(hw); | ||
40 | struct rtl_phy *rtlphy = &(rtlpriv->phy); | ||
41 | struct rtl_mac *mac = rtl_mac(rtl_priv(hw)); | ||
42 | long undecorated_smoothed_pwdb; | ||
43 | |||
44 | if (!rtlpriv->dm.dynamic_txpower_enable) | ||
45 | return; | ||
46 | |||
47 | if (rtlpriv->dm.dm_flag & HAL_DM_HIPWR_DISABLE) { | ||
48 | rtlpriv->dm.dynamic_txhighpower_lvl = TXHIGHPWRLEVEL_NORMAL; | ||
49 | return; | ||
50 | } | ||
51 | |||
52 | if ((mac->link_state < MAC80211_LINKED) && | ||
53 | (rtlpriv->dm.entry_min_undecoratedsmoothed_pwdb == 0)) { | ||
54 | RT_TRACE(rtlpriv, COMP_POWER, DBG_TRACE, | ||
55 | ("Not connected to any\n")); | ||
56 | |||
57 | rtlpriv->dm.dynamic_txhighpower_lvl = TXHIGHPWRLEVEL_NORMAL; | ||
58 | |||
59 | rtlpriv->dm.last_dtp_lvl = TXHIGHPWRLEVEL_NORMAL; | ||
60 | return; | ||
61 | } | ||
62 | |||
63 | if (mac->link_state >= MAC80211_LINKED) { | ||
64 | if (mac->opmode == NL80211_IFTYPE_ADHOC) { | ||
65 | undecorated_smoothed_pwdb = | ||
66 | rtlpriv->dm.entry_min_undecoratedsmoothed_pwdb; | ||
67 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
68 | ("AP Client PWDB = 0x%lx\n", | ||
69 | undecorated_smoothed_pwdb)); | ||
70 | } else { | ||
71 | undecorated_smoothed_pwdb = | ||
72 | rtlpriv->dm.undecorated_smoothed_pwdb; | ||
73 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
74 | ("STA Default Port PWDB = 0x%lx\n", | ||
75 | undecorated_smoothed_pwdb)); | ||
76 | } | ||
77 | } else { | ||
78 | undecorated_smoothed_pwdb = | ||
79 | rtlpriv->dm.entry_min_undecoratedsmoothed_pwdb; | ||
80 | |||
81 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
82 | ("AP Ext Port PWDB = 0x%lx\n", | ||
83 | undecorated_smoothed_pwdb)); | ||
84 | } | ||
85 | |||
86 | if (undecorated_smoothed_pwdb >= TX_POWER_NEAR_FIELD_THRESH_LVL2) { | ||
87 | rtlpriv->dm.dynamic_txhighpower_lvl = TXHIGHPWRLEVEL_LEVEL1; | ||
88 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
89 | ("TXHIGHPWRLEVEL_LEVEL1 (TxPwr=0x0)\n")); | ||
90 | } else if ((undecorated_smoothed_pwdb < | ||
91 | (TX_POWER_NEAR_FIELD_THRESH_LVL2 - 3)) && | ||
92 | (undecorated_smoothed_pwdb >= | ||
93 | TX_POWER_NEAR_FIELD_THRESH_LVL1)) { | ||
94 | |||
95 | rtlpriv->dm.dynamic_txhighpower_lvl = TXHIGHPWRLEVEL_LEVEL1; | ||
96 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
97 | ("TXHIGHPWRLEVEL_LEVEL1 (TxPwr=0x10)\n")); | ||
98 | } else if (undecorated_smoothed_pwdb < | ||
99 | (TX_POWER_NEAR_FIELD_THRESH_LVL1 - 5)) { | ||
100 | rtlpriv->dm.dynamic_txhighpower_lvl = TXHIGHPWRLEVEL_NORMAL; | ||
101 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
102 | ("TXHIGHPWRLEVEL_NORMAL\n")); | ||
103 | } | ||
104 | |||
105 | if ((rtlpriv->dm.dynamic_txhighpower_lvl != rtlpriv->dm.last_dtp_lvl)) { | ||
106 | RT_TRACE(rtlpriv, COMP_POWER, DBG_LOUD, | ||
107 | ("PHY_SetTxPowerLevel8192S() Channel = %d\n", | ||
108 | rtlphy->current_channel)); | ||
109 | rtl92c_phy_set_txpower_level(hw, rtlphy->current_channel); | ||
110 | } | ||
111 | |||
112 | rtlpriv->dm.last_dtp_lvl = rtlpriv->dm.dynamic_txhighpower_lvl; | ||
113 | } | ||