2011-04-15 16:54:52 +00:00
|
|
|
--- a/drivers/net/wireless/ath/ath5k/mac80211-ops.c
|
|
|
|
+++ b/drivers/net/wireless/ath/ath5k/mac80211-ops.c
|
2012-04-16 21:08:41 +00:00
|
|
|
@@ -86,13 +86,8 @@ ath5k_add_interface(struct ieee80211_hw
|
2011-04-15 16:54:52 +00:00
|
|
|
goto end;
|
|
|
|
}
|
|
|
|
|
|
|
|
- /* Don't allow other interfaces if one ad-hoc is configured.
|
|
|
|
- * TODO: Fix the problems with ad-hoc and multiple other interfaces.
|
|
|
|
- * We would need to operate the HW in ad-hoc mode to allow TSF updates
|
|
|
|
- * for the IBSS, but this breaks with additional AP or STA interfaces
|
|
|
|
- * at the moment. */
|
2011-08-11 13:52:27 +00:00
|
|
|
- if (ah->num_adhoc_vifs ||
|
|
|
|
- (ah->nvifs && vif->type == NL80211_IFTYPE_ADHOC)) {
|
2011-04-15 16:54:52 +00:00
|
|
|
+ /* Don't allow more than one ad-hoc interface */
|
2011-08-11 13:52:27 +00:00
|
|
|
+ if (ah->num_adhoc_vifs && vif->type == NL80211_IFTYPE_ADHOC) {
|
|
|
|
ATH5K_ERR(ah, "Only one single ad-hoc interface is allowed.\n");
|
2011-04-15 16:54:52 +00:00
|
|
|
ret = -ELNRNG;
|
|
|
|
goto end;
|
|
|
|
--- a/drivers/net/wireless/ath/ath5k/base.c
|
|
|
|
+++ b/drivers/net/wireless/ath/ath5k/base.c
|
2012-04-16 21:08:41 +00:00
|
|
|
@@ -1871,7 +1871,7 @@ ath5k_beacon_send(struct ath5k_hw *ah)
|
2011-04-15 16:54:52 +00:00
|
|
|
}
|
|
|
|
|
2012-04-16 21:08:41 +00:00
|
|
|
if ((ah->opmode == NL80211_IFTYPE_AP && ah->num_ap_vifs +
|
|
|
|
- ah->num_mesh_vifs > 1) ||
|
|
|
|
+ ah->num_adhoc_vifs + ah->num_mesh_vifs > 1) ||
|
2011-08-11 13:52:27 +00:00
|
|
|
ah->opmode == NL80211_IFTYPE_MESH_POINT) {
|
2011-04-15 16:54:52 +00:00
|
|
|
u64 tsf = ath5k_hw_get_tsf64(ah);
|
|
|
|
u32 tsftu = TSF_TO_TU(tsf);
|
2012-04-16 21:08:41 +00:00
|
|
|
@@ -1957,7 +1957,7 @@ ath5k_beacon_update_timers(struct ath5k_
|
2011-04-15 16:54:52 +00:00
|
|
|
|
2011-08-11 13:52:27 +00:00
|
|
|
intval = ah->bintval & AR5K_BEACON_PERIOD;
|
2012-04-16 21:08:41 +00:00
|
|
|
if (ah->opmode == NL80211_IFTYPE_AP && ah->num_ap_vifs
|
|
|
|
- + ah->num_mesh_vifs > 1) {
|
|
|
|
+ + ah->num_adhoc_vifs + ah->num_mesh_vifs > 1) {
|
2011-04-15 16:54:52 +00:00
|
|
|
intval /= ATH_BCBUF; /* staggered multi-bss beacons */
|
|
|
|
if (intval < 15)
|
2011-08-11 13:52:27 +00:00
|
|
|
ATH5K_WARN(ah, "intval %u is too low, min 15\n",
|
2012-04-16 21:08:41 +00:00
|
|
|
@@ -2419,6 +2419,7 @@ ath5k_tx_complete_poll_work(struct work_
|
|
|
|
static const struct ieee80211_iface_limit if_limits[] = {
|
|
|
|
{ .max = 256, .types = BIT(NL80211_IFTYPE_STATION) },
|
|
|
|
{ .max = 4, .types = BIT(NL80211_IFTYPE_AP) |
|
|
|
|
+ BIT(NL80211_IFTYPE_ADHOC) |
|
|
|
|
BIT(NL80211_IFTYPE_MESH_POINT) },
|
|
|
|
};
|
|
|
|
|