--- a/src/ap/hostapd.h +++ b/src/ap/hostapd.h @@ -235,6 +235,7 @@ struct hostapd_iface { int (*for_each_interface)(struct hapd_interfaces *interfaces, int (*cb)(struct hostapd_iface *iface, void *ctx), void *ctx); + int (*init_complete)(struct hostapd_iface *iface); }; /* hostapd.c */ --- a/src/ap/hostapd.c +++ b/src/ap/hostapd.c @@ -804,6 +804,9 @@ int hostapd_setup_interface_complete(str wpa_printf(MSG_DEBUG, "%s: Setup of interface done.", iface->bss[0]->conf->iface); + if (iface->init_complete) + iface->init_complete(iface); + return 0; } --- a/hostapd/main.c +++ b/hostapd/main.c @@ -36,6 +36,8 @@ extern int wpa_debug_level; extern int wpa_debug_show_keys; extern int wpa_debug_timestamp; +static int daemonize = 0; +static char *pid_file = NULL; extern struct wpa_driver_ops *wpa_drivers[]; @@ -173,6 +175,16 @@ static void hostapd_logger_cb(void *ctx, } #endif /* CONFIG_NO_HOSTAPD_LOGGER */ +static int hostapd_init_complete(struct hostapd_iface *iface) +{ + if (daemonize && os_daemonize(pid_file)) { + perror("daemon"); + return -1; + } + daemonize = 0; + return 0; +} + /** * hostapd_init - Allocate and initialize per-interface data @@ -194,6 +206,7 @@ static struct hostapd_iface * hostapd_in if (hapd_iface == NULL) goto fail; + hapd_iface->init_complete = hostapd_init_complete; hapd_iface->reload_config = hostapd_reload_config; hapd_iface->config_read_cb = hostapd_config_read; hapd_iface->config_fname = os_strdup(config_file); @@ -442,7 +455,7 @@ static int hostapd_global_init(struct ha } -static void hostapd_global_deinit(const char *pid_file) +static void hostapd_global_deinit(void) { int i; @@ -472,8 +485,7 @@ static void hostapd_global_deinit(const } -static int hostapd_global_run(struct hapd_interfaces *ifaces, int daemonize, - const char *pid_file) +static int hostapd_global_run(struct hapd_interfaces *iface) { #ifdef EAP_SERVER_TNC int tnc = 0; @@ -494,11 +506,6 @@ static int hostapd_global_run(struct hap } #endif /* EAP_SERVER_TNC */ - if (daemonize && os_daemonize(pid_file)) { - perror("daemon"); - return -1; - } - eloop_run(); return 0; @@ -555,8 +562,7 @@ int main(int argc, char *argv[]) struct hapd_interfaces interfaces; int ret = 1; size_t i; - int c, debug = 0, daemonize = 0; - char *pid_file = NULL; + int c, debug = 0; const char *log_file = NULL; const char *entropy_file = NULL; @@ -634,7 +640,7 @@ int main(int argc, char *argv[]) goto out; } - if (hostapd_global_run(&interfaces, daemonize, pid_file)) + if (hostapd_global_run(&interfaces)) goto out; ret = 0; @@ -645,7 +651,7 @@ int main(int argc, char *argv[]) hostapd_interface_deinit_free(interfaces.iface[i]); os_free(interfaces.iface); - hostapd_global_deinit(pid_file); + hostapd_global_deinit(); os_free(pid_file); if (log_file) --- a/hostapd/config_file.c +++ b/hostapd/config_file.c @@ -1925,6 +1925,8 @@ struct hostapd_config * hostapd_config_r } #endif /* CONFIG_IEEE80211W */ #ifdef CONFIG_IEEE80211N + } else if (os_strcmp(buf, "noscan") == 0) { + conf->noscan = atoi(pos); } else if (os_strcmp(buf, "ieee80211n") == 0) { conf->ieee80211n = atoi(pos); } else if (os_strcmp(buf, "ht_capab") == 0) { --- a/src/ap/ap_config.h +++ b/src/ap/ap_config.h @@ -412,6 +412,7 @@ struct hostapd_config { int ht_op_mode_fixed; u16 ht_capab; + int noscan; int ieee80211n; int secondary_channel; int require_ht; --- a/src/ap/hw_features.c +++ b/src/ap/hw_features.c @@ -449,7 +449,7 @@ static int ieee80211n_check_40mhz(struct { struct wpa_driver_scan_params params; - if (!iface->conf->secondary_channel) + if (!iface->conf->secondary_channel || iface->conf->noscan) return 0; /* HT40 not used */ wpa_printf(MSG_DEBUG, "Scan for neighboring BSSes prior to enabling "