]> git.pld-linux.org Git - packages/kernel.git/blame - kernel-bcm43xx-patch_2.6.18.1_signal_quality.patch
- take from suse kernel-source-2.6.22.5-31.src.rpm -> patches.fixes.tar.bz2 -> patche...
[packages/kernel.git] / kernel-bcm43xx-patch_2.6.18.1_signal_quality.patch
CommitLineData
88ffe99d
MK
1Index: linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx.h
2===================================================================
3--- linux-2.6.18.orig/drivers/net/wireless/bcm43xx/bcm43xx.h
4+++ linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx.h
5@@ -365,6 +365,9 @@
6 #define BCM43xx_DEFAULT_SHORT_RETRY_LIMIT 7
7 #define BCM43xx_DEFAULT_LONG_RETRY_LIMIT 4
8
9+/* FIXME: the next line is a guess as to what the maximum RSSI value might be */
10+#define RX_RSSI_MAX 60
11+
12 /* Max size of a security key */
13 #define BCM43xx_SEC_KEYSIZE 16
14 /* Security algorithms. */
15Index: linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx_main.c
16===================================================================
17--- linux-2.6.18.orig/drivers/net/wireless/bcm43xx/bcm43xx_main.c
18+++ linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx_main.c
19@@ -3647,6 +3647,8 @@ static int bcm43xx_read_phyinfo(struct b
20 phy_type);
21 return -ENODEV;
22 };
23+ bcm->ieee->perfect_rssi = RX_RSSI_MAX;
24+ bcm->ieee->worst_rssi = 0;
25 if (!phy_rev_ok) {
26 printk(KERN_WARNING PFX "Invalid PHY Revision %x\n",
27 phy_rev);
28Index: linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx_wx.c
29===================================================================
30--- linux-2.6.18.orig/drivers/net/wireless/bcm43xx/bcm43xx_wx.c
31+++ linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx_wx.c
32@@ -48,7 +48,6 @@
33
34 #define MAX_WX_STRING 80
35
36-
37 static int bcm43xx_wx_get_name(struct net_device *net_dev,
38 struct iw_request_info *info,
39 union iwreq_data *data,
40@@ -227,15 +226,14 @@ static int bcm43xx_wx_get_rangeparams(st
41 range->throughput = 27 * 1000 * 1000;
42
43 range->max_qual.qual = 100;
44- /* TODO: Real max RSSI */
45- range->max_qual.level = 3;
46- range->max_qual.noise = 100;
47- range->max_qual.updated = 7;
48-
49- range->avg_qual.qual = 70;
50- range->avg_qual.level = 2;
51- range->avg_qual.noise = 40;
52- range->avg_qual.updated = 7;
53+ range->max_qual.level = 146; /* set floor at -110 dBm (146 - 256) */
54+ range->max_qual.noise = 146;
55+ range->max_qual.updated = IW_QUAL_ALL_UPDATED;
56+
57+ range->avg_qual.qual = 50;
58+ range->avg_qual.level = 0;
59+ range->avg_qual.noise = 0;
60+ range->avg_qual.updated = IW_QUAL_ALL_UPDATED;
61
62 range->min_rts = BCM43xx_MIN_RTS_THRESHOLD;
63 range->max_rts = BCM43xx_MAX_RTS_THRESHOLD;
64@@ -840,6 +838,10 @@ static struct iw_statistics *bcm43xx_get
65 struct bcm43xx_private *bcm = bcm43xx_priv(net_dev);
66 struct ieee80211softmac_device *mac = ieee80211_priv(net_dev);
67 struct iw_statistics *wstats;
68+ struct ieee80211_network *network = NULL;
69+ static int tmp_level = 0;
70+ static int tmp_qual = 0;
71+ unsigned long flags;
72
73 wstats = &bcm->stats.wstats;
74 if (!mac->associated) {
75@@ -857,16 +859,28 @@ static struct iw_statistics *bcm43xx_get
76 wstats->qual.level = 0;
77 wstats->qual.noise = 0;
78 wstats->qual.updated = 7;
79- wstats->qual.updated |= IW_QUAL_NOISE_INVALID |
80- IW_QUAL_QUAL_INVALID | IW_QUAL_LEVEL_INVALID;
81+ wstats->qual.updated |= IW_QUAL_ALL_UPDATED | IW_QUAL_DBM;
82 return wstats;
83 }
84 /* fill in the real statistics when iface associated */
85- wstats->qual.qual = 100; // TODO: get the real signal quality
86- wstats->qual.level = 3 - bcm->stats.link_quality;
87+ spin_lock_irqsave(&mac->ieee->lock, flags);
88+ list_for_each_entry(network, &mac->ieee->network_list, list) {
89+ if (!memcmp(mac->associnfo.bssid, network->bssid, ETH_ALEN)) {
90+ if (!tmp_level) { /* get initial values */
91+ tmp_level = network->stats.signal;
92+ tmp_qual = network->stats.rssi;
93+ } else { /* smooth results */
94+ tmp_level = (15 * tmp_level + network->stats.signal)/16;
95+ tmp_qual = (15 * tmp_qual + network->stats.rssi)/16;
96+ }
97+ break;
98+ }
99+ }
100+ spin_unlock_irqrestore(&mac->ieee->lock, flags);
101+ wstats->qual.level = tmp_level;
102+ wstats->qual.qual = 100 * tmp_qual / RX_RSSI_MAX;
103 wstats->qual.noise = bcm->stats.noise;
104- wstats->qual.updated = IW_QUAL_QUAL_UPDATED | IW_QUAL_LEVEL_UPDATED |
105- IW_QUAL_NOISE_UPDATED;
106+ wstats->qual.updated = IW_QUAL_ALL_UPDATED | IW_QUAL_DBM;
107 wstats->discard.code = bcm->ieee->ieee_stats.rx_discards_undecryptable;
108 wstats->discard.retries = bcm->ieee->ieee_stats.tx_retry_limit_exceeded;
109 wstats->discard.nwid = bcm->ieee->ieee_stats.tx_discards_wrong_sa;
110Index: linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx_xmit.c
111===================================================================
112--- linux-2.6.18.orig/drivers/net/wireless/bcm43xx/bcm43xx_xmit.c
113+++ linux-2.6.18/drivers/net/wireless/bcm43xx/bcm43xx_xmit.c
114@@ -492,20 +492,18 @@ int bcm43xx_rx(struct bcm43xx_private *b
115
116 memset(&stats, 0, sizeof(stats));
117 stats.mac_time = le16_to_cpu(rxhdr->mactime);
118- stats.rssi = bcm43xx_rssi_postprocess(bcm, rxhdr->rssi, is_ofdm,
119+ stats.rssi = rxhdr->rssi;
120+ stats.signal = bcm43xx_rssi_postprocess(bcm, rxhdr->rssi, is_ofdm,
121 !!(rxflags1 & BCM43xx_RXHDR_FLAGS1_2053RSSIADJ),
122 !!(rxflags3 & BCM43xx_RXHDR_FLAGS3_2050RSSIADJ));
123- stats.signal = rxhdr->signal_quality; //FIXME
124-//TODO stats.noise =
125+ stats.noise = bcm->stats.noise;
126 if (is_ofdm)
127 stats.rate = bcm43xx_plcp_get_bitrate_ofdm(plcp);
128 else
129 stats.rate = bcm43xx_plcp_get_bitrate_cck(plcp);
130-//printk("RX ofdm %d, rate == %u\n", is_ofdm, stats.rate);
131 stats.received_channel = radio->channel;
132-//TODO stats.control =
133 stats.mask = IEEE80211_STATMASK_SIGNAL |
134-//TODO IEEE80211_STATMASK_NOISE |
135+ IEEE80211_STATMASK_NOISE |
136 IEEE80211_STATMASK_RATE |
137 IEEE80211_STATMASK_RSSI;
138 if (phy->type == BCM43xx_PHYTYPE_A)
This page took 0.061111 seconds and 4 git commands to generate.