ath5k: allow simultaneous ad-hoc+ap operation (backport of r26685)
authorFelix Fietkau <nbd@openwrt.org>
Fri, 15 Apr 2011 16:55:24 +0000 (16:55 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Fri, 15 Apr 2011 16:55:24 +0000 (16:55 +0000)
SVN-Revision: 26686

package/mac80211/patches/411-ath5k_allow_adhoc_and_ap.patch [new file with mode: 0644]
package/mac80211/patches/463-ath5k_fix_slottime.patch
package/mac80211/patches/472-ath_unshare_bus_ops.patch

diff --git a/package/mac80211/patches/411-ath5k_allow_adhoc_and_ap.patch b/package/mac80211/patches/411-ath5k_allow_adhoc_and_ap.patch
new file mode 100644 (file)
index 0000000..b1d835f
--- /dev/null
@@ -0,0 +1,38 @@
+--- a/drivers/net/wireless/ath/ath5k/mac80211-ops.c
++++ b/drivers/net/wireless/ath/ath5k/mac80211-ops.c
+@@ -97,13 +97,8 @@ ath5k_add_interface(struct ieee80211_hw 
+               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. */
+-      if (sc->num_adhoc_vifs ||
+-          (sc->nvifs && vif->type == NL80211_IFTYPE_ADHOC)) {
++      /* Don't allow more than one ad-hoc interface */
++      if (sc->num_adhoc_vifs && vif->type == NL80211_IFTYPE_ADHOC) {
+               ATH5K_ERR(sc, "Only one single ad-hoc interface is allowed.\n");
+               ret = -ELNRNG;
+               goto end;
+--- a/drivers/net/wireless/ath/ath5k/base.c
++++ b/drivers/net/wireless/ath/ath5k/base.c
+@@ -1857,7 +1857,7 @@ ath5k_beacon_send(struct ath5k_softc *sc
+               sc->bmisscount = 0;
+       }
+-      if ((sc->opmode == NL80211_IFTYPE_AP && sc->num_ap_vifs > 1) ||
++      if ((sc->opmode == NL80211_IFTYPE_AP && sc->num_ap_vifs + sc->num_adhoc_vifs > 1) ||
+                       sc->opmode == NL80211_IFTYPE_MESH_POINT) {
+               u64 tsf = ath5k_hw_get_tsf64(ah);
+               u32 tsftu = TSF_TO_TU(tsf);
+@@ -1935,7 +1935,7 @@ ath5k_beacon_update_timers(struct ath5k_
+       u64 hw_tsf;
+       intval = sc->bintval & AR5K_BEACON_PERIOD;
+-      if (sc->opmode == NL80211_IFTYPE_AP && sc->num_ap_vifs > 1) {
++      if (sc->opmode == NL80211_IFTYPE_AP && sc->num_ap_vifs + sc->num_adhoc_vifs > 1) {
+               intval /= ATH_BCBUF;    /* staggered multi-bss beacons */
+               if (intval < 15)
+                       ATH5K_WARN(sc, "intval %u is too low, min 15\n",
index 01e55d35d441cb2f7e1631bf5cfcd254b229f1b2..3f38ee392c79c16bc085d449cce86d3397dd3c93 100644 (file)
@@ -10,7 +10,7 @@
        u32                     ah_ant_ctl[AR5K_EEPROM_N_MODES][AR5K_ANT_MAX];
 --- a/drivers/net/wireless/ath/ath5k/mac80211-ops.c
 +++ b/drivers/net/wireless/ath/ath5k/mac80211-ops.c
-@@ -282,6 +282,15 @@ ath5k_bss_info_changed(struct ieee80211_
+@@ -277,6 +277,15 @@ ath5k_bss_info_changed(struct ieee80211_
        if (changes & BSS_CHANGED_BEACON_INT)
                sc->bintval = bss_conf->beacon_int;
  
index b3b0eab1f1480cad8554ae26755f8605980ad9f6..3b0ffb972815d422145a30794c5befad34127cea 100644 (file)
@@ -18,7 +18,7 @@
        void *ah;
 --- a/drivers/net/wireless/ath/ath9k/hw.h
 +++ b/drivers/net/wireless/ath/ath9k/hw.h
-@@ -847,6 +847,14 @@ struct ath_hw {
+@@ -846,6 +846,14 @@ struct ath_hw {
        u32 ent_mode;
  };