blob: ac874ad66a4b774565741aa52f8ffbfef33b29ff [file] [log] [blame]
developerfaf1ea22022-04-29 17:53:25 +08001--- a/hostapd/main.c
2+++ b/hostapd/main.c
3@@ -39,6 +39,8 @@ struct hapd_global {
4 };
5
6 static struct hapd_global global;
7+static int daemonize = 0;
8+static char *pid_file = NULL;
9
10
11 #ifndef CONFIG_NO_HOSTAPD_LOGGER
12@@ -146,6 +148,14 @@ static void hostapd_logger_cb(void *ctx,
13 }
14 #endif /* CONFIG_NO_HOSTAPD_LOGGER */
15
16+static void hostapd_setup_complete_cb(void *ctx)
17+{
18+ if (daemonize && os_daemonize(pid_file)) {
19+ perror("daemon");
20+ return;
21+ }
22+ daemonize = 0;
23+}
24
25 /**
26 * hostapd_driver_init - Preparate driver interface
27@@ -164,6 +174,8 @@ static int hostapd_driver_init(struct ho
28 return -1;
29 }
30
31+ hapd->setup_complete_cb = hostapd_setup_complete_cb;
32+
33 /* Initialize the driver interface */
34 if (!(b[0] | b[1] | b[2] | b[3] | b[4] | b[5]))
35 b = NULL;
36@@ -404,8 +416,6 @@ static void hostapd_global_deinit(const
37 #endif /* CONFIG_NATIVE_WINDOWS */
38
39 eap_server_unregister_methods();
40-
41- os_daemonize_terminate(pid_file);
42 }
43
44
45@@ -431,18 +441,6 @@ static int hostapd_global_run(struct hap
46 }
47 #endif /* EAP_SERVER_TNC */
48
49- if (daemonize) {
50- if (os_daemonize(pid_file)) {
51- wpa_printf(MSG_ERROR, "daemon: %s", strerror(errno));
52- return -1;
53- }
54- if (eloop_sock_requeue()) {
55- wpa_printf(MSG_ERROR, "eloop_sock_requeue: %s",
56- strerror(errno));
57- return -1;
58- }
59- }
60-
61 eloop_run();
62
63 return 0;
64@@ -645,8 +643,7 @@ int main(int argc, char *argv[])
65 struct hapd_interfaces interfaces;
66 int ret = 1;
67 size_t i, j;
68- int c, debug = 0, daemonize = 0;
69- char *pid_file = NULL;
70+ int c, debug = 0;
71 const char *log_file = NULL;
72 const char *entropy_file = NULL;
73 char **bss_config = NULL, **tmp_bss;