From: Felix Fietkau Date: Sat, 16 Feb 2013 14:26:36 +0000 (+0000) Subject: hostapd: add back the patch that waits for interface bringup in ht40, it got lost... X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fsvn-archive%2Farchive.git;a=commitdiff_plain;hb=b82dc3a77e5aee95e414ea73a087759380829f10 hostapd: add back the patch that waits for interface bringup in ht40, it got lost with the update Backport of r35619 SVN-Revision: 35620 --- diff --git a/package/hostapd/patches/620-scan_wait.patch b/package/hostapd/patches/620-scan_wait.patch new file mode 100644 index 0000000000..5dd874ac0e --- /dev/null +++ b/package/hostapd/patches/620-scan_wait.patch @@ -0,0 +1,73 @@ +--- a/hostapd/main.c ++++ b/hostapd/main.c +@@ -32,6 +32,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[]; + +@@ -279,6 +281,14 @@ static int hostapd_driver_init(struct ho + return 0; + } + ++static void hostapd_setup_complete_cb(void *ctx) ++{ ++ if (daemonize && os_daemonize(pid_file)) { ++ perror("daemon"); ++ return; ++ } ++ daemonize = 0; ++} + + static struct hostapd_iface * + hostapd_interface_init(struct hapd_interfaces *interfaces, +@@ -298,6 +308,7 @@ hostapd_interface_init(struct hapd_inter + iface->bss[0]->conf->logger_stdout_level--; + } + ++ iface->bss[0]->setup_complete_cb = hostapd_setup_complete_cb; + if (iface->conf->bss[0].iface[0] != 0 || + hostapd_drv_none(iface->bss[0])) { + if (hostapd_driver_init(iface) || +@@ -310,7 +321,6 @@ hostapd_interface_init(struct hapd_inter + return iface; + } + +- + /** + * handle_term - SIGINT and SIGTERM handler to terminate hostapd process + */ +@@ -425,8 +435,6 @@ static void hostapd_global_deinit(const + #endif /* CONFIG_NATIVE_WINDOWS */ + + eap_server_unregister_methods(); +- +- os_daemonize_terminate(pid_file); + } + + +@@ -452,11 +460,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; +@@ -540,8 +543,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; +