diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/wireless/mwifiex/cfg80211.c | 49 | ||||
-rw-r--r-- | drivers/net/wireless/mwifiex/ioctl.h | 7 | ||||
-rw-r--r-- | drivers/net/wireless/mwifiex/main.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/mwifiex/sta_ioctl.c | 61 |
4 files changed, 24 insertions, 95 deletions
diff --git a/drivers/net/wireless/mwifiex/cfg80211.c b/drivers/net/wireless/mwifiex/cfg80211.c index 787dbe2aa408..64bf64051aa9 100644 --- a/drivers/net/wireless/mwifiex/cfg80211.c +++ b/drivers/net/wireless/mwifiex/cfg80211.c | |||
@@ -331,37 +331,38 @@ mwifiex_set_rf_channel(struct mwifiex_private *priv, | |||
331 | enum nl80211_channel_type channel_type) | 331 | enum nl80211_channel_type channel_type) |
332 | { | 332 | { |
333 | struct mwifiex_chan_freq_power cfp; | 333 | struct mwifiex_chan_freq_power cfp; |
334 | struct mwifiex_ds_band_cfg band_cfg; | ||
335 | u32 config_bands = 0; | 334 | u32 config_bands = 0; |
336 | struct wiphy *wiphy = priv->wdev->wiphy; | 335 | struct wiphy *wiphy = priv->wdev->wiphy; |
336 | struct mwifiex_adapter *adapter = priv->adapter; | ||
337 | 337 | ||
338 | if (chan) { | 338 | if (chan) { |
339 | memset(&band_cfg, 0, sizeof(band_cfg)); | ||
340 | /* Set appropriate bands */ | 339 | /* Set appropriate bands */ |
341 | if (chan->band == IEEE80211_BAND_2GHZ) | 340 | if (chan->band == IEEE80211_BAND_2GHZ) |
342 | config_bands = BAND_B | BAND_G | BAND_GN; | 341 | config_bands = BAND_B | BAND_G | BAND_GN; |
343 | else | 342 | else |
344 | config_bands = BAND_AN | BAND_A; | 343 | config_bands = BAND_AN | BAND_A; |
345 | if (priv->bss_mode == NL80211_IFTYPE_STATION | ||
346 | || priv->bss_mode == NL80211_IFTYPE_UNSPECIFIED) { | ||
347 | band_cfg.config_bands = config_bands; | ||
348 | } else if (priv->bss_mode == NL80211_IFTYPE_ADHOC) { | ||
349 | band_cfg.config_bands = config_bands; | ||
350 | band_cfg.adhoc_start_band = config_bands; | ||
351 | } | ||
352 | 344 | ||
353 | band_cfg.sec_chan_offset = | 345 | if (!((config_bands | adapter->fw_bands) & |
346 | ~adapter->fw_bands)) { | ||
347 | adapter->config_bands = config_bands; | ||
348 | if (priv->bss_mode == NL80211_IFTYPE_ADHOC) { | ||
349 | adapter->adhoc_start_band = config_bands; | ||
350 | if ((config_bands & BAND_GN) || | ||
351 | (config_bands & BAND_AN)) | ||
352 | adapter->adhoc_11n_enabled = true; | ||
353 | else | ||
354 | adapter->adhoc_11n_enabled = false; | ||
355 | } | ||
356 | } | ||
357 | adapter->chan_offset = | ||
354 | mwifiex_cfg80211_channel_type_to_mwifiex_channels | 358 | mwifiex_cfg80211_channel_type_to_mwifiex_channels |
355 | (channel_type); | 359 | (channel_type); |
356 | 360 | ||
357 | if (mwifiex_set_radio_band_cfg(priv, &band_cfg)) | ||
358 | return -EFAULT; | ||
359 | |||
360 | mwifiex_send_domain_info_cmd_fw(wiphy); | 361 | mwifiex_send_domain_info_cmd_fw(wiphy); |
361 | } | 362 | } |
362 | 363 | ||
363 | wiphy_dbg(wiphy, "info: setting band %d, channel offset %d and " | 364 | wiphy_dbg(wiphy, "info: setting band %d, channel offset %d and " |
364 | "mode %d\n", config_bands, band_cfg.sec_chan_offset, | 365 | "mode %d\n", config_bands, adapter->chan_offset, |
365 | priv->bss_mode); | 366 | priv->bss_mode); |
366 | if (!chan) | 367 | if (!chan) |
367 | return 0; | 368 | return 0; |
@@ -697,9 +698,9 @@ static int mwifiex_cfg80211_set_bitrate_mask(struct wiphy *wiphy, | |||
697 | const u8 *peer, | 698 | const u8 *peer, |
698 | const struct cfg80211_bitrate_mask *mask) | 699 | const struct cfg80211_bitrate_mask *mask) |
699 | { | 700 | { |
700 | struct mwifiex_ds_band_cfg band_cfg; | ||
701 | struct mwifiex_private *priv = mwifiex_netdev_get_priv(dev); | 701 | struct mwifiex_private *priv = mwifiex_netdev_get_priv(dev); |
702 | int index = 0, mode = 0, i; | 702 | int index = 0, mode = 0, i; |
703 | struct mwifiex_adapter *adapter = priv->adapter; | ||
703 | 704 | ||
704 | /* Currently only 2.4GHz is supported */ | 705 | /* Currently only 2.4GHz is supported */ |
705 | for (i = 0; i < mwifiex_band_2ghz.n_bitrates; i++) { | 706 | for (i = 0; i < mwifiex_band_2ghz.n_bitrates; i++) { |
@@ -721,16 +722,14 @@ static int mwifiex_cfg80211_set_bitrate_mask(struct wiphy *wiphy, | |||
721 | mode |= BAND_B; | 722 | mode |= BAND_B; |
722 | } | 723 | } |
723 | 724 | ||
724 | memset(&band_cfg, 0, sizeof(band_cfg)); | 725 | if (!((mode | adapter->fw_bands) & ~adapter->fw_bands)) { |
725 | band_cfg.config_bands = mode; | 726 | adapter->config_bands = mode; |
726 | 727 | if (priv->bss_mode == NL80211_IFTYPE_ADHOC) { | |
727 | if (priv->bss_mode == NL80211_IFTYPE_ADHOC) | 728 | adapter->adhoc_start_band = mode; |
728 | band_cfg.adhoc_start_band = mode; | 729 | adapter->adhoc_11n_enabled = false; |
729 | 730 | } | |
730 | band_cfg.sec_chan_offset = NO_SEC_CHANNEL; | 731 | } |
731 | 732 | adapter->chan_offset = NO_SEC_CHANNEL; | |
732 | if (mwifiex_set_radio_band_cfg(priv, &band_cfg)) | ||
733 | return -EFAULT; | ||
734 | 733 | ||
735 | wiphy_debug(wiphy, "info: device configured in 802.11%s%s mode\n", | 734 | wiphy_debug(wiphy, "info: device configured in 802.11%s%s mode\n", |
736 | (mode & BAND_B) ? "b" : "", | 735 | (mode & BAND_B) ? "b" : "", |
diff --git a/drivers/net/wireless/mwifiex/ioctl.h b/drivers/net/wireless/mwifiex/ioctl.h index e0b68e7c8ca2..eb76b7b749ad 100644 --- a/drivers/net/wireless/mwifiex/ioctl.h +++ b/drivers/net/wireless/mwifiex/ioctl.h | |||
@@ -66,13 +66,6 @@ enum { | |||
66 | #define SEC_CHANNEL_ABOVE 1 | 66 | #define SEC_CHANNEL_ABOVE 1 |
67 | #define SEC_CHANNEL_BELOW 3 | 67 | #define SEC_CHANNEL_BELOW 3 |
68 | 68 | ||
69 | struct mwifiex_ds_band_cfg { | ||
70 | u32 config_bands; | ||
71 | u32 adhoc_start_band; | ||
72 | u32 adhoc_channel; | ||
73 | u32 sec_chan_offset; | ||
74 | }; | ||
75 | |||
76 | enum { | 69 | enum { |
77 | ADHOC_IDLE, | 70 | ADHOC_IDLE, |
78 | ADHOC_STARTED, | 71 | ADHOC_STARTED, |
diff --git a/drivers/net/wireless/mwifiex/main.h b/drivers/net/wireless/mwifiex/main.h index 9207fc64641e..d659650a1379 100644 --- a/drivers/net/wireless/mwifiex/main.h +++ b/drivers/net/wireless/mwifiex/main.h | |||
@@ -954,8 +954,6 @@ int mwifiex_main_process(struct mwifiex_adapter *); | |||
954 | 954 | ||
955 | int mwifiex_bss_set_channel(struct mwifiex_private *, | 955 | int mwifiex_bss_set_channel(struct mwifiex_private *, |
956 | struct mwifiex_chan_freq_power *cfp); | 956 | struct mwifiex_chan_freq_power *cfp); |
957 | int mwifiex_set_radio_band_cfg(struct mwifiex_private *, | ||
958 | struct mwifiex_ds_band_cfg *); | ||
959 | int mwifiex_get_bss_info(struct mwifiex_private *, | 957 | int mwifiex_get_bss_info(struct mwifiex_private *, |
960 | struct mwifiex_bss_info *); | 958 | struct mwifiex_bss_info *); |
961 | int mwifiex_fill_new_bss_desc(struct mwifiex_private *priv, | 959 | int mwifiex_fill_new_bss_desc(struct mwifiex_private *priv, |
diff --git a/drivers/net/wireless/mwifiex/sta_ioctl.c b/drivers/net/wireless/mwifiex/sta_ioctl.c index 6d990c798a20..e40196dfdea0 100644 --- a/drivers/net/wireless/mwifiex/sta_ioctl.c +++ b/drivers/net/wireless/mwifiex/sta_ioctl.c | |||
@@ -472,67 +472,6 @@ int mwifiex_get_bss_info(struct mwifiex_private *priv, | |||
472 | } | 472 | } |
473 | 473 | ||
474 | /* | 474 | /* |
475 | * The function sets band configurations. | ||
476 | * | ||
477 | * it performs extra checks to make sure the Ad-Hoc | ||
478 | * band and channel are compatible. Otherwise it returns an error. | ||
479 | * | ||
480 | */ | ||
481 | int mwifiex_set_radio_band_cfg(struct mwifiex_private *priv, | ||
482 | struct mwifiex_ds_band_cfg *radio_cfg) | ||
483 | { | ||
484 | struct mwifiex_adapter *adapter = priv->adapter; | ||
485 | u8 infra_band, adhoc_band; | ||
486 | u32 adhoc_channel; | ||
487 | |||
488 | infra_band = (u8) radio_cfg->config_bands; | ||
489 | adhoc_band = (u8) radio_cfg->adhoc_start_band; | ||
490 | adhoc_channel = radio_cfg->adhoc_channel; | ||
491 | |||
492 | /* SET Infra band */ | ||
493 | if ((infra_band | adapter->fw_bands) & ~adapter->fw_bands) | ||
494 | return -1; | ||
495 | |||
496 | adapter->config_bands = infra_band; | ||
497 | |||
498 | /* SET Ad-hoc Band */ | ||
499 | if ((adhoc_band | adapter->fw_bands) & ~adapter->fw_bands) | ||
500 | return -1; | ||
501 | |||
502 | if (adhoc_band) | ||
503 | adapter->adhoc_start_band = adhoc_band; | ||
504 | adapter->chan_offset = (u8) radio_cfg->sec_chan_offset; | ||
505 | /* | ||
506 | * If no adhoc_channel is supplied verify if the existing adhoc | ||
507 | * channel compiles with new adhoc_band | ||
508 | */ | ||
509 | if (!adhoc_channel) { | ||
510 | if (!mwifiex_get_cfp_by_band_and_channel_from_cfg80211 | ||
511 | (priv, adapter->adhoc_start_band, | ||
512 | priv->adhoc_channel)) { | ||
513 | /* Pass back the default channel */ | ||
514 | radio_cfg->adhoc_channel = DEFAULT_AD_HOC_CHANNEL; | ||
515 | if ((adapter->adhoc_start_band & BAND_A) | ||
516 | || (adapter->adhoc_start_band & BAND_AN)) | ||
517 | radio_cfg->adhoc_channel = | ||
518 | DEFAULT_AD_HOC_CHANNEL_A; | ||
519 | } | ||
520 | } else { /* Retrurn error if adhoc_band and | ||
521 | adhoc_channel combination is invalid */ | ||
522 | if (!mwifiex_get_cfp_by_band_and_channel_from_cfg80211 | ||
523 | (priv, adapter->adhoc_start_band, (u16) adhoc_channel)) | ||
524 | return -1; | ||
525 | priv->adhoc_channel = (u8) adhoc_channel; | ||
526 | } | ||
527 | if ((adhoc_band & BAND_GN) || (adhoc_band & BAND_AN)) | ||
528 | adapter->adhoc_11n_enabled = true; | ||
529 | else | ||
530 | adapter->adhoc_11n_enabled = false; | ||
531 | |||
532 | return 0; | ||
533 | } | ||
534 | |||
535 | /* | ||
536 | * The function disables auto deep sleep mode. | 475 | * The function disables auto deep sleep mode. |
537 | */ | 476 | */ |
538 | int mwifiex_disable_auto_ds(struct mwifiex_private *priv) | 477 | int mwifiex_disable_auto_ds(struct mwifiex_private *priv) |