Add code to report periodic scan results whenever they are available. This adds NL80211_CMD_PERIODIC_RESULTS to the API. Signed-off-by: Luciano Coelho <luciano.coelho@xxxxxxxxx> --- include/linux/nl80211.h | 2 ++ net/wireless/nl80211.c | 19 +++++++++++++++++++ net/wireless/nl80211.h | 2 ++ net/wireless/scan.c | 2 +- 4 files changed, 24 insertions(+), 1 deletions(-) diff --git a/include/linux/nl80211.h b/include/linux/nl80211.h index b3d1306..3206b8f 100644 --- a/include/linux/nl80211.h +++ b/include/linux/nl80211.h @@ -201,6 +201,7 @@ * * @NL80211_CMD_START_PERIODIC_SCAN: start a periodic scan * @NL80211_CMD_STOP_PERIODIC_SCAN: stop a periodic scan + * @NL80211_CMD_PERIODIC_RESULTS: there are periodic scan results available. * * @NL80211_CMD_GET_SURVEY: get survey resuls, e.g. channel occupation * or noise level @@ -448,6 +449,7 @@ enum nl80211_commands { NL80211_CMD_START_PERIODIC_SCAN, NL80211_CMD_STOP_PERIODIC_SCAN, + NL80211_CMD_PERIODIC_RESULTS, NL80211_CMD_REG_CHANGE, diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index fd50186..e1d7ab2 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c @@ -5151,6 +5151,25 @@ void nl80211_send_scan_aborted(struct cfg80211_registered_device *rdev, nl80211_scan_mcgrp.id, GFP_KERNEL); } +void nl80211_send_periodic_results(struct cfg80211_registered_device *rdev, + struct net_device *netdev) +{ + struct sk_buff *msg; + + msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL); + if (!msg) + return; + + if (nl80211_send_periodic_msg(msg, rdev, netdev, 0, 0, 0, + NL80211_CMD_PERIODIC_RESULTS) < 0) { + nlmsg_free(msg); + return; + } + + genlmsg_multicast_netns(wiphy_net(&rdev->wiphy), msg, 0, + nl80211_scan_mcgrp.id, GFP_KERNEL); +} + void nl80211_send_periodic(struct cfg80211_registered_device *rdev, struct net_device *netdev, u32 cmd) { diff --git a/net/wireless/nl80211.h b/net/wireless/nl80211.h index 435d452..586fd1f 100644 --- a/net/wireless/nl80211.h +++ b/net/wireless/nl80211.h @@ -14,6 +14,8 @@ void nl80211_send_scan_aborted(struct cfg80211_registered_device *rdev, struct net_device *netdev); void nl80211_send_periodic(struct cfg80211_registered_device *rdev, struct net_device *netdev, u32 cmd); +void nl80211_send_periodic_results(struct cfg80211_registered_device *rdev, + struct net_device *netdev); void nl80211_send_reg_change_event(struct regulatory_request *request); void nl80211_send_rx_auth(struct cfg80211_registered_device *rdev, struct net_device *netdev, diff --git a/net/wireless/scan.c b/net/wireless/scan.c index 300876b..925bdfb 100644 --- a/net/wireless/scan.c +++ b/net/wireless/scan.c @@ -101,7 +101,7 @@ void __cfg80211_periodic_results(struct work_struct *wk) periodic_wk); cfg80211_lock_rdev(rdev); - nl80211_send_scan_done(rdev, rdev->periodic_req->dev); + nl80211_send_periodic_results(rdev, rdev->periodic_req->dev); cfg80211_unlock_rdev(rdev); } -- 1.7.0.4 -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html