|
@@ -554,27 +554,8 @@ static int nl80211_msg_put_channel(struct sk_buff *msg,
|
|
|
if ((chan->flags & IEEE80211_CHAN_NO_IBSS) &&
|
|
|
nla_put_flag(msg, NL80211_FREQUENCY_ATTR_NO_IBSS))
|
|
|
goto nla_put_failure;
|
|
|
- if (chan->flags & IEEE80211_CHAN_RADAR) {
|
|
|
- u32 time = elapsed_jiffies_msecs(chan->dfs_state_entered);
|
|
|
- if (nla_put_flag(msg, NL80211_FREQUENCY_ATTR_RADAR))
|
|
|
- goto nla_put_failure;
|
|
|
- if (nla_put_u32(msg, NL80211_FREQUENCY_ATTR_DFS_STATE,
|
|
|
- chan->dfs_state))
|
|
|
- goto nla_put_failure;
|
|
|
- if (nla_put_u32(msg, NL80211_FREQUENCY_ATTR_DFS_TIME, time))
|
|
|
- goto nla_put_failure;
|
|
|
- }
|
|
|
- if ((chan->flags & IEEE80211_CHAN_NO_HT40MINUS) &&
|
|
|
- nla_put_flag(msg, NL80211_FREQUENCY_ATTR_NO_HT40_MINUS))
|
|
|
- goto nla_put_failure;
|
|
|
- if ((chan->flags & IEEE80211_CHAN_NO_HT40PLUS) &&
|
|
|
- nla_put_flag(msg, NL80211_FREQUENCY_ATTR_NO_HT40_PLUS))
|
|
|
- goto nla_put_failure;
|
|
|
- if ((chan->flags & IEEE80211_CHAN_NO_80MHZ) &&
|
|
|
- nla_put_flag(msg, NL80211_FREQUENCY_ATTR_NO_80MHZ))
|
|
|
- goto nla_put_failure;
|
|
|
- if ((chan->flags & IEEE80211_CHAN_NO_160MHZ) &&
|
|
|
- nla_put_flag(msg, NL80211_FREQUENCY_ATTR_NO_160MHZ))
|
|
|
+ if ((chan->flags & IEEE80211_CHAN_RADAR) &&
|
|
|
+ nla_put_flag(msg, NL80211_FREQUENCY_ATTR_RADAR))
|
|
|
goto nla_put_failure;
|
|
|
|
|
|
if (nla_put_u32(msg, NL80211_FREQUENCY_ATTR_MAX_TX_POWER,
|
|
@@ -900,9 +881,6 @@ static int nl80211_put_iface_combinations(struct wiphy *wiphy,
|
|
|
nla_put_u32(msg, NL80211_IFACE_COMB_MAXNUM,
|
|
|
c->max_interfaces))
|
|
|
goto nla_put_failure;
|
|
|
- if (nla_put_u32(msg, NL80211_IFACE_COMB_RADAR_DETECT_WIDTHS,
|
|
|
- c->radar_detect_widths))
|
|
|
- goto nla_put_failure;
|
|
|
|
|
|
nla_nest_end(msg, nl_combi);
|
|
|
}
|
|
@@ -914,48 +892,6 @@ nla_put_failure:
|
|
|
return -ENOBUFS;
|
|
|
}
|
|
|
|
|
|
-#ifdef CONFIG_PM
|
|
|
-static int nl80211_send_wowlan_tcp_caps(struct cfg80211_registered_device *rdev,
|
|
|
- struct sk_buff *msg)
|
|
|
-{
|
|
|
- const struct wiphy_wowlan_tcp_support *tcp = rdev->wiphy.wowlan.tcp;
|
|
|
- struct nlattr *nl_tcp;
|
|
|
-
|
|
|
- if (!tcp)
|
|
|
- return 0;
|
|
|
-
|
|
|
- nl_tcp = nla_nest_start(msg, NL80211_WOWLAN_TRIG_TCP_CONNECTION);
|
|
|
- if (!nl_tcp)
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- if (nla_put_u32(msg, NL80211_WOWLAN_TCP_DATA_PAYLOAD,
|
|
|
- tcp->data_payload_max))
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- if (nla_put_u32(msg, NL80211_WOWLAN_TCP_DATA_PAYLOAD,
|
|
|
- tcp->data_payload_max))
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- if (tcp->seq && nla_put_flag(msg, NL80211_WOWLAN_TCP_DATA_PAYLOAD_SEQ))
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- if (tcp->tok && nla_put(msg, NL80211_WOWLAN_TCP_DATA_PAYLOAD_TOKEN,
|
|
|
- sizeof(*tcp->tok), tcp->tok))
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- if (nla_put_u32(msg, NL80211_WOWLAN_TCP_DATA_INTERVAL,
|
|
|
- tcp->data_interval_max))
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- if (nla_put_u32(msg, NL80211_WOWLAN_TCP_WAKE_PAYLOAD,
|
|
|
- tcp->wake_payload_max))
|
|
|
- return -ENOBUFS;
|
|
|
-
|
|
|
- nla_nest_end(msg, nl_tcp);
|
|
|
- return 0;
|
|
|
-}
|
|
|
-#endif
|
|
|
-
|
|
|
static int nl80211_send_wiphy(struct sk_buff *msg, u32 portid, u32 seq, int flags,
|
|
|
struct cfg80211_registered_device *dev)
|
|
|
{
|
|
@@ -1330,9 +1266,6 @@ static int nl80211_send_wiphy(struct sk_buff *msg, u32 portid, u32 seq, int flag
|
|
|
goto nla_put_failure;
|
|
|
}
|
|
|
|
|
|
- if (nl80211_send_wowlan_tcp_caps(dev, msg))
|
|
|
- goto nla_put_failure;
|
|
|
-
|
|
|
nla_nest_end(msg, nl_wowlan);
|
|
|
}
|
|
|
#endif
|
|
@@ -1365,15 +1298,6 @@ static int nl80211_send_wiphy(struct sk_buff *msg, u32 portid, u32 seq, int flag
|
|
|
dev->wiphy.max_acl_mac_addrs))
|
|
|
goto nla_put_failure;
|
|
|
|
|
|
- if (dev->wiphy.extended_capabilities &&
|
|
|
- (nla_put(msg, NL80211_ATTR_EXT_CAPA,
|
|
|
- dev->wiphy.extended_capabilities_len,
|
|
|
- dev->wiphy.extended_capabilities) ||
|
|
|
- nla_put(msg, NL80211_ATTR_EXT_CAPA_MASK,
|
|
|
- dev->wiphy.extended_capabilities_len,
|
|
|
- dev->wiphy.extended_capabilities_mask)))
|
|
|
- goto nla_put_failure;
|
|
|
-
|
|
|
return genlmsg_end(msg, hdr);
|
|
|
|
|
|
nla_put_failure:
|
|
@@ -1383,7 +1307,7 @@ static int nl80211_send_wiphy(struct sk_buff *msg, u32 portid, u32 seq, int flag
|
|
|
|
|
|
static int nl80211_dump_wiphy(struct sk_buff *skb, struct netlink_callback *cb)
|
|
|
{
|
|
|
- int idx = 0;
|
|
|
+ int idx = 0, ret;
|
|
|
int start = cb->args[0];
|
|
|
struct cfg80211_registered_device *dev;
|
|
|
|
|
@@ -1393,9 +1317,29 @@ static int nl80211_dump_wiphy(struct sk_buff *skb, struct netlink_callback *cb)
|
|
|
continue;
|
|
|
if (++idx <= start)
|
|
|
continue;
|
|
|
- if (nl80211_send_wiphy(skb, NETLINK_CB(cb->skb).portid,
|
|
|
- cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
|
|
- dev) < 0) {
|
|
|
+ ret = nl80211_send_wiphy(skb, NETLINK_CB(cb->skb).portid,
|
|
|
+ cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
|
|
+ dev);
|
|
|
+ if (ret < 0) {
|
|
|
+ /*
|
|
|
+ * If sending the wiphy data didn't fit (ENOBUFS or
|
|
|
+ * EMSGSIZE returned), this SKB is still empty (so
|
|
|
+ * it's not too big because another wiphy dataset is
|
|
|
+ * already in the skb) and we've not tried to adjust
|
|
|
+ * the dump allocation yet ... then adjust the alloc
|
|
|
+ * size to be bigger, and return 1 but with the empty
|
|
|
+ * skb. This results in an empty message being RX'ed
|
|
|
+ * in userspace, but that is ignored.
|
|
|
+ *
|
|
|
+ * We can then retry with the larger buffer.
|
|
|
+ */
|
|
|
+ if ((ret == -ENOBUFS || ret == -EMSGSIZE) &&
|
|
|
+ !skb->len &&
|
|
|
+ cb->min_dump_alloc < 4096) {
|
|
|
+ cb->min_dump_alloc = 4096;
|
|
|
+ mutex_unlock(&cfg80211_mutex);
|
|
|
+ return 1;
|
|
|
+ }
|
|
|
idx--;
|
|
|
break;
|
|
|
}
|
|
@@ -1412,7 +1356,7 @@ static int nl80211_get_wiphy(struct sk_buff *skb, struct genl_info *info)
|
|
|
struct sk_buff *msg;
|
|
|
struct cfg80211_registered_device *dev = info->user_ptr[0];
|
|
|
|
|
|
- msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
|
|
|
+ msg = nlmsg_new(4096, GFP_KERNEL);
|
|
|
if (!msg)
|
|
|
return -ENOMEM;
|
|
|
|