3 * Functions for debugging and logging as well as some other
4 * simple helper functions.
6 * Russ Dill <Russ.Dill@asu.edu> 2001-2003
7 * Rewritten by Vladimir Oleynik <dzo@simtreas.ru> (C) 2003
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
31 #include <sys/socket.h>
32 #include <sys/sysinfo.h>
39 static int daemonized;
45 printf("uptime %d\n", info.uptime);
51 * This function makes sure our first socket calls
52 * aren't going to fd 1 (printf badness...) and are
53 * not later closed by daemon()
55 static inline void sanitize_fds(void)
58 if ((zero = open(_PATH_DEVNULL, O_RDWR, 0)) < 0) return;
59 while (zero < 3) zero = dup(zero);
64 void background(const char *pidfile)
67 LOG(LOG_ERR, "Cannot background in uclinux (yet)");
68 #else /* __uClinux__ */
71 /* hold lock during fork. */
72 pid_fd = pidfile_acquire(pidfile);
73 if (daemon(0, 0) == -1) {
78 pidfile_write_release(pid_fd);
79 #endif /* __uClinux__ */
84 void udhcp_logging(int level, const char *fmt, ...)
95 vsyslog(level, fmt, p2);
100 void start_log_and_pid(const char *client_server, const char *pidfile)
104 /* Make sure our syslog fd isn't overwritten */
107 /* do some other misc startup stuff while we are here to save bytes */
108 pid_fd = pidfile_acquire(pidfile);
109 pidfile_write_release(pid_fd);
111 /* equivelent of doing a fflush after every \n */
114 openlog(client_server, LOG_PID | LOG_CONS, LOG_LOCAL0);
115 udhcp_logging(LOG_INFO, "%s (v%s) started", client_server, VERSION);
122 static char *syslog_level_msg[] = {
123 [LOG_EMERG] = "EMERGENCY!",
124 [LOG_ALERT] = "ALERT!",
125 [LOG_CRIT] = "critical!",
126 [LOG_WARNING] = "warning",
129 [LOG_DEBUG] = "debug"
133 void udhcp_logging(int level, const char *fmt, ...)
139 printf("%s, ", syslog_level_msg[level]);
147 void start_log_and_pid(const char *client_server, const char *pidfile)
151 /* Make sure our syslog fd isn't overwritten */
154 /* do some other misc startup stuff while we are here to save bytes */
155 pid_fd = pidfile_acquire(pidfile);
156 pidfile_write_release(pid_fd);
158 /* equivelent of doing a fflush after every \n */
161 udhcp_logging(LOG_INFO, "%s (v%s) started", client_server, VERSION);