Commit 93a59d75 authored by Christian Lamparter's avatar Christian Lamparter Committed by John W. Linville

p54: disable channels with incomplete calibration data sets

James Grossmann [1] reported that p54 spews out confusing
messages instead of preventing the mayhem from happening.

the reason is that "p54: generate channel list dynamically"
is not perfect. It didn't discard incomplete channel data
sets and therefore p54 advertised to support them as well.

[1]: http://marc.info/?l=linux-wireless&m=125699830215890

Cc: Larry Finger <Larry.Finger@lwfinger.net>
Reported-by: default avatarJames Grossmann <cctsurf@gmail.com>
Signed-off-by: default avatarChristian Lamparter <chunkeey@web.de>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 6d3560d4
...@@ -126,7 +126,7 @@ static int p54_generate_band(struct ieee80211_hw *dev, ...@@ -126,7 +126,7 @@ static int p54_generate_band(struct ieee80211_hw *dev,
int ret = -ENOMEM; int ret = -ENOMEM;
if ((!list->entries) || (!list->band_channel_num[band])) if ((!list->entries) || (!list->band_channel_num[band]))
return 0; return -EINVAL;
tmp = kzalloc(sizeof(*tmp), GFP_KERNEL); tmp = kzalloc(sizeof(*tmp), GFP_KERNEL);
if (!tmp) if (!tmp)
...@@ -158,6 +158,7 @@ static int p54_generate_band(struct ieee80211_hw *dev, ...@@ -158,6 +158,7 @@ static int p54_generate_band(struct ieee80211_hw *dev,
(list->channels[i].data & CHAN_HAS_CURVE ? "" : (list->channels[i].data & CHAN_HAS_CURVE ? "" :
" [curve data]"), " [curve data]"),
list->channels[i].index, list->channels[i].freq); list->channels[i].index, list->channels[i].freq);
continue;
} }
tmp->channels[j].band = list->channels[i].band; tmp->channels[j].band = list->channels[i].band;
...@@ -165,7 +166,16 @@ static int p54_generate_band(struct ieee80211_hw *dev, ...@@ -165,7 +166,16 @@ static int p54_generate_band(struct ieee80211_hw *dev,
j++; j++;
} }
tmp->n_channels = list->band_channel_num[band]; if (j == 0) {
printk(KERN_ERR "%s: Disabling totally damaged %s band.\n",
wiphy_name(dev->wiphy), (band == IEEE80211_BAND_2GHZ) ?
"2 GHz" : "5 GHz");
ret = -ENODATA;
goto err_out;
}
tmp->n_channels = j;
old = priv->band_table[band]; old = priv->band_table[band];
priv->band_table[band] = tmp; priv->band_table[band] = tmp;
if (old) { if (old) {
...@@ -228,13 +238,13 @@ static int p54_generate_channel_lists(struct ieee80211_hw *dev) ...@@ -228,13 +238,13 @@ static int p54_generate_channel_lists(struct ieee80211_hw *dev)
struct p54_common *priv = dev->priv; struct p54_common *priv = dev->priv;
struct p54_channel_list *list; struct p54_channel_list *list;
unsigned int i, j, max_channel_num; unsigned int i, j, max_channel_num;
int ret = -ENOMEM; int ret = 0;
u16 freq; u16 freq;
if ((priv->iq_autocal_len != priv->curve_data->entries) || if ((priv->iq_autocal_len != priv->curve_data->entries) ||
(priv->iq_autocal_len != priv->output_limit->entries)) (priv->iq_autocal_len != priv->output_limit->entries))
printk(KERN_ERR "%s: EEPROM is damaged... you may not be able" printk(KERN_ERR "%s: Unsupported or damaged EEPROM detected. "
"to use all channels with this device.\n", "You may not be able to use all channels.\n",
wiphy_name(dev->wiphy)); wiphy_name(dev->wiphy));
max_channel_num = max_t(unsigned int, priv->output_limit->entries, max_channel_num = max_t(unsigned int, priv->output_limit->entries,
...@@ -243,8 +253,10 @@ static int p54_generate_channel_lists(struct ieee80211_hw *dev) ...@@ -243,8 +253,10 @@ static int p54_generate_channel_lists(struct ieee80211_hw *dev)
priv->curve_data->entries); priv->curve_data->entries);
list = kzalloc(sizeof(*list), GFP_KERNEL); list = kzalloc(sizeof(*list), GFP_KERNEL);
if (!list) if (!list) {
ret = -ENOMEM;
goto free; goto free;
}
list->max_entries = max_channel_num; list->max_entries = max_channel_num;
list->channels = kzalloc(sizeof(struct p54_channel_entry) * list->channels = kzalloc(sizeof(struct p54_channel_entry) *
...@@ -282,14 +294,9 @@ static int p54_generate_channel_lists(struct ieee80211_hw *dev) ...@@ -282,14 +294,9 @@ static int p54_generate_channel_lists(struct ieee80211_hw *dev)
p54_compare_channels, NULL); p54_compare_channels, NULL);
for (i = 0, j = 0; i < IEEE80211_NUM_BANDS; i++) { for (i = 0, j = 0; i < IEEE80211_NUM_BANDS; i++) {
if (list->band_channel_num[i]) { if (p54_generate_band(dev, list, i) == 0)
ret = p54_generate_band(dev, list, i);
if (ret)
goto free;
j++; j++;
} }
}
if (j == 0) { if (j == 0) {
/* no useable band available. */ /* no useable band available. */
ret = -EINVAL; ret = -EINVAL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment