diff options
| author | Jiri Kosina <jkosina@suse.cz> | 2011-04-26 04:22:15 -0400 | 
|---|---|---|
| committer | Jiri Kosina <jkosina@suse.cz> | 2011-04-26 04:22:59 -0400 | 
| commit | 07f9479a40cc778bc1462ada11f95b01360ae4ff (patch) | |
| tree | 0676cf38df3844004bb3ebfd99dfa67a4a8998f5 /net/wireless | |
| parent | 9d5e6bdb3013acfb311ab407eeca0b6a6a3dedbf (diff) | |
| parent | cd2e49e90f1cae7726c9a2c54488d881d7f1cd1c (diff) | |
Merge branch 'master' into for-next
Fast-forwarded to current state of Linus' tree as there are patches to be
applied for files that didn't exist on the old branch.
Diffstat (limited to 'net/wireless')
| -rw-r--r-- | net/wireless/reg.c | 4 | ||||
| -rw-r--r-- | net/wireless/scan.c | 31 | 
2 files changed, 23 insertions, 12 deletions
| diff --git a/net/wireless/reg.c b/net/wireless/reg.c index 3332d5bce317..ab801a1097b2 100644 --- a/net/wireless/reg.c +++ b/net/wireless/reg.c | |||
| @@ -809,7 +809,7 @@ static void handle_channel(struct wiphy *wiphy, | |||
| 809 | if (r) { | 809 | if (r) { | 
| 810 | /* | 810 | /* | 
| 811 | * We will disable all channels that do not match our | 811 | * We will disable all channels that do not match our | 
| 812 | * recieved regulatory rule unless the hint is coming | 812 | * received regulatory rule unless the hint is coming | 
| 813 | * from a Country IE and the Country IE had no information | 813 | * from a Country IE and the Country IE had no information | 
| 814 | * about a band. The IEEE 802.11 spec allows for an AP | 814 | * about a band. The IEEE 802.11 spec allows for an AP | 
| 815 | * to send only a subset of the regulatory rules allowed, | 815 | * to send only a subset of the regulatory rules allowed, | 
| @@ -838,7 +838,7 @@ static void handle_channel(struct wiphy *wiphy, | |||
| 838 | request_wiphy && request_wiphy == wiphy && | 838 | request_wiphy && request_wiphy == wiphy && | 
| 839 | request_wiphy->flags & WIPHY_FLAG_STRICT_REGULATORY) { | 839 | request_wiphy->flags & WIPHY_FLAG_STRICT_REGULATORY) { | 
| 840 | /* | 840 | /* | 
| 841 | * This gaurantees the driver's requested regulatory domain | 841 | * This guarantees the driver's requested regulatory domain | 
| 842 | * will always be used as a base for further regulatory | 842 | * will always be used as a base for further regulatory | 
| 843 | * settings | 843 | * settings | 
| 844 | */ | 844 | */ | 
| diff --git a/net/wireless/scan.c b/net/wireless/scan.c index ea427f418f64..fbf6f33ae4d0 100644 --- a/net/wireless/scan.c +++ b/net/wireless/scan.c | |||
| @@ -124,6 +124,15 @@ void cfg80211_bss_age(struct cfg80211_registered_device *dev, | |||
| 124 | } | 124 | } | 
| 125 | 125 | ||
| 126 | /* must hold dev->bss_lock! */ | 126 | /* must hold dev->bss_lock! */ | 
| 127 | static void __cfg80211_unlink_bss(struct cfg80211_registered_device *dev, | ||
| 128 | struct cfg80211_internal_bss *bss) | ||
| 129 | { | ||
| 130 | list_del_init(&bss->list); | ||
| 131 | rb_erase(&bss->rbn, &dev->bss_tree); | ||
| 132 | kref_put(&bss->ref, bss_release); | ||
| 133 | } | ||
| 134 | |||
| 135 | /* must hold dev->bss_lock! */ | ||
| 127 | void cfg80211_bss_expire(struct cfg80211_registered_device *dev) | 136 | void cfg80211_bss_expire(struct cfg80211_registered_device *dev) | 
| 128 | { | 137 | { | 
| 129 | struct cfg80211_internal_bss *bss, *tmp; | 138 | struct cfg80211_internal_bss *bss, *tmp; | 
| @@ -134,9 +143,7 @@ void cfg80211_bss_expire(struct cfg80211_registered_device *dev) | |||
| 134 | continue; | 143 | continue; | 
| 135 | if (!time_after(jiffies, bss->ts + IEEE80211_SCAN_RESULT_EXPIRE)) | 144 | if (!time_after(jiffies, bss->ts + IEEE80211_SCAN_RESULT_EXPIRE)) | 
| 136 | continue; | 145 | continue; | 
| 137 | list_del(&bss->list); | 146 | __cfg80211_unlink_bss(dev, bss); | 
| 138 | rb_erase(&bss->rbn, &dev->bss_tree); | ||
| 139 | kref_put(&bss->ref, bss_release); | ||
| 140 | expired = true; | 147 | expired = true; | 
| 141 | } | 148 | } | 
| 142 | 149 | ||
| @@ -585,16 +592,23 @@ cfg80211_inform_bss_frame(struct wiphy *wiphy, | |||
| 585 | struct cfg80211_internal_bss *res; | 592 | struct cfg80211_internal_bss *res; | 
| 586 | size_t ielen = len - offsetof(struct ieee80211_mgmt, | 593 | size_t ielen = len - offsetof(struct ieee80211_mgmt, | 
| 587 | u.probe_resp.variable); | 594 | u.probe_resp.variable); | 
| 588 | size_t privsz = wiphy->bss_priv_size; | 595 | size_t privsz; | 
| 596 | |||
| 597 | if (WARN_ON(!mgmt)) | ||
| 598 | return NULL; | ||
| 599 | |||
| 600 | if (WARN_ON(!wiphy)) | ||
| 601 | return NULL; | ||
| 589 | 602 | ||
| 590 | if (WARN_ON(wiphy->signal_type == CFG80211_SIGNAL_TYPE_UNSPEC && | 603 | if (WARN_ON(wiphy->signal_type == CFG80211_SIGNAL_TYPE_UNSPEC && | 
| 591 | (signal < 0 || signal > 100))) | 604 | (signal < 0 || signal > 100))) | 
| 592 | return NULL; | 605 | return NULL; | 
| 593 | 606 | ||
| 594 | if (WARN_ON(!mgmt || !wiphy || | 607 | if (WARN_ON(len < offsetof(struct ieee80211_mgmt, u.probe_resp.variable))) | 
| 595 | len < offsetof(struct ieee80211_mgmt, u.probe_resp.variable))) | ||
| 596 | return NULL; | 608 | return NULL; | 
| 597 | 609 | ||
| 610 | privsz = wiphy->bss_priv_size; | ||
| 611 | |||
| 598 | res = kzalloc(sizeof(*res) + privsz + ielen, gfp); | 612 | res = kzalloc(sizeof(*res) + privsz + ielen, gfp); | 
| 599 | if (!res) | 613 | if (!res) | 
| 600 | return NULL; | 614 | return NULL; | 
| @@ -662,11 +676,8 @@ void cfg80211_unlink_bss(struct wiphy *wiphy, struct cfg80211_bss *pub) | |||
| 662 | 676 | ||
| 663 | spin_lock_bh(&dev->bss_lock); | 677 | spin_lock_bh(&dev->bss_lock); | 
| 664 | if (!list_empty(&bss->list)) { | 678 | if (!list_empty(&bss->list)) { | 
| 665 | list_del_init(&bss->list); | 679 | __cfg80211_unlink_bss(dev, bss); | 
| 666 | dev->bss_generation++; | 680 | dev->bss_generation++; | 
| 667 | rb_erase(&bss->rbn, &dev->bss_tree); | ||
| 668 | |||
| 669 | kref_put(&bss->ref, bss_release); | ||
| 670 | } | 681 | } | 
| 671 | spin_unlock_bh(&dev->bss_lock); | 682 | spin_unlock_bh(&dev->bss_lock); | 
| 672 | } | 683 | } | 
