X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fmisc%2Fsyslog.c;h=13d4b0a6d7bc34f737eb9bb36d09bf0881f6b557;hb=b4712ba445a5cb589d1ac37785c29164cd3cf1f9;hp=e026f9b4dbb07ee2596fd75406d3254a5f249797;hpb=6de071a0be00ec2ff08af3c89c7caaa20f1044d7;p=musl diff --git a/src/misc/syslog.c b/src/misc/syslog.c index e026f9b4..13d4b0a6 100644 --- a/src/misc/syslog.c +++ b/src/misc/syslog.c @@ -9,9 +9,9 @@ #include #include #include -#include "libc.h" +#include "lock.h" -static volatile int lock[2]; +static volatile int lock[1]; static char log_ident[32]; static int log_opt; static int log_facility = LOG_USER; @@ -48,12 +48,8 @@ void closelog(void) static void __openlog() { - int fd = socket(AF_UNIX, SOCK_DGRAM|SOCK_CLOEXEC, 0); - if (fd < 0) return; - if (connect(fd, (void *)&log_addr, sizeof log_addr) < 0) - close(fd); - else - log_fd = fd; + log_fd = socket(AF_UNIX, SOCK_DGRAM|SOCK_CLOEXEC, 0); + if (log_fd >= 0) connect(log_fd, (void *)&log_addr, sizeof log_addr); } void openlog(const char *ident, int opt, int facility) @@ -78,6 +74,11 @@ void openlog(const char *ident, int opt, int facility) pthread_setcancelstate(cs, 0); } +static int is_lost_conn(int e) +{ + return e==ECONNREFUSED || e==ECONNRESET || e==ENOTCONN || e==EPIPE; +} + static void _vsyslog(int priority, const char *message, va_list ap) { char timebuf[16]; @@ -107,7 +108,10 @@ static void _vsyslog(int priority, const char *message, va_list ap) if (l2 >= sizeof buf - l) l = sizeof buf - 1; else l += l2; if (buf[l-1] != '\n') buf[l++] = '\n'; - if (send(log_fd, buf, l, 0) < 0 && (log_opt & LOG_CONS)) { + if (send(log_fd, buf, l, 0) < 0 && (!is_lost_conn(errno) + || connect(log_fd, (void *)&log_addr, sizeof log_addr) < 0 + || send(log_fd, buf, l, 0) < 0) + && (log_opt & LOG_CONS)) { fd = open("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC); if (fd >= 0) { dprintf(fd, "%.*s", l-hlen, buf+hlen); @@ -118,7 +122,7 @@ static void _vsyslog(int priority, const char *message, va_list ap) } } -void __vsyslog(int priority, const char *message, va_list ap) +static void __vsyslog(int priority, const char *message, va_list ap) { int cs; if (!(log_mask & LOG_MASK(priority&7)) || (priority&~0x3ff)) return;