diff options
author | Ivo van Doorn <ivdoorn@gmail.com> | 2009-09-06 09:14:23 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-09-09 11:18:14 -0400 |
commit | 4789666e13fb0b2d45feb1b4a5119a1b997ec84c (patch) | |
tree | 2071e79396f94d56177eab6386b5ce09e799abb8 /drivers/net/wireless/rt2x00/rt2400pci.c | |
parent | fd413da852991e96c555ad7253cc481bc133e221 (diff) |
rt2x00: Hardcode TX ack timeout and consume time
The calculated values for the ACK timeout and ACK
consume time are different then the values as
used by the Legacy drivers.
After testing from James Ledwith it appeared that
the calculated values caused a high amount of TX
failures, and the values from the Legacy drivers
were the most optimal to prevent TX failure due to
excessive retries.
The symptoms of this problem:
- Rate control module always falls back to 1Mbs
- Low throughput when bitrate was fixed
Possible side-effects (not confirmed but highly likely)
- Problems with DHCP
- Broken connections due to lack of probe response
This should fix at least:
Kernel bugzilla reports: [13362], [13009], [9273]
Fedora bugzilla reports: [443203]
but possible some additional bugs as well.
Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2400pci.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2400pci.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2400pci.c b/drivers/net/wireless/rt2x00/rt2400pci.c index 164df9347a2f..798f625e38f7 100644 --- a/drivers/net/wireless/rt2x00/rt2400pci.c +++ b/drivers/net/wireless/rt2x00/rt2400pci.c | |||
@@ -331,9 +331,8 @@ static void rt2400pci_config_erp(struct rt2x00_dev *rt2x00dev, | |||
331 | preamble_mask = erp->short_preamble << 3; | 331 | preamble_mask = erp->short_preamble << 3; |
332 | 332 | ||
333 | rt2x00pci_register_read(rt2x00dev, TXCSR1, ®); | 333 | rt2x00pci_register_read(rt2x00dev, TXCSR1, ®); |
334 | rt2x00_set_field32(®, TXCSR1_ACK_TIMEOUT, erp->ack_timeout); | 334 | rt2x00_set_field32(®, TXCSR1_ACK_TIMEOUT, 0x1ff); |
335 | rt2x00_set_field32(®, TXCSR1_ACK_CONSUME_TIME, | 335 | rt2x00_set_field32(®, TXCSR1_ACK_CONSUME_TIME, 0x13a); |
336 | erp->ack_consume_time); | ||
337 | rt2x00_set_field32(®, TXCSR1_TSF_OFFSET, IEEE80211_HEADER); | 336 | rt2x00_set_field32(®, TXCSR1_TSF_OFFSET, IEEE80211_HEADER); |
338 | rt2x00_set_field32(®, TXCSR1_AUTORESPONDER, 1); | 337 | rt2x00_set_field32(®, TXCSR1_AUTORESPONDER, 1); |
339 | rt2x00pci_register_write(rt2x00dev, TXCSR1, reg); | 338 | rt2x00pci_register_write(rt2x00dev, TXCSR1, reg); |