nl80211: Tie connect handle to bss init/destroy
This commit creates a connect nl_sock * for every bss unconditionally. It is used in the next commit for nl80211 control port RX. Signed-off-by: Markus Theil <markus.theil@tu-ilmenau.de>
This commit is contained in:
parent
b4a70018ee
commit
8609aa5ba3
1 changed files with 6 additions and 5 deletions
|
@ -158,6 +158,7 @@ static void wpa_driver_nl80211_deinit(struct i802_bss *bss);
|
||||||
static int wpa_driver_nl80211_set_mode_ibss(struct i802_bss *bss,
|
static int wpa_driver_nl80211_set_mode_ibss(struct i802_bss *bss,
|
||||||
struct hostapd_freq_params *freq);
|
struct hostapd_freq_params *freq);
|
||||||
|
|
||||||
|
static int nl80211_init_connect_handle(struct i802_bss *bss);
|
||||||
static int
|
static int
|
||||||
wpa_driver_nl80211_finish_drv_init(struct wpa_driver_nl80211_data *drv,
|
wpa_driver_nl80211_finish_drv_init(struct wpa_driver_nl80211_data *drv,
|
||||||
const u8 *set_addr, int first,
|
const u8 *set_addr, int first,
|
||||||
|
@ -1928,6 +1929,8 @@ static int nl80211_init_bss(struct i802_bss *bss)
|
||||||
nl_cb_set(bss->nl_cb, NL_CB_VALID, NL_CB_CUSTOM,
|
nl_cb_set(bss->nl_cb, NL_CB_VALID, NL_CB_CUSTOM,
|
||||||
process_bss_event, bss);
|
process_bss_event, bss);
|
||||||
|
|
||||||
|
nl80211_init_connect_handle(bss);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1936,6 +1939,9 @@ static void nl80211_destroy_bss(struct i802_bss *bss)
|
||||||
{
|
{
|
||||||
nl_cb_put(bss->nl_cb);
|
nl_cb_put(bss->nl_cb);
|
||||||
bss->nl_cb = NULL;
|
bss->nl_cb = NULL;
|
||||||
|
|
||||||
|
if (bss->nl_connect)
|
||||||
|
nl80211_destroy_eloop_handle(&bss->nl_connect, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2715,8 +2721,6 @@ wpa_driver_nl80211_finish_drv_init(struct wpa_driver_nl80211_data *drv,
|
||||||
if (drv->vendor_cmd_test_avail)
|
if (drv->vendor_cmd_test_avail)
|
||||||
qca_vendor_test(drv);
|
qca_vendor_test(drv);
|
||||||
|
|
||||||
nl80211_init_connect_handle(bss);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2829,9 +2833,6 @@ static void wpa_driver_nl80211_deinit(struct i802_bss *bss)
|
||||||
nl80211_del_p2pdev(bss);
|
nl80211_del_p2pdev(bss);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bss->nl_connect)
|
|
||||||
nl80211_destroy_eloop_handle(&bss->nl_connect, 1);
|
|
||||||
|
|
||||||
nl80211_destroy_bss(drv->first_bss);
|
nl80211_destroy_bss(drv->first_bss);
|
||||||
|
|
||||||
os_free(drv->filter_ssids);
|
os_free(drv->filter_ssids);
|
||||||
|
|
Loading…
Reference in a new issue