Move hostapd driver initialization away from hostapd.c
This makes it easier to customize AP mode initialization for wpa_supplicant.
This commit is contained in:
parent
363b9e6052
commit
e5f2b59c7e
4 changed files with 92 additions and 53 deletions
|
@ -18,42 +18,6 @@
|
||||||
#include "drivers/driver.h"
|
#include "drivers/driver.h"
|
||||||
#include "ap/config.h"
|
#include "ap/config.h"
|
||||||
|
|
||||||
static inline void *
|
|
||||||
hostapd_driver_init(struct hostapd_data *hapd, const u8 *bssid)
|
|
||||||
{
|
|
||||||
struct wpa_init_params params;
|
|
||||||
void *ret;
|
|
||||||
size_t i;
|
|
||||||
|
|
||||||
if (hapd->driver == NULL || hapd->driver->hapd_init == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
os_memset(¶ms, 0, sizeof(params));
|
|
||||||
params.bssid = bssid;
|
|
||||||
params.ifname = hapd->conf->iface;
|
|
||||||
params.ssid = (const u8 *) hapd->conf->ssid.ssid;
|
|
||||||
params.ssid_len = hapd->conf->ssid.ssid_len;
|
|
||||||
params.test_socket = hapd->conf->test_socket;
|
|
||||||
params.use_pae_group_addr = hapd->conf->use_pae_group_addr;
|
|
||||||
|
|
||||||
params.num_bridge = hapd->iface->num_bss;
|
|
||||||
params.bridge = os_zalloc(hapd->iface->num_bss * sizeof(char *));
|
|
||||||
if (params.bridge == NULL)
|
|
||||||
return NULL;
|
|
||||||
for (i = 0; i < hapd->iface->num_bss; i++) {
|
|
||||||
struct hostapd_data *bss = hapd->iface->bss[i];
|
|
||||||
if (bss->conf->bridge[0])
|
|
||||||
params.bridge[i] = bss->conf->bridge;
|
|
||||||
}
|
|
||||||
|
|
||||||
params.own_addr = hapd->own_addr;
|
|
||||||
|
|
||||||
ret = hapd->driver->hapd_init(hapd, ¶ms);
|
|
||||||
os_free(params.bridge);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
hostapd_driver_deinit(struct hostapd_data *hapd)
|
hostapd_driver_deinit(struct hostapd_data *hapd)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1199,26 +1199,14 @@ static void hostapd_tx_queue_params(struct hostapd_iface *iface)
|
||||||
static int setup_interface(struct hostapd_iface *iface)
|
static int setup_interface(struct hostapd_iface *iface)
|
||||||
{
|
{
|
||||||
struct hostapd_data *hapd = iface->bss[0];
|
struct hostapd_data *hapd = iface->bss[0];
|
||||||
struct hostapd_bss_config *conf = hapd->conf;
|
|
||||||
size_t i;
|
size_t i;
|
||||||
char country[4];
|
char country[4];
|
||||||
u8 *b = conf->bssid;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialize the driver interface and make sure that all BSSes get
|
* Make sure that all BSSes get configured with a pointer to the same
|
||||||
* configured with a pointer to this driver interface.
|
* driver interface.
|
||||||
*/
|
*/
|
||||||
if (!(b[0] | b[1] | b[2] | b[3] | b[4] | b[5]))
|
for (i = 1; i < iface->num_bss; i++) {
|
||||||
b = NULL;
|
|
||||||
hapd->drv_priv = hostapd_driver_init(hapd, b);
|
|
||||||
|
|
||||||
if (hapd->drv_priv == NULL) {
|
|
||||||
wpa_printf(MSG_ERROR, "%s driver initialization failed.",
|
|
||||||
hapd->driver ? hapd->driver->name : "Unknown");
|
|
||||||
hapd->driver = NULL;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
for (i = 0; i < iface->num_bss; i++) {
|
|
||||||
iface->bss[i]->driver = hapd->driver;
|
iface->bss[i]->driver = hapd->driver;
|
||||||
iface->bss[i]->drv_priv = hapd->drv_priv;
|
iface->bss[i]->drv_priv = hapd->drv_priv;
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include "eloop.h"
|
#include "eloop.h"
|
||||||
#include "crypto/tls.h"
|
#include "crypto/tls.h"
|
||||||
#include "common/version.h"
|
#include "common/version.h"
|
||||||
|
#include "drivers/driver.h"
|
||||||
#include "eap_server/eap.h"
|
#include "eap_server/eap.h"
|
||||||
#include "eap_server/tncs.h"
|
#include "eap_server/tncs.h"
|
||||||
#include "ap/hostapd.h"
|
#include "ap/hostapd.h"
|
||||||
|
@ -224,6 +225,56 @@ fail:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int hostapd_driver_init(struct hostapd_iface *iface)
|
||||||
|
{
|
||||||
|
struct wpa_init_params params;
|
||||||
|
size_t i;
|
||||||
|
struct hostapd_data *hapd = iface->bss[0];
|
||||||
|
struct hostapd_bss_config *conf = hapd->conf;
|
||||||
|
u8 *b = conf->bssid;
|
||||||
|
|
||||||
|
if (hapd->driver == NULL || hapd->driver->hapd_init == NULL) {
|
||||||
|
wpa_printf(MSG_ERROR, "No hostapd driver wrapper available");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Initialize the driver interface */
|
||||||
|
if (!(b[0] | b[1] | b[2] | b[3] | b[4] | b[5]))
|
||||||
|
b = NULL;
|
||||||
|
|
||||||
|
os_memset(¶ms, 0, sizeof(params));
|
||||||
|
params.bssid = b;
|
||||||
|
params.ifname = hapd->conf->iface;
|
||||||
|
params.ssid = (const u8 *) hapd->conf->ssid.ssid;
|
||||||
|
params.ssid_len = hapd->conf->ssid.ssid_len;
|
||||||
|
params.test_socket = hapd->conf->test_socket;
|
||||||
|
params.use_pae_group_addr = hapd->conf->use_pae_group_addr;
|
||||||
|
|
||||||
|
params.num_bridge = hapd->iface->num_bss;
|
||||||
|
params.bridge = os_zalloc(hapd->iface->num_bss * sizeof(char *));
|
||||||
|
if (params.bridge == NULL)
|
||||||
|
return -1;
|
||||||
|
for (i = 0; i < hapd->iface->num_bss; i++) {
|
||||||
|
struct hostapd_data *bss = hapd->iface->bss[i];
|
||||||
|
if (bss->conf->bridge[0])
|
||||||
|
params.bridge[i] = bss->conf->bridge;
|
||||||
|
}
|
||||||
|
|
||||||
|
params.own_addr = hapd->own_addr;
|
||||||
|
|
||||||
|
hapd->drv_priv = hapd->driver->hapd_init(hapd, ¶ms);
|
||||||
|
os_free(params.bridge);
|
||||||
|
if (hapd->drv_priv == NULL) {
|
||||||
|
wpa_printf(MSG_ERROR, "%s driver initialization failed.",
|
||||||
|
hapd->driver->name);
|
||||||
|
hapd->driver = NULL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static struct hostapd_iface *
|
static struct hostapd_iface *
|
||||||
hostapd_interface_init(struct hapd_interfaces *interfaces,
|
hostapd_interface_init(struct hapd_interfaces *interfaces,
|
||||||
const char *config_fname, int debug)
|
const char *config_fname, int debug)
|
||||||
|
@ -242,7 +293,8 @@ hostapd_interface_init(struct hapd_interfaces *interfaces,
|
||||||
iface->bss[0]->conf->logger_stdout_level--;
|
iface->bss[0]->conf->logger_stdout_level--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hostapd_setup_interface(iface)) {
|
if (hostapd_driver_init(iface) ||
|
||||||
|
hostapd_setup_interface(iface)) {
|
||||||
hostapd_interface_deinit(iface);
|
hostapd_interface_deinit(iface);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -402,6 +402,40 @@ static int wpa_supplicant_conf_ap(struct wpa_supplicant *wpa_s,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int hostapd_driver_init(struct hostapd_iface *iface)
|
||||||
|
{
|
||||||
|
struct wpa_init_params params;
|
||||||
|
struct hostapd_data *hapd = iface->bss[0];
|
||||||
|
|
||||||
|
if (hapd->driver == NULL || hapd->driver->hapd_init == NULL) {
|
||||||
|
wpa_printf(MSG_ERROR, "No hostapd driver wrapper available");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
os_memset(¶ms, 0, sizeof(params));
|
||||||
|
params.ifname = hapd->conf->iface;
|
||||||
|
params.ssid = (const u8 *) hapd->conf->ssid.ssid;
|
||||||
|
params.ssid_len = hapd->conf->ssid.ssid_len;
|
||||||
|
|
||||||
|
params.num_bridge = hapd->iface->num_bss;
|
||||||
|
params.bridge = os_zalloc(hapd->iface->num_bss * sizeof(char *));
|
||||||
|
if (params.bridge == NULL)
|
||||||
|
return -1;
|
||||||
|
params.own_addr = hapd->own_addr;
|
||||||
|
|
||||||
|
hapd->drv_priv = hapd->driver->hapd_init(hapd, ¶ms);
|
||||||
|
os_free(params.bridge);
|
||||||
|
if (hapd->drv_priv == NULL) {
|
||||||
|
wpa_printf(MSG_ERROR, "%s driver initialization failed.",
|
||||||
|
hapd->driver->name);
|
||||||
|
hapd->driver = NULL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int wpa_supplicant_create_ap(struct wpa_supplicant *wpa_s,
|
int wpa_supplicant_create_ap(struct wpa_supplicant *wpa_s,
|
||||||
struct wpa_ssid *ssid)
|
struct wpa_ssid *ssid)
|
||||||
{
|
{
|
||||||
|
@ -468,7 +502,8 @@ int wpa_supplicant_create_ap(struct wpa_supplicant *wpa_s,
|
||||||
hapd_iface->bss[i]->msg_ctx = wpa_s;
|
hapd_iface->bss[i]->msg_ctx = wpa_s;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hostapd_setup_interface(wpa_s->ap_iface)) {
|
if (hostapd_driver_init(wpa_s->ap_iface) ||
|
||||||
|
hostapd_setup_interface(wpa_s->ap_iface)) {
|
||||||
wpa_printf(MSG_ERROR, "Failed to initialize AP interface");
|
wpa_printf(MSG_ERROR, "Failed to initialize AP interface");
|
||||||
wpa_supplicant_ap_deinit(wpa_s);
|
wpa_supplicant_ap_deinit(wpa_s);
|
||||||
return -1;
|
return -1;
|
||||||
|
|
Loading…
Reference in a new issue