aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211/mlme.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/mac80211/mlme.c')
-rw-r--r--net/mac80211/mlme.c89
1 files changed, 4 insertions, 85 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index 25f90f7ccf3e..f1ee9d22cf4b 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -445,53 +445,6 @@ static void ieee80211_send_deauth_disassoc(struct ieee80211_sub_if_data *sdata,
445 ieee80211_sta_tx(sdata, skb, 0); 445 ieee80211_sta_tx(sdata, skb, 0);
446} 446}
447 447
448static void ieee80211_send_refuse_measurement_request(struct ieee80211_sub_if_data *sdata,
449 struct ieee80211_msrment_ie *request_ie,
450 const u8 *da, const u8 *bssid,
451 u8 dialog_token)
452{
453 struct ieee80211_local *local = sdata->local;
454 struct sk_buff *skb;
455 struct ieee80211_mgmt *msr_report;
456
457 skb = dev_alloc_skb(sizeof(*msr_report) + local->hw.extra_tx_headroom +
458 sizeof(struct ieee80211_msrment_ie));
459
460 if (!skb) {
461 printk(KERN_ERR "%s: failed to allocate buffer for "
462 "measurement report frame\n", sdata->dev->name);
463 return;
464 }
465
466 skb_reserve(skb, local->hw.extra_tx_headroom);
467 msr_report = (struct ieee80211_mgmt *)skb_put(skb, 24);
468 memset(msr_report, 0, 24);
469 memcpy(msr_report->da, da, ETH_ALEN);
470 memcpy(msr_report->sa, sdata->dev->dev_addr, ETH_ALEN);
471 memcpy(msr_report->bssid, bssid, ETH_ALEN);
472 msr_report->frame_control = cpu_to_le16(IEEE80211_FTYPE_MGMT |
473 IEEE80211_STYPE_ACTION);
474
475 skb_put(skb, 1 + sizeof(msr_report->u.action.u.measurement));
476 msr_report->u.action.category = WLAN_CATEGORY_SPECTRUM_MGMT;
477 msr_report->u.action.u.measurement.action_code =
478 WLAN_ACTION_SPCT_MSR_RPRT;
479 msr_report->u.action.u.measurement.dialog_token = dialog_token;
480
481 msr_report->u.action.u.measurement.element_id = WLAN_EID_MEASURE_REPORT;
482 msr_report->u.action.u.measurement.length =
483 sizeof(struct ieee80211_msrment_ie);
484
485 memset(&msr_report->u.action.u.measurement.msr_elem, 0,
486 sizeof(struct ieee80211_msrment_ie));
487 msr_report->u.action.u.measurement.msr_elem.token = request_ie->token;
488 msr_report->u.action.u.measurement.msr_elem.mode |=
489 IEEE80211_SPCT_MSR_RPRT_MODE_REFUSED;
490 msr_report->u.action.u.measurement.msr_elem.type = request_ie->type;
491
492 ieee80211_sta_tx(sdata, skb, 0);
493}
494
495/* MLME */ 448/* MLME */
496static void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata, 449static void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata,
497 struct ieee80211_sta_bss *bss) 450 struct ieee80211_sta_bss *bss)
@@ -1011,24 +964,6 @@ static void ieee80211_auth_challenge(struct ieee80211_sub_if_data *sdata,
1011 elems.challenge_len + 2, 1); 964 elems.challenge_len + 2, 1);
1012} 965}
1013 966
1014static void ieee80211_sta_process_measurement_req(struct ieee80211_sub_if_data *sdata,
1015 struct ieee80211_mgmt *mgmt,
1016 size_t len)
1017{
1018 /*
1019 * Ignoring measurement request is spec violation.
1020 * Mandatory measurements must be reported optional
1021 * measurements might be refused or reported incapable
1022 * For now just refuse
1023 * TODO: Answer basic measurement as unmeasured
1024 */
1025 ieee80211_send_refuse_measurement_request(sdata,
1026 &mgmt->u.action.u.measurement.msr_elem,
1027 mgmt->sa, mgmt->bssid,
1028 mgmt->u.action.u.measurement.dialog_token);
1029}
1030
1031
1032static void ieee80211_rx_mgmt_auth(struct ieee80211_sub_if_data *sdata, 967static void ieee80211_rx_mgmt_auth(struct ieee80211_sub_if_data *sdata,
1033 struct ieee80211_if_sta *ifsta, 968 struct ieee80211_if_sta *ifsta,
1034 struct ieee80211_mgmt *mgmt, 969 struct ieee80211_mgmt *mgmt,
@@ -1870,32 +1805,16 @@ static void ieee80211_rx_mgmt_action(struct ieee80211_sub_if_data *sdata,
1870 size_t len, 1805 size_t len,
1871 struct ieee80211_rx_status *rx_status) 1806 struct ieee80211_rx_status *rx_status)
1872{ 1807{
1873 struct ieee80211_local *local = sdata->local; 1808 /* currently we only handle mesh interface action frames here */
1874 1809 if (!ieee80211_vif_is_mesh(&sdata->vif))
1875 /* all categories we currently handle have action_code */
1876 if (len < IEEE80211_MIN_ACTION_SIZE + 1)
1877 return; 1810 return;
1878 1811
1879 switch (mgmt->u.action.category) { 1812 switch (mgmt->u.action.category) {
1880 case WLAN_CATEGORY_SPECTRUM_MGMT:
1881 if (local->hw.conf.channel->band != IEEE80211_BAND_5GHZ)
1882 break;
1883 switch (mgmt->u.action.u.measurement.action_code) {
1884 case WLAN_ACTION_SPCT_MSR_REQ:
1885 if (len < (IEEE80211_MIN_ACTION_SIZE +
1886 sizeof(mgmt->u.action.u.measurement)))
1887 break;
1888 ieee80211_sta_process_measurement_req(sdata, mgmt, len);
1889 break;
1890 }
1891 break;
1892 case PLINK_CATEGORY: 1813 case PLINK_CATEGORY:
1893 if (ieee80211_vif_is_mesh(&sdata->vif)) 1814 mesh_rx_plink_frame(sdata, mgmt, len, rx_status);
1894 mesh_rx_plink_frame(sdata, mgmt, len, rx_status);
1895 break; 1815 break;
1896 case MESH_PATH_SEL_CATEGORY: 1816 case MESH_PATH_SEL_CATEGORY:
1897 if (ieee80211_vif_is_mesh(&sdata->vif)) 1817 mesh_rx_path_sel_frame(sdata, mgmt, len);
1898 mesh_rx_path_sel_frame(sdata, mgmt, len);
1899 break; 1818 break;
1900 } 1819 }
1901} 1820}