aboutsummaryrefslogtreecommitdiffstats
path: root/package/hostapd/patches/620-scan_wait.patch
blob: 5dd874ac0e828c1d6b6bb49916e70848bc4fbae6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
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;