diff options
-rw-r--r-- | include/linux/nl80211.h | 41 | ||||
-rw-r--r-- | include/net/cfg80211.h | 27 | ||||
-rw-r--r-- | net/mac80211/cfg.c | 6 | ||||
-rw-r--r-- | net/mac80211/mesh_plink.c | 72 | ||||
-rw-r--r-- | net/mac80211/rx.c | 2 | ||||
-rw-r--r-- | net/mac80211/sta_info.c | 2 | ||||
-rw-r--r-- | net/mac80211/sta_info.h | 6 | ||||
-rw-r--r-- | net/wireless/nl80211.c | 2 |
8 files changed, 83 insertions, 75 deletions
diff --git a/include/linux/nl80211.h b/include/linux/nl80211.h index 0ea497cb607c..fc3a94821b1e 100644 --- a/include/linux/nl80211.h +++ b/include/linux/nl80211.h | |||
@@ -973,9 +973,10 @@ enum nl80211_commands { | |||
973 | * @NL80211_ATTR_SUPPORT_MESH_AUTH: Currently, this means the underlying driver | 973 | * @NL80211_ATTR_SUPPORT_MESH_AUTH: Currently, this means the underlying driver |
974 | * allows auth frames in a mesh to be passed to userspace for processing via | 974 | * allows auth frames in a mesh to be passed to userspace for processing via |
975 | * the @NL80211_MESH_SETUP_USERSPACE_AUTH flag. | 975 | * the @NL80211_MESH_SETUP_USERSPACE_AUTH flag. |
976 | * @NL80211_ATTR_STA_PLINK_STATE: The state of a mesh peer link. Used when | 976 | * @NL80211_ATTR_STA_PLINK_STATE: The state of a mesh peer link as |
977 | * userspace is driving the peer link management state machine. | 977 | * defined in &enum nl80211_plink_state. Used when userspace is |
978 | * @NL80211_MESH_SETUP_USERSPACE_AMPE must be enabled. | 978 | * driving the peer link management state machine. |
979 | * @NL80211_MESH_SETUP_USERSPACE_AMPE must be enabled. | ||
979 | * | 980 | * |
980 | * @NL80211_ATTR_WOWLAN_SUPPORTED: indicates, as part of the wiphy capabilities, | 981 | * @NL80211_ATTR_WOWLAN_SUPPORTED: indicates, as part of the wiphy capabilities, |
981 | * the supported WoWLAN triggers | 982 | * the supported WoWLAN triggers |
@@ -1396,6 +1397,7 @@ enum nl80211_sta_bss_param { | |||
1396 | * @NL80211_STA_INFO_LLID: the station's mesh LLID | 1397 | * @NL80211_STA_INFO_LLID: the station's mesh LLID |
1397 | * @NL80211_STA_INFO_PLID: the station's mesh PLID | 1398 | * @NL80211_STA_INFO_PLID: the station's mesh PLID |
1398 | * @NL80211_STA_INFO_PLINK_STATE: peer link state for the station | 1399 | * @NL80211_STA_INFO_PLINK_STATE: peer link state for the station |
1400 | * (see %enum nl80211_plink_state) | ||
1399 | * @NL80211_STA_INFO_RX_BITRATE: last unicast data frame rx rate, nested | 1401 | * @NL80211_STA_INFO_RX_BITRATE: last unicast data frame rx rate, nested |
1400 | * attribute, like NL80211_STA_INFO_TX_BITRATE. | 1402 | * attribute, like NL80211_STA_INFO_TX_BITRATE. |
1401 | * @NL80211_STA_INFO_BSS_PARAM: current station's view of BSS, nested attribute | 1403 | * @NL80211_STA_INFO_BSS_PARAM: current station's view of BSS, nested attribute |
@@ -2326,4 +2328,37 @@ enum nl80211_if_combination_attrs { | |||
2326 | MAX_NL80211_IFACE_COMB = NUM_NL80211_IFACE_COMB - 1 | 2328 | MAX_NL80211_IFACE_COMB = NUM_NL80211_IFACE_COMB - 1 |
2327 | }; | 2329 | }; |
2328 | 2330 | ||
2331 | |||
2332 | /** | ||
2333 | * enum nl80211_plink_state - state of a mesh peer link finite state machine | ||
2334 | * | ||
2335 | * @NL80211_PLINK_LISTEN: initial state, considered the implicit | ||
2336 | * state of non existant mesh peer links | ||
2337 | * @NL80211_PLINK_OPN_SNT: mesh plink open frame has been sent to | ||
2338 | * this mesh peer | ||
2339 | * @NL80211_PLINK_OPN_RCVD: mesh plink open frame has been received | ||
2340 | * from this mesh peer | ||
2341 | * @NL80211_PLINK_CNF_RCVD: mesh plink confirm frame has been | ||
2342 | * received from this mesh peer | ||
2343 | * @NL80211_PLINK_ESTAB: mesh peer link is established | ||
2344 | * @NL80211_PLINK_HOLDING: mesh peer link is being closed or cancelled | ||
2345 | * @NL80211_PLINK_BLOCKED: all frames transmitted from this mesh | ||
2346 | * plink are discarded | ||
2347 | * @NUM_NL80211_PLINK_STATES: number of peer link states | ||
2348 | * @MAX_NL80211_PLINK_STATES: highest numerical value of plink states | ||
2349 | */ | ||
2350 | enum nl80211_plink_state { | ||
2351 | NL80211_PLINK_LISTEN, | ||
2352 | NL80211_PLINK_OPN_SNT, | ||
2353 | NL80211_PLINK_OPN_RCVD, | ||
2354 | NL80211_PLINK_CNF_RCVD, | ||
2355 | NL80211_PLINK_ESTAB, | ||
2356 | NL80211_PLINK_HOLDING, | ||
2357 | NL80211_PLINK_BLOCKED, | ||
2358 | |||
2359 | /* keep last */ | ||
2360 | NUM_NL80211_PLINK_STATES, | ||
2361 | MAX_NL80211_PLINK_STATES = NUM_NL80211_PLINK_STATES - 1 | ||
2362 | }; | ||
2363 | |||
2329 | #endif /* __LINUX_NL80211_H */ | 2364 | #endif /* __LINUX_NL80211_H */ |
diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h index 04afcfb9eaf4..0a2d795d35de 100644 --- a/include/net/cfg80211.h +++ b/include/net/cfg80211.h | |||
@@ -372,33 +372,6 @@ enum plink_actions { | |||
372 | }; | 372 | }; |
373 | 373 | ||
374 | /** | 374 | /** |
375 | * enum plink_states - state of a mesh peer link finite state machine | ||
376 | * | ||
377 | * @PLINK_LISTEN: initial state, considered the implicit state of non | ||
378 | * existant mesh peer links | ||
379 | * @PLINK_OPN_SNT: mesh plink open frame has been sent to this mesh | ||
380 | * peer @PLINK_OPN_RCVD: mesh plink open frame has been received from | ||
381 | * this mesh peer | ||
382 | * @PLINK_CNF_RCVD: mesh plink confirm frame has been received from | ||
383 | * this mesh peer | ||
384 | * @PLINK_ESTAB: mesh peer link is established | ||
385 | * @PLINK_HOLDING: mesh peer link is being closed or cancelled | ||
386 | * @PLINK_BLOCKED: all frames transmitted from this mesh plink are | ||
387 | * discarded | ||
388 | * @PLINK_INVALID: reserved | ||
389 | */ | ||
390 | enum plink_state { | ||
391 | PLINK_LISTEN, | ||
392 | PLINK_OPN_SNT, | ||
393 | PLINK_OPN_RCVD, | ||
394 | PLINK_CNF_RCVD, | ||
395 | PLINK_ESTAB, | ||
396 | PLINK_HOLDING, | ||
397 | PLINK_BLOCKED, | ||
398 | PLINK_INVALID, | ||
399 | }; | ||
400 | |||
401 | /** | ||
402 | * struct station_parameters - station parameters | 375 | * struct station_parameters - station parameters |
403 | * | 376 | * |
404 | * Used to change and create a new station. | 377 | * Used to change and create a new station. |
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index 6ecd5862735d..be70c70d3f5b 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c | |||
@@ -730,9 +730,9 @@ static void sta_apply_parameters(struct ieee80211_local *local, | |||
730 | #ifdef CONFIG_MAC80211_MESH | 730 | #ifdef CONFIG_MAC80211_MESH |
731 | if (sdata->u.mesh.security & IEEE80211_MESH_SEC_SECURED) | 731 | if (sdata->u.mesh.security & IEEE80211_MESH_SEC_SECURED) |
732 | switch (params->plink_state) { | 732 | switch (params->plink_state) { |
733 | case PLINK_LISTEN: | 733 | case NL80211_PLINK_LISTEN: |
734 | case PLINK_ESTAB: | 734 | case NL80211_PLINK_ESTAB: |
735 | case PLINK_BLOCKED: | 735 | case NL80211_PLINK_BLOCKED: |
736 | sta->plink_state = params->plink_state; | 736 | sta->plink_state = params->plink_state; |
737 | break; | 737 | break; |
738 | default: | 738 | default: |
diff --git a/net/mac80211/mesh_plink.c b/net/mac80211/mesh_plink.c index 2c37bee3095a..f4adc0917888 100644 --- a/net/mac80211/mesh_plink.c +++ b/net/mac80211/mesh_plink.c | |||
@@ -83,7 +83,7 @@ void mesh_plink_dec_estab_count(struct ieee80211_sub_if_data *sdata) | |||
83 | */ | 83 | */ |
84 | static inline void mesh_plink_fsm_restart(struct sta_info *sta) | 84 | static inline void mesh_plink_fsm_restart(struct sta_info *sta) |
85 | { | 85 | { |
86 | sta->plink_state = PLINK_LISTEN; | 86 | sta->plink_state = NL80211_PLINK_LISTEN; |
87 | sta->llid = sta->plid = sta->reason = 0; | 87 | sta->llid = sta->plid = sta->reason = 0; |
88 | sta->plink_retries = 0; | 88 | sta->plink_retries = 0; |
89 | } | 89 | } |
@@ -126,11 +126,11 @@ static bool __mesh_plink_deactivate(struct sta_info *sta) | |||
126 | struct ieee80211_sub_if_data *sdata = sta->sdata; | 126 | struct ieee80211_sub_if_data *sdata = sta->sdata; |
127 | bool deactivated = false; | 127 | bool deactivated = false; |
128 | 128 | ||
129 | if (sta->plink_state == PLINK_ESTAB) { | 129 | if (sta->plink_state == NL80211_PLINK_ESTAB) { |
130 | mesh_plink_dec_estab_count(sdata); | 130 | mesh_plink_dec_estab_count(sdata); |
131 | deactivated = true; | 131 | deactivated = true; |
132 | } | 132 | } |
133 | sta->plink_state = PLINK_BLOCKED; | 133 | sta->plink_state = NL80211_PLINK_BLOCKED; |
134 | mesh_path_flush_by_nexthop(sta); | 134 | mesh_path_flush_by_nexthop(sta); |
135 | 135 | ||
136 | return deactivated; | 136 | return deactivated; |
@@ -268,7 +268,7 @@ void mesh_neighbour_update(u8 *hw_addr, u32 rates, | |||
268 | sta->last_rx = jiffies; | 268 | sta->last_rx = jiffies; |
269 | sta->sta.supp_rates[local->hw.conf.channel->band] = rates; | 269 | sta->sta.supp_rates[local->hw.conf.channel->band] = rates; |
270 | if (mesh_peer_accepts_plinks(elems) && | 270 | if (mesh_peer_accepts_plinks(elems) && |
271 | sta->plink_state == PLINK_LISTEN && | 271 | sta->plink_state == NL80211_PLINK_LISTEN && |
272 | sdata->u.mesh.accepting_plinks && | 272 | sdata->u.mesh.accepting_plinks && |
273 | sdata->u.mesh.mshcfg.auto_open_plinks) | 273 | sdata->u.mesh.mshcfg.auto_open_plinks) |
274 | mesh_plink_open(sta); | 274 | mesh_plink_open(sta); |
@@ -308,8 +308,8 @@ static void mesh_plink_timer(unsigned long data) | |||
308 | sdata = sta->sdata; | 308 | sdata = sta->sdata; |
309 | 309 | ||
310 | switch (sta->plink_state) { | 310 | switch (sta->plink_state) { |
311 | case PLINK_OPN_RCVD: | 311 | case NL80211_PLINK_OPN_RCVD: |
312 | case PLINK_OPN_SNT: | 312 | case NL80211_PLINK_OPN_SNT: |
313 | /* retry timer */ | 313 | /* retry timer */ |
314 | if (sta->plink_retries < dot11MeshMaxRetries(sdata)) { | 314 | if (sta->plink_retries < dot11MeshMaxRetries(sdata)) { |
315 | u32 rand; | 315 | u32 rand; |
@@ -328,17 +328,17 @@ static void mesh_plink_timer(unsigned long data) | |||
328 | } | 328 | } |
329 | reason = cpu_to_le16(MESH_MAX_RETRIES); | 329 | reason = cpu_to_le16(MESH_MAX_RETRIES); |
330 | /* fall through on else */ | 330 | /* fall through on else */ |
331 | case PLINK_CNF_RCVD: | 331 | case NL80211_PLINK_CNF_RCVD: |
332 | /* confirm timer */ | 332 | /* confirm timer */ |
333 | if (!reason) | 333 | if (!reason) |
334 | reason = cpu_to_le16(MESH_CONFIRM_TIMEOUT); | 334 | reason = cpu_to_le16(MESH_CONFIRM_TIMEOUT); |
335 | sta->plink_state = PLINK_HOLDING; | 335 | sta->plink_state = NL80211_PLINK_HOLDING; |
336 | mod_plink_timer(sta, dot11MeshHoldingTimeout(sdata)); | 336 | mod_plink_timer(sta, dot11MeshHoldingTimeout(sdata)); |
337 | spin_unlock_bh(&sta->lock); | 337 | spin_unlock_bh(&sta->lock); |
338 | mesh_plink_frame_tx(sdata, PLINK_CLOSE, sta->sta.addr, llid, plid, | 338 | mesh_plink_frame_tx(sdata, PLINK_CLOSE, sta->sta.addr, llid, plid, |
339 | reason); | 339 | reason); |
340 | break; | 340 | break; |
341 | case PLINK_HOLDING: | 341 | case NL80211_PLINK_HOLDING: |
342 | /* holding timer */ | 342 | /* holding timer */ |
343 | del_timer(&sta->plink_timer); | 343 | del_timer(&sta->plink_timer); |
344 | mesh_plink_fsm_restart(sta); | 344 | mesh_plink_fsm_restart(sta); |
@@ -386,11 +386,11 @@ int mesh_plink_open(struct sta_info *sta) | |||
386 | spin_lock_bh(&sta->lock); | 386 | spin_lock_bh(&sta->lock); |
387 | get_random_bytes(&llid, 2); | 387 | get_random_bytes(&llid, 2); |
388 | sta->llid = llid; | 388 | sta->llid = llid; |
389 | if (sta->plink_state != PLINK_LISTEN) { | 389 | if (sta->plink_state != NL80211_PLINK_LISTEN) { |
390 | spin_unlock_bh(&sta->lock); | 390 | spin_unlock_bh(&sta->lock); |
391 | return -EBUSY; | 391 | return -EBUSY; |
392 | } | 392 | } |
393 | sta->plink_state = PLINK_OPN_SNT; | 393 | sta->plink_state = NL80211_PLINK_OPN_SNT; |
394 | mesh_plink_timer_set(sta, dot11MeshRetryTimeout(sdata)); | 394 | mesh_plink_timer_set(sta, dot11MeshRetryTimeout(sdata)); |
395 | spin_unlock_bh(&sta->lock); | 395 | spin_unlock_bh(&sta->lock); |
396 | mpl_dbg("Mesh plink: starting establishment with %pM\n", | 396 | mpl_dbg("Mesh plink: starting establishment with %pM\n", |
@@ -407,7 +407,7 @@ void mesh_plink_block(struct sta_info *sta) | |||
407 | 407 | ||
408 | spin_lock_bh(&sta->lock); | 408 | spin_lock_bh(&sta->lock); |
409 | deactivated = __mesh_plink_deactivate(sta); | 409 | deactivated = __mesh_plink_deactivate(sta); |
410 | sta->plink_state = PLINK_BLOCKED; | 410 | sta->plink_state = NL80211_PLINK_BLOCKED; |
411 | spin_unlock_bh(&sta->lock); | 411 | spin_unlock_bh(&sta->lock); |
412 | 412 | ||
413 | if (deactivated) | 413 | if (deactivated) |
@@ -430,13 +430,13 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
430 | __le16 plid, llid, reason; | 430 | __le16 plid, llid, reason; |
431 | #ifdef CONFIG_MAC80211_VERBOSE_MPL_DEBUG | 431 | #ifdef CONFIG_MAC80211_VERBOSE_MPL_DEBUG |
432 | static const char *mplstates[] = { | 432 | static const char *mplstates[] = { |
433 | [PLINK_LISTEN] = "LISTEN", | 433 | [NL80211_PLINK_LISTEN] = "LISTEN", |
434 | [PLINK_OPN_SNT] = "OPN-SNT", | 434 | [NL80211_PLINK_OPN_SNT] = "OPN-SNT", |
435 | [PLINK_OPN_RCVD] = "OPN-RCVD", | 435 | [NL80211_PLINK_OPN_RCVD] = "OPN-RCVD", |
436 | [PLINK_CNF_RCVD] = "CNF_RCVD", | 436 | [NL80211_PLINK_CNF_RCVD] = "CNF_RCVD", |
437 | [PLINK_ESTAB] = "ESTAB", | 437 | [NL80211_PLINK_ESTAB] = "ESTAB", |
438 | [PLINK_HOLDING] = "HOLDING", | 438 | [NL80211_PLINK_HOLDING] = "HOLDING", |
439 | [PLINK_BLOCKED] = "BLOCKED" | 439 | [NL80211_PLINK_BLOCKED] = "BLOCKED" |
440 | }; | 440 | }; |
441 | #endif | 441 | #endif |
442 | 442 | ||
@@ -502,7 +502,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
502 | return; | 502 | return; |
503 | } | 503 | } |
504 | 504 | ||
505 | if (sta && sta->plink_state == PLINK_BLOCKED) { | 505 | if (sta && sta->plink_state == NL80211_PLINK_BLOCKED) { |
506 | rcu_read_unlock(); | 506 | rcu_read_unlock(); |
507 | return; | 507 | return; |
508 | } | 508 | } |
@@ -572,7 +572,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
572 | event = CNF_ACPT; | 572 | event = CNF_ACPT; |
573 | break; | 573 | break; |
574 | case PLINK_CLOSE: | 574 | case PLINK_CLOSE: |
575 | if (sta->plink_state == PLINK_ESTAB) | 575 | if (sta->plink_state == NL80211_PLINK_ESTAB) |
576 | /* Do not check for llid or plid. This does not | 576 | /* Do not check for llid or plid. This does not |
577 | * follow the standard but since multiple plinks | 577 | * follow the standard but since multiple plinks |
578 | * per sta are not supported, it is necessary in | 578 | * per sta are not supported, it is necessary in |
@@ -607,14 +607,14 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
607 | reason = 0; | 607 | reason = 0; |
608 | switch (sta->plink_state) { | 608 | switch (sta->plink_state) { |
609 | /* spin_unlock as soon as state is updated at each case */ | 609 | /* spin_unlock as soon as state is updated at each case */ |
610 | case PLINK_LISTEN: | 610 | case NL80211_PLINK_LISTEN: |
611 | switch (event) { | 611 | switch (event) { |
612 | case CLS_ACPT: | 612 | case CLS_ACPT: |
613 | mesh_plink_fsm_restart(sta); | 613 | mesh_plink_fsm_restart(sta); |
614 | spin_unlock_bh(&sta->lock); | 614 | spin_unlock_bh(&sta->lock); |
615 | break; | 615 | break; |
616 | case OPN_ACPT: | 616 | case OPN_ACPT: |
617 | sta->plink_state = PLINK_OPN_RCVD; | 617 | sta->plink_state = NL80211_PLINK_OPN_RCVD; |
618 | sta->plid = plid; | 618 | sta->plid = plid; |
619 | get_random_bytes(&llid, 2); | 619 | get_random_bytes(&llid, 2); |
620 | sta->llid = llid; | 620 | sta->llid = llid; |
@@ -631,7 +631,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
631 | } | 631 | } |
632 | break; | 632 | break; |
633 | 633 | ||
634 | case PLINK_OPN_SNT: | 634 | case NL80211_PLINK_OPN_SNT: |
635 | switch (event) { | 635 | switch (event) { |
636 | case OPN_RJCT: | 636 | case OPN_RJCT: |
637 | case CNF_RJCT: | 637 | case CNF_RJCT: |
@@ -640,7 +640,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
640 | if (!reason) | 640 | if (!reason) |
641 | reason = cpu_to_le16(MESH_CLOSE_RCVD); | 641 | reason = cpu_to_le16(MESH_CLOSE_RCVD); |
642 | sta->reason = reason; | 642 | sta->reason = reason; |
643 | sta->plink_state = PLINK_HOLDING; | 643 | sta->plink_state = NL80211_PLINK_HOLDING; |
644 | if (!mod_plink_timer(sta, | 644 | if (!mod_plink_timer(sta, |
645 | dot11MeshHoldingTimeout(sdata))) | 645 | dot11MeshHoldingTimeout(sdata))) |
646 | sta->ignore_plink_timer = true; | 646 | sta->ignore_plink_timer = true; |
@@ -652,7 +652,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
652 | break; | 652 | break; |
653 | case OPN_ACPT: | 653 | case OPN_ACPT: |
654 | /* retry timer is left untouched */ | 654 | /* retry timer is left untouched */ |
655 | sta->plink_state = PLINK_OPN_RCVD; | 655 | sta->plink_state = NL80211_PLINK_OPN_RCVD; |
656 | sta->plid = plid; | 656 | sta->plid = plid; |
657 | llid = sta->llid; | 657 | llid = sta->llid; |
658 | spin_unlock_bh(&sta->lock); | 658 | spin_unlock_bh(&sta->lock); |
@@ -660,7 +660,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
660 | plid, 0); | 660 | plid, 0); |
661 | break; | 661 | break; |
662 | case CNF_ACPT: | 662 | case CNF_ACPT: |
663 | sta->plink_state = PLINK_CNF_RCVD; | 663 | sta->plink_state = NL80211_PLINK_CNF_RCVD; |
664 | if (!mod_plink_timer(sta, | 664 | if (!mod_plink_timer(sta, |
665 | dot11MeshConfirmTimeout(sdata))) | 665 | dot11MeshConfirmTimeout(sdata))) |
666 | sta->ignore_plink_timer = true; | 666 | sta->ignore_plink_timer = true; |
@@ -673,7 +673,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
673 | } | 673 | } |
674 | break; | 674 | break; |
675 | 675 | ||
676 | case PLINK_OPN_RCVD: | 676 | case NL80211_PLINK_OPN_RCVD: |
677 | switch (event) { | 677 | switch (event) { |
678 | case OPN_RJCT: | 678 | case OPN_RJCT: |
679 | case CNF_RJCT: | 679 | case CNF_RJCT: |
@@ -682,7 +682,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
682 | if (!reason) | 682 | if (!reason) |
683 | reason = cpu_to_le16(MESH_CLOSE_RCVD); | 683 | reason = cpu_to_le16(MESH_CLOSE_RCVD); |
684 | sta->reason = reason; | 684 | sta->reason = reason; |
685 | sta->plink_state = PLINK_HOLDING; | 685 | sta->plink_state = NL80211_PLINK_HOLDING; |
686 | if (!mod_plink_timer(sta, | 686 | if (!mod_plink_timer(sta, |
687 | dot11MeshHoldingTimeout(sdata))) | 687 | dot11MeshHoldingTimeout(sdata))) |
688 | sta->ignore_plink_timer = true; | 688 | sta->ignore_plink_timer = true; |
@@ -700,7 +700,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
700 | break; | 700 | break; |
701 | case CNF_ACPT: | 701 | case CNF_ACPT: |
702 | del_timer(&sta->plink_timer); | 702 | del_timer(&sta->plink_timer); |
703 | sta->plink_state = PLINK_ESTAB; | 703 | sta->plink_state = NL80211_PLINK_ESTAB; |
704 | spin_unlock_bh(&sta->lock); | 704 | spin_unlock_bh(&sta->lock); |
705 | mesh_plink_inc_estab_count(sdata); | 705 | mesh_plink_inc_estab_count(sdata); |
706 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON); | 706 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON); |
@@ -713,7 +713,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
713 | } | 713 | } |
714 | break; | 714 | break; |
715 | 715 | ||
716 | case PLINK_CNF_RCVD: | 716 | case NL80211_PLINK_CNF_RCVD: |
717 | switch (event) { | 717 | switch (event) { |
718 | case OPN_RJCT: | 718 | case OPN_RJCT: |
719 | case CNF_RJCT: | 719 | case CNF_RJCT: |
@@ -722,7 +722,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
722 | if (!reason) | 722 | if (!reason) |
723 | reason = cpu_to_le16(MESH_CLOSE_RCVD); | 723 | reason = cpu_to_le16(MESH_CLOSE_RCVD); |
724 | sta->reason = reason; | 724 | sta->reason = reason; |
725 | sta->plink_state = PLINK_HOLDING; | 725 | sta->plink_state = NL80211_PLINK_HOLDING; |
726 | if (!mod_plink_timer(sta, | 726 | if (!mod_plink_timer(sta, |
727 | dot11MeshHoldingTimeout(sdata))) | 727 | dot11MeshHoldingTimeout(sdata))) |
728 | sta->ignore_plink_timer = true; | 728 | sta->ignore_plink_timer = true; |
@@ -734,7 +734,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
734 | break; | 734 | break; |
735 | case OPN_ACPT: | 735 | case OPN_ACPT: |
736 | del_timer(&sta->plink_timer); | 736 | del_timer(&sta->plink_timer); |
737 | sta->plink_state = PLINK_ESTAB; | 737 | sta->plink_state = NL80211_PLINK_ESTAB; |
738 | spin_unlock_bh(&sta->lock); | 738 | spin_unlock_bh(&sta->lock); |
739 | mesh_plink_inc_estab_count(sdata); | 739 | mesh_plink_inc_estab_count(sdata); |
740 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON); | 740 | ieee80211_bss_info_change_notify(sdata, BSS_CHANGED_BEACON); |
@@ -749,13 +749,13 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
749 | } | 749 | } |
750 | break; | 750 | break; |
751 | 751 | ||
752 | case PLINK_ESTAB: | 752 | case NL80211_PLINK_ESTAB: |
753 | switch (event) { | 753 | switch (event) { |
754 | case CLS_ACPT: | 754 | case CLS_ACPT: |
755 | reason = cpu_to_le16(MESH_CLOSE_RCVD); | 755 | reason = cpu_to_le16(MESH_CLOSE_RCVD); |
756 | sta->reason = reason; | 756 | sta->reason = reason; |
757 | deactivated = __mesh_plink_deactivate(sta); | 757 | deactivated = __mesh_plink_deactivate(sta); |
758 | sta->plink_state = PLINK_HOLDING; | 758 | sta->plink_state = NL80211_PLINK_HOLDING; |
759 | llid = sta->llid; | 759 | llid = sta->llid; |
760 | mod_plink_timer(sta, dot11MeshHoldingTimeout(sdata)); | 760 | mod_plink_timer(sta, dot11MeshHoldingTimeout(sdata)); |
761 | spin_unlock_bh(&sta->lock); | 761 | spin_unlock_bh(&sta->lock); |
@@ -775,7 +775,7 @@ void mesh_rx_plink_frame(struct ieee80211_sub_if_data *sdata, struct ieee80211_m | |||
775 | break; | 775 | break; |
776 | } | 776 | } |
777 | break; | 777 | break; |
778 | case PLINK_HOLDING: | 778 | case NL80211_PLINK_HOLDING: |
779 | switch (event) { | 779 | switch (event) { |
780 | case CLS_ACPT: | 780 | case CLS_ACPT: |
781 | if (del_timer(&sta->plink_timer)) | 781 | if (del_timer(&sta->plink_timer)) |
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index 1b9413fb3839..3a9515cb7ce1 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
@@ -490,7 +490,7 @@ ieee80211_rx_mesh_check(struct ieee80211_rx_data *rx) | |||
490 | * establisment frame, beacon or probe, drop the frame. | 490 | * establisment frame, beacon or probe, drop the frame. |
491 | */ | 491 | */ |
492 | 492 | ||
493 | if (!rx->sta || sta_plink_state(rx->sta) != PLINK_ESTAB) { | 493 | if (!rx->sta || sta_plink_state(rx->sta) != NL80211_PLINK_ESTAB) { |
494 | struct ieee80211_mgmt *mgmt; | 494 | struct ieee80211_mgmt *mgmt; |
495 | 495 | ||
496 | if (!ieee80211_is_mgmt(hdr->frame_control)) | 496 | if (!ieee80211_is_mgmt(hdr->frame_control)) |
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c index 82ab6b4643fc..4a15f9603562 100644 --- a/net/mac80211/sta_info.c +++ b/net/mac80211/sta_info.c | |||
@@ -277,7 +277,7 @@ struct sta_info *sta_info_alloc(struct ieee80211_sub_if_data *sdata, | |||
277 | #endif /* CONFIG_MAC80211_VERBOSE_DEBUG */ | 277 | #endif /* CONFIG_MAC80211_VERBOSE_DEBUG */ |
278 | 278 | ||
279 | #ifdef CONFIG_MAC80211_MESH | 279 | #ifdef CONFIG_MAC80211_MESH |
280 | sta->plink_state = PLINK_LISTEN; | 280 | sta->plink_state = NL80211_PLINK_LISTEN; |
281 | init_timer(&sta->plink_timer); | 281 | init_timer(&sta->plink_timer); |
282 | #endif | 282 | #endif |
283 | 283 | ||
diff --git a/net/mac80211/sta_info.h b/net/mac80211/sta_info.h index d6b566076f05..c6ae8718bd57 100644 --- a/net/mac80211/sta_info.h +++ b/net/mac80211/sta_info.h | |||
@@ -318,7 +318,7 @@ struct sta_info { | |||
318 | u8 plink_retries; | 318 | u8 plink_retries; |
319 | bool ignore_plink_timer; | 319 | bool ignore_plink_timer; |
320 | bool plink_timer_was_running; | 320 | bool plink_timer_was_running; |
321 | enum plink_state plink_state; | 321 | enum nl80211_plink_state plink_state; |
322 | u32 plink_timeout; | 322 | u32 plink_timeout; |
323 | struct timer_list plink_timer; | 323 | struct timer_list plink_timer; |
324 | #endif | 324 | #endif |
@@ -336,12 +336,12 @@ struct sta_info { | |||
336 | struct ieee80211_sta sta; | 336 | struct ieee80211_sta sta; |
337 | }; | 337 | }; |
338 | 338 | ||
339 | static inline enum plink_state sta_plink_state(struct sta_info *sta) | 339 | static inline enum nl80211_plink_state sta_plink_state(struct sta_info *sta) |
340 | { | 340 | { |
341 | #ifdef CONFIG_MAC80211_MESH | 341 | #ifdef CONFIG_MAC80211_MESH |
342 | return sta->plink_state; | 342 | return sta->plink_state; |
343 | #endif | 343 | #endif |
344 | return PLINK_LISTEN; | 344 | return NL80211_PLINK_LISTEN; |
345 | } | 345 | } |
346 | 346 | ||
347 | static inline void set_sta_flags(struct sta_info *sta, const u32 flags) | 347 | static inline void set_sta_flags(struct sta_info *sta, const u32 flags) |
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index beac296b1fde..2222ce08ee91 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c | |||
@@ -2335,7 +2335,7 @@ static int nl80211_set_station(struct sk_buff *skb, struct genl_info *info) | |||
2335 | memset(¶ms, 0, sizeof(params)); | 2335 | memset(¶ms, 0, sizeof(params)); |
2336 | 2336 | ||
2337 | params.listen_interval = -1; | 2337 | params.listen_interval = -1; |
2338 | params.plink_state = PLINK_INVALID; | 2338 | params.plink_state = -1; |
2339 | 2339 | ||
2340 | if (info->attrs[NL80211_ATTR_STA_AID]) | 2340 | if (info->attrs[NL80211_ATTR_STA_AID]) |
2341 | return -EINVAL; | 2341 | return -EINVAL; |