syslogd: MARK code is buggy. Disabling it altogether on anti-bloat grounds
authorDenis Vlasenko <vda.linux@googlemail.com>
Wed, 14 Feb 2007 20:51:46 +0000 (20:51 -0000)
committerDenis Vlasenko <vda.linux@googlemail.com>
Wed, 14 Feb 2007 20:51:46 +0000 (20:51 -0000)
include/usage.h
sysklogd/syslogd.c

index fb1617a7cb562769d544913bb5e7f90633e9d3e7..f9d3de8c67bda6830e4ed23cb97c10b99f430664 100644 (file)
        "System logging utility.\n" \
        "Note that this version of syslogd ignores /etc/syslog.conf." \
        "\n\nOptions:" \
-       "\n     -m MIN          Minutes between MARK lines (default=20, 0=off)" \
        "\n     -n              Run as foreground process" \
        "\n     -O FILE         Use an alternate log file (default=/var/log/messages)" \
        "\n     -l n            Sets the local log level of messages to n" \
        USE_FEATURE_IPC_SYSLOG( \
        "\n     -C[size(KiB)]   Log to a shared mem buffer (read the buffer using logread)")
        /* NB: -Csize shouldn't have space (because size is optional) */
+/*       "\n   -m MIN          Minutes between MARK lines (default=20, 0=off)" */
 #define syslogd_example_usage \
        "$ syslogd -R masterlog:514\n" \
        "$ syslogd -R 192.168.1.1:601\n"
index 53290f1ccfcbbb7d46141dd1446ec3391ce7f9fd..53cb4ba5e9c329864143304908e1374bd40dbd73 100644 (file)
 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