startup: fork before initialising the event subsystem
On FreeBSD 4.8, fork(2) doesn't actually behave like fork(2). Namely, kqueue(2) descriptors are not inherited by the child. IOW, we can't fork(2) after we get the kqueue(2) descriptor. So we'll just have to rely on people to actually read the server log file if they want to understand why their server is dying during startup.
This commit is contained in:
parent
0c23c0b1c5
commit
f4e9d91580
1 changed files with 7 additions and 6 deletions
13
ircd/ircd.c
13
ircd/ircd.c
|
@ -724,6 +724,12 @@ charybdis_main(int argc, char * const argv[])
|
||||||
if(!testing_conf)
|
if(!testing_conf)
|
||||||
{
|
{
|
||||||
check_pidfile(pidFileName);
|
check_pidfile(pidFileName);
|
||||||
|
|
||||||
|
#ifndef _WIN32
|
||||||
|
if(!server_state_foreground)
|
||||||
|
make_daemon();
|
||||||
|
#endif
|
||||||
|
|
||||||
inotice("starting %s ...", ircd_version);
|
inotice("starting %s ...", ircd_version);
|
||||||
inotice("%s", rb_lib_version());
|
inotice("%s", rb_lib_version());
|
||||||
}
|
}
|
||||||
|
@ -838,6 +844,7 @@ charybdis_main(int argc, char * const argv[])
|
||||||
construct_umodebuf();
|
construct_umodebuf();
|
||||||
|
|
||||||
check_class();
|
check_class();
|
||||||
|
write_pidfile(pidFileName);
|
||||||
load_help();
|
load_help();
|
||||||
open_logfiles();
|
open_logfiles();
|
||||||
|
|
||||||
|
@ -861,12 +868,6 @@ charybdis_main(int argc, char * const argv[])
|
||||||
if(server_state_foreground)
|
if(server_state_foreground)
|
||||||
inotice("now running in foreground mode from %s as pid %d ...",
|
inotice("now running in foreground mode from %s as pid %d ...",
|
||||||
ConfigFileEntry.dpath, getpid());
|
ConfigFileEntry.dpath, getpid());
|
||||||
#ifndef _WIN32
|
|
||||||
else
|
|
||||||
make_daemon();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
write_pidfile(pidFileName);
|
|
||||||
|
|
||||||
rb_lib_loop(0);
|
rb_lib_loop(0);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue