X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fmisc%2Fsyslog.c;h=e026f9b4dbb07ee2596fd75406d3254a5f249797;hb=43e9f652bf4b2195b04fc14c93db591b30a7b790;hp=fdf90ba9fb074ddecb4353496dc12d579d84f601;hpb=781f26bc92b0710ac025fae3be42f5575468f1a5;p=musl diff --git a/src/misc/syslog.c b/src/misc/syslog.c index fdf90ba9..e026f9b4 100644 --- a/src/misc/syslog.c +++ b/src/misc/syslog.c @@ -10,9 +10,8 @@ #include #include #include "libc.h" -#include "atomic.h" -static int lock[2]; +static volatile int lock[2]; 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,8 +48,12 @@ void closelog(void) static void __openlog() { - log_fd = socket(AF_UNIX, SOCK_DGRAM|SOCK_CLOEXEC, 0); - if (log_fd >= 0) connect(log_fd, (void *)&log_addr, sizeof log_addr); + 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; } void openlog(const char *ident, int opt, int facility) @@ -77,7 +83,7 @@ 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;