X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fmisc%2Fsyslog.c;h=13d4b0a6d7bc34f737eb9bb36d09bf0881f6b557;hb=55fb9a177316aa46c639d93dd0323d9a9a8c160c;hp=fbce4bcd4011f826fde592bc86d1a57b524914d9;hpb=c574321d75f035ff6d2c18dfb7e3f70db60ba7bd;p=musl diff --git a/src/misc/syslog.c b/src/misc/syslog.c index fbce4bcd..13d4b0a6 100644 --- a/src/misc/syslog.c +++ b/src/misc/syslog.c @@ -9,10 +9,9 @@ #include #include #include -#include "libc.h" -#include "atomic.h" +#include "lock.h" -static int lock[2]; +static volatile int lock[1]; static char log_ident[32]; static int log_opt; static int log_facility = LOG_USER; @@ -21,8 +20,11 @@ static int log_fd = -1; int setlogmask(int maskpri) { - if (maskpri) return a_swap(&log_mask, maskpri); - else return log_mask; + LOCK(lock); + int ret = log_mask; + if (maskpri) log_mask = maskpri; + UNLOCK(lock); + return ret; } static const struct { @@ -46,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) @@ -76,12 +74,17 @@ 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]; time_t now; struct tm tm; - char buf[256]; + char buf[1024]; int errno_save = errno; int pid; int l, l2; @@ -105,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); @@ -116,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;