diff options
| author | Jingjun Wu <jingjun_wu@realsil.com.cn> | 2012-03-02 21:52:14 -0500 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-04-02 12:27:09 -0400 |
| commit | 75e375312eb27ce49f71ed760e12fe770a32f579 (patch) | |
| tree | c7dca972762b34a2aef3173bd9037d81b609c664 /drivers/net/wireless | |
| parent | debc5a0ed2f7cc40c31ea56f070b1af6920f6c53 (diff) | |
rtlwifi: rtl8192ce: Fix loss of receive performance
commit a9b89e2567c743483e6354f64d7a7e3a8c101e9e upstream.
Driver rtl8192ce when used with the RTL8188CE device would start at about
20 Mbps on a 54 Mbps connection, but quickly drop to 1 Mbps. One of the
symptoms is that the AP would need to retransmit each packet 4 of 5 times
before the driver would acknowledge it. Recovery is possible only by
unloading and reloading the driver. This problem was reported at
https://bugzilla.redhat.com/show_bug.cgi?id=770207.
The problem is due to a missing update of the gain setting.
Signed-off-by: Jingjun Wu <jingjun_wu@realsil.com.cn>
Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/net/wireless')
| -rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8192c/dm_common.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/net/wireless/rtlwifi/rtl8192c/dm_common.c b/drivers/net/wireless/rtlwifi/rtl8192c/dm_common.c index 27f2f5df21f..2d33d7d8403 100644 --- a/drivers/net/wireless/rtlwifi/rtl8192c/dm_common.c +++ b/drivers/net/wireless/rtlwifi/rtl8192c/dm_common.c | |||
| @@ -523,6 +523,10 @@ void rtl92c_dm_write_dig(struct ieee80211_hw *hw) | |||
| 523 | dm_digtable.cur_igvalue, dm_digtable.pre_igvalue, | 523 | dm_digtable.cur_igvalue, dm_digtable.pre_igvalue, |
| 524 | dm_digtable.backoff_val)); | 524 | dm_digtable.backoff_val)); |
| 525 | 525 | ||
| 526 | dm_digtable.cur_igvalue += 2; | ||
| 527 | if (dm_digtable.cur_igvalue > 0x3f) | ||
| 528 | dm_digtable.cur_igvalue = 0x3f; | ||
| 529 | |||
| 526 | if (dm_digtable.pre_igvalue != dm_digtable.cur_igvalue) { | 530 | if (dm_digtable.pre_igvalue != dm_digtable.cur_igvalue) { |
| 527 | rtl_set_bbreg(hw, ROFDM0_XAAGCCORE1, 0x7f, | 531 | rtl_set_bbreg(hw, ROFDM0_XAAGCCORE1, 0x7f, |
| 528 | dm_digtable.cur_igvalue); | 532 | dm_digtable.cur_igvalue); |
