nl80211: Add control_port_over_nl80211 to mesh_setup
authorDenis Kenzior <denkenz@gmail.com>
Mon, 26 Mar 2018 17:52:49 +0000 (12:52 -0500)
committerJohannes Berg <johannes.berg@intel.com>
Thu, 29 Mar 2018 12:01:27 +0000 (14:01 +0200)
Signed-off-by: Denis Kenzior <denkenz@gmail.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
include/net/cfg80211.h
net/wireless/nl80211.c

index ed2773f..250dac3 100644 (file)
@@ -1454,6 +1454,8 @@ struct mesh_config {
  * @userspace_handles_dfs: whether user space controls DFS operation, i.e.
  *     changes the channel when a radar is detected. This is required
  *     to operate on DFS channels.
+ * @control_port_over_nl80211: TRUE if userspace expects to exchange control
+ *     port frames over NL80211 instead of the network interface.
  *
  * These parameters are fixed when the mesh is created.
  */
@@ -1476,6 +1478,7 @@ struct mesh_setup {
        u32 basic_rates;
        struct cfg80211_bitrate_mask beacon_rate;
        bool userspace_handles_dfs;
+       bool control_port_over_nl80211;
 };
 
 /**
index f8e1040..ff28f8f 100644 (file)
@@ -10168,6 +10168,15 @@ static int nl80211_join_mesh(struct sk_buff *skb, struct genl_info *info)
        setup.userspace_handles_dfs =
                nla_get_flag(info->attrs[NL80211_ATTR_HANDLE_DFS]);
 
+       if (info->attrs[NL80211_ATTR_CONTROL_PORT_OVER_NL80211]) {
+               int r = validate_pae_over_nl80211(rdev, info);
+
+               if (r < 0)
+                       return r;
+
+               setup.control_port_over_nl80211 = true;
+       }
+
        wdev_lock(dev->ieee80211_ptr);
        err = __cfg80211_join_mesh(rdev, dev, &setup, &cfg);
        if (!err && info->attrs[NL80211_ATTR_SOCKET_OWNER])