aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/rt2x00/rt2500pci.c
diff options
context:
space:
mode:
authorIvo van Doorn <ivdoorn@gmail.com>2008-03-09 17:49:04 -0400
committerJohn W. Linville <linville@tuxdriver.com>2008-03-13 19:32:31 -0400
commit89993890aeb8fe58b2d49b2661965524802ab73c (patch)
treed541a26a8a370401ef2c4d0cafdd8868853ed127 /drivers/net/wireless/rt2x00/rt2500pci.c
parentdac37d720860bbbc535adc90249184308501c1f0 (diff)
rt2x00: Fix rt2400pci signal
After sampling hundreds of RX frame descriptors, the results were conclusive: - The Ralink documentation regarding the SIGNAL and RSSI are wrong. It turns out that of the 5 BBR registers, we should not use BBR0 and BBR1 for SIGNAL and RSSI respectively, but actually BBR1 and BBR2. BBR0 does show values, but the exact meaning remains unclear, but they cannot be translated into a SIGNAL or RSSI field. BBR3, BBR4 and BBR5 are always 0, so their meaning is unknown. As it turns out, the reported SIGNAL is the PLCP value, this in contradiction to what was expected looking at rt2500pci which only reported the PLCP values for OFDM rates and bitrate values for CCK rates. This means we should let the driver raise the flag about the contents of the SIGNAL field so rt2x00lib can always do the right thing based on what the driver reports. 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/rt2500pci.c')
-rw-r--r--drivers/net/wireless/rt2x00/rt2500pci.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2500pci.c b/drivers/net/wireless/rt2x00/rt2500pci.c
index 4ae09b418704..0f5139a2f238 100644
--- a/drivers/net/wireless/rt2x00/rt2500pci.c
+++ b/drivers/net/wireless/rt2x00/rt2500pci.c
@@ -1219,10 +1219,17 @@ static void rt2500pci_fill_rxdone(struct queue_entry *entry,
1219 if (rt2x00_get_field32(word0, RXD_W0_PHYSICAL_ERROR)) 1219 if (rt2x00_get_field32(word0, RXD_W0_PHYSICAL_ERROR))
1220 rxdesc->flags |= RX_FLAG_FAILED_PLCP_CRC; 1220 rxdesc->flags |= RX_FLAG_FAILED_PLCP_CRC;
1221 1221
1222 /*
1223 * Obtain the status about this packet.
1224 * When frame was received with an OFDM bitrate,
1225 * the signal is the PLCP value. If it was received with
1226 * a CCK bitrate the signal is the rate in 100kbit/s.
1227 */
1228 rxdesc->ofdm = rt2x00_get_field32(word0, RXD_W0_OFDM);
1222 rxdesc->signal = rt2x00_get_field32(word2, RXD_W2_SIGNAL); 1229 rxdesc->signal = rt2x00_get_field32(word2, RXD_W2_SIGNAL);
1230 rxdesc->signal_plcp = rxdesc->ofdm;
1223 rxdesc->rssi = rt2x00_get_field32(word2, RXD_W2_RSSI) - 1231 rxdesc->rssi = rt2x00_get_field32(word2, RXD_W2_RSSI) -
1224 entry->queue->rt2x00dev->rssi_offset; 1232 entry->queue->rt2x00dev->rssi_offset;
1225 rxdesc->ofdm = rt2x00_get_field32(word0, RXD_W0_OFDM);
1226 rxdesc->size = rt2x00_get_field32(word0, RXD_W0_DATABYTE_COUNT); 1233 rxdesc->size = rt2x00_get_field32(word0, RXD_W0_DATABYTE_COUNT);
1227 rxdesc->my_bss = !!rt2x00_get_field32(word0, RXD_W0_MY_BSS); 1234 rxdesc->my_bss = !!rt2x00_get_field32(word0, RXD_W0_MY_BSS);
1228} 1235}