- chdir("/"); /* avoid keeping a mointpoint busy */
-
- openlog(identname, LOG_CONS | LOG_PID, LOG_DAEMON);
-
- if(debug_lvl > 1)
- syslog(LOG_NOTICE, "tincd %s (%s %s) starting, debug level %d.",
- VERSION, __DATE__, __TIME__, debug_lvl);
- else
- syslog(LOG_NOTICE, "tincd %s starting, debug level %d.", VERSION, debug_lvl);
-
- xalloc_fail_func = memory_full;
-
- return 0;
-}
-
-/*
- Close network connections, and terminate neatly
-*/
-void cleanup_and_exit(int c)
-{
- close_network_connections();
-
- if(debug_lvl > 0)
- syslog(LOG_INFO, "Total bytes written: tap %d, socket %d; bytes read: tap %d, socket %d.",
- total_tap_out, total_socket_out, total_tap_in, total_socket_in);
-
- closelog();
- kill(ppid, SIGTERM);
- exit(c);
-}
-
-/*
- check for an existing tinc for this net, and write pid to pidfile
-*/
-int write_pidfile(void)
-{
- int pid;
-
- if((pid = check_pid(pidfilename)))
- {
- if(netname)
- fprintf(stderr, "A tincd is already running for net `%s' with pid %d.\n",
- netname, pid);
- else
- fprintf(stderr, "A tincd is already running with pid %d.\n", pid);
- return 1;
- }
-
- /* if it's locked, write-protected, or whatever */
- if(!write_pid(pidfilename))
- return 1;
-
- return 0;
-}
-
-/*
- kill older tincd for this net
-*/
-int kill_other(void)
-{
- int pid;
-
- if(!(pid = read_pid(pidfilename)))
- {
- if(netname)
- fprintf(stderr, "No other tincd is running for net `%s'.\n", netname);
- else
- fprintf(stderr, "No other tincd is running.\n");
- return 1;
- }
-
- errno = 0; /* No error, sometimes errno is only changed on error */
- /* ESRCH is returned when no process with that pid is found */
- if(kill(pid, SIGTERM) && errno == ESRCH)
- fprintf(stderr, "Removing stale lock file.\n");
- remove_pid(pidfilename);