]> git.pld-linux.org Git - packages/kernel.git/blob - kernel-bcm43xx-patch_2.6.18.1_signal_quality.patch
- 2.6.19 ready
[packages/kernel.git] / kernel-bcm43xx-patch_2.6.18.1_signal_quality.patch
1 Index: 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. */
15 Index: 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);
28 Index: 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;
110 Index: 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.147473 seconds and 3 git commands to generate.