summaryrefslogtreecommitdiff
path: root/sysklogd
diff options
context:
space:
mode:
Diffstat (limited to 'sysklogd')
-rw-r--r--sysklogd/syslogd.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/sysklogd/syslogd.c b/sysklogd/syslogd.c
index 53290f1..53cb4ba 100644
--- a/sysklogd/syslogd.c
+++ b/sysklogd/syslogd.c
@@ -28,8 +28,13 @@
static const char *logFilePath = "/var/log/messages";
static int logFD = -1;
+/* This is not very useful, is bloat, and broken:
+ * can deadlock if alarmed to make MARK while writing to IPC buffer
+ * (semaphores are down but do_mark routine tries to down them again) */
+#ifdef SYSLOGD_MARK
/* interval between marks in seconds */
static int markInterval = 20 * 60;
+#endif
/* level of messages to be locally logged */
static int logLevel = 8;
@@ -448,6 +453,7 @@ static void quit_signal(int sig)
exit(1);
}
+#ifdef SYSLOGD_MARK
static void do_mark(int sig)
{
if (markInterval) {
@@ -455,6 +461,7 @@ static void do_mark(int sig)
alarm(markInterval);
}
}
+#endif
static void do_syslogd(void) ATTRIBUTE_NORETURN;
static void do_syslogd(void)
@@ -473,8 +480,10 @@ static void do_syslogd(void)
#ifdef SIGCLD
signal(SIGCLD, SIG_IGN);
#endif
+#ifdef SYSLOGD_MARK
signal(SIGALRM, do_mark);
alarm(markInterval);
+#endif
memset(&sunx, 0, sizeof(sunx));
sunx.sun_family = AF_UNIX;
@@ -558,8 +567,10 @@ int syslogd_main(int argc, char **argv)
/* do normal option parsing */
opt_complementary = "=0"; /* no non-option params */
getopt32(argc, argv, OPTION_STR, OPTION_PARAM);
+#ifdef SYSLOGD_MARK
if (option_mask32 & OPT_mark) // -m
markInterval = xatou_range(opt_m, 0, INT_MAX/60) * 60;
+#endif
//if (option_mask32 & OPT_nofork) // -n
//if (option_mask32 & OPT_outfile) // -O
if (option_mask32 & OPT_loglevel) // -l