diff options
Diffstat (limited to 'net/mac80211/mlme.c')
-rw-r--r-- | net/mac80211/mlme.c | 89 |
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 | ||
448 | static 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 */ |
496 | static void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata, | 449 | static 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 | ||
1014 | static 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 | |||
1032 | static void ieee80211_rx_mgmt_auth(struct ieee80211_sub_if_data *sdata, | 967 | static 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 | } |