struct dl_list interfaces;
int if_add_ifindex;
struct netlink_data *netlink;
+ struct nl_cb *nl_cb;
};
static void nl80211_global_deinit(void *priv);
int scan_complete_events;
struct nl80211_handles nl, nl_event, nl_preq;
- struct nl_cb *nl_cb;
struct genl_family *nl80211;
u8 auth_bssid[ETH_ALEN];
struct nl_cb *cb;
int err = -ENOMEM;
- cb = nl_cb_clone(drv->nl_cb);
+ cb = nl_cb_clone(drv->global->nl_cb);
if (!cb)
goto out;
wpa_printf(MSG_DEBUG, "nl80211: Event message available");
- cb = nl_cb_clone(drv->nl_cb);
+ cb = nl_cb_clone(drv->global->nl_cb);
if (!cb)
return;
nl_cb_set(cb, NL_CB_SEQ_CHECK, NL_CB_CUSTOM, no_seq_check, NULL);
}
+static int wpa_driver_nl80211_init_nl_global(struct nl80211_global *global)
+{
+ global->nl_cb = nl_cb_alloc(NL_CB_DEFAULT);
+ if (global->nl_cb == NULL) {
+ wpa_printf(MSG_ERROR, "nl80211: Failed to allocate netlink "
+ "callbacks");
+ return -1;
+ }
+
+ return 0;
+}
+
+
static int wpa_driver_nl80211_init_nl(struct wpa_driver_nl80211_data *drv)
{
+ struct nl80211_global *global = drv->global;
int ret;
/* Initialize generic netlink and nl80211 */
- drv->nl_cb = nl_cb_alloc(NL_CB_DEFAULT);
- if (drv->nl_cb == NULL) {
- wpa_printf(MSG_ERROR, "nl80211: Failed to allocate netlink "
- "callbacks");
- goto err1;
- }
-
- if (nl_create_handles(&drv->nl, drv->nl_cb, "nl"))
+ if (nl_create_handles(&drv->nl, global->nl_cb, "nl"))
goto err2;
- if (nl_create_handles(&drv->nl_event, drv->nl_cb, "event"))
+ if (nl_create_handles(&drv->nl_event, global->nl_cb, "event"))
goto err3;
drv->nl80211 = genl_ctrl_search_by_name(drv->nl.cache, "nl80211");
err3:
nl_destroy_handles(&drv->nl);
err2:
- nl_cb_put(drv->nl_cb);
-err1:
return -1;
}
genl_family_put(drv->nl80211);
nl_destroy_handles(&drv->nl);
nl_destroy_handles(&drv->nl_event);
- nl_cb_put(drv->nl_cb);
os_free(drv->filter_ssids);
return 0;
}
- if (nl_create_handles(&drv->nl_preq, drv->nl_cb, "preq"))
+ if (nl_create_handles(&drv->nl_preq, drv->global->nl_cb, "preq"))
return -1;
if (nl80211_register_frame(drv, drv->nl_preq.handle,
goto err;
}
+ if (wpa_driver_nl80211_init_nl_global(global) < 0)
+ goto err;
+
return global;
err:
if (global->netlink)
netlink_deinit(global->netlink);
+ if (global->nl_cb)
+ nl_cb_put(global->nl_cb);
+
os_free(global);
}