nl80211: allow configuring IBSS beacon interval
authorJohannes Berg <johannes@sipsolutions.net>
Wed, 22 Apr 2009 15:45:38 +0000 (17:45 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Wed, 22 Apr 2009 20:57:20 +0000 (16:57 -0400)
Make the JOIN_IBSS command look at the beacon interval
attribute to see if the user requested a specific beacon
interval, if not default to 100 TU (wext too).

Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
include/linux/nl80211.h
include/net/cfg80211.h
net/wireless/ibss.c
net/wireless/nl80211.c

index dc9d9ec5d1aeae71a7103940e1c719753e5d11e4..b6a48dd502ce441880e6d54c807568d5492b380f 100644 (file)
  *     and optionally a MAC (as BSSID) and FREQ_FIXED attribute if those
  *     should be fixed rather than automatically determined. Can only be
  *     executed on a network interface that is UP, and fixed BSSID/FREQ
- *     may be rejected.
+ *     may be rejected. Another optional parameter is the beacon interval,
+ *     given in the %NL80211_ATTR_BEACON_INTERVAL attribute, which if not
+ *     given defaults to 100 TU (102.4ms).
  * @NL80211_CMD_LEAVE_IBSS: Leave the IBSS -- no special arguments, the IBSS is
  *     determined by the network interface.
  *
index 54bc69c836914b0902b7b76ee28b799c8496b6b2..7f7b53b69cb2cd0f88856fde093a379e457b9026 100644 (file)
@@ -733,6 +733,7 @@ struct cfg80211_disassoc_request {
  *     IBSSs to join on other channels.
  * @ie: information element(s) to include in the beacon
  * @ie_len: length of that
+ * @beacon_interval: beacon interval to use
  */
 struct cfg80211_ibss_params {
        u8 *ssid;
@@ -740,6 +741,7 @@ struct cfg80211_ibss_params {
        struct ieee80211_channel *channel;
        u8 *ie;
        u8 ssid_len, ie_len;
+       u16 beacon_interval;
        bool channel_fixed;
 };
 
index b5c601e1b1b7a8240c0b2de0b1bda47b4e8b3700..3c38afaed28a8e6649fefff2161052d332520f02 100644 (file)
@@ -116,6 +116,9 @@ static int cfg80211_ibss_wext_join(struct cfg80211_registered_device *rdev,
        enum ieee80211_band band;
        int i;
 
+       if (!wdev->wext.beacon_interval)
+               wdev->wext.beacon_interval = 100;
+
        /* try to find an IBSS channel if none requested ... */
        if (!wdev->wext.channel) {
                for (band = 0; band < IEEE80211_NUM_BANDS; band++) {
index 97bb5c80125d2cc592a0768977d5098a4fd81927..3b21b3e89e9646d444949046f39de869e798ad92 100644 (file)
@@ -3159,6 +3159,8 @@ static int nl80211_join_ibss(struct sk_buff *skb, struct genl_info *info)
        struct wiphy *wiphy;
        int err;
 
+       memset(&ibss, 0, sizeof(ibss));
+
        if (!is_valid_ie_attr(info->attrs[NL80211_ATTR_IE]))
                return -EINVAL;
 
@@ -3167,6 +3169,15 @@ static int nl80211_join_ibss(struct sk_buff *skb, struct genl_info *info)
            !nla_len(info->attrs[NL80211_ATTR_SSID]))
                return -EINVAL;
 
+       ibss.beacon_interval = 100;
+
+       if (info->attrs[NL80211_ATTR_BEACON_INTERVAL]) {
+               ibss.beacon_interval =
+                       nla_get_u32(info->attrs[NL80211_ATTR_BEACON_INTERVAL]);
+               if (ibss.beacon_interval < 1 || ibss.beacon_interval > 10000)
+                       return -EINVAL;
+       }
+
        rtnl_lock();
 
        err = get_drv_dev_by_info_ifindex(info->attrs, &drv, &dev);
@@ -3189,7 +3200,6 @@ static int nl80211_join_ibss(struct sk_buff *skb, struct genl_info *info)
        }
 
        wiphy = &drv->wiphy;
-       memset(&ibss, 0, sizeof(ibss));
 
        if (info->attrs[NL80211_ATTR_MAC])
                ibss.bssid = nla_data(info->attrs[NL80211_ATTR_MAC]);