diff options
author | Alina Friedrichsen <x-alina@gmx.net> | 2009-02-20 19:27:29 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-02-27 14:52:54 -0500 |
commit | 79f6440c527c61bcd84edfbdeb390841b9fe5095 (patch) | |
tree | 90d86bb64fade58b3acdc8b5954b9e9148c963bd /net/mac80211/ibss.c | |
parent | 5f9724dd94d63e26edb02d9f6a4ce1ce35737f14 (diff) |
mac80211: Introduce a generic commit() to apply changes
This patch introduces a generic commit() function which initiate a
new network joining process. It should be called after some interface
config changes, so that the changes get applied more cleanly. Currently
set_ssid() and set_bssid() call it. Others can be added in future
patches.
In version 1 the header files was forgotten, sorry.
Signed-off-by: Alina Friedrichsen <x-alina@gmx.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/ibss.c')
-rw-r--r-- | net/mac80211/ibss.c | 30 |
1 files changed, 19 insertions, 11 deletions
diff --git a/net/mac80211/ibss.c b/net/mac80211/ibss.c index 1bbfc7029879..aa8937c56285 100644 --- a/net/mac80211/ibss.c +++ b/net/mac80211/ibss.c | |||
@@ -788,6 +788,23 @@ void ieee80211_ibss_setup_sdata(struct ieee80211_sub_if_data *sdata) | |||
788 | IEEE80211_IBSS_AUTO_CHANNEL_SEL; | 788 | IEEE80211_IBSS_AUTO_CHANNEL_SEL; |
789 | } | 789 | } |
790 | 790 | ||
791 | int ieee80211_ibss_commit(struct ieee80211_sub_if_data *sdata) | ||
792 | { | ||
793 | struct ieee80211_if_ibss *ifibss = &sdata->u.ibss; | ||
794 | |||
795 | ifibss->flags &= ~IEEE80211_IBSS_PREV_BSSID_SET; | ||
796 | |||
797 | if (ifibss->ssid_len) | ||
798 | ifibss->flags |= IEEE80211_IBSS_SSID_SET; | ||
799 | else | ||
800 | ifibss->flags &= ~IEEE80211_IBSS_SSID_SET; | ||
801 | |||
802 | ifibss->ibss_join_req = jiffies; | ||
803 | ifibss->state = IEEE80211_IBSS_MLME_SEARCH; | ||
804 | |||
805 | return ieee80211_sta_find_ibss(sdata); | ||
806 | } | ||
807 | |||
791 | int ieee80211_ibss_set_ssid(struct ieee80211_sub_if_data *sdata, char *ssid, size_t len) | 808 | int ieee80211_ibss_set_ssid(struct ieee80211_sub_if_data *sdata, char *ssid, size_t len) |
792 | { | 809 | { |
793 | struct ieee80211_if_ibss *ifibss = &sdata->u.ibss; | 810 | struct ieee80211_if_ibss *ifibss = &sdata->u.ibss; |
@@ -801,16 +818,7 @@ int ieee80211_ibss_set_ssid(struct ieee80211_sub_if_data *sdata, char *ssid, siz | |||
801 | ifibss->ssid_len = len; | 818 | ifibss->ssid_len = len; |
802 | } | 819 | } |
803 | 820 | ||
804 | ifibss->flags &= ~IEEE80211_IBSS_PREV_BSSID_SET; | 821 | return ieee80211_ibss_commit(sdata); |
805 | |||
806 | if (len) | ||
807 | ifibss->flags |= IEEE80211_IBSS_SSID_SET; | ||
808 | else | ||
809 | ifibss->flags &= ~IEEE80211_IBSS_SSID_SET; | ||
810 | |||
811 | ifibss->ibss_join_req = jiffies; | ||
812 | ifibss->state = IEEE80211_IBSS_MLME_SEARCH; | ||
813 | return ieee80211_sta_find_ibss(sdata); | ||
814 | } | 822 | } |
815 | 823 | ||
816 | int ieee80211_ibss_get_ssid(struct ieee80211_sub_if_data *sdata, char *ssid, size_t *len) | 824 | int ieee80211_ibss_get_ssid(struct ieee80211_sub_if_data *sdata, char *ssid, size_t *len) |
@@ -842,7 +850,7 @@ int ieee80211_ibss_set_bssid(struct ieee80211_sub_if_data *sdata, u8 *bssid) | |||
842 | } | 850 | } |
843 | } | 851 | } |
844 | 852 | ||
845 | return ieee80211_ibss_set_ssid(sdata, ifibss->ssid, ifibss->ssid_len); | 853 | return ieee80211_ibss_commit(sdata); |
846 | } | 854 | } |
847 | 855 | ||
848 | /* scan finished notification */ | 856 | /* scan finished notification */ |